前几天有个朋友问了个LDR指令的问题。他的程序如下:
内存值:0X1234 = 0X12; 0X1235=0X34; 0X1236=0X56; 0X1237=0X78; (小端模式)
LDR R2, =0x1234
LDR R1, [R2,#1]
R1 = 0x12785634
发现R1中的值很奇怪。
原因是:
LDR操作的时候,如果地址不是对齐的,根据地址最低2位的值,会有个移位操作,这是LDR指令里详细定义了的:
如果地址[1:0] == 0b00
读取的值 = 目标地址存储的值
如果地址[1:0] == 0b01
读取的值 = (目标地址存储的值 往右循环移位8位)
如果地址[1:0] == 0b10
读取的值 = (目标地址存储的值 往右循环移位16位)
如果地址[1:0] == 0b11
读取的值 = (目标地址存储的值 往右循环移位24位)
例子:
内存值:0X1234 = 0X12; 0X1235=0X34; 0X1236=0X56; 0X1237=0X78; (小端模式)
LDR R2, =0x1234
LDR R1, [R2,#0]
R1 = 0x78563412
LDR R2, =0x1234
LDR R1, [R2,#1]
R1 = 0x12785634
LDR R2, =0x1234
LDR R1, [R2,#2]
R1 = 0x34127856
LDR R2, =0x1234
LDR R1, [R2,#3]
R1 = 0x56341278
打赏帖 | |
---|---|
宏定义和const关键字定义被打赏5分 | |
【功率监测与控制系统DIY活动成果贴】DIY功率计与LabVIEW数据采集被打赏100分 | |
【Freertos】任务管理被打赏10分 | |
分享博世的两种不同的喷射系统模式被打赏5分 | |
汽车+开路实验与短路实验被打赏10分 | |
多点式电子控制汽油喷射系统知识分享被打赏10分 | |
分享机械控制式汽油喷射系统被打赏5分 | |
【分享开发笔记,赚取电动螺丝刀】解决基于CH341制作无线模块时芯片发热问题被打赏31分 | |
【分享开发笔记,赚取电动螺丝刀】使用STM32F103ZE主控调试RS485通讯的避坑经验被打赏36分 | |
【分享开发笔记,赚取电动螺丝刀】移植xprintf模块被打赏27分 |