前几天有个朋友问了个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
有奖活动 | |
---|---|
东芝TB6560AHQ步进电机驱动器芯片 | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
【有奖活动】智能可穿戴设备AR/VR如何引领科技新潮流! | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 |
打赏帖 | |
---|---|
【换取手持数字示波器】+AT89C2051串口接收数据显示到LCD1602上被打赏50分 | |
【分享评测,赢取加热台】+AT89C2051控制NRF24L01收发数据被打赏50分 | |
【分享评测,赢取加热台】迪文屏设计实战技巧被打赏40分 | |
“DFRobot盖革计数器模块评测”基础模型搭建被打赏50分 | |
【换取手持数字示波器】+角点检测----Harris被打赏40分 | |
【换取手持数字示波器】常见音频指标被打赏20分 | |
【分享评测,赢取加热台】从零配置MCX-N947——PWM(SCtimer)被打赏50分 | |
【分享评测,赢取加热台】实际测试MCX-N947——PWM(Ctimer)被打赏50分 | |
【换取手持数字示波器】红外触摸框及各类红外设备的工作原理被打赏20分 | |
【换取手持数字示波器】+精英板驱动两相四线步进电机被打赏10分 |