版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3指令系統(tǒng)簡(jiǎn)介尋址方式ARM指令集GNUARM匯編器支持的偽操作指令A(yù)RM匯編偽指令A(yù)RM匯編編程簡(jiǎn)介第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.1
指令系統(tǒng)簡(jiǎn)介
指令是規(guī)定處理器進(jìn)行某種操作的命令,處理器能夠執(zhí)行的各種指令的集合稱為指令系統(tǒng)。3.1.1
ARM指令分類1、ARM指令集ARM指令集主要包括數(shù)據(jù)處理和雜項(xiàng)指令、分支指令、存儲(chǔ)器訪問指令、程序狀態(tài)寄存器處理指令、協(xié)處理器指令和異常中斷指令六大類。所有ARM指令均為32位長度,指令以字對(duì)齊方式保存在存儲(chǔ)器中。2、Thumb指令集
當(dāng)處理器工作在Thumb狀態(tài)時(shí),執(zhí)行Thumb指令集。所有的Thumb指令都是16位長度,指令以半字對(duì)齊方式保存在存儲(chǔ)器中。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)表3.1ARM指令的典型編碼格式3.1.2
ARM指令的編碼格式各部分編碼含義如下:
cond:指令執(zhí)行的條件碼;opcode:指令操作符的編碼;S:決定指令的執(zhí)行是否影響CPSR(當(dāng)前程序狀態(tài)寄存器)的值;Rn:包含第一個(gè)源操作數(shù)的寄存器編碼;第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.1.3ARM指令的條件碼域表3.2指令的條件碼第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)
當(dāng)處理器工作在ARM狀態(tài)時(shí),幾乎所有的指令均根據(jù)CPSR中條件碼的狀態(tài)和指令的條件域有條件地執(zhí)行,如表3.2所示。當(dāng)指令的執(zhí)行條件滿足時(shí),指令被執(zhí)行,否則指令被忽略,繼續(xù)執(zhí)行下一條指令。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.2
尋址方式1.立即數(shù)尋址立即數(shù)尋址指令中,操作碼字段后面的地址部分即操作數(shù)本身。SUBSR0,R0,#1;R0←R0–1,并且影響標(biāo)志位ADDR0,R0,#0x3f;R0←R0+0x3f第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)2.寄存器尋址寄存器尋址就是利用寄存器中的數(shù)值作為操作數(shù)。ADDR0,R1,R2;R0←R1?+?R2該指令的執(zhí)行效果是將寄存器R1和R2的內(nèi)容相加,其結(jié)果存放在寄存器R0中。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.寄存器移位尋址寄存器移位尋址是ARM指令集特有的尋址方式。當(dāng)?shù)诙€(gè)操作數(shù)是寄存器方式時(shí),第二個(gè)寄存器操作數(shù)在與第一個(gè)操作數(shù)結(jié)合之前,先進(jìn)行移位操作。MOVR0,R2,LSL#3 ;R2的值左移3位,結(jié)果放入R0ANDSR1,R1,R2,LSLR3;R2的值左移R3位,然后和R1相“與”,結(jié)果放入R1中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)4.寄存器間接尋址寄存器間接尋址指令中的地址碼給出的是一個(gè)通用寄存器的編號(hào),所需的操作數(shù)保存在寄存器指定地址的存儲(chǔ)單元中,即寄存器為操作數(shù)的地址指針。LDRR1,[R2];將R2指向的存儲(chǔ)單元的數(shù)據(jù)讀出,保存在R1中SWPR1,R1,[R2];將寄存器R1的值和R2指定的存儲(chǔ)單元的內(nèi)容交換第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)5.基址變址尋址基址變址尋址就是將寄存器(該寄存器一般稱作基址寄存器)的內(nèi)容與指令中給出的地址偏移量相加,從而得到一個(gè)操作數(shù)的有效地址。LDRR0,[R1,#4];將寄存器R1的內(nèi)容加上4形成操作數(shù)的有效地址,從該地
址取得操作數(shù)存入寄存器R0中。LDRR0,[R1,R2];將寄存器R1的內(nèi)容加上寄存器R2的內(nèi)容,形成操作數(shù)的有效地址,從該地址取得操作數(shù)存入寄存器R0中。LDRR0,[R1],#4;寄存器R1的內(nèi)容作為操作數(shù)的有效地址,從該地址取得操作數(shù)存入寄存器R0中,然后,R1的內(nèi)容自增4個(gè)字節(jié)。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)6.多寄存器尋址該指令可以一次完成多個(gè)寄存器值的傳送,這種尋址方式可以用一條指令完成傳送最多16個(gè)通用寄存器的值。LDMIAR0,{R1,R2,R3,R4};R1←[R0],R2←[R0?+?4],R3←[R0?+?8],R4←[R0?+?12]第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)7.相對(duì)尋址相對(duì)尋址以程序計(jì)數(shù)器PC的當(dāng)前值為基地址,指令中的地址標(biāo)號(hào)作為偏移量,將兩者相加之后得到的操作數(shù)作為有效地址。8.堆棧尋址使用一個(gè)稱作堆棧指針的專用寄存器指示當(dāng)前的操作位置,堆棧指針總是指向棧頂。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3
ARM指令集3.3.1
移位操作指令
移位操作包括LSL(邏輯左移)、ASL(算術(shù)左移)、LSR(邏輯右移)、ASR(算術(shù)右移)、ROR(循環(huán)右移)和RRX(帶擴(kuò)展的循環(huán)右移)6種類型。1.LSL(或ASL)LSL(或ASL)可完成對(duì)通用寄存器中的內(nèi)容進(jìn)行邏輯(或算術(shù))左移的操作。MOVR0,R1,LSL#2;將R1中的內(nèi)容左移兩位后傳送到R0中。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)2.?LSRLSR可完成對(duì)通用寄存器中的內(nèi)容進(jìn)行邏輯右移的操作,按操作數(shù)所指定的數(shù)量向右移位,左端用零來填充。MOVR0,R1,LSR#2;將R1中的內(nèi)容右移兩位后傳送到R0中,左端用零來填充。3.?ASRASR可完成對(duì)通用寄存器中的內(nèi)容進(jìn)行算術(shù)右移的操作,按操作數(shù)所指定的數(shù)量向右移位,左端用位31的值來填充。MOVR0,R1,ASR#2;將R1中的內(nèi)容右移兩位后傳送到R0中,左端用位31的值來填充第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)4.?RORROR可完成對(duì)通用寄存器中的內(nèi)容進(jìn)行循環(huán)右移的操作,按操作數(shù)所指定的數(shù)量向右循環(huán)移位,左端用右端移出的位來填充。MOVR0,R1,ROR#2;將R1中的內(nèi)容循環(huán)右移兩位后傳送到R0中。5.?RRXRRX可完成對(duì)通用寄存器中的內(nèi)容進(jìn)行帶擴(kuò)展的循環(huán)右移的操作,按操作數(shù)所指定的數(shù)量向右循環(huán)移位,左端用進(jìn)位標(biāo)志位C來填充。MOVR0,R1,RRX#2;將R1中的內(nèi)容進(jìn)行帶擴(kuò)展的循環(huán)右移兩位后傳送到R0中。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.2數(shù)據(jù)處理指令
數(shù)據(jù)處理指令可分為數(shù)據(jù)傳送指令、算術(shù)邏輯運(yùn)算指令和比較指令等。數(shù)據(jù)傳送指令:
1)MOVMOVR1,R0;
將寄存器R0的值傳送到寄存器R1中MOVPC,R14;
將寄存器R14的值傳送到PC中,常用于子程序返回
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)傳送指令:
2)MOVN
與MOV不同的是在傳送之前,將操作數(shù)按位取反,再進(jìn)行傳送。
MVNR0,#0;
將立即數(shù)0取反傳送到寄存器R0中,完成后R0=-1
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)算術(shù)邏輯運(yùn)算指令:
1)AND
將兩個(gè)操作數(shù)進(jìn)行邏輯與操作,常用于屏蔽操作數(shù)1的某些位。
ANDR0,R0,#3(#00000011);指令保持R0的0、1位,其余位清零
2)ORR
將兩個(gè)操作數(shù)進(jìn)行邏輯或運(yùn)算,常用于設(shè)置操作數(shù)1的某些位。ORRR0,R0,#3(#00000011);該指令設(shè)置R0的0、1位,其余位保持不變第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)算術(shù)邏輯運(yùn)算指令:
3)EOR
將兩個(gè)操作數(shù)進(jìn)行異或操作,常用于反轉(zhuǎn)操作數(shù)1的某些位。
EORR0,R0,#3(#00000011);
該指令反轉(zhuǎn)R0的0、1位,其余位不變
4)ADD
將兩個(gè)操作數(shù)進(jìn)行算術(shù)相加運(yùn)算。 ADDR0,R1,R2;該指令將寄存器R1的內(nèi)容與R2的內(nèi)容相加,結(jié)果放在寄存器R0里面第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)算術(shù)邏輯運(yùn)算指令:
5)ADC
與ADD的區(qū)別是除了兩個(gè)操作數(shù)進(jìn)行相加外,還包括CPSR中的C標(biāo)志位。
ADDSR0,R4,R8;
加低端的字
ADCSR1,R5,R9;
加第二個(gè)字,帶進(jìn)位
ADCSR2,R6,R10;
加第三個(gè)字,帶進(jìn)位 ADCR3,R7,R11;
加第四個(gè)字,帶進(jìn)位
上面四行指令的作用是實(shí)現(xiàn)兩個(gè)128位數(shù)的加法運(yùn)算。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)算術(shù)邏輯運(yùn)算指令:
6)SUB
將兩個(gè)操作數(shù)進(jìn)行相減操作。
SUBR0,R2,R3,LSL#1;
將R3寄存器的內(nèi)容左移一位后的結(jié)果與R3相減
7)SBC
與SUB的區(qū)別是還要減去C標(biāo)志位的反碼。 SBCR0,R1,R2; R0=R1-R2-!C,并根據(jù)結(jié)果設(shè)置CPSR的進(jìn)位標(biāo)志位第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)算術(shù)邏輯運(yùn)算指令:
8)RSB
與SUB的區(qū)別是:減數(shù)與被減數(shù)的位置顛倒一下。
RSBR0,R1,R2;
R0=R2–R1
9)RSC
與RSB的區(qū)別是:除了兩個(gè)數(shù)相減外,還要減去C標(biāo)志位的反碼。
RSCR0,R1,R2;
R0=R2–R1-!C第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)算術(shù)邏輯運(yùn)算指令:
10)TST
將操作數(shù)1和操作數(shù)2按位與運(yùn)算之后,再更新GPSR中的條件標(biāo)志位。一般用來檢測(cè)是否設(shè)置了特定的位
TSTR1,#0xffee;
將寄存器R1的值與0xffe按位與,并根據(jù)結(jié)果設(shè)置CPSR的標(biāo)志位
11)TEQ
將操作數(shù)1和操作數(shù)2按位異或運(yùn)算之后,再更新GPSR中的條件標(biāo)志位。一般用來檢測(cè)操作數(shù)1和操作數(shù)2是否相等 TEQR1,R2;
檢查兩個(gè)操作數(shù)是否相等第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)比較指令:
1)CMP
將兩個(gè)操作數(shù)進(jìn)行比較,同時(shí)更新CPSR中的標(biāo)志位。
CMPR1,R0 ;
將寄存器R1的值與寄存器R0的值相減,并根據(jù)結(jié)果設(shè)置CPSR的標(biāo)志位
2)CMN
操作數(shù)1和取反后的操作數(shù)2進(jìn)行比較,再更新CPSR中的標(biāo)志位。 CMNR1,R0 ;
將寄存器R1的值與寄存器R0的值相加,并根據(jù)結(jié)果設(shè)置CPSR的標(biāo)志位第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)比較指令:
3)BIC
操作數(shù)2是32位的掩碼,如果在掩碼中設(shè)置了某一位,則相應(yīng)的在操作數(shù)1中清除對(duì)應(yīng)的那一位。
BICR0,R0,#%1011;該指令清除R0中的位0、1和3,其余的位保持不變
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.3乘法指令與乘加指令
指令中的寄存器必須是通用寄存器,不能是立即數(shù)。乘法指令:
1)MUL
操作數(shù)1和操作數(shù)2進(jìn)行相乘運(yùn)算。
MULR0,R1,R2;R0=R1×R2
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)乘法指令:
2)SMULL
完成操作數(shù)1與操作數(shù)2的乘法運(yùn)算,并把結(jié)果的低32位放置到目的寄存器Low中,結(jié)果的高32位放置到目的寄存器High中。
SMULLR0,R1,R2,R3;R0=(R2×R3)的低32位,R1=(R2×R3)的高32位
3)UMLAL
與SMULL的區(qū)別是操作數(shù)1和2均為無符號(hào)整數(shù)。
UMULLR0,R1,R2,R3;R0?=?(R2?×?R3)的低32位,R1?=?(R2?×?R3)的高32位第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)乘加指令:
1)MLA
完成操作數(shù)1與操作數(shù)2的乘法運(yùn)算,再將乘積加上操作數(shù)3,并把結(jié)果放置到目的寄存器中。
MLAR0,R1,R2,R3;
R0=R1×R2+R3
2)SMLAL
與SMULL的區(qū)別是將SMULL得到的結(jié)果低32位同目的寄存器的低32位相加放到目的寄存器low中,高32位是類似的。
SMLALR0,R1,R2,R3;R0?=?(R2?×?R3)的低32位?+?R0,R1?=?(R2?×?R3)的高32位?+?R1第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)乘加指令:
3)UMLAL
與SMLAL的區(qū)別是操作數(shù)1和2均為無符號(hào)的32位整數(shù)。
UMLALR0,R1,R2,R3;
R0?=?(R2?×?R3)的低32位?+?R0,R1=(R2?×?R3)的高32位?+?R1第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.4加載/存儲(chǔ)指令
加載/存儲(chǔ)指令用于寄存器和存儲(chǔ)器之間的數(shù)據(jù)傳送。加載指令用于將存儲(chǔ)器中的數(shù)據(jù)傳送到寄存器,存儲(chǔ)指令則完成相反的操作。加載指令:
1)LDR
從存儲(chǔ)器中將一個(gè)32位的字?jǐn)?shù)據(jù)傳送到目的寄存器中。
LDRR0,[R1,R2];
將存儲(chǔ)器地址為R1?+?R2的字?jǐn)?shù)據(jù)讀入寄存器R0 LDRR0,[R1],R2;
將存儲(chǔ)器地址為R1的字?jǐn)?shù)據(jù)讀入寄存器R0,并將新地址R1?+?R2寫入R1第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)加載指令:
2)LDRH
從存儲(chǔ)器中將一個(gè)16位的半字?jǐn)?shù)據(jù)傳送到目的寄存器中,將寄存器的高16位清零。
LDRHR0,[R1,#8];
將存儲(chǔ)器地址為R1?+?8的半字?jǐn)?shù)據(jù)讀入寄存器R0,并將R0的高16位清零
3)LDRB
與LDRH的區(qū)別是傳送的是8位字節(jié)數(shù)據(jù),將寄存器的高24位清零。 LDRBR0,[R1];
將存儲(chǔ)器地址為R1的字節(jié)數(shù)據(jù)讀入寄存器R0,并將R0的高24位清零第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)存儲(chǔ)指令:
1)STR
將源寄存器的32位數(shù)據(jù)傳送到存儲(chǔ)器上面。
STRR0,[R1,#8];
將R0中的字?jǐn)?shù)據(jù)寫入以R1?+?8為地址的存儲(chǔ)器中
2)STRH
將源寄存器的低16位數(shù)據(jù)傳送到存儲(chǔ)器上面。 STRHR0,[R1,#8];
將寄存器R0中的半字?jǐn)?shù)據(jù)寫入以R1?+?8為地址的存儲(chǔ)器中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)存儲(chǔ)指令:
3)STRB
將源寄存器的低8位數(shù)據(jù)傳送到存儲(chǔ)器上面。
STRBR0,[R1];
將寄存器R0中的字節(jié)數(shù)據(jù)寫入以R1為地址的存儲(chǔ)器中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.5批量數(shù)據(jù)加載/存儲(chǔ)指令
批量數(shù)據(jù)加載指令用于將一片連續(xù)的存儲(chǔ)器中的數(shù)據(jù)傳送到多個(gè)寄存器,批量數(shù)據(jù)存儲(chǔ)指令則完成相反的操作。批量數(shù)據(jù)加載指令為LDM,批量數(shù)據(jù)存儲(chǔ)指令為STM。 LDM(或STM)指令的格式為: LDM(或STM){條件}{類型}基址寄存器{!},寄存器列表{^}注意:基址寄存器不能為R15!!!!!第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì){類型}有以下幾種情況: IA—每次傳送后地址加1; IB—每次傳送前地址加1; DA—每次傳送后地址減1; DB—每次傳送前地址減1; FD—滿遞減堆棧; ED—空遞減堆棧; FA—滿遞增堆棧; EA—空遞增堆棧;第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)STMFD?R13!,{R0,R4-R12,LR};
將寄存器列表中的寄存器(R0,R4到R12,LR)存入堆棧LDMFD?R13!,{R0,R4-R12,LR} ;將堆棧內(nèi)容恢復(fù)到寄存器(R0,R4到R12,LR)第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.6跳轉(zhuǎn)指令
跳轉(zhuǎn)指令用于實(shí)現(xiàn)程序流程的跳轉(zhuǎn)。一般有兩種方法實(shí)現(xiàn)程序的跳轉(zhuǎn):(1)使用專門的跳轉(zhuǎn)指令。(2)直接向程序計(jì)數(shù)器PC寫入跳轉(zhuǎn)地址值。
1)B
處理器將立即跳轉(zhuǎn)到給定的目標(biāo)地址,從那里繼續(xù)執(zhí)行。
B?Label; 程序無條件跳轉(zhuǎn)到標(biāo)號(hào)Label處執(zhí)行 CMP?R1,#0; BEQ?Label; 當(dāng)CPSR寄存器中的Z條件碼置位,程序跳轉(zhuǎn)到標(biāo)號(hào)Label處執(zhí)行第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)跳轉(zhuǎn)指令:
2)BL
與B的區(qū)別是:在跳轉(zhuǎn)之前會(huì)將當(dāng)前PC的值保存在R14中。
BLLabel;當(dāng)程序無條件跳轉(zhuǎn)到標(biāo)號(hào)Label處執(zhí)行時(shí),將當(dāng)前的PC值保存到R14中
3)BLX
與BL的區(qū)別是ARM處理器的狀態(tài)由ARM狀態(tài)轉(zhuǎn)換到Thumb狀態(tài)。
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.7程序狀態(tài)寄存器訪問指令 ARM微處理器支持程序狀態(tài)寄存器訪問指令,這些指令用于在程序狀態(tài)寄存器和通用寄存器之間傳送數(shù)據(jù)。程序狀態(tài)寄存器訪問指令包括MRS指令和MSR指令。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 1)MRS
MRS指令用于將程序狀態(tài)寄存器的內(nèi)容傳送到通用寄存器中。
MRS指令的語法格式為:MRS{條件}通用寄存器,程序狀態(tài)寄存器(CPSR或SPSR) MRS?R0,CPSR;
傳送CPSR的內(nèi)容到R0 MRS?R0,SPSR;
傳送SPSR的內(nèi)容到R0第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 2)MSR
MSR指令用于將操作數(shù)的內(nèi)容傳送到程序狀態(tài)寄存器的特定域中。
MSR指令的語法格式為:MSR{條件}程序狀態(tài)寄存器(CPSR或SPSR)_<域>,操作數(shù) MSR?CPSR,R0;
傳送R0的內(nèi)容到CPSR MSR?SPSR,R0;
傳送R0的內(nèi)容到SPSR MSR?CPSR_c,R0;
傳送R0的內(nèi)容到SPSR,但僅僅修改CPSR中的控制位域第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.8數(shù)據(jù)交換指令 ARM微處理器支持?jǐn)?shù)據(jù)交換指令,這些指令用于在存儲(chǔ)器和寄存器之間交換數(shù)據(jù)。數(shù)據(jù)交換指令包括SWP(字?jǐn)?shù)據(jù)交換指令)和SWPB(字節(jié)數(shù)據(jù)交換指令)。與之相對(duì)應(yīng)的程序狀態(tài)寄存器訪問指令,它用于的是在程序狀態(tài)寄存器和通用寄存器之間的數(shù)據(jù)交換。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 1)SWP
SWP指令用于將源寄存器2所指向的存儲(chǔ)器中的字?jǐn)?shù)據(jù)傳送到目的寄存器中,同時(shí)將源寄存器1中的字?jǐn)?shù)據(jù)傳送到源寄存器2所指向的存儲(chǔ)器中。
SWP指令的語法格式為
SWP{條件}目的寄存器,源寄存器1,[源寄存器2] SWPR0,R1,[R2]; 將R2所指向的存儲(chǔ)器中的字?jǐn)?shù)據(jù)傳送到R0,同時(shí)將R1中的字?jǐn)?shù)據(jù)傳送到R2所指向的存儲(chǔ)單元第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 2)SWPB
SWPB指令用于將源寄存器2所指向的存儲(chǔ)器中的字節(jié)數(shù)據(jù)傳送到目的寄存器中,目的寄存器的高24位清零,同時(shí)將源寄存器1中的字節(jié)數(shù)據(jù)傳送到源寄存器2所指向的存儲(chǔ)器中。
SWPB指令的語法格式為SWPB{條件}目的寄存器,源寄存器1,[源寄存器2] SWPB?R0,R0,[R1]; 將R1所指向的存儲(chǔ)器中的字節(jié)數(shù)據(jù)與R0中的低8位數(shù)據(jù)交換第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.9協(xié)處理器指令 ARM的協(xié)處理器指令主要用于ARM處理器初始化、ARM協(xié)處理器的數(shù)據(jù)處理操作、在ARM處理器的寄存器和協(xié)處理器的寄存器之間傳送數(shù)據(jù)、在ARM協(xié)處理器的寄存器和存儲(chǔ)器之間傳送數(shù)據(jù)。ARM協(xié)處理器指令包括CDP、LDC、STC、和MRC。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 1)CDP
CDP指令用于ARM處理器通知ARM協(xié)處理器執(zhí)行特定的操作。若協(xié)處理器不能成功完成特定的操作,則產(chǎn)生未定義指令異常。
CDP指令的語法格式為CDP{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,目的寄存器,源寄存器1,源寄存器2,協(xié)處理器操作碼2 CDP?P3,2,C12,C10,C3,4;
完成協(xié)處理器P3的初始化第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 2)LDC
LDC指令用于將源寄存器所指向的存儲(chǔ)器中的字?jǐn)?shù)據(jù)傳送到目的寄存器中。若協(xié)處理器不能成功完成傳送操作,則產(chǎn)生未定義指令異常。
LDC指令的語法格式為LDC{條件}{L}協(xié)處理器編碼,目的寄存器,[源寄存器]
LDC?P3,C4,[R0];
將ARM處理器的寄存器R0所指向的存儲(chǔ)器中的字?jǐn)?shù)據(jù)傳送到協(xié)處理器P3的寄存器C4中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 3)STC
STC指令用于將源寄存器中的字?jǐn)?shù)據(jù)傳送到目的寄存器所指向的存儲(chǔ)器中。若協(xié)處理器不能成功完成傳送操作,則產(chǎn)生未定義指令異常。 STC指令的語法格式為STC{條件}{L}協(xié)處理器編碼,源寄存器,[目的寄存器]
STC?P3,C4,[R0];
將協(xié)處理器P3的寄存器C4中的字?jǐn)?shù)據(jù)傳送到ARM處理器的寄存器R0所指向的存儲(chǔ)器中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 4)MCR
MCR指令用于將ARM處理器的寄存器中的數(shù)據(jù)傳送到協(xié)處理器的寄存器中。若協(xié)處理器不能成功完成操作,則產(chǎn)生未定義指令異常。 MCR指令的語法格式為MCR{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,源寄存器,目的寄存器1,目的寄存器2,協(xié)處理器操作碼2
MCR?P3,3,R0,C4,C5,6;
將ARM處理器的寄存器R0中的數(shù)據(jù)傳送到協(xié)處理器P3的寄存器C4和C5中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 5)MRC
MRC指令用于將協(xié)處理器寄存器中的數(shù)據(jù)傳送到ARM處理器的寄存器中。若協(xié)處理器不能成功完成操作,則產(chǎn)生未定義指令異常。 MRC指令的語法格式為MRC{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,目的寄存器,源寄存器1,源寄存器2,協(xié)處理器操作碼2
MRC?P3,3,R0,C4,C5,6;
將協(xié)處理器P3的寄存器中的數(shù)據(jù)傳送到ARM處理器的寄存器中第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.3.10異常產(chǎn)生指令 ARM微處理器支持的異常指令有SWI指令(軟件中斷指令)和BKPT指令(斷點(diǎn)中斷指令)。
1)SWI
SWI指令用于產(chǎn)生軟件中斷,以便用戶程序能調(diào)用操作系統(tǒng)的系統(tǒng)例程。SWI指令的語法格式為: SWI{條件}24位的立即數(shù) SWI?0x02;
調(diào)用操作系統(tǒng)編號(hào)為02的系統(tǒng)例程第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì) 2)BKPT
BKPT指令產(chǎn)生軟件斷點(diǎn)中斷,可用于程序的調(diào)試。 BKPT指令的語法格式為: BKPT16位的立即數(shù)
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.4GNUARM匯編器支持的偽操作指令
在ARM匯編語言程序中,有一些特殊指令助記符,它們與指令系統(tǒng)的助記符有所不同,沒有相應(yīng)的操作碼,通常稱這些特殊指令助記符為偽操作標(biāo)識(shí)符。在匯編程序中,偽操作指令主要有符號(hào)定義偽操作指令、數(shù)據(jù)定義偽操作指令、匯編控制偽操作指令及其雜項(xiàng)偽操作指令等。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)符號(hào)定義偽操作指令:
1)GBLA、GBLL
和GBLS GBLA:用于定義一個(gè)全局的數(shù)字變量;
GBLL:用于定義一個(gè)全局的邏輯變量; GBLS:用于定義一個(gè)全局的字符串變量。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)符號(hào)定義偽操作指令:
2)LCLA、LCLL和LCLS LCLA:用于定義一個(gè)ARM程序中的局部變量; LCLL:用于定義一個(gè)局部的邏輯變量; LCLS:用于定義一個(gè)局部的字符串變量。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)符號(hào)定義偽操作指令:
3)SETA、SETL和SETS SETA:用于給一個(gè)已經(jīng)定義的全局變量或局部變量賦值; SETL:用于給一個(gè)邏輯變量賦值; SETS:用于給一個(gè)字符串變量賦值。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)符號(hào)定義偽操作指令:
4)RLIST
RLIST偽指令用于對(duì)一個(gè)通用寄存器列表定義名稱。該偽指令定義的名稱可在ARM指令LDM/STM中使用。在LDM/STM指令中,列表中的寄存器訪問次序需根據(jù)寄存器的編號(hào)由低到高,而與列表中的寄存器排列次序無關(guān)。 RLIST偽指令的語法格式為
名稱RLIST{寄存器列表}第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)符號(hào)定義偽操作指令:
GBLATest1;
定義一個(gè)全局的數(shù)字變量,變量名為Test1
Test1SETA0xaa;
將該變量賦值為0xaa
LCLLTest5;
聲明一個(gè)局部的邏輯變量,變量名為Test5
Test4SETL{TRUE};
將該變量賦值為真
LCLATest3;
聲明一個(gè)局部的數(shù)字變量,變量名為Test3
Test3SETA0xaa;
將該變量賦值為0xaa
RegListRLIST{R0-R5,R8,R10};
將寄存器列表定義為RegList,可在ARM指令LDM/STM中通過該名稱訪問寄存器列表第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
1)DCB
DCB偽指令用于分配一片連續(xù)的字節(jié)存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。
DCB偽指令的語法格式為:
標(biāo)號(hào)DCB表達(dá)式 StrDCB"Thisisatest!";
分配一片連續(xù)的字節(jié)存儲(chǔ)單元并初始化第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
2)DCW(DCWU)
DCW(DCWU)偽指令用于分配一片連續(xù)的半字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。
DCW偽指令的語法格式為:
標(biāo)號(hào)DCW(DCWU)表達(dá)式 DataTestDCW1,2,3;
分配一片連續(xù)的半字存儲(chǔ)單元并初始化第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
3)DCD(DCDU)
DCD(DCDU)偽指令用于分配一片連續(xù)的字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。
DCD(DCDU)偽指令的語法格式為:
標(biāo)號(hào)DCD(DCDU)表達(dá)式 DataTestDCD4,5,6;
分配一片連續(xù)的字存儲(chǔ)單元并初始化第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
4)DCFD(DCFDU)
DCFD(DCFDU)偽指令用于為雙精度的浮點(diǎn)數(shù)分配一片連續(xù)的字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。
DCFD(DCFDU)偽指令的語法格式為:
標(biāo)號(hào)DCFD(或DCFDU)表達(dá)式 FDataTestDCFD2E115,-5E7;
分配一片連續(xù)的字存儲(chǔ)單元并初始化為指定的雙精度數(shù)第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
5)DCFS(DCFSU)
DCFS(或DCFSU)偽指令用于為單精度的浮點(diǎn)數(shù)分配一片連續(xù)的字存儲(chǔ)單元并用偽指令中指定的表達(dá)式初始化。
DCFS(DCFSU)偽指令的語法格式為:
標(biāo)號(hào)DCFS(或DCFSU)表達(dá)式 FDataTestDCFS2E5,-5E-7;
分配一片連續(xù)的字存儲(chǔ)單元并初始化為指定的單精度數(shù)第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
6)DCQ(DCQU)
DCQ(DCQU)偽指令用于分配一片以8個(gè)字節(jié)為單位的連續(xù)存儲(chǔ)區(qū)域并用偽指令中指定的表達(dá)式初始化。
DCQ(DCQU)偽指令的語法格式為:
標(biāo)號(hào)DCQ(DCQU)表達(dá)式 DataTestDCQ100;
分配一片連續(xù)的存儲(chǔ)單元并初始化為指定的值第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
7)SPACE
SPACE偽指令用于分配一片連續(xù)的存儲(chǔ)區(qū)域并初始化為0。其中,表達(dá)式為要分配的字節(jié)數(shù)。SPACE也可用“%”代替。 SPACE偽指令的語法格式為:
標(biāo)號(hào)SPACE表達(dá)式 DataSpaceSPACE100 ;分配連續(xù)100字節(jié)的存儲(chǔ)單元并初始化為0第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
8)MAP
MAP偽指令用于定義一個(gè)結(jié)構(gòu)化的內(nèi)存表的首地址。 MAP偽指令的語法格式為: MAP表達(dá)式{,基址寄存器} MAP0x100,R0;
定義結(jié)構(gòu)化內(nèi)存表首地址的值為0x100?+?R0第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)數(shù)據(jù)定義偽操作指令:
9)FIELD
FIELD偽指令用于定義一個(gè)結(jié)構(gòu)化內(nèi)存表中的數(shù)據(jù)域。 FIELD偽指令的語法格式為:
標(biāo)號(hào)FIELD表達(dá)式 MAP0x100;
定義結(jié)構(gòu)化內(nèi)存表首地址的值為0x100 AFIELD16;
定義A的長度為16字節(jié),位置為0x100第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編控制偽操作指令:
1).if….else….endif
.if….else….endif偽操作指令的語法格式為 .if邏輯表達(dá)式
指令1
… .elseif邏輯表達(dá)式2
指令2
… .endif第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編控制偽操作指令:
2).macro….endm
.macro….endm偽操作指令的語法格式為 .macro {$標(biāo)號(hào)}宏名{$參數(shù)1{,參數(shù)2,…}}
指令 .endm第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編控制偽操作指令:
3).mexit
.mexit偽操作指令的語法格式為 .macro {$標(biāo)號(hào)}宏名{$參數(shù)1{,參數(shù)2,…}}
指令 .endm第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編控制偽操作指令:
4)WHILE、WEND
WHILE、WEND偽操作指令的語法格式為 WHILE邏輯表達(dá)式
指令序列
WEND第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)雜項(xiàng)偽操作指令:
1)AREA
AREA偽指令用于定義一個(gè)代碼段或數(shù)據(jù)段。其中,段名若以數(shù)字開頭,則該段名需用“?|?”括起來,如?|1_test|。屬性字段表示該代碼段(或數(shù)據(jù)段)的相關(guān)屬性,多個(gè)屬性用逗號(hào)分隔。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)常用的屬性如下:●?CODE屬性:定義代碼段,默認(rèn)為READONLY?!?/p>
DATA屬性:定義數(shù)據(jù)段,默認(rèn)為READWRITE。●
READONLY屬性:指定本段為只讀,代碼段默認(rèn)為READONLY?!?/p>
READWRITE屬性:指定本段為可讀可寫,數(shù)據(jù)段的默認(rèn)屬性為READWRITE?!?/p>
COMMON屬性:定義一個(gè)通用的段,不包含任何用戶代碼和數(shù)據(jù)。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)雜項(xiàng)偽操作指令:
2)ALIGN 8)IMPORT 3)CODE16 9)EXTERN 4)ENTRY 10)GET 5)END 11)INCBIN 6)EQU 12)RN 7)EXPORT 13)ROUT第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.5ARM匯編偽指令A(yù)RM匯編程序中的偽指令不是真正的ARM指令或者Thumb指令。這些偽指令在匯編編譯時(shí)被替換成對(duì)應(yīng)的ARM或Thumb指令(序列)。ARM偽指令包括ADR、ADRL、LDR和NOP等。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
1)ADR(小范圍地址的讀取偽指令)
ADR指令將基于PC的地址值或基于寄存器的地址值讀取到寄存器中。 ADR偽指令的語法格式為: ADR{cond}register,expr
其中,cond為可選的指令執(zhí)行條件,register為目標(biāo)寄存器,expr為基于PC或者基于寄存器的地址表達(dá)式。
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
startMOVr0,#10;
因?yàn)镻C值為當(dāng)前指令地址值加8字節(jié) ADRr4,start;
本ADR偽指令將被編譯器替換成SUBr4,pc,#0xc
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
2)ADRL(中等范圍的地址讀取偽指令)
ADRL指令將基于PC或基于寄存器的地址值讀取到寄存器中。ADRL偽指令比ADR偽指令可以讀取更大范圍的地址。 ADRL偽指令的語法格式為: ADRL{cond}register,expr
其中,地址表達(dá)式expr的取值范圍為:當(dāng)?shù)刂分凳亲止?jié)對(duì)齊時(shí),其取指范圍為?-64?K~64?K;當(dāng)?shù)刂分凳亲謱?duì)齊時(shí),其取指范圍為?-256?K~256?K。
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
startMOVr0,#10;
因?yàn)镻C值為當(dāng)前指令地址值加8字節(jié) ADRLr4,start?+?60000;
本ADRL偽指令將被編譯器替換成下面兩條指令 ADDr4,pc,#0xe800 ADDr4,r4,#0x254
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
3)LDR(大范圍的地址讀取偽指令)
LDR偽指令將一個(gè)32位的常數(shù)或者一個(gè)地址值讀取到寄存器中。 LDR偽指令的語法格式為: LDR{cond}register,=[expr|label-expr]
其中,expr為32位的常量。label-expr為基于PC的地址表達(dá)式或者是外部表達(dá)式。
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
LDR偽指令主要有以下兩種用途:
①當(dāng)需要讀取到寄存器中的數(shù)據(jù)超過了MOV及MVN指令可以操作的范圍時(shí),可以使用LDR偽指令將該數(shù)據(jù)讀取到寄存器中。
②將一個(gè)基于PC的地址值或者外部的地址值讀取到寄存器中。
第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)匯編偽指令:
LDRR1,=0xFF0;
將0xff0讀取到R1中
匯編后將得到 MOVR1,0xFF0 LDRR1,=0xFFF;
將0xfff讀取到R1中
匯編后將得到 LDRR1,[PC,OFFSET_TO_LPOOL]
… LPOOLDCD0xFFF LDRR1,=ADDR1;
將外部地址ADDR1讀取到R1中
匯編后將得到 LDRR1,[PC,OFFSET_TO_LPOOL] 第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)程
序文件名后綴匯編*.SC程序*.C頭文件*.H引入文件*.INC3.6ARM匯編編程簡(jiǎn)介3.6.1ARM匯編語言文件格式表3.3ARM源程序文件名的后綴名第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.6.2ARM匯編語言語句格式
ARM匯編語言的語句格式為: [標(biāo)號(hào)]<指令|條件|S><操作數(shù)>[;注釋]
ARM匯編語言中,所有標(biāo)號(hào)必須在一行的頂格書寫,其后面不要添加“:”,而所有指令均不能頂格書寫。ARM匯編器對(duì)標(biāo)示符大小寫敏感,書寫標(biāo)號(hào)及指令時(shí)字母大小寫要一致。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)1、匯編語言程序中的標(biāo)號(hào)1)標(biāo)號(hào)
在ARM匯編程序中,標(biāo)號(hào)代表一個(gè)地址,段內(nèi)標(biāo)號(hào)的地址在匯編時(shí)確定,而段外標(biāo)號(hào)的地址值在連接時(shí)確定。根據(jù)標(biāo)號(hào)的生成方式可將其分為三種:基于PC的標(biāo)號(hào)基于寄存器的標(biāo)號(hào)絕對(duì)地址第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)2)局部標(biāo)號(hào)
局部標(biāo)號(hào)主要用于局部范圍代碼中,也經(jīng)常在宏定義中使用。
局部標(biāo)號(hào)的定義格式為: N{routname}
其中,N為局部標(biāo)號(hào),范圍為0~99;routname為局部標(biāo)號(hào)作用范圍的名稱,由ROUT偽指令定義。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)2、匯編語言程序中的符號(hào)1)常量(1)數(shù)字常量:
①十進(jìn)制數(shù),如12、4、987、0。
②十六進(jìn)制數(shù),如0x439、0xFF0、0x1。
③n進(jìn)制數(shù),用n-XXX表示,其中n?=?2~9,XXX為具體的數(shù)。(2)字符常量。(3)布爾常量。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)2)變量
變量是指其值在程序的運(yùn)行過程中可以改變的量。ARM匯編程序所支持的變量有數(shù)字變量、邏輯變量和字符串變量。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3)匯編語言程序中的表達(dá)式和運(yùn)算符
常用的表達(dá)式有數(shù)學(xué)表達(dá)式、邏輯表達(dá)式和字符串表達(dá)式,其運(yùn)算的優(yōu)先級(jí)次序如下:(1)優(yōu)先級(jí)相同的雙目運(yùn)算符的運(yùn)算順序?yàn)閺淖蟮接遥?2)相鄰的單目運(yùn)算符的運(yùn)算順序是從右到左,且單目運(yùn)算符的優(yōu)先級(jí)高于其他運(yùn)算符;(3)括號(hào)運(yùn)算符的優(yōu)先級(jí)最高。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)3.6.3C語言和匯編語言的混合編程1.匯編語言的程序結(jié)構(gòu)
一個(gè)匯編程序至少應(yīng)該有一個(gè)代碼段,當(dāng)程序較長時(shí),可以分割為多個(gè)代碼段和數(shù)據(jù)段。多個(gè)段在程序編譯鏈接時(shí)最終形成一個(gè)可執(zhí)行的映像文件。第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)以下是一個(gè)匯編語言源程序的基本結(jié)構(gòu): AREAInit,CODE,READONLY ENTRY Start LDR R0,=0x3FF5000 LDR R1,0xFF STR R1,[R0] LDR R0,=0x3FF5008 LDR R0,=0x01 STR R1,[R0]
… END第3章ARM的指令系統(tǒng)及匯編程序設(shè)計(jì)2.匯編語言與C語言的混合編程
在應(yīng)用系統(tǒng)的程序設(shè)計(jì)中,若所有的編程任務(wù)都用匯
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024建筑工程材料采購的合同
- 2024成都二手房產(chǎn)買賣交易協(xié)議
- 2024年版私房菜廚師合作經(jīng)營協(xié)議3篇
- 2024中介行業(yè)二手房買賣合同規(guī)范模板3篇
- 2025年度寫字樓租賃合同補(bǔ)充協(xié)議3篇
- 2024年酒店服務(wù)與供貨合同
- 2025年度長沙離婚后子女撫養(yǎng)權(quán)及生活費(fèi)支付協(xié)議3篇
- 2024建筑鋼管租賃合同模板
- 2024版簡(jiǎn)易離婚合同書寫范例版B版
- 2024年酒店多功能廳租賃協(xié)議標(biāo)準(zhǔn)文本一
- GB 21258-2024燃煤發(fā)電機(jī)組單位產(chǎn)品能源消耗限額
- 期末 (試題) -2024-2025學(xué)年人教PEP版(2024)英語三年級(jí)上冊(cè)
- 微視頻評(píng)分標(biāo)準(zhǔn)
- 運(yùn)籌學(xué)(課件)
- 《軸系結(jié)構(gòu)設(shè)計(jì)》ppt課件
- 應(yīng)用化學(xué)專業(yè)英語unit.ppt
- 精益制造快速切換作業(yè)指導(dǎo)書模板
- 膠囊劑生產(chǎn)工藝流程圖
- 小學(xué)期末班級(jí)頒獎(jiǎng)典禮動(dòng)態(tài)PPT模板
- 制藥廠安全事故應(yīng)急救援預(yù)案匯編
- 上市公司信息披露制度的跨國比較及借鑒
評(píng)論
0/150
提交評(píng)論