加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 为什么堆栈必须是页面对齐的?

发布时间:2020-12-13 23:03:28 所属栏目:Linux 来源:网络整理
导读:在 Linux中,我尝试(只是为了好玩)修改process.c中的内核源代码创建一个具有更多熵的堆栈地址,即特别是行: sp -= get_random_int() % 8192; 当我改变太多时,内核停止或我得到一些看似未定义的行为.我猜这会导致PAGE_ALIGN()以某种方式失败?我对于为什么特别
在 Linux中,我尝试(只是为了好玩)修改process.c中的内核源代码创建一个具有更多熵的堆栈地址,即特别是行:

sp -= get_random_int() % 8192;

当我改变太多时,内核停止或我得到一些看似未定义的行为.我猜这会导致PAGE_ALIGN()以某种方式失败?我对于为什么特别是PAGE_ALIGN()失败,或者内核中失败的代码片段(尽管知道它也很好)并不感兴趣;我更感兴趣的是为什么堆栈必须完全驻留在特定区域.这背后的建筑理由和动机是什么?这是否与GDT / LDT在保护模式下的工作方式有关?

只是为了弄清楚我在问什么:

为什么堆栈必须具有0xbfXXXXXX(在32位上)?为什么堆栈不能成为例如0xaaXXXXXX,还是其他任何值?

解决方法

do_page_fault()中有一个限制,就是在它认为它是一个糟糕的访问之前,你可以在堆栈外面走多远,也许你正在达到这个目的?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读