版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第三節(jié)ARM指令集凌明東南大學國家專用集成電路系統(tǒng)工程技術研究中心trio@trio@WhydoweneedtoknowtheinstructionsetARMandThumbinstructionsetsweredesignedtogivethebestoutputfromcompilersEspeciallytheThumbInstructionsetMostdesigneffortformanysystemsisfocussedoncompiledcodeandknowledgeoftheinstructionsetisnotrequiredBut…..EmbeddedsystemsrequireinitialisationcodeandinterruptroutinesAllsystemsrequiredebugging–possiblyattheinstructionlevelPerformancegainscanbemadebywritingassemblerroutinesSomefeaturesoftheARMarchitecturearenotavailablewithcompilers目錄ARM指令集匯編語言編程簡介ARM指令集ARM指令集所有指令都是32位長許多指令都是單周期指令指令可條件執(zhí)行LOAD/STORE架構例數據處理指令SUBr0,r1,#5ADDr2,r3,r3,LSL#2ANDSr4,r4,#0x20ADDEQr5,r5,r6特定的訪問存儲器的指令LDRR0,[R1],#4STRNEBr2,[r3,r4]LDRSHr5,[r6,#8]!STMFDsp!,{r0,r2-r7,r10}ARM指令的一般編碼格式ARM指令字長為固定的32位。一條典型的ARM指令編碼格式如圖。Opcode 指令操作符編碼Cond 指令執(zhí)行的條件編碼S 決定指令的操作是否影響CPSR的值Rd 目標寄存器編碼Rn 包含第1個操作數的寄存器編碼Shifter_operand 表示第二個操作數指令格式<opcode>{<cond>}{S}<Rd>,<Rn>{,<operand2>}ARMinstructionscanbemadetoexecuteconditionallybypost-fixingthemwiththeappropriateconditioncodeThiscanincreasecodedensityandincreaseperformancebyreducingthenumberofforwardbranches
CMPr0,r1ADDGTr2,r2,#1ADDLEr3,r3,#1Bydefault,dataprocessinginstructionsdonotaffecttheconditionflagsbutthiscanbeachievedbypostfixingtheinstruction(andanyconditioncode)withan“S”loopADDr2,r2,r3SUBSr1,r1,#0x01 BNE
loop
r2=r2+r3ifZflagclearthenbranchdecrementr1andsetflagsr0-r1,comparer0withr1andsetflagsif>r2=r2+1flagsremainunchangedif<=r3=r3+1flagsremainunchangedConditionalExecutionandFlagsConditionalexecutionexamplesif(r0==0){r1=r1+1;}else{r2=r2+1;}Csourcecode5instructions5words5or6cycles3instructions3words3cyclesCMPr0,#0BNEelseADDr1,r1,#1BendelseADDr2,r2,#1end...ARMinstructionsunconditionalCMPr0,#0ADDEQr1,r1,#1ADDNEr2,r2,#1...conditional條件碼條件執(zhí)行ARM指令可以通過增加條件執(zhí)行碼后綴來條件執(zhí)行這樣可以增加代碼密度,看下面的例子CMPr3,r0# CMPr3,#0 BEQskip ADDNEr0,r1,r2ADDr0,r1,r2skip缺省情況下,數據處理指令不影響條件碼標志,但是條件碼標志可由“S”來設置,CMP不需要加“S”SUBSr1,r1,#1 r1減1并設置標志BNEloop 如果Z標志清除則跳轉條件執(zhí)行的例子使用一系列條件執(zhí)行的指令If(a==0)func(1);CMP r0,#0MOVEQ r0,#1BLEQ func設置標志后使用不同的條件碼If(a==0)x=0;If(a>0)x=1;CMP r0,#0MOVEQ r1,#0MOVGT r1,#1使用條件比較指令If(a==4||a==10) x=0;CMP r0,#4CMPNE r0,#10MOVEQ r1,#0DataprocessingInstructionsConsistof:Arithmetic: ADD ADC SUB SBC RSB RSCLogical: AND ORR EOR BICComparisons: CMP CMN TST TEQDatamovement: MOV MVNTheseinstructionsonlyworkonregisters,NOTmemory.Syntax:
<Operation>{<cond>}{S}Rd,Rn,Operand2Operand2canbearegisteroranimmediatevalueSUBr0,r1,r2 ANDr1,r4,#0xFFComparisonssetflagsonly-theydonotspecifyRdCMPr0,r3DatamovementdoesnotspecifyRnMOVr0,r1Operand2issenttotheALUviabarrelshifterRegister,optionallywithshiftoperationappliedShiftvaluecanbeeitherbe:5bitunsignedintegerSpecifiedinbottombyteofanotherregisterUsedformultiplicationbyconstantADDr0,r5,r5LSL1r0=r5x3Immediatevalue8bitnumber,witharangeof0-255.RotatedrightthroughevennumberofpositionsAllowsincreasedrangeof32-bitconstantstobeloadeddirectlyintoregistersResultOperand1Barrel
ShifterOperand2ALUTheSecondOperandShiftOperationsDestinationCF0DestinationCFLSL:LogicalLeftShiftASR:ArithmeticRightShiftMultiplicationbyapowerof2Divisionbyapowerof2,preservingthesignbitDestinationCF...0DestinationCFLSR:LogicalShiftRightROR:RotateRightDivisionbyapowerof2BitrotatewithwraparoundfromLSBtoMSBDestinationRRX:RotateRightExtendedSinglebitrotatewithwraparound
fromCFtoMSBCFTheseshiftoperationsareusedaspartofdataprocessinginstructions.bitscanbeshiftedfrom0-31places,typicallywithoutperformancepenaltyNoARMinstructioncancontaina32bitimmediateconstantAllARMinstructionsarefixedas32bitslongThedataprocessinginstructionformathas12bitsavailableforoperand24bitrotatevalue(0-15)ismultipliedbytwotogiverange0-30instepsof2Ruletorememberis
“8-bitsrotatedrightbyanevennumberofbitpositions”07118immed_8Shifter
RORrotx2QuickQuiz:
0xe3a004ff
MOVr0,#???Immediateconstants關于立即數的例子!匯編器把立即數轉換為移位的方式MOVr0,#0x4096; 0x40循環(huán)右移26位ADDr1,r2,#0xFF0000; 0xFF循環(huán)右移16位不能夠按照規(guī)則生成的立即數會導致錯誤Toallowlargerconstantstobeloaded,theassembleroffersapseudo-instruction:LDRrd,=constThiswilleither:ProduceaMOVorMVNinstructiontogeneratethevalue(ifpossible) orGenerateaLDRinstructionwithaPC-relativeaddresstoreadtheconstantfromaliteralpool(Constantdataareaembeddedinthecode)ForexampleLDRr0,=0xFF => MOVr0,#0xFFLDRr0,=0x55555555
=>
LDRr0,[PC,#Imm12]
…
…
DCD0x55555555ThisistherecommendedwayofloadingconstantsintoaregisterLoading32bitconstantsThereare2classesofmultiply-producing32-bitand64-bitresults32-bitversionsonanARM7TDMIwillexecutein2-5cyclesMULr0,r1,r2 ;r0=r1*r2MLAr0,r1,r2,r3 ;r0=(r1*r2)+r364-bitmultiplyinstructionsofferbothsignedandunsignedversionsFortheseinstructionthereare2destinationregisters[U|S]MULLr4,r5,r2,r3 ;r5:r4=r2*r3[U|S]MLALr4,r5,r2,r3 ;r5:r4=(r2*r3)+r5:r4MostARMcoresdonotofferintegerdivideinstructionsDivisionoperationswillbeperformedbyClibraryroutinesorinlineshiftsMultiplyandDivide乘法MUL{條件}{S} 目的寄存器,操作數1,操作數2例:MULS R0,R1,R2 ;R0=R1×R2,同時設置CPSR中的相關條件標志位MLA{條件}{S} 目的寄存器,操作數1,操作數2,操作數3MLAS R0,R1,R2,R3 ;R0=R1×R2+R3,同時設置CPSR中的相關條件標志位SMULL、SMLAL、UMULL、UMLAL等乘法指令的執(zhí)行周期ARM7TDMI約為2-5個時鐘周期StrongARM/XScale約為1-3個時鐘周期ARM9E/ARM102xE約為2個時鐘周期跳轉指令B Label ;PC相對地址,32M范圍。程序無條件跳轉到標號Label處執(zhí)行BL Label ;當程序無條件跳轉到標號Label處執(zhí)行時,同時將當前的PC值保存到R14中在LR中保存返回地址子程序返回時從LR中恢復PC存儲在跳轉指令中的實際值是相對當前PC值的一個偏移量,而不是一個絕對地址。它是24位有符號數,左移兩位后有符號擴展為32位,表示的有效偏移為26位(前后32MB的地址空間)。利用相對PC的偏移量進行跳轉的好處是可以生成PIC代碼。如果跳轉的空間超過32MB,如何處理?:BLfunc2::BXlrfunc1func2voidfunc1(void){
: func2(); :}子函數Implementingaconventionalsubroutinecallrequirestwosteps:StorethereturnaddressBranchtotheaddressoftherequiredsubroutineThesestepsarecarriedoutinoneinstruction,BLThereturnaddressisstoredinthelinkregister(lr/r14)Branchtoanaddressanywherewithina+/-32MBrangeReturningisperformedbyrestoringtheprogramcounter(pc)fromlr單寄存器數據傳送LDR STR
Word
LDRB STRB
Byte
LDRH STRH
Halfword
LDRSB
SignedbyteloadLDRSH
SignedhalfwordloadMemorysystemmustsupportallaccesssizesSyntax:LDR{<cond>}{<size>}Rd,<address>STR{<cond>}{<size>}Rd,<address>e.g.LDREQBLDR/STR指令的尋址方式AddressaccessedbyLDR/STRisspecifiedbyabaseregisterwithanoffsetForwordandunsignedbyteaccesses,offsetcanbe:Anunsigned12-bitimmediatevalue(i.e.0-4095bytes)
LDRr0,[r1,#8]Aregister,optionallyshiftedbyanimmediatevalue
LDRr0,[r1,r2]
LDRr0,[r1,r2,LSL#2]Thiscanbeeitheraddedorsubtractedfromthebaseregister:
LDRr0,[r1,#-8]
LDRr0,[r1,-r2,LSL#2]Forhalfwordandsignedhalfword/byte,offsetcanbe:Anunsigned8bitimmediatevalue(i.e.0-255bytes)Aregister(unshifted)Choiceofpre-indexedorpost-indexedaddressingChoiceofwhethertoupdatethebasepointer(pre-indexedonly)
LDRr0,[r1,#-8]!
0x50x5r10x200Base
Register0x200r00x5Source
Register
forSTROffset120x20cr10x200Original
Base
Register0x200r00x5Source
Register
forSTROffset120x20cr10x20cUpdated
Base
RegisterAuto-updateform:
STRr0,[r1,#12]!PreorPostIndexedAddressing?
Pre-indexed:
STRr0,[r1,#12]
Post-indexed:
STRr0,[r1],#12關于前變址后變址的小結Word或者unsignedbyteHalfword,signedhalf,signedbyte尋址方式1語法1尋址方式2語法2立即數偏移前變址[Rn,#+/-offset_12]立即數偏移前變址[Rn,#+/-offset_8]寄存器偏移前變址[Rn,+/-Rm]寄存器偏移前變址[Rn,+/-Rm]比例寄存器偏移前變址[Rn,+/-Rm,shift_imm]立即數偏移回寫前變址[Rn,#+/-offset_12]!立即數偏移回寫前變址[Rn,#+/-offset_8]!寄存器回寫前變址[Rn,+/-Rm]!寄存器回寫前變址[Rn,+/-Rm]!比例寄存器回寫前變址[Rn,+/-Rm,shift_imm]!立即數后變址[Rn],#+/-offset_12立即數后變址[Rn],#+/-offset_8寄存器后變址[Rn],+/-Rm寄存器后變址[Rn],+/-Rm比例寄存器后變址[Rn],+/-Rm,shift_immGeneratingBrancheswithLDRTheARM’sbranchinstructionislimitedtoarangeof±32MBHoweverbranchescanalsobeperformedbyloadingaddressvaluesdirectlyintothePC(r15)armasmprovidespseudoinstructionstomakethiseasier
AssemblerCodeLDRpc,=label;loadaddressoflabelintoPCARMASM
ObjectCode
LDRpc,[pc,#n] .--------------DCD0x12345678LiteralpooladdressdataBranchesanywherewithinthe4GBaddressspacearethuspossibleTheuseofbaseregisterupdatingenablessimplecopyingroutinestobewrittenForexample:Thepost-indexedvariantcouldbeusedtocopyablockofmemory;r8pointstostartofsourcedata;r9pointstoendofsourcedata;r10pointstostartofdestinationdataloop LDR r0,[r8],#4 ;load4bytes STR r0,[r10],#4 ;andstorethem CMP r8,r9 ;checkfortheend BLT loop ;elseloopInthisexample1wordiscopiedperiterationMemoryBlockCopying(1)IncreasingMemoryr9r8r10塊數據傳送批量加載和存儲指令(LDM/STM)允許在存儲器和16個寄存器之間傳送數據寄存器的傳送順序不能任意指定低地址的內容總是總是傳送到低寄存器例:LDMIAr10!,{r0,r1,r4}基址寄存器指定了訪問存儲器的地址這些指令有效的用于:在存儲器中傳送數據塊在堆棧中保存和恢復上下文LDM/STM操作LDM(或STM){條件}{類型}基址寄存器{!},寄存器列表{∧},例:LDMIAr12!,{r0-r11};由基址寄存器所指示的一片連續(xù)存儲器到寄存器列表所指示的多個寄存器之間傳送數據IA 每次傳送后地址加1;IB 每次傳送前地址加1;DA 每次傳送后地址減1;DB 每次傳送前地址減1;FD 滿遞減堆棧;ED 空遞減堆棧;FA 滿遞增堆棧;EA 空遞增堆棧;LoadandStoreMultiplesSyntax:<LDM|STM>{<cond>}<addressing_mode>Rb{!},<registerlist>4addressingmodes:LDMIA/STMIAincrementafter
LDMIB/STMIB incrementbefore
LDMDA/STMDAdecrementafter
LDMDB/STMDBdecrementbeforeIAr1Increasing
Addressr4r0r1r4r0r1r4r0r1r4r0r10IBDADBLDMxxr10,{r0,r1,r4}STMxxr10,{r0,r1,r4}BaseRegister(Rb)內存塊拷貝!可以使得STM/LDM指令自動更新基址寄存器對于IA、IB,寄存器的內容加4對于DA、DB,寄存器的內容減4例:;r12指向源數據的起始地址;r14指向源數據的結束地址;r13指向目標數據的起始地址LoopLDMIAr12!,{r0-r11};STMIAr13!,{r0-r11};CMP r12,r14 BNE loopAswellasbeingusedforstackoperations,theSTM/LDM
instructionscanperformblockcopyingofmemoryForexample;r8pointstostartofsourcedata;r9pointstoendofsourcedata;r10pointstostartofdestinationdataloop LDMIA r8!,{r0-r7} ;load32bytes STMIA r10!,{r0-r7} ;andstorethem CMP r8,r9 ;checkfortheend BLT loop ;andloopInthisexample8wordsarecopiedperloopMemoryBlockCopying(2)IncreasingMemoryr9r8r10堆棧ARM的堆棧操作由塊傳送指令來實現(xiàn)STMFD (Push)批量存儲-滿遞減堆棧LDMFD (Pop)批量加載-滿遞減堆棧例:STMFDsp!,{r4-r7,lr};現(xiàn)場保存,將r4-r7、lr入棧例:LDMFDsp!,{r4-r7,pc}^;恢復現(xiàn)場,異常處理返回StacksLDMFDsp!,{r4-r7,pc}SP100FF1234AOBE80341010123484209753r41r514544r60r712lr9048pc9020r4100100FFr5FF1234r61234A0BEr7A0BE8034pc8034r4100r5FFr61234r7A0BElr8034ABCD8765102E16FFFF1010123484209753TopofMemorySPSP100FF1234A0BE8034SPOldSP100FF1234A0BE8034ARMstackoperationsareimplementedblocktransferinstructions:STMFD
(Push) StoreMultiple-FullDescendingstack[STMDB]LDMFD
(Pop) LoadMultiple-FullDescendingstack[LDMIA]Note:MultipleregisterswillalwaysbestackedinregisterorderfromlowestregistertolowestmemorylocationTheorderregistersarespecifiedhasnoeffect.STMFDsp!,{r4-r7,lr}LowAddressHighAddressAtomicoperationofamemoryreadfollowedbyamemorywritewhichmovesabyteorwordbetweenregisterandmemory.Syntax:SWP{<cond>}{B}Rd,Rm,[Rn]CanbeusedtoimplementflagsCannotbegeneratedfromCusingarmcc-mustuseassemblerRmRd321tempMemoryRnSWP數據交換指令(SWP)指令格式SWP{條件}目的寄存器,源寄存器1,[源寄存器2]例:SWP R0,R1,[R2] ;將R2所指向的存儲器中的字數據傳送到R0,同時將R1中的字數據傳送到R2所指向的存儲單元。SWP R0,R0,[R1] ;該指令完成將R1所指向的存儲器中的字數據與R0中的字數據交換??蓪崿F(xiàn)信號量操作I2C_SEM EQU 0x40003000I2C_SEM_WAITMOV R1,#0LDR R0,=I2C_SEMSWP R1,R1,[R0] ;取出信號量,并設置其為0CMP R1,#0 ;判斷是否有信號BEQ I2C_SEM_WAIT ;若沒有信號,則等待軟件中斷(SWI)產生一個軟件中斷異常SWI異常處理需要檢查SWI號,以確定進行何種所請求的操作通過使用SWI機制,應用程序可以在用戶模式下通過系統(tǒng)調用執(zhí)行一系列特權操作。例:SWI 0x02 ;調用操作系統(tǒng)編號為02的系統(tǒng)調用例程。SoftwareInterrupt(SWI)CausesanexceptiontraptotheSWIhardwarevectorTheSWIhandlercanexaminetheSWInumbertodecidewhatoperationhasbeenrequested.ByusingtheSWImechanism,anoperatingsystemcanimplementasetofprivilegedoperationswhichapplicationsrunninginusermodecanrequest.Syntax:
SWI{<cond>}<SWInumber>283124270Cond1111SWInumber(ignoredbyprocessor)23ConditionFieldSWI中斷處理程序實例SWI_handler ; ;保存寄存器r0~r12和lr ; STMFDsp!,{r0-r12,lr} ;讀SWI指令 LDRr10,[lr,#-4] ;屏蔽高8位 BICr10,r10,#0xff000000 ;r10中是SWI號 BLservice_routine ;returnfromSWI LDMFDsp!,{r0-r12,pc}^
PSR傳送指令MRS和MSR指令允許傳送CPSR/SPSR的值到一個通用寄存器,或反之例:MRS R0,SPSR;傳送SPSR的內容到R0在用戶模式下,所有的位均可讀,但是只有條件標志可寫。協(xié)處理器指令ARM的體系結構支持16個協(xié)處理器每一個協(xié)處理器指令都占用ARM指令集的固定部分如果指令中的協(xié)處理器在系統(tǒng)中并不存在,會產生一個未定義指令異常有三種類型的協(xié)處理器指令協(xié)處理器數據處理CDP:初始化協(xié)處理器數據處理操作協(xié)處理器寄存器傳送MRC:從協(xié)處理器寄存器傳送到ARM寄存器MCR:從ARM寄存器傳送到協(xié)處理器寄存器協(xié)處理器存儲器傳送指令LDC:從存儲器中加載協(xié)處理器寄存器STC:把協(xié)處理器寄存器的值存到存儲器中ARM指令集總結跳轉指令數據處理指令乘法指令狀態(tài)寄存器訪問指令Load/Store內存訪問指令批量Load/Store內存訪問指令信號量操作指令SWI系統(tǒng)調用指令ARM協(xié)處理器指令ARM匯編語言偽指令ARM中偽指令不是真正的ARM指令,這些偽指令在匯編編譯器堆源程序進行匯編處理時被替換成對應的ARM指令。ADR(小范圍的地址讀取偽指令)ADRL(中等范圍的地址讀取偽指令)LDR(大范圍的地址讀取偽指令)將一個32位的常數或者一個地址值讀取到寄存器中LDRR1,=0x12345678NOP空操作偽指令ARM匯編語言編程ARM匯編的程序設計ARM匯編語言以段(section)為單位組織源文件;段是相對獨立,具有特定名稱,不可分割的指令或數據序列;段分為代碼段和數據
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 通信行業(yè)保安工作總結
- 咖啡店銷售員銷售工作總結
- 礦業(yè)工程師礦產開采管理
- 食品飲料行業(yè)美工工作總結
- 《熱卷板產品介紹》課件
- 2021年四川省成都市公開招聘警務輔助人員輔警筆試自考題1卷含答案
- 2021年湖南省益陽市公開招聘警務輔助人員輔警筆試自考題1卷含答案
- 2021年河南省許昌市公開招聘警務輔助人員輔警筆試自考題1卷含答案
- 《婚姻家庭繼承法》課件
- 電視臺新年新春團拜會及廣告詞選用資料
- GB/T 5130-1997電氣用熱固性樹脂工業(yè)硬質層壓板試驗方法
- FZ/T 01041-2014絨毛織物絨毛長度和絨毛高度的測定
- 《經濟學導論》考試復習題庫(含答案)
- 農田水利渠道灌溉與排水課件
- 精品解析浙教版科學 九年級上冊 3.43 簡單機械之機械效率 同步練習
- 六棱塊護坡施工方案
- 機械制圖課件(完整版)
- 夸美紐斯-大教學論-文本細讀
- 《行政組織學小抄》word版
- 日立多聯(lián)機系統(tǒng)調試培訓教材
- (完整版)環(huán)境科學與工程-專業(yè)英語詞匯必備(免費)
評論
0/150
提交評論