今天看了一个小程序,学习了下ARM 在裸机下的开发。学习了写东西,整理下作为笔记,程序名为link.s。
.text
.global _start
.start:
b step1
step1:
ldr pc, =step2
step2:
b step2
这个小程序使用了两种跳转方法,b 跳转指令,直接向pc 寄存器赋值。
下面进行编译,链接,反汇编,看看两者的区别:
1.arm-linux-gcc -c -o link.o link.s
2.arm-linux-ld -Ttext 0x00000000 link.o -o link_elf_0x00000000
3.arm-linux-ld -Ttetx 0x30000000 link.o -o link_elf_0x30000000
4.arm-linux-objdump -D link_elf_0x00000000 >link_0x00000000.dis
5.arm-linux-objdump -D link_elf_0x30000000 >link_0x30000000.dis
其中4,5 两条语句用来反汇编,查看代码。
link_0x00000000.dis文件如下:
link_elf_0x00000000: file format elf32-littlearm
Disassembly of section .text:
00000000 <_start>:
0: eaffffff b 4 <