版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
80C51系列單片機指令系統(tǒng)51系列單片機指令集含有111條指令
每條指令在執(zhí)行時要花去一定的時間,以機器週期為單位。按指令執(zhí)行時間分類:單週期(64條);雙週期(45條);4週期(2條)按指令的功能分類,可分為5大類:數(shù)據(jù)傳送類(29條);算術運算類(24條)邏輯運算及移位類(24);控制轉(zhuǎn)移類(17條)位操作類(17條)每條指令在程式記憶體ROM中佔據(jù)一定的空間,以位元組為單位。按指令所占位元組數(shù)分類:單字節(jié)(49條);雙位元組(46條);3位元組(16條)§3-1指令系統(tǒng)基本概念標號:操作碼運算元;注釋
3.1.1指令基本格式方括符[]表示可選項標號代表指令所在地址,1-8個字母/數(shù)字,“:”結尾[標號:]操作碼[目的運算元][,源運算元][;注釋]START:MOVA,#30H;將立即數(shù)30H傳送至A中
MOVDPTR,#5678H;將立即數(shù)5678H傳送至DPTR⑴標號:指令的符號地址。①用於一段功能程式的識別標記或控制 轉(zhuǎn)移地址。指令前的標號代表該指令的地址,是用符號表示的地址。
一般用英文字母和數(shù)字組成。④標號必須用冒號“:”與操作碼分隔。⑵操作碼:表示指令的操作功能。①操作碼用助記符表示,它代表了指令 的操作功能。②操作碼是指令的必需部分,是指令的核心,不可缺少。⑶運算元:參加操作的數(shù)據(jù)或數(shù)據(jù)地址。⑤運算元與操作碼之間用空格分隔,運算元與 運算元之間用逗號“,”分隔。①運算元可以是數(shù)據(jù),也可以是數(shù)據(jù)的地址、 數(shù)據(jù)地址的地址或運算元的其他資訊。②運算元可分為目的運算元和源運算元。③運算元可用二進位數(shù)、十進位數(shù)或十六進制 數(shù)表示。④運算元的個數(shù)可以是0~3個。⑷注釋:指令功能說明。①注釋屬於非必需項,是為便於閱讀, 對指令功能作的說明和注解。②注釋必須以“;”開始。3.1.2指令分類⑶ 按指令功能分類:
可分為數(shù)據(jù)傳送類、算術運算類、邏輯運算類、位操作類和控制轉(zhuǎn)移類等5大類指令。80C51共有111條指令。⑴ 按指令長度分類:
可分為1位元組、2位元組和3字節(jié)指令。⑵ 按指令執(zhí)行時間分類:
可分為1機周、2機周和4機周指令。3.1.3指令系統(tǒng)中的常用符號⑹bit:位地址。SETBACC.7
代表片內(nèi)RAM中的可尋址位00H~7FH及SFR中的可尋址位。⑴#:立即數(shù)符。MOVA,#30H
#data:8位立即數(shù);#data16:16位立即數(shù)。⑵direct:8位直接地址MOVA,3AH
代表內(nèi)RAM00H~7FH或SFR的80H~FFH。⑶@:間接尋址符。MOVA,@R0如@Ri,@DPTR,@A+PC,@A+DPTR。⑷addr11:11位目的地址。
addr16:16位目的地址。⑸rel:帶符號的8位偏移地址。SJMPrel
用於轉(zhuǎn)移指令,其範圍是相對於下一條指令第1位元組地址的-128~+127個位元組。3.1.4尋址方式尋址就是尋找運算元的地址。七種尋址方式,一條指令可能含多種尋址方式立即尋址直接尋址寄存器尋址寄存器間接尋址變址尋址(基址寄存器+變址寄存器間接尋址)相對尋址位尋址【例】⒈立即尋址
立即尋址是直接給出運算元,運算元前有立即數(shù)符“#”。MOVA,#30H;將立即數(shù)30H傳送至A中MOVDPTR,#5678H;將立即數(shù)5678H傳送至DPTRADDA,#05H;(A)←(A)+立即數(shù)05H注意:符號“#”表明其後跟的是立即數(shù),
立即數(shù)——就是數(shù)字量本身。⒉直接尋址MOVA,3AH
;將內(nèi)RAM3AH單元中的數(shù)據(jù)傳送至A中MOVA,P0
;將特殊功能寄存器P0口中的數(shù)據(jù)傳送至A中說明:3AH和P0是以direct形式出現(xiàn)的直接地址訪問特殊功能寄存器SFR只能採用直接尋址方式。
直接尋址是給出運算元的直接地址。直接尋址範圍為內(nèi)RAM128B和特殊功能寄存器?!纠竣臣拇嫫鲗ぶ稭OVA,R0;將R0中的數(shù)據(jù)傳送至A中INCAMULAB從寄存器中讀取運算元或存放運算元進寄存器寄存器尋址的運算元在規(guī)定的寄存器中。
規(guī)定的寄存器有:①工作寄存器R0~R7
②累加器A
③雙位元組AB
④數(shù)據(jù)指針DPTR
⑤位累加器Cy
這些被尋址寄存器中的內(nèi)容就是運算元【例】⒋寄存器間接尋址MOVA,@R0;將以R0中內(nèi)容為地址的存儲單元中的數(shù)據(jù)傳送至A中MOVXA,@DPTR;將外RAMDPTR所指存儲單元中的數(shù)據(jù)傳送至A中PUSHPSW;將PSW中數(shù)據(jù)傳送至堆疊指針SP所指的存儲單元中MOV@R1,#0FH;(30H)←立即數(shù)0FH
寄存器中的內(nèi)容是一個地址,由該地址單元尋址到所需的運算元。間接尋址用間址符“@”作為首碼?!纠孔⒁猓?)“間接”表示某寄存器中的“內(nèi)容”只是一個“單元地址”,這個地址單元中存放的數(shù)據(jù)才是要找的“運算元”。2)符號“@”表示“在…”,其含義與讀音皆同“at”。⒌變址尋址MOVCA,@A+DPTR
【例】在變址尋址中,運算元地址=基址+變址用於讀ROM數(shù)據(jù)操作。;將A的內(nèi)容與DPTR內(nèi)容相加,得到一個新地址,從該地址ROM中讀取數(shù)據(jù)送入A中。
以16位的地址指針寄存器DPTR或16位的PC寄存器為基址寄存器,以累加器A為變址寄存器,兩者中的“內(nèi)容”形成一個16位的“地址”,該“地址”所指的存儲單元中的內(nèi)容才是運算元。MOVCA,@A+PC;A(A+PC)
當前PC值加上指令中規(guī)定的偏移量rel,構成實際的運算元地址
例:
SJMPrel
操作:跳轉(zhuǎn)到的目的地址=當前16位PC值+rel⒍相對尋址注意:1)“當前PC值”指程式中下一條指令所在的首地址,是一個16位數(shù);2)符號“rel”表示“偏移量”,是一個帶符號的單字節(jié)數(shù),範圍是:-128—+127(80H—7FH)在實際編程中,“rel”通常用標號代替在實際編程中,“rel”通常用標號代替例:SJMPLOOP1例:2000H:SJMP08H
;
原PC值為2000H;執(zhí)行這條指令後的當前PC值為2002H,rel為08H。2002H+08H=200AH,轉(zhuǎn)移目的地址為200AH,程式就跳轉(zhuǎn)至200AH去執(zhí)行了。右圖為SJMP08H相對尋址示意圖。;將位地址07H(位元組地址20H中最高位)中的數(shù)據(jù)傳送至進位位Cy。⒎位尋址
位尋址是對內(nèi)RAM和特殊功能寄存器中的可尋址位進行操作的尋址方式。MOVC,07H
指令中直接給出了運算元所在的位地址。例:CLRP1.0;(P1.0)←0SETBACC.7;(ACC.7)←1CPLC;(C)←NOT(C)注意:
1)位地址裏的數(shù)據(jù)只可能是一個0或12)有的位地址十分明確,如P1.0,ACC.7等,有的位地址則“不太明確”,如:
MOVA,17H;(A)←(17H),17H是位元組地址
MOVACC.0,17H;(ACC.0)←(17H),這裏ACC.0是位地址所以該指令中的17H是22H單元的第7位§3-2指令系統(tǒng)功能分五類,共111條指令
數(shù)據(jù)傳送類指令
算術運算類指令
邏輯運算及移位指令
位操作類指令
控制轉(zhuǎn)移類指令①MOVA,Rn
;Rn→A,n=0~7
②MOVA,@Ri
;(Ri)→A,i=0、1③MOVA,direct;(direct)→A④MOVA,#data;data→A
3.2.1數(shù)據(jù)傳送類指令⒈內(nèi)RAM數(shù)據(jù)傳送指令⑴以累加器A為目的位元組的傳送指令(4條)【例3-1】若R0=40H,(30H)=60H,(40H)=50HMOVA,R0;將工作寄存器R0中的數(shù)據(jù)傳送至A中,A=40HMOVA,@R0;將以R0中內(nèi)容為地址的存儲單元中的數(shù)據(jù)送至A
中A=50HMOVA,30H;將直接地址30H存儲單元中的數(shù)據(jù)傳送至A中,
A=60HMOVA,#30H;將立即數(shù)#30H送入A中,A=30H①MOVRn,A;A→Rn,n=0~7②MOVRn,direct;(direct)→Rn,n=0~7③MOVRn,#data;data→Rn,n=0~7⑵以工作寄存器Rn為目的位元組 的傳送指令(3條)⑶以直接地址為目的位元組的傳送指令(5條)①MOVdirect,A ;A→(direct)②MOVdirect,Rn ;Rn→(direct),n=0~7③MOVdirect,@Ri ;(Ri)→(direct),i=0、1④MOVdirect1,direct2;(direct2)→(direct1)⑤MOVdirect,#data ;data→(direct)⑷以寄存器間址為目的位元組的傳送指令(3條)①MOV@Ri,A ;A→(Ri),i=0、1②MOV@Ri,direct;(direct)→(Ri),i=0、1③MOV@Ri,#data;data→(Ri),i=0、1⒉16位數(shù)據(jù)傳送指令MOVDPTR,#data16;data16→DPTR【例】MOVDPTR,#1234H;DPTR=1234H該指令也可以用兩條8位數(shù)據(jù)傳送指令實現(xiàn):MOVDPH,#12H;DPH=12HMOVDPL,#34H;DPL=34H,DPTR=1234H①MOVXA,@Ri;(Ri)→A,i=0、1②MOVXA,@DPTR;(DPTR)→A③MOVX@Ri,A;A→(Ri),i=0、1④MOVX@DATR,A;A→(DATR)⒊外RAM傳送指令(4條)⒋讀ROM指令(2條)內(nèi)RAM(包括特殊功能寄存器):用MOV指令傳送;外RAM:用MOVX指令傳送;ROM:用MOVC指令傳送。①MOVCA,@A+DPTR;(A+DPTR)→A②MOVCA,@A+PC;PC+1→PC,(A+PC)→A
三個不同的存儲空間用三種不同的指令傳送:【例3-9】按下列要求傳送數(shù)據(jù):設ROM(2000H)=ABH(1)ROM2000H單元數(shù)據(jù)送內(nèi)RAM10H單元;
(2)R0M2000H單元數(shù)據(jù)送外RAM80H單元;
(3)ROM2000H單元數(shù)據(jù)送外RAM1000H單元;解(1):MOVDPTR,#2000H;置基址2000H,DPTR=2000H MOVA,#00H;置變址0,A=00H MOVCA,@A+DPTR;讀ROM2000H,A=ABH MOV10H,A;存內(nèi)RAM10H單元,(10H)=ABH解(2):MOVDPTR,#1FFFH;置基址1FFFH,DPTR=1FFFH MOVA,#01H;置變址01H,A=01H MOVCA,@A+DPTR;讀ROM2000H,A=ABH NOVR0,#80H;置外RAN間址,R0=80H MOVX@R0,A;寫外RAM80H,外RAM(80H)=ABH解(3):MOVDPTR,#2000H;置基址2000H,DPTR=2000H MOVA,#00H;置變址0,A=00H MOVCA,@A+DPTR;讀ROM2000H,A=ABH MOVDPH,1OH;修改外RAN地址,DPTR=1000H MOVX@DPTR,A;寫外RAM1000H,外RAM(1000H)=ABH【例3.10】已知ROM中存有0~9的平方表,首地址為2000H,試根據(jù)累加器A中的數(shù)值查找對應的平方值,存入內(nèi)RAM30H。(設A=3)
解:若用DPTR作為基址寄存器,可編程如下:1000H:MOVDPTR,#2000H;置ROM平方表首地址
MOVCA,@A+DPTR;A+2000H=2003H(設A=3),;A=(2003H)=09HMOV30H,A;平方值存入內(nèi)RAM30H中
……
……2000H:00H;平方表:02=02001H:01H;12=12002H:04H;22=42003H:09H;32=92004H:10H;42=16,16=10H
……
……2009H:51H;92=81,81=51H①PUSHdirect;SP+1→SP,(direct)→(SP)
②POPdirect;(SP)→(direct),SP-1→SP
⒌堆疊操作指令(2條)⑴PUSH為入棧指令例PUSH30H;(30H)=2BH,具體操作是:
先將堆疊指針SP的內(nèi)容(0FH)加1,指向堆疊頂?shù)囊粋€空單元,此時SP=10H;②然後將指令指定的直接尋址單元30H中的數(shù)據(jù)(2BH)送到該空單元中。⑵POP為出棧指令例POP40H;(40H)=4CH,具體操作是:先將SP所指單元0FH(棧頂?shù)刂罚┲械臄?shù)據(jù)(4CH)彈出,送到指定的內(nèi)RAM單元40H,(40H)=4CH;②然後SP-1→SP,SP=0EH,SP仍指向棧頂?shù)刂?。⒍交換指令(5條)
①XCHA,Rn ;A←→Rn,n=0~7②XCHA,@Ri ;A←→(Ri),i=0、1③XCHA,direct;A←→(direct)SWAPA;A7~4←→A3~0⑴位元組交換指令⑵半位元組交換指令XCHDA,@Ri;A3~0←→(Ri)3~0
高4位不變。i=0、1⑶累加器高低四位互換①ADDA,Rn;A+Rn→A(n=0~7)
有進位,Cy=1;無進位,Cy=0②ADDA,@Ri;A+(Ri)→A(i=0、1)
有進位,Cy=1;無進位,Cy=0③ADDA,direct;A+(direct)→A
有進位,Cy=1;無進位,Cy=0④ADDA,#data;A+data→A
有進位,Cy=1;無進位,Cy=0
3.2.2算術運算類指令⒈加法指令⑴不帶Cy加法指令(4條)⑵帶Cy加法指令(4條)①ADDCA,Rn;A+Rn+Cy→A(n=0~7)
有進位,Cy=1;無進位,Cy=0②ADDCA,@Ri;A+(Ri)+Cy→A(i=0、1)
有進位,Cy=1;無進位,Cy=0③ADDCA,direct;A+(direct)+Cy→A
有進位,Cy=1;無進位,Cy=0④ADDCA,#data;A+data+Cy→A
有進位,Cy=1;無進位,Cy=0
⒉減法指令(4條)①SUBBA,Rn;A-Rn-Cy→A,(n=0~7),
有借位,Cy=1;無借位,Cy=0
②SUBBA,@Ri;A-(Ri)-Cy→A,(n=0~1),
有借位,Cy=1;無借位,Cy=0③SUBBA,direct;A-direct-Cy→A,
有借位,Cy=1;無借位,Cy=0④SUBBA,#data;A-data-Cy→A,
有借位,Cy=1;無借位,Cy=0
①INCA ;A+1→A②INCRn ;Rn+1→Rn,n=0~7③INC@Ri ;(Ri)+1→(Ri),i=0、1④INCdirect ;(direct)+1→(direct)⑤INCDPTR ;DPTR+1→DPTR⒊加1減1指令⑴加1指令(5條)⑵減1指令(4條)①DECA ;A-1→A②DECRn ;Rn-1→Rn,n=0~7③DEC@Ri ;(Ri)-1→(Ri),i=0、1④DECdirect;(direct)-1→(direct)
加1減1指令涉及A時,會影響P,但不影響其他標誌位。
⒋BCD碼調(diào)整指令DAA功能:對加法運算結果進行BCD碼調(diào)整。十進位調(diào)整:(DAA——1條)用於兩個BCD碼之間的相加,這條指令只能跟在ADD或ADDC之後BCD碼是指“用二進位表達的十進位數(shù)”。如:十進位數(shù)20可以用二進位數(shù)00010100B表示;也可以用十六進制數(shù)14H表示;還可以用BCD碼00100000B或20H表示。4個二進位位就可以表示一位BCD碼:0000~1001可表示十進位數(shù)(BCD數(shù))0~9;8個二進位位就可以表示兩位壓縮的BCD碼:00000000~10011001表示00~99。
十進位調(diào)整:(DAA——1條)用於兩個BCD碼之間的相加,這條指令只能跟在ADD或ADDC之後若(A)3~0
9或(AC)=1則(A)3~0
(A)3~0+6;若(A)7~4
9或(CY)=1則(A)7~4
(A)7~4+6;例:兩個十進位數(shù)“65”與“58”相加,根據(jù)常識,顯然其和應當為“123”。MOVA,#65HADDA,#58HDAA結果:(A)=23H(CY)=1
指令“DAA”完成的操作:
65011001015801011000
+13181926601100110若(A)3~0
9或(AC)=1則(A)3~0
(A)3~0+6;若(A)7~4
9或(CY)=1則(A)7~4
(A)7~4+6;又如:兩個十進位數(shù)“39”與“58”相加,根據(jù)常識,顯然其和應當為“97”。MOVA,#39HADDA,#58HDAA結果:(A)=97H(CY)=0
39001110015801011000
+07239
60110指令“DAA”完成的操作:
DIVAB;(A÷B)商→A,餘數(shù)→BCy=0,OV=0
⒌乘除法指令⑴乘法指令(1條)MULAB;A×B→BA⑵除法指令(1條)三、邏輯運算及移位指令①ANLA,Rn;A∧Rn→A②ANLA,@Ri;A∧(Ri)→A③ANLA,#data;A∧data→A④ANLA,direct;A∧(direct)→A⑤ANLdirect,A;(direct)∧A→direct⑥ANLdirect,#data;(direct)∧data→direct⒈邏輯“與”運算指令(6條)⒉邏輯“或”運算指令(6條)①ORLA,Rn;A∨Rn→A②ORLA,@Ri;A∨(Ri)→A③ORLA,#data;A∨data→A④ORLA,direct;A∨(direct)→A⑤ORLdirect,A;(direct)∨A→direct⑥ORLdirect,#data;(direct)∨data→direct⒊邏輯“異或”運算指令(6條)①XRLA,Rn;A
Rn→A②XRLA,@Ri;A
(Ri)→A③XRLA,#data;A
data→A④XRLA,direct;A
(direct)→A⑤XRLdirect,A;(direct)
A→direct⑥XRLdirect,#data;(direct)
data→direct
①CLRA ;0→A ②CPLA ;A→A⒋清零和取反指令⒌迴圈移位指令(4條)①迴圈左移:RLA②帶Cy迴圈左移:RLCA
③迴圈右移:RRA
④帶Cy迴圈右移:RRCA
①MOVC,bit;(bit)→Cy
②MOVbit,C;Cy→bit四、位操作類指令⒈位傳送指令(2條)
指令中C即進位位Cy的助記符,bit為內(nèi)RAM20H~2FH中的128個可尋址位和特殊功能寄存器中的可尋址位存儲單元。
【例3-36】將位存儲單元24H.4中的內(nèi)容傳送到位存儲單元24H.0。
解:MOVC,24H.4;(24H.4)CMOV24H.0,C;C(24H.0)
或?qū)懗桑?/p>
MOVC,24H;(24H)C,(24H=24H.4)MOV20H,C;C(20H),(20H=24H.0)⑵位取反指令:①
CPLC ;C→C②CPLbit ;(bit)→bit⒉位修正指令(6條)⑴位清0指令:①CLRC ;0→C②CLRbit ;0→bit⑶位置1指令:①SETBC ;1→C②SETBbit ;1→bit⑴位邏輯“與”運算指令:①ANLC,bit ;C∧(bit)→C②ANLC,/bit ;C∧(bit)→C⑵位邏輯“或”運算指令:①ORLC,bit ;C∨(bit)→C②ORLC,/bit
;C∨(bit)→C⒊位邏輯運算指令(4條)⑶相對轉(zhuǎn)移指令
SJMPrel;PC+2→PC,PC+rel→PC五、控制轉(zhuǎn)移類指令⒈無條件轉(zhuǎn)移指令(3條)⑴長轉(zhuǎn)移指令
LJMPaddr16;addr15~0→PC,
⑵短轉(zhuǎn)移指令
AJMPaddr11 ;PC+2→PC, addr10~0→PC10~0, PC15~11不變⑷間接轉(zhuǎn)移指令(散轉(zhuǎn)指令)
JMP@A+DPTR ;A+DPTR→PCLJMP、AJMP、SJMP三條無條件轉(zhuǎn)移指令的區(qū)別:①轉(zhuǎn)移範圍不一樣。
LJMP轉(zhuǎn)移範圍是64KB;
AJMP轉(zhuǎn)移範圍是與當前PC值同一2KB;
SJMP轉(zhuǎn)移範圍是當前PC-128B~+127B。
使用AJMP和SJMP指令應注意轉(zhuǎn)移目標地址是否在轉(zhuǎn)移範圍內(nèi),若超出範圍,程式將出錯。②指令位元組不一樣。
LJMP是3位元組指令;
AJMP、SJMP是2位元組指令。⒉條件轉(zhuǎn)移指令(13條)
條件轉(zhuǎn)移指令根據(jù)判斷條件可分為:
⑴判C轉(zhuǎn)移
⑵判bit轉(zhuǎn)移
⑶判A轉(zhuǎn)移
⑷減1非0轉(zhuǎn)移
⑸比較不相等轉(zhuǎn)移指令滿足條件,則轉(zhuǎn)移;不滿足條件,則程式順序執(zhí)行。②
C=0轉(zhuǎn)移指令:
JNCrel ;PC+2→PC,
若Cy=0,則PC+rel→PC,轉(zhuǎn)移
若Cy=1,則程式順序執(zhí)行。⑴判C轉(zhuǎn)移指令(2條)①C=1轉(zhuǎn)移指令:
JCrel ;PC+2→PC,
若Cy=1,則PC+rel→PC,轉(zhuǎn)移若Cy=0,則程式順序執(zhí)行。③(bit)=1轉(zhuǎn)移並清0指令:
JBCbit,rel
;PC+3→PC,
;若(bit)=1,則PC+rel→PC,轉(zhuǎn)移,且0→(bit) ;若(bit)=0,則程式順序執(zhí)行⑵判bit轉(zhuǎn)移指令(3條)①(bit)=1轉(zhuǎn)移指令:
JBbit,rel
;PC+3→PC,
若(bit)=1,則PC+rel→PC,轉(zhuǎn)移若(bit)=0,則程式順序執(zhí)行②(bit)=0轉(zhuǎn)移指令:
JNBbit,rel
;PC+3→PC,
若(bit)=0,則PC+rel→PC,轉(zhuǎn)移若(bit)=1,則程式順序執(zhí)行①A=0轉(zhuǎn)移指令:
JZrel;PC+2→PC,
若A=0,則PC+rel→PC,轉(zhuǎn)移若A
0,則程式順序執(zhí)行⑶判A轉(zhuǎn)移指令(2條)②A0轉(zhuǎn)移指令:
JNZrel;PC+2→PC,
若A0,則PC+rel→PC,轉(zhuǎn)移若A=0,則程式順序執(zhí)行⑷減1非0轉(zhuǎn)移指令(2條)②DJNZdirect,rel;PC+3→PC,(direct)-1→direct
若(direct)=0,則程式順序執(zhí)行若(direct)0,則PC+rel→PC,轉(zhuǎn)移
①
DJNZ
Rn,rel
;PC+2→PC,Rn-1→Rn, 若Rn=0,則程式順序執(zhí)行 若Rn
0,則PC+rel→PC,轉(zhuǎn)移⑸比較轉(zhuǎn)移指令(4條)①CJNEA,direct,rel;PC+3→PC,;若A=(direct),則程式順序執(zhí)行
;若A≠(direct),則PC+rel→PC,轉(zhuǎn)移
;且若A≥(direct),Cy=0;若A<(direct),Cy=1
②
CJNEA,#data,rel
;PC+3→PC,;若A=data,則程式順序執(zhí)行
;若A≠data,則PC+rel→PC,轉(zhuǎn)移
;且若A≥data,Cy=0;若A<data,Cy=1
③
CJNERn,#data,rel;PC+3→PC,;若Rn=data,則程式順序執(zhí)行
;若Rn≠data,則PC+rel→PC,轉(zhuǎn)移
;且若Rn≥data,Cy=0;若Rn<data,Cy=1④
CJNE@Ri,#data,rel;PC+3→PC,;若(Ri)=data,則程式順序執(zhí)行
;若(Ri)≠data,則PC+rel→PC,轉(zhuǎn)移
;且若(Ri)≥data,Cy=0;若(Ri)<data,Cy=1①產(chǎn)生當前PC:PC+3→PC, (PC+3是因為該指令為三位元組指令)②斷口地址低8位保存到堆疊中: SP+1→SP,(PC)0~7→(SP)③斷口地址高8位保存到堆疊中: SP+1→SP,(PC)8~15→(SP)
④形成轉(zhuǎn)移目標地址:addr16→PC⒊調(diào)用和返回指令LCALLaddr16 ;PC+3→PC,SP+1→SP,(PC)0~7→(SP) ;SP+1→SP,(PC)8~15→(SP);addr16→PC⑴長調(diào)用指令LCALL指令執(zhí)行步驟:①產(chǎn)生當前PC:PC+2→PC,
(PC+2是因為該指令為雙位元組指令)②斷口地址低8位保存到堆疊中: SP+1→SP,(PC)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年09月四川四川銀行新設分行專場社會招考筆試歷年參考題庫附帶答案詳解
- 2024年09月北京光大銀行北京分行社會招考(917)筆試歷年參考題庫附帶答案詳解
- 2024年09月北京中信銀行法律保全部社會招考(914)筆試歷年參考題庫附帶答案詳解
- 2025屆萊蕪市重點中學中考五模生物試題含解析
- 2024年09月2024年中國銀行銀總行直屬機構科技運營中心校園招聘240人筆試歷年參考題庫附帶答案詳解
- 2024消防系統(tǒng)人工操作培訓及認證合同范本3篇
- 2025至2031年中國反滲透純水機行業(yè)投資前景及策略咨詢研究報告
- 河南經(jīng)貿(mào)職業(yè)學院《文化地理學》2023-2024學年第一學期期末試卷
- 2025至2031年中國精巧型過塑機行業(yè)投資前景及策略咨詢研究報告
- 2024至2030年高頻焊接管項目投資價值分析報告
- 大一中國近代史綱要期末考試試題及答案
- (完整版)鋼筋加工棚驗算
- 安徽省合肥市廬陽區(qū)2023-2024學年三年級上學期期末數(shù)學試卷
- 概念方案模板
- 西南交大畢業(yè)設計-地鐵車站主體結構設計
- 2024年山東傳媒職業(yè)學院高職單招(英語/數(shù)學/語文)筆試歷年參考題庫含答案解析
- 江蘇省南通市崇川區(qū)2023-2024學年三年級上學期期末語文試卷
- crtd植入術護理查房
- 掃雪鏟冰安全教育培訓
- 人教版三年級下冊必讀書目《中國古代寓言故事》
- 涉密內(nèi)網(wǎng)分級保護設計方案
評論
0/150
提交評論