调试前提:
-g 编译所有的代码
包括汇编和.c
1. 打开gdb 并加载镜像
1. 打开 gdb
gdb
2. 连接服务器
target remote localhost:1234
3. 加载并运行
file xxx.elf
load
run
1. 打开 gdb
gdb ./app
2.让其开始运行
run
单个调试命令
file
load
run
c
n
s
monitor halt
3. 打印地址中的值
命令格式:x/nfu <addr>
(gdb)x/1xb 0x7fffffffd708
---------------------------
x : examine 的缩写
---------------------------
n : 表示要显示的内存单元个数
---------------------------
f : 表示显示方式, 可取如下值
x 按十六进制格式显示变量。
d 按十进制格式显示变量。
u 按十进制格式显示无符号整型。
o 按八进制格式显示变量。
t 按二进制格式显示变量。
a 按十六进制格式显示变量。
i 指令地址格式
c 按字符格式显示变量。
f 按浮点数格式显示变量。
---------------------------
u表示一个地址单元的长度,与n一起表示显示的地址长度
b表示单字节,
h表示双字节,
w表示四字节,
g表示八字节
修改地址值
print *(char*)0xbff444f1=5
print *(int*)0xbff444f1=0x55555555
break main
info break
断点
b *0x40a833c4
观察点
watch *0x1234
查看
p *tmp_p
p/x array
修改
set x = 12
set array 1 2 3 4
p $sp
p $r1
info registers
info all-registers
修改
p $sp=17
x $sp
x/1 $sp
x/2 $sp
x/10 $sp
disassemble main
list
info sources
脚本
把 一个个命令写到 一个 txt 里 , 然后在 gdb 命令行下 source 该 txt
自动化脚本
expect
stop 时 自动运行命令
https:
define hook-stop
handle SIGALRM nopass
end