str -(Store Register)存儲指令
格式:
str{條件} 源寄存器,<存儲器地址>
將源寄存器中數據存到存儲器地址中。
實例1:
str r1,[r2] ; 將r1中的值存到r2所指定的地址中
str r1,[r2,#4] ;將r1中的值存到r2+4所指定的地址中
str r1,[r2],#4 ;將r1中的值存到r2所指定的地址中, 同時r2=r2+4
實例2(以u-boot中lowlevel_init函數的一段代碼說明str指令的用法):
ldr r0, =SMRDATA //將SMRDATA的首地址(0x33F806C8)存到r0中
ldr r1, _TEXT_BASE //r1等於_TEXT_BASE內容,也就是TEXT_BASE(0x3ff80000)
sub r0, r0, r1 //計算以0x0000 0000為標准的相對地址,因為現在程序運行在起始地址為0x0000 0000的地方
ldr r1, =BWSCON //將BWSCON所指向的首地址值存到r1中 (第一個存儲器寄存器首地址)
add r2, r0, #13*4 //每個寄存器4字節,r2=r0+13*4=最后一個存儲器寄存器+4
0:
ldr r3, [r0], #4 /將r0的內容存到r3的內容中,同時r0地址+=4;
str r3, [r1], #4 //將r3的內容存到r1所指的地址中,同時r1地址+=4;
cmp r2, r0 // 判斷r2和r0
bne 0b //不等則跳轉到第6行繼續執行
mov pc, lr //跳回到返回地址中繼續執行
SMRDATA:
.word (0+(B1_BWSCON<<4)+(B2_BWSCON<<8)+(B3_BWSCON<<12)+(B4_BWSCON<<16)+(B5_BWSCON<<20)+(B6_BWSCON<<24)+(B7_BWSCON<<28))
//設置每個BWSCON,注意BANK0由硬件連線決定了
.word ((B0_Tacs<<13)+(B0_Tcos<<11)+(B0_Tacc<<8)+(B0_Tcoh<<6)+(B0_Tah<<4)+(B0_Tacp<<2)+(B0_PMC))
.word ((B1_Tacs<<13)+(B1_Tcos<<11)+(B1_Tacc<<8)+(B1_Tcoh<<6)+(B1_Tah<<4)+(B1_Tacp<<2)+(B1_PMC))
.word ((B2_Tacs<<13)+(B2_Tcos<<11)+(B2_Tacc<<8)+(B2_Tcoh<<6)+(B2_Tah<<4)+(B2_Tacp<<2)+(B2_PMC))
.word ((B3_Tacs<<13)+(B3_Tcos<<11)+(B3_Tacc<<8)+(B3_Tcoh<<6)+(B3_Tah<<4)+(B3_Tacp<<2)+(B3_PMC))
.word ((B4_Tacs<<13)+(B4_Tcos<<11)+(B4_Tacc<<8)+(B4_Tcoh<<6)+(B4_Tah<<4)+(B4_Tacp<<2)+(B4_PMC))
.word ((B5_Tacs<<13)+(B5_Tcos<<11)+(B5_Tacc<<8)+(B5_Tcoh<<6)+(B5_Tah<<4)+(B5_Tacp<<2)+(B5_PMC))
//設置BANKCON0~BANKCON5
.word ((B6_MT<<15)+(B6_Trcd<<2)+(B6_SCAN))
.word ((B7_MT<<15)+(B7_Trcd<<2)+(B7_SCAN))
//設置BANKCON6~BANKCON7
.word ((REFEN<<23)+(TREFMD<<22)+(Trp<<20)+(Trc<<18)+(Tchr<<16)+REFCNT)
//設置REFRESH,在S3C2440中11~17位是保留的,也即(Tchr<<16)無意義
.word 0xb1 //設置BANKSIZE,對於容量可以設置大寫,多出來的空內存會被自動檢測出來
.word 0x30 //設置MRSRB6
.word 0x30 //設置MRSRB7
