<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 數(shù)據(jù)傳送指令之:多寄存器Load/Store內(nèi)存訪問指令

          數(shù)據(jù)傳送指令之:多寄存器Load/Store內(nèi)存訪問指令

          作者: 時(shí)間:2013-09-13 來源:網(wǎng)絡(luò) 收藏

          本文引用地址:http://www.ex-cimer.com/article/257079.htm

          5.4.4 應(yīng)用

          LDM/STM批量加載/存儲(chǔ)指令可以實(shí)現(xiàn)在一組寄存器和一塊連續(xù)的內(nèi)存單元之間傳輸數(shù)據(jù)。LDM為加載多個(gè)寄存器,STM為存儲(chǔ)多個(gè)寄存器。允許一條指令傳送16個(gè)寄存器的任何子集或所有寄存器。指令格式如下:

          LDM{cond}模式> Rn{!},regist{ˆ}

          STM{cond}模式> Rn{!},regist{ˆ}

          LDM/STM的主要用途有現(xiàn)場(chǎng)保護(hù)、數(shù)據(jù)復(fù)制和參數(shù)傳遞等。其模式有8種,如下所示。

          前面4種用于數(shù)據(jù)塊的傳輸,后面4種是堆棧操作。

          (1)IA:每次傳送后地址加4。

          (2)IB:每次傳送前地址加4。

          (3)DA:每次傳送后地址減4。

          (4)DB:每次傳送前地址減4。

          (5)FD:滿遞減堆棧。

          (6)ED:空遞增堆棧。

          (7)FA:滿遞增堆棧。

          (8)EA:空遞增堆棧。

          其中,寄存器Rn為基址寄存器,裝有傳送數(shù)據(jù)的初始地址,Rn不允許為R15;后綴“!”表示最后的地址寫回到Rn中;寄存器列表reglist可包含多于一個(gè)寄存器或寄存器范圍,使用“,”分開,如{R1,R2,R6~R9},寄存器排列由小到大排列;“ˆ”后綴不允許在用戶模式下,只能在系統(tǒng)模式下使用。若在LDM指令用寄存器列表中包含有PC時(shí)使用,那么除了正常的傳送外,將SPSR拷貝到CPSR中,這可用于異常處理返回;使用“ˆ”后綴進(jìn)行數(shù)據(jù)傳送且寄存器列表不包含PC時(shí),加載/存儲(chǔ)的是用戶模式寄存器,而不是當(dāng)前模式寄存器。

          注意

          地址對(duì)齊問題,在這些指令中,忽略地址位[1:0]。

          批量加載/存儲(chǔ)指令舉例如下。

          LDMIA r0!,{r3~r9} ;加載r0指向的地址上的多字?jǐn)?shù)據(jù),保存到r3~r9中,r0值更新

          STMIA r1!,{r3~r9} ;將r3~r9的數(shù)據(jù)存儲(chǔ)到r1指向的地址上,r1值更新

          STMFD SP!,{r0~r7,LR} ;現(xiàn)場(chǎng)保存,將r0~r7、LR入棧

          LDMFD SP!,{r0~r7,PC}ˆ ;恢復(fù)現(xiàn)場(chǎng),異常處理返回

          在進(jìn)行數(shù)據(jù)復(fù)制時(shí),先設(shè)置好源數(shù)據(jù)指針,然后使用塊拷貝尋址指令LDMIA/STMIA、LDMIB/STMIB、LDMDA/STMDA、LDMDB/STMDB進(jìn)行讀取和存儲(chǔ)。而進(jìn)行堆棧操作時(shí),則要先設(shè)置堆棧指針,一般使用SP然后使用堆棧尋址指令STMFD/LDMFD、STMED/LDMED、STMEA/LDMEA實(shí)現(xiàn)堆棧操作。

          傳送指令如例5.3所示。其中r1為指令執(zhí)行前的基址寄存器,r1’則為指令執(zhí)行后的基址寄存器。

          【例5.3】傳送指令示意。

          (1)STMIA r1,{r5~r7}

          (2)STMIB r1!,{r5~r7}

          (3)STMDA r1!,{r5~r7}

          (4)STMDB r1!,{r5~r7}

          數(shù)據(jù)是存儲(chǔ)在基址寄存器的地址之上還是之下,地址是存儲(chǔ)第一個(gè)值之前還是之后、增加還是減少,如表5.3所示。

          表5.3 多寄存器映射

          向 上 生 長(zhǎng)

          向 下 生 長(zhǎng)

          滿

          滿

          增加

          之前

          STMIB

          LDMIB

          STMFA

          LDMED

          之后

          STMIA

          LDMIA

          STMEA

          LDMFD

          增加

          之前

          LDMDB

          STMDB

          LDMEA

          STMFD

          之后

          LDMDA

          STMDA

          LDMFA

          STMED

          【例5.4】使用LDM/STM進(jìn)行數(shù)據(jù)復(fù)制。

          LDR r0,=SrcData ;設(shè)置源數(shù)據(jù)地址

          LDR r1,=DstData ;設(shè)置目標(biāo)地址

          LDMIA r0,{r2~r9} ;加載8字?jǐn)?shù)據(jù)到寄存器r2~r9

          STMIA r1,{r2~r9} ;存儲(chǔ)寄存器r2~r9到目標(biāo)地址

          【例5.5】使用LDM/STM進(jìn)行現(xiàn)場(chǎng)寄存器保護(hù),常在子程序或異常處理使用。

          SENDBYTE

          STMFD SP!,{r0~r7,LR} ;寄存器壓棧保護(hù)

          …….

          BL DELAY ;調(diào)用DELAY子程序

          …….

          LDMFD SP!,{r0~r7,PC} ;恢復(fù)寄存器,并返回


          上一頁 1 2 3 4 5 下一頁

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();