電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開發(fā)>Thumb指令集之多寄存器數(shù)據(jù)傳送指令解析

Thumb指令集之多寄存器數(shù)據(jù)傳送指令解析

2017-10-19 | rar | 0.4 MB | 次下載 | 1積分

資料介紹

11.6 多寄存器數(shù)據(jù)傳送指令
  Thumb指令集的多寄存器Load/Store指令是ARM指令集的多寄存器Load/Store指令的簡化形式。同ARM指令一樣,Thumb多寄存器數(shù)據(jù)傳送指令可以用于過程調(diào)用與返回以及存儲器塊拷貝。但為了編碼的緊湊性,這兩種用法由分開的指令實現(xiàn),并且這些指令也只使用單一的尋址方式。在其他方面,這些指令的性質(zhì)與等價的ARM指令相同。
  Thumb多寄存器數(shù)據(jù)傳送指令的基本語法格式分為以下兩種,一種用于實現(xiàn)塊拷貝,另一種用于實現(xiàn)堆棧操作。
 ?、?《opcode1》 《Rn》!,《registers
  《opcode1》:=LDMIA|STMIA
  ② PUSH {《registers》}
  POP {《registers》}
  下面詳細介紹多寄存器數(shù)據(jù)傳送指令的語法格式及用法。
  11.6.1 多寄存器數(shù)據(jù)加載指令LDMIA
 ?。?)編碼格式
  多寄存器加載指令LDMIA的編碼格式如圖11.59所示。
  多寄存器數(shù)據(jù)裝載指令LDMIA(Load Multiple Increment After)裝載連續(xù)的內(nèi)存單元到多個通用寄存器。
  Thumb指令集之多寄存器數(shù)據(jù)傳送指令解析
  圖11.59 LDMIA指令的編碼格式
 ?。?)指令的語法格式
  LDMIA 《Rn》!,《registers》
  ① 《Rn》
  基址寄存器。指定被裝載的內(nèi)存單元基地址。
 ?、?!
  采用回寫(writeback)的尋址方式。Thumb指令集中多寄存器數(shù)據(jù)傳送指令采用固定的后增量IA(Increment After)尋址方式,并且采用寄存器回寫方式。
 ?、?《registers》
  被加載的寄存器列表。不同的寄存器之間用“,”隔開。完整的寄存器列表包含在“{}”中。編號低的寄存器對應(yīng)于內(nèi)存中低地址單元,編號高的寄存器對應(yīng)于內(nèi)存中高地址單元。寄存器r0~r7分別對應(yīng)于指令編碼中bit[0]~bit[7]位。如果Ri存在于寄存器列表中,則相應(yīng)的bit[i]指1,否則為0。
  注意如果基址寄存器Rn出現(xiàn)在寄存器列表《registers》中,則Rn的值為對于的內(nèi)存單元數(shù)據(jù),而非地址回寫值。
  (3)指令操作的偽代碼
  Start_address = Rn
  End_address = Rn + (Number_of_Set_Bits_In(register_list)*4) – 4
  Address = start_address
  For i = 0 to 7
  If register_list[i] = = 1
  Ri = Memory[address,4]
  Address = address + 4
  Assert end_address = = address – 4
  Rn = Rn + (Number_of_Set_Bits_In(register_list) * 4)
  (4)對應(yīng)的ARM指令
 ?、?如果基址寄存器在寄存器列表《registers》中,對應(yīng)的ARM指令為:
  LDMIA 《Rn》!,《registers》。
  ② 如果基址寄存器不存在于寄存器列表《registers》中,對應(yīng)的ARM指令為:
  LDMIA 《Rn》,《registers》
  11.6.2 多寄存器數(shù)據(jù)存儲指令STMIA
 ?。?)編碼格式
  多寄存器數(shù)據(jù)存儲指令STMIA的編碼格式如圖11.60所示。
  Thumb指令集之多寄存器數(shù)據(jù)傳送指令解析
  圖11.60 STMIA指令的編碼格式
  多寄存器數(shù)據(jù)存儲指令STMIA(Store Multiple Increment After)存儲多個通用寄存器的內(nèi)容到連續(xù)的內(nèi)存單元。
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1TC358743XBG評估板參考手冊
  2. 1.36 MB  |  330次下載  |  免費
  3. 2開關(guān)電源基礎(chǔ)知識
  4. 5.73 MB  |  6次下載  |  免費
  5. 3100W短波放大電路圖
  6. 0.05 MB  |  4次下載  |  3 積分
  7. 4嵌入式linux-聊天程序設(shè)計
  8. 0.60 MB  |  3次下載  |  免費
  9. 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
  10. 0.61 MB  |  2次下載  |  免費
  11. 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
  12. 0.70 MB  |  2次下載  |  免費
  13. 751單片機窗簾控制器仿真程序
  14. 1.93 MB  |  2次下載  |  免費
  15. 8基于51單片機的RGB調(diào)色燈程序仿真
  16. 0.86 MB  |  2次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33564次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關(guān)電源設(shè)計實例指南
  8. 未知  |  21548次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設(shè)計》 溫德爾著
  16. 0.00 MB  |  6653次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537796次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191185次下載  |  免費
  13. 7十天學(xué)會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183278次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費