- Linux 内核编译完成后在当前目录下查看System.map 查找调试符号
- 查找 start_kernel 然后在命令行 执行: b start_kernel 断到内核入口点(== main入口点)
start_kernel () at init/main.c:859
(gdb) p &init_task //查看任务堆栈
$6 = (struct task_struct *) 0x80c07b00 <init_task>
(gdb) p/x init_task.stack // 查找init_task.stack 初始化堆栈边界 ,16进制显示
$7 = 0x80c00000
(gdb) x/8w 0x80c00000 // 查看内存0x80c00000 4字节,显示8个
0x80c00000 <init_thread_info>: 0x00000000 0x00000001 0x00000000 0x80c07b00(默认用来初始化堆栈的标志)
0x80c00010 <init_thread_info+16>: 0x00000000 0x00000000 0x00000000 0x00000000
(gdb)