linux – 为什么堆栈必须是页面对齐的?
作者:互联网
在Linux中,我尝试(只是为了好玩)修改process.c中的内核源代码创建一个具有更多熵的堆栈地址,即特别是行:
sp -= get_random_int() % 8192;
当我改变太多时,内核停止或我得到一些看似未定义的行为.我猜这会导致PAGE_ALIGN()以某种方式失败?我对于为什么特别是PAGE_ALIGN()失败,或者内核中失败的代码片段(尽管知道它也很好)并不感兴趣;我更感兴趣的是为什么堆栈必须完全驻留在特定区域.这背后的建筑理由和动机是什么?这是否与GDT / LDT在保护模式下的工作方式有关?
只是为了弄清楚我在问什么:
为什么堆栈必须具有0xbfXXXXXX(在32位上)?为什么堆栈不能成为例如0xaaXXXXXX,还是其他任何值?
解决方法:
do_page_fault()中有一个限制,就是在它认为它是一个糟糕的访问之前,你可以在堆栈外面走多远,也许你正在达到这个目的?
标签:stack,linux,kernel,aslr 来源: https://codeday.me/bug/20190626/1289051.html