LDR(load register)指令将内存内容加载入通用寄存器
STR(store register)指令将寄存器内容存入内存空间中
1 #define GPJ0CON 0xE0200240 2 3 _start: 4 5 ldr r0, =0x11111111 // 将立即数/非法立即数,赋值给r0 6 7 ldr r1, =GPJ0CON // 将GPJ0CON的地址赋给r1 8 9 str r0, [r1] // 寄存器间接寻址。把r0中的数写入到r1中的数为地址的内存中去 10 11 ldr r0,[r1] //将r1的值赋给r0,ARM是RISC结构,数据从内存到CPU之间的移动只能通过LDR/STR指令来完成。 但想把数据从内存中某处读取到寄存器,
只能使用ldr ,mov只能在寄存器之间移动数据,或者把立即数移动到寄存器中,如 MOV r0,#0是将立即数0放到r0中
1、LDR与MOV的不同:ldr能将数据从内存读到CPU,或者从内存中某处读取到寄存器中,而mov只能在寄存器之间移动数据,或者把立即数移动到寄存器中,如 MOV r0,#0是将立即数0放到r0中;
2、MOV是从一个寄存器或者移位的寄存器或者立即数的值传递到另外一个寄存器。但不是所有立即数都可以传递的,这个立即数要符合一个8位数循环右移偶数位的取值。 原因是,MOV本身就是一条32bit指令,除了指令码本身,它不可能再带一个可以表示32bit的数字,所以用了其中的12bit来表示立即数,其中4bit表示移位的位数(循环右移,且数值乘以2),8bit用来表示要移位的一个基数。而对于ldr伪指令,可以在立即数前加上=,以表示把一个地址写到某寄存器中,比如: ldr r0, =0x12345678 这样,就把0x12345678这个地址写到r0中了。ldr伪指令和mov是比较相似,但mov指令限制了立即数的长度为8位,也就是不能超过512。而ldr伪指令没有这个限制。如果使用ldr伪指令时,后面跟的立即数没有超过8位,那么在实际汇编的时候该ldr伪指令是被转换为 mov指令的。
3、LDR指令的寻址方式实例分类:
LDR r0,[r1] //将存储器地址为R1的数据读入寄存器r0
LDR r0,[r1,r2] //将存储器地址为r1+r2的数据读入寄存器r0
LDR r0,[r1,#8] //将存储器地址为r1+8的数据读入寄存器r0
LDR r0,[r1],r2 //将存储器地址为r1的数据读入寄存器r0,并将r1+r2的值存入r1
LDR r0,[r1],#8 //将存储器地址为r1的数据读入寄存器r0,并将r1+8的值存入r1
LDR r0,[r1,r2]! //将存储器地址为r1+r2的数据读入寄存器r0,并将r1+r2的值存入r1
LDR r0,[r1,LSL #3] //将存储器地址为r1*8的数据读入寄存器r0
LDR r0,[r1,r2,LSL #2] //将存储器地址为r1+r2*4的数据读入寄存器r0
LDR r0,[r1,r2,LSL #2]! //将存储器地址为r1+r2*4的数据读入寄存器r0,并将r1+r2*4的值存入r1
LDR r0,[r1],r2,LSL #2 //将存储器地址为r1的数据读入寄存器R0,并将r1+r2*4的值存入r1
LDR r0,Label //Label为程序标号,Label必须是当前指令的-4~4KB范围内