Linux   发布时间:2022-03-31  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了linux – 为什么堆栈必须是页面对齐的?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

在 Linux中,我尝试(只是为了好玩)修改process.c中的内核源代码创建一个具有更多熵的堆栈地址,即特别是行: sp -= get_random_int() % 8192; 当我改变太多时,内核停止或我得到一些看似未定义的行为.我猜这会导致PAGE_ALIGN()以某种方式失败?我对于为什么特别是PAGE_ALIGN()失败,或者内核中失败的代码片段(尽管知道它也很好)并不感兴趣;我更感兴
Linux中,我尝试(只是为了好玩)修改process.c中的内核源代码创建一个具有更多熵的堆栈地址,即特别是行:

sp -= get_random_int() % 8192;

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

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

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

解决方法

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

大佬总结

以上是大佬教程为你收集整理的linux – 为什么堆栈必须是页面对齐的?全部内容,希望文章能够帮你解决linux – 为什么堆栈必须是页面对齐的?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。