请问这些汇编是怎么运行的 :OR: SFR_BASE<<16
RomBaseAddr EQU 0RomEndAddr EQU &20
RamBaseAddr EQU &100
RamEndAddr EQU &200
AREA text, CODE, READONLY
SFR_BASE EQU 0x3ff ;0x3ff0000
SRAM_BASE EQU 0x3f8 ;0x3f80000
;EXPORT InitMemory
InitMemory
ldr r0, =SYSCFG
ldr r1, =SDRAM_ITF :OR: SFR_BASE<<16 :OR: SRAM_BASE<<6 :OR: CACHE_ALL :OR: CACHE_EN
;这是怎么运行的.
str r1,
ldr r0, =CLKCON
ldr r1, =0
str r1,
ldr r0, =EXTACON0
ldr r1, =0x0fff0fff
str r1,
ldr r0, =EXTACON1
ldr r1, =0x0fff0fff
str r1,
ldr r0, =EXTDBWTH
ldr r1, =0xffff556
str r1,
adr r0, MemCfgPara
ldmia r0, {r1-r11}
ldr r0, =ROMCON0
stmia r0, {r1-r11}
mov pc, r14
MemCfgPara
DCD RomBaseAddr<<10 :OR RomEndAddr<<20 :OR: &60 ;&10840060
;DCD怎么分配 是怎么理解的?
;这个 &10840060 地址怎么计算出来的,我怎么都算不到
DCD &10842060
DCD &10842060
DCD &10842060
DCD &10842060
DCD &10842060
DCD RamBaseAddr<<10 :OR: RamEndAddr<<20 :OR: &398 ;&10000398
DCD &10040398
DCD &10040398
DCD &10040398
DCD &ce2983fd
EXPORT RemapMemory
RemapMemory
adr r0, RemapMemPara
1.ldr r1, =SDRAM_ITF :OR: SFR_BASE<<16 :OR: SRAM_BASE<<6 :OR: CACHE_ALL :OR: CACHE_EN
;这是怎么运行的理解的?
2. DCD RomBaseAddr<<10 :OR RomEndAddr<<20 :OR: &60 ;&10840060
;DCD怎么分配 是怎么理解的?
3这个 &10840060 地址怎么计算出来的,我怎么都算不到是这个结果
望版主给予帮助.那个ADS的HELP文档也找不到 这里涉及到关于 S3C4510 内部一些寄存器的配置情况,详细可以参考看看 s3c4510 的 datasheet。
这个bootloader的代码,在启动之后做了一次 remap ,remap前的 Flash 在 0-2M 地址上, sdram 在 16-32M 的地址上; 这个是 remap 之前的设置情况:
RomBaseAddr EQU 0
RomEndAddr EQU &20
RamBaseAddr EQU &100
RamEndAddr EQU &200
remap 后的 sdram 在 0-16M, Flash 在 16-18M 地址上。
;&10840060这个注释似乎是不对的,是代码原作者的注释,我也没看懂。
页:
[1]