汇编工具安装
binutils
1. sudo -sH 切换root
2. apt-get install binutils-doc (dpkg -l | grep binutil(Debian类型查询))
3. Kdbg在ubuntu软件中心安装
man手册页更新:sudo apt-get install manpages-dev
编译小程序(cpuid.s取自Professional.Assembly.Lauguage附带code)
使用gas + ld
1. as -o cpuid.o cpuid.s
2. ld -o cpuid cpuid.o
若需要连接动态库
ld -dynamic-linker /lib/ld-linux.so.2 -lc -o cpuid cpuid.o
使用gcc
gcc编译器会自动连接所需C库,不过用gcc编译汇编程序时,必须把汇编代码中的_start标签改为main,然后
gcc -o cpuid2 cpuid2.s
将*.c的代码转换为汇编代码
gcc -S *.c
为方便gdb调试汇编代码,连接时加上-gstabs参数
as -gstabs -o cpuid.o cpuid.s
ld -o cpuid cpuid.o
gdb -q cpuid
gdb中,常用命令
设置断点: b *_start+1(此时需要在_start标签后的第一条语句前增加一条nop指令)
运行: r/run
单步运行: n/s
查看信息
所有寄存器:info register
某个寄存器:print/x $eax
某个变量值:例如 x/d &data, x/4d &value
查看返回值:echo $?
退出:q
以后将结合Professional.Assembly.Lauguage进行补充。