我已经有几年没有编程了,但是我已经安装了VS2017,并从这个pdf:https://spectreattack.com/spectre.pdf中编译了这个幽灵示例。
但是,我不知道谱示例在命令行上的地址是如何工作的?
我修改了代码以输出秘密字符串的指针地址,并在本机工具Shell中用cl编译,它输出的内容如下:
00007FF6CF2210F0在命令行上输入此地址到它正确输出秘密字符串的示例中。
但是,如果我用一个类似的字符串制作了一个简单的程序,并输出该地址,然后在另一个shell中将其提供给谱示例,我就无法得到正确的字符串。
我读过关于虚拟地址和物理地址以及页面和偏移的文章,但我还是很迷茫。
所以问题是:
您将如何在C代码中计算指针的物理地址?
发布于 2018-01-10 14:52:16
您将如何在C代码中计算指针的物理地址?
我认为您是在询问如何计算由指针值表示的物理地址,而不是存储指针值的物理地址。后者只是简单地归结为前者。
但是就C语言本身而言,不需要这样做。C一开始就不承认物理内存和虚拟内存之间的区别,也没有必要这样做。这种区别是操作系统级关注的硬件支持。因此,完成所描述的任务的任何技术都依赖于C实现和执行环境的细节。
幽灵设法打破了由虚拟内存提供的进程隔离,这可能是最可怕的事情。
https://stackoverflow.com/questions/48189240
复制相似问题