電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開(kāi)發(fā)>Thumb指令集之異常中斷產(chǎn)生指令解析

Thumb指令集之異常中斷產(chǎn)生指令解析

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

資料介紹

 11.7 異常中斷產(chǎn)生指令(斷點(diǎn)指令)
  Thumb異常中斷產(chǎn)生指令與ARM指令集下的異常中斷指令十分相似。同ARM指令集相同,Thumb指令集中同樣包含兩條異常中斷產(chǎn)生指令:軟件中斷指令SWI用于產(chǎn)生SWI異常中斷;斷點(diǎn)中斷指令BKPT主要用于產(chǎn)生軟件斷點(diǎn),供調(diào)試程序使用(只在ARMv5及以上版本中使用)。
  11.7.1 軟中斷指令SWI
 ?。?)編碼格式
  軟中斷指令SWI的編碼格式如圖11.63所示。
  Thumb指令集之異常中斷產(chǎn)生指令解析
  圖11.63 SWI指令的編碼格式
  軟中斷指令SWI(Software Interrupt)用于使處理器產(chǎn)生軟中斷異常,使用這種機(jī)制實(shí)現(xiàn)在用戶模式對(duì)操作系統(tǒng)中特權(quán)模式的程序調(diào)用。
 ?。?)指令的語(yǔ)法格式
  SWI 《immed_8》
  其中,immed_8為8位立即數(shù),該立即數(shù)被處理器忽略,但可以被操作系統(tǒng)用來(lái)判斷用戶程序請(qǐng)求的服務(wù)類型。
 ?。?)指令操作的偽代碼
  R14_svc = address of next instruction after the SWI instruction
  SPSR_svc = CPSR
  CPSR[4:0] = 0b10011 /*進(jìn)入超級(jí)模式*/
  CPSR[5] = 0 /*進(jìn)入ARM狀態(tài)*/
  /*CPSR[6] is unchanged*/
  CPSR[7] = 1 /*禁止正常中斷*/
  If high vectors configured then
  PC = 0xffff0008
  Else
  PC = 0x00000008
 ?。?)對(duì)應(yīng)的ARM指令
  SWI 《immed_8》
  11.7.2 斷點(diǎn)中斷指令 BKPT
 ?。?)編碼格式
  斷點(diǎn)中斷指令BKPT的編碼格式如圖11.64所示。
  Thumb指令集之異常中斷產(chǎn)生指令解析
  圖11.64 BKPT指令的編碼格式
  斷點(diǎn)中斷指令BKPT(Breakpoint)可以使處理器產(chǎn)生預(yù)取異常(Prefetch Abort),使用這種機(jī)制可以在沒(méi)有調(diào)試硬件的情況下,實(shí)現(xiàn)程序的軟件調(diào)試。當(dāng)系統(tǒng)中使用硬件調(diào)試部件時(shí),可忽略該中斷。
 ?。?)指令的語(yǔ)法格式
  BKPT 《immed_8》
  其中,immed_8為8位立即數(shù),該立即數(shù)被處理器忽略,但可以向調(diào)試系統(tǒng)提供附加的斷點(diǎn)信息。
  注意當(dāng)系統(tǒng)中存在調(diào)試硬件時(shí),BKPT指令有兩種處理方法:一種由調(diào)試硬件處理BKPT指令;另一種可以直接由預(yù)取異常處理函數(shù)來(lái)處理BKPT指令,使用這種方法時(shí),由于使用了異常模式下的鏈接地址寄存器r14_abt和程序狀態(tài)寄存器SPSR_abt,所有要特別注意程序的嵌套。
  (3)指令操作的偽代碼
  if (not overridden by debug hardware)
  R14_abt = address of BKPT instruction +4
  SPSR_abt = CPSR
  CPSR[4:0] = 0b10111 /*進(jìn)入異常模式*/
  CPSR[5] = 0 /*進(jìn)入ARM狀態(tài)*/
  /*CPSR[6] is unchanged*/
  CPSR[7] = 1
  If high vectors configured then
  PC = 0xffff000c
  Else
  PC = 0x0000000c
 ?。?)對(duì)應(yīng)的ARM指令
  BKPT 《immed_8》
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

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

本月

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

總榜

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