我在内存中有一个地址,我想找出该内存地址的权限(r/w/x)。
例如
char *s = "hello";
这里,字符串文字“hello”存储在只读内存中。通过 gdb 运行程序时,是否可以检查该内存地址的权限(是否只允许读取等)?
最佳答案
你可以先找到s
指向的地方:
(gdb) print s
$6 = 0x400dbc "foo"
然后找到它所在的部分:
(gdb) maintenance info sections
Exec file:
`/home/mfukar/tmp', file type elf64-x86-64.
...sections...
0x00400db8->0x00400dfb at 0x00000db8: .rodata ALLOC LOAD READONLY DATA HAS_CONTENTS
...more sections...
并寻找 READONLY
标志。
或者,查看 /proc/PID/maps
,其中 PID
是您正在调试的进程的 pid,您可以使用 info proc
.
关于c - GDB 检查内存权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10780540/