[问答] 关于adrl指令的问题: adrl r2, mem_cfg_val

[复制链接]

技术员

发表于 2018-1-12 16:07:39   145 查看 1 回复 显示全部楼层 倒序浏览
分享
本帖最后由 Mr_RMS 于 2018-1-12 17:04 编辑

学习韦东山老师sdram 实例程序,有部分看不懂什么意思,问题如下:
  mov r1,     #1207959552       @ #1207959552=0x48000000 存储控制器的13个寄存器的开始地址
    adrl    r2, mem_cfg_val         @ 这13个值的起始存储地址
    add r3,     r1, #52             @ 13*4 = 54
1:  
    ldr r4,     [r2], #4            @ 读取设置值,并让r2加4
    str r4,     [r1], #4            @ 将此值写入寄存器,并让r1加4
    cmp r1,     r3                  @ 判断是否设置完所有13个寄存器
    bne 1b                          @ 若没有写成,继续
    mov pc,     lr                  @ 返回

.align 4
mem_cfg_val:
    @ 存储控制器13个寄存器的设置值
    .long   0x22011110      @ BWSCON
    .long   0x00000700      @ BANKCON0
    .long   0x00000700      @ BANKCON1
    .long   0x00000700      @ BANKCON2
    .long   0x00000700      @ BANKCON3  
    .long   0x00000700      @ BANKCON4
    .long   0x00000700      @ BANKCON5
    .long   0x00018005      @ BANKCON6
    .long   0x00018005      @ BANKCON7
    .long   0x008C07A3      @ REFRESH
    .long   0x000000B1      @ BANKSIZE
    .long   0x00000030      @ MRSRB6
    .long   0x00000030      @ MRSRB7


其中, adrl    r2, mem_cfg_val 为什么这一步是设置这13个值的起始地址?是如何设置的?这一步是什么意思?经过这一步后,r2里存放的是什么值?看不懂,求教,谢谢


标签:ARM 汇编语言 Linux

技术员

发表于 2018-1-12 17:01:36    楼主|
本帖最后由 Mr_RMS 于 2018-1-12 17:03 编辑

第一次执行 adrl    r2, mem_cfg_val 是将mem_cfg_val的地址放到r2中, mem_cfg_val是标号,无实际意义,mem_cfg_val的地址就是  第一个立即数 0x22011110 所在的地址,也就是说, adrl    r2, mem_cfg_val 是将立即数  0x22011110 所在的地址放到任中。
ldr r4,     [r2], #4         @ 将0x22011110写入r4,并r2=0x22011110所在的地址+0x4,此时,r2中的数表示的
                                  @是第二个值0x00000700 所在的地址(.long表示定义长整型占4个字节,0x00000700
                                   @所在的地址=0x22011110所在的地址+0x4)
str r4,     [r1], #4         @ 将0x22011110写入到地址0x48000000,并r1=0x48000000+0x4=0x48000004
cmp r1,     r3               @ 判断是否设置完所有13个寄存器
bne 1b                        @ 若没有写成,继续 ldr r4,     [r2], #4 (将0x00000700写到r4中,......)......
回复

点赞 举报

高级模式
您需要登录后才可以回帖 登录 | 注册

关闭

站长推荐 上一条 /7 下一条

快速回复 返回顶部 返回列表
-

推荐专区

技术干货集中营

专家问答

用户帮助┃咨询与建议┃版主议事

工程师杂谈

工程师创意

工程师职场

论坛电子赛事

社区活动专版

发烧友活动

-

嵌入式论坛

ARM技术论坛

Android论坛

Linux论坛

单片机/MCU论坛

FPGA|CPLD|ASIC论坛

DSP论坛

嵌入式系统论坛

-

电源技术论坛

电源技术论坛

无线充电技术

-

硬件设计论坛

PCB设计论坛

电路设计论坛

电子元器件论坛

控制|传感

总线技术|接口技术

-

测试测量论坛

LabVIEW论坛

Matlab论坛

测试测量技术专区

仪器仪表技术专区

-

EDA设计论坛

multisim论坛

PADS技术论坛

Protel|AD|DXP论坛

Allegro论坛

proteus论坛|仿真论坛

EasyEDA-中国人自已的EDA工具

Orcad论坛

-

综合技术与应用

电机控制

智能电网

光电及显示

参考设计中心

汽车电子技术论坛

医疗电子论坛

-

开源硬件

-

无线通信论坛

无线通信技术专区

天线|RF射频|微波|雷达技术

-

IC设计论坛

芯片测试与失效分析

Mixed Signal/SOC[数模混合芯片设计]

Analog/RF IC设计

设计与制造封装测试

-

厂商专区

TI论坛

TI Deyisupport社区

-

检测技术与质量

电磁兼容(EMC)设计与整改

安规知识论坛

检测与认证

-

消费电子论坛

手机技术论坛

平板电脑/mid论坛

音视/视频/机顶盒论坛

-

电子论坛综合区

聚丰众筹官方社区

新人报道区

聚丰供应链

-

论坛服务区

-

供求信息发布

供需广告

招聘┃求职发布区

电子展览展会专区