匯編指令-str存儲指令(4)


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM