简介
上一篇文章我们在linux里安装了arm环境,不知道怎么安装的可以去看上一篇文章
HelloWorld
连接ssh后,然后创建一个文件夹来存放我们写的项目
mkdir HelloWorld
cd HelloWorld
然后用nano工具创建一个文件
nano HelloWorld.s
首先创建基本的标签,写入我们想输出的字符串
.global _start
_start:
.data
message:
.asciz "hello world !\n" //.asciz:ascii集,后面是输出的字符
len = .-message //定义字符串的长度
然后就要写主程序了,第一件事是我们要把数据或者字符存放到哪里,第二件事是要输出什么,第三件事是我们输出字符的长度是多少
.global _start
_start:
MOV R0,#1 //计算机标准输出
LDR R1,=message //告诉程序字符串位置在哪里
LDR R2,=len //告诉程序要输出的字符串长度
MOV R7,#4 //当我们与操作系统交互时,r7是一个特殊的寄存器,4意思是输出
SWI 0 //中断程序
MOV R7,#1 //1终止此程序
SWI 0 //中断程序
.data
message:
.asciz "hello world !\n"
len = .-message
ctrl+o保存,然后ctrl+x退出
然后编译程序
as HelloWorld.s -o helloworld.o
ld helloworld.o -o hellworld
执行
./helloworld
成功输出
gdb调试Arm程序
gdb是linux动态调试工具
chmod 777 helloworld
gdb helloworld
然后对程序添加断点,让程序停在我们想要分析的地址上
b _start //在_start处添加断点
disassemble _start //查看_start的汇编代码
输入run就能停在断点处,现在程序是正在运行中的
输入layout asm 可以获得一个方便观察的界面
可以看到,这里的汇编代码和我们写的差不多,输入info register [小写的寄存器] 可以查看当前寄存器的值,现在没有执行,所以是0
或者输入layout regs,上面就会显示寄存器的界面
可以用键盘上的上下键查看其他地址,输入stepi,执行第一条汇编代码
可以看到,r0寄存器里的值就为1了,使用x/16x $r1 查看r1内存地址里的值
x/10d $r1以十进制显示内存里的数值
x/10c $r1以ascii码新式查看内存里的数据