Ⅰ 51單片機指令集
51匯編語言指令集
符號定義表
符號 含義
Rn R0~R7寄存器n=0~7
Direct 直接地址,內部數據區的地址RAM(00H~7FH)
SFR(80H~FFH) B,ACC,PSW,IP,P3,IE,P2,SCON,P1,TCON,P0
@Ri 間接地址Ri=R0或R1 8051/31RAM地址(00H~7FH) 8052/32RAM地址(00H~FFH)
#data 8位常數
#data16 16位常數
Addr16 16位的目標地址
Addr11 11位的目標地址
Rel 相關地址
bit 內部數據RAM(20H~2FH),特殊功能寄存器的直接地址的位
指令介紹
指令 位元組 周期 動作說明
算數運算指令
1.ADD A,Rn 1 1 將累加器與寄存器的內容相加,結果存回累加器
2.ADD A,direct 2 1 將累加器與直接地址的內容相加,結果存回累加器
3.ADD A,@Ri 1 1 將累加器與間接地址的內容相加,結果存回累加器
4.ADD A,#data 2 1 將累加器與常數相加,結果存回累加器
5.ADDC A,Rn 1 1 將累加器與寄存器的內容及進位C相加,結果存回累加器
6.ADDC A,direct 2 1 將累加器與直接地址的內容及進位C相加,結果存回累加器
7.ADDC A,@Ri 1 1 將累加器與間接地址的內容及進位C相加,結果存回累加器
8.ADDC A,#data 2 1 將累加器與常數及進位C相加,結果存回累加器
9.SUBB A,Rn 1 1 將累加器的值減去寄存器的值減借位C,結果存回累加器
10.SUBB A,direct 2 1 將累加器的值減直接地址的值減借位C,結果存回累加器
11.SUBB A,@Ri 1 1 將累加器的值減間接地址的值減借位C,結果存回累加器
12.SUBB A,#data 2 1 將累加器的值減常數值減借位C,結果存回累加器
13.INC A 1 1 將累加器的值加1
14.INC Rn 1 1 將寄存器的值加l
15.INC direct 2 1 將直接地址的內容加1
16.INC @Ri 1 1 將間接地址的內容加1
17.INC DPTR 1 1 數據指針寄存器值加1
說明:將16位的DPTR加1,當DPTR的低位元組(DPL)從FFH溢出至00H時,會使高位元組(DPH)加1,不影響任何標志位
18.DEC A 1 1 將累加器的值減1
19.DEC Rn 1 1 將寄存器的值減1
20.DEC direct 2 1 將直接地址的內容減1
21.DEC @Ri 1 1 將間接地址的內容減1
22.MUL AB 1 4 將累加器的值與B寄存器的值相乘,乘積的低位位元組存回累加器,高位位元組存回B寄存器
說明:將累加器A和寄存器B內的無符號整數相乘,產生16位的積,低位位元組存入A,高位位元組存入B寄存器。如果積大於FFH,則溢出標志位(OV)被設定為1,而進位標志位為0
23.DIV AB 1 4 將累加器的值除以B寄存器的值,結果的商存回累加器,余數存回B寄存器
說明:無符號的除法運算,將累加器A除以B寄存器的值,商存入A,余數存入B。執行本指令後,進位位(C)及溢出位(OV)被清除為0
24.DA A 1 1 將累加器A作十進制調整,
若(A) 3-0>9或(AC)=1,則(A) 3-0←(A)3-0+6
若(A) 7-4>9或 (C)=1,則(A) 7-4←(A)7-4+6
邏輯運算指令
25.ANL A,Rn 1 1 將累加器的值與寄存器的值做AND的邏輯判斷,結果存回累加器
26.ANL A,direct 2 1 將累加器的值與直接地址的內容做AND的邏輯判斷,結果存回累加器
27.ANL A,@Ri 1 1 將累加器的值與間接地址的內容做AND的邏輯判斷,結果存回累加器
28.ANL A,#data 2 1 將累加器的值與常數做AND的邏輯判斷,結果存回累加器
29.ANL direct,A 2 1 將直接地址的內容與累加器的值做AND的邏輯判斷,結果存回該直接地址
30.ANL direct,#data 3 2 將直接地址的內容與常數值做AND的邏輯判斷,結果存回該直接地址
31.ORL A,Rn 1 1 將累加器的值與寄存器的值做OR的邏輯判斷,結果存回累加器
32.ORL A,direct 2 1 將累加器的值與直接地址的內容做OR的邏輯判斷,結果存回累加器
33.ORL A,@Ri 1 1 將累加器的值與間接地址的內容做OR的邏輯判斷,結果存回累加器
34.ORL A,#data 2 1 將累加器的值與常數做OR的邏輯判斷,結果存回累加器
35.ORL direct,A 2 1 將直接地址的內容與累加器的值做OR的邏輯判斷,結果存回該直接地址
36.ORL direct,#data 3 2 將直接地址的內容與常數值做OR的邏輯判斷,結果存回該直接地址
37.XRL A,Rn 1 1 將累加器的值與寄存器的值做XOR的邏輯判斷,結果存回累加器
38.XRL A,direct 2 1 將累加器的值與直接地址的內容做XOR的邏輯判斷,結果存回累加器
39.XRL A,@Ri 1 1 將累加器的值與間接地扯的內容做XOR的邏輯判斷,結果存回累加器
40.XRL A,#data 2 1 將累加器的值與常數作XOR的邏輯判斷,結果存回累加器
41.XRL direct,A 2 1 將直接地址的內容與累加器的值做XOR的邏輯判斷,結果存回該直接地址
42.XRL direct,#data 3 2 將直接地址的內容與常數的值做XOR的邏輯判斷,結果存回該直接地址
43.CLR A 1 1 清除累加器的值為0
44.CPL A 1 1 將累加器的值反相
45.RL A 1 1 將累加器的值左移一位
46.RLC A 1 1 將累加器含進位C左移一位
47.RR A 1 1 將累加器的值右移一位
48.RRC A 1 1 將累加器含進位C右移一位
49.SWAP A 1 1 將累加器的高4位與低4位的內容交換。(A)3-0←(A)7-4
數據轉移指令
50.MOV A,Rn 1 1 將寄存器的內容載入累加器
51.MOV A,direct 2 1 將直接地址的內容載入累加器
52.MOV A,@Ri 1 1 將間接地址的內容載入累加器
53.MOV A,#data 2 1 將常數載入累加器
54.MOV Rn,A 1 1 將累加器的內容載入寄存器
55.MOV Rn,direct 2 2 將直接地址的內容載入寄存器
56.MOV Rn,gdata 2 1 將常數載入寄存器
57.MOV direct,A 2 1 將累加器的內容存入直接地址
58.MOV direct,Rn 2 2 將寄存器的內容存入直接地址
59.MOV direct1, direct2 3 2 將直接地址2的內容存入直接地址1
60.MOV direct,@Ri 2 2 將間接地址的內容存入直接地址
61.MOV direct,#data 3 2 將常數存入直接地址
62.MOV @Ri,A 1 1 將累加器的內容存入某間接地址
63.MOV @Ri,direct 2 2 將直接地址的內容存入某間接地址
64.MOV @Ri,#data 2 1 將常數存入某間接地址
65.MOV DPTR,#data16 3 2 將16位的常數存入數據指針寄存器
66.MOVC A,@A+DPTR 1 2 (A) ←((A)+(DPTR))
累加器的值再加數據指針寄存器的值為其所指定地址,將該地址的內容讀入累加器
67.MOVC A,@A+PC 1 2 (PC)←(PC)+1;(A)←((A)+(PC))累加器的值加程序計數器的值作為其所指定地址,將該地址的內容讀入累加器
68.MOVX A,@Ri 1 2 將間接地址所指定外部存儲器的內容讀入累加器(8位地址)
69.MOVX A,@DPTR 1 2 將數據指針所指定外部存儲器的內容讀入累加器(16位地址)
70.MOVX @Ri,A 1 2 將累加器的內容寫入間接地址所指定的外部存儲器(8位地址)
71.MOVX @DPTR,A 1 2 將累加器的內容寫入數據指針所指定的外部存儲器(16位地址)
72.PUSH direct 2 2 將直接地址的內容壓入堆棧區
73.POP direct 2 2 從堆棧彈出該直接地址的內容
74.XCH A,Rn 1 1 將累加器的內容與寄存器的內容互換
75.XCH A,direct 2 1 將累加器的值與直接地址的內容互換
76.XCH A,@Ri 1 1 將累加器的值與間接地址的內容互換
77.XCHD A,@Ri 1 1 將累加器的低4位與間接地址的低4位互換
布爾代數運算
78.CLR C 1 1 清除進位C為0
79.CLR bit 2 1 清除直接地址的某位為0
80.SETB C 1 1 設定進位C為1
81.SETB bit 2 1 設定直接地址的某位為1
82.CPL C 1 1 將進位C的值反相
83.CPL bit 2 1 將直接地址的某位值反相
84.ANL C,bit 2 2 將進位C與直接地址的某位做AND的邏輯判斷,結果存回進位C
85.ANL C,/bit 2 2 將進位C與直接地址的某位的反相值做AND的邏輯判斷,結果存回進位C
86.ORL C,bit 2 2 將進位C與直接地址的某位做OR的邏輯判斷,結果存回進位C
87.ORL C,/bit 2 2 將進位C與直接地址的某位的反相值做OR的邏輯判斷,結果存回進位C
88.MOV C,bit 2 1 將直接地址的某位值存入進位C
89.MOV bit,C 2 2 將進位C的值存入直接地址的某位
90.JC rel 2 2 若進位C=1則跳至rel的相關地址
91.JNC rel 2 2 若進位C=0則跳至rel的相關地址
92.JB bit,rel 3 2 若直接地址的某位為1,則跳至rel的相關地址
93.JNB bit,rel 3 2 若直接地址的某位為0,則跳至rel的相關地址
94.JBC bit,rel 3 2 若直接地址的某位為1,則跳至rel的相關地址,並將該位值清除為0
程序跳躍
95.ACALL addr11 2 2 調用2K程序存儲器范圍內的子程序
96.LCALL addr16 3 2 調用64K程序存儲器范圍內的子程序
97.RET 1 2 從子程序返回
98.RETI 1 2 從中斷子程序返回
99.AJMP addr11 2 2 絕對跳躍(2K內)
100.LJMP addr16 3 2 長跳躍(64K內)
101.SJMP rel 2 2 短跳躍(2K內)-128~+127位元組
102.JMP @A+DPTR 1 2 跳至累加器的內容加數據指針所指的相關地址
103.JZ rel 2 2 累加器的內容為0,則跳至rel所指相關地址
104.JNZ rel 2 2 累加器的內容不為0,則跳至rel所指相關地址
105.CJNE A,direct,rel 3 2 將累加器的內容與直接地址的內容比較,不相等則跳至rel所指的相關地址
106.CJNE A,#data,rel 3 2 將累加器的內容與常數比較,若不相等則跳至rel所指的相關地址
107.CJNE @Rn,#data,rel 3 2 將寄存器的內容與常數比較,若不相等則跳至rel所指的相關地址
108.CJNE @Ri,#data,rel 3 2 將間接地址的內容與常數比較,若不相等則跳至rel所指的相關地址
109.DJNZ Rn,rel 2 2 將寄存器的內容減1,不等於0則跳至rel所指的相關地址
110.DJNZ direct,rel 3 2 將直接地址的內容減1,不等於0則跳至rel所指的相關地址
111.NOP 1 1 無動作
Ⅱ 求8051單片機編程 指令集
8051 INSTRUCTION SET
1.Arithmetic operations:
Mnemonic Byte Cyc
ADD A,@Ri 1 1
ADD A,Rn 1 1
ADD A,direct 2 1
ADD A,#data 2 1
ADDC A,@Ri 1 1
ADDC A,Rn 1 1
ADDC A,direct 2 1
ADDC A,#data 2 1
SUBB A,@Ri 1 1
SUBB A,Rn 1 1
SUBB A,direct 2 1
SUBB A,#data 2 1
INC A 1 1
INC @Ri 1 1
INC Rn 1 1
INC DPTR 1 1
INC direct 2 1
INC direct 2 1
DEC A 1 1
DEC @Ri 1 1
DEC Rn 1 1
DEC direct 2 1
MUL AB 1 4
DIV AB 1 4
DA A 1 1
2.Logical opreations:
ANL A,@Ri 1 1
XRL A,@Ri 1 1
ANL A,Rn 1 1
XRL A,Rn 1 1
ANL A,direct 2 1
XRL A,direct 2 1
ANL A,#data 2 1
XRL A,#data 2 1
ANL direct,A 2 1
XRL direct,A 2 1
ANL direct,#data 3 2
XRL direct,#data 3 2
ORL A,@Ri 1 1
CLR A 1 1
ORL A,Rn 1 1
CPL A 1 1
ORL A,direct 2 1
RL A 1 1
ORL A,#data 2 1
RLC A 1 1
ORL direct,A 2 1
RR A 1 1
ORL direct,#data 3 2
RRC A 1 1
SWAP A 1 1
3.Data transfer:
Mnemonic Byte Cyc
MOV A,@Ri 1 1
MOV DPTR,#data16 3 2
MOV A,Rn 1 1
MOVC A,@A+DPTR 1 2
MOV A,direct 2 1
MOVC A,@A+PC 1 2
MOV A,#data 2 1
MOVX A,@Ri 1 2
MOV @Ri,A 1 1
MOVX A,@DPTR 1 2
MOV @Ri,direct 2 2
MOVX @Ri,A 1 2
MOV @Ri,#data 2 1
MOVX @DPTR,A 1 2
MOV Rn,A 1 1
PUSH direct 2 2
MOV Rn,direct 2 2
POP direct 2 2
MOV Rn,#data 2 1
XCH A,@Ri 1 1
MOV direct,A 2 1
XCH A,Rn 1 1
MOV direct,@Ri 2 2
XCH A,direct 2 1
MOV direct,Rn 2 2
XCHD A,@Ri 1 1
MOV direct,direct 3 2
MOV direct,#data 3 2
4.Boolean variable manipulation:
Mnemonic Byte Cyc
CLR C 1 1
ANL C,bit 2 2
SETB C 1 1
ANL C,/bit 2 2
CPL C 1 1
ORL C,bit 2 2
CLR bit 2 1
ORL C,/bit 2 2
SETB bit 2 1
MOV C,bit 2 1
CPL bit 2 1
MOV bit,C 2 2
5.Program and machine control:
Mnemonic Byte Cyc
NOP 1 1
JZ rel 2 2
RET 1 2
JNZ rel 2 2
RETI 1 2
JC rel 2 2
ACALL addr11 2 2
JNC rel 2 2
AJMP addr11 2 2
JB bit,rel 3 2
LCALL addr16 3 2
JNB bit,rel 3 2
LJMP addr16 3 2
JBC bit,rel 3 2
SJMP rel 2 2
CJNE A,direct,rel 3 2
JMP @A+DPTR 1 2
CJNE A,#data,rel 3 2
DJNZ Rn,rel 2 2
CJNE @Ri,#data,rel 3 2
DJNZ direct,rel 3 2
CJNE Rn,#data,rel3 2
嗯嗯,20分是我的嗎?吼吼
Ⅲ 單片機無論51,M0還是M3都有指令集嗎
當然有,單片機的運算器工作過程就是對各種指令進行分析和執行的過程,這個過程就叫運算
Ⅳ 8051單片機的指令集有多少種多少條在指令集里有定址方式有多少種
分有5種指令,有111條
7種定址方式,
寄存器定址、直接定址、寄存器間接定址、變址定址、相對定址和位定址
Ⅳ 單片機的基本指令有哪些
不知道你是問的哪種單片機下面給你的是MCS-51的,希望對你有幫助,如有,麻煩採納,謝謝 數據傳送指令共有29條,數據傳送指令一般的操作是把源操作數傳送到目的操作數,指令執行完成後,源操作數不變,目的操作數等於源操作數。如果要求在進行數據傳送時,目的操作數不丟失,則不能用直接傳送指令,而採用交換型的數據傳送指令,數據傳送指令不影響標志C,AC和OV,但可能會對奇偶標志P有影響。
[1]. 以累加器A為目的操作數類指令(4條)
這4條指令的作用是把源操作數指向的內容送到累加器A。有直接、立即數、寄存器和寄存器間接定址方式:
MOV A,data ;(data)→(A) 直接單元地址中的內容送到累加器A
MOV A,#data ;#data→(A) 立即數送到累加器A中
MOV A,Rn ;(Rn)→(A) Rn中的內容送到累加器A中
MOV A,@Ri ;((Ri))→(A) Ri內容指向的地址單元中的內容送到累加器A
[2]. 以寄存器Rn為目的操作數的指令(3條)
這3條指令的功能是把源操作數指定的內容送到所選定的工作寄存器Rn中。有直接、立即和寄存器定址方式:
MOV Rn,data ;(data)→(Rn) 直接定址單元中的內容送到寄存器Rn中
MOV Rn,#data ;#data→(Rn) 立即數直接送到寄存器Rn中
MOV Rn,A ;(A)→(Rn) 累加器A中的內容送到寄存器Rn中
[3]. 以直接地址為目的操作數的指令(5條)
這組指令的功能是把源操作數指定的內容送到由直接地址data所選定的片內RAM中。有直接、立即、寄存器和寄存器間接4種定址方式:
MOV data,data ;(data)→(data) 直接地址單元中的內容送到直接地址單元
MOV data,#data ;#data→(data) 立即數送到直接地址單元
MOV data,A ;(A)→(data) 累加器A中的內容送到直接地址單元
MOV data,Rn ;(Rn)→(data) 寄存器Rn中的內容送到直接地址單元
MOV data,@Ri ;((Ri))→(data) 寄存器Ri中的內容指定的地址單元中數據送到直接地址單元
[4]. 以間接地址為目的操作數的指令(3條)
這組指令的功能是把源操作數指定的內容送到以Ri中的內容為地址的片內RAM中。有直接、立即和寄存器3種定址方式:
MOV @Ri,data ;(data)→((Ri)) 直接地址單元中的內容送到以Ri中的內容為地址的RAM單元
MOV @Ri,#data ;#data→((Ri)) 立即數送到以Ri中的內容為地址的RAM單元
MOV @Ri,A ;(A)→((Ri)) 累加器A中的內容送到以Ri中的內容為地址的RAM單元
[5]. 查表指令(2條)
這組指令的功能是對存放於程序存儲器中的數據表格進行查找傳送,使用變址定址方式:
MOVC A,@A+DPTR ;((A))+(DPTR)→(A) 表格地址單元中的內容送到累加器A中
MOVC A,@A+PC ;((PC))+1→(A),((A))+(PC)→(A) 表格地址單元中的內容送到累加器A中
[6]. 累加器A與片外數據存儲器RAM傳送指令(4條)
這4條指令的作用是累加器A與片外RAM間的數據傳送。使用寄存器定址方式:
MOVX @DPTR,A ;(A)→((DPTR)) 累加器中的內容送到數據指針指向片外RAM地址中
MOVX A, @DPTR ;((DPTR))→(A) 數據指針指向片外RAM地址中的內容送到累加器A中
MOVX A, @Ri ;((Ri))→(A) 寄存器Ri指向片外RAM地址中的內容送到累加器A中
MOVX @Ri,A ;(A)→((Ri)) 累加器中的內容送到寄存器Ri指向片外RAM地址中
[7]. 堆棧操作類指令(2條)
這4類指令的作用是把直接定址單元的內容傳送到堆棧指針SP所指的單元中,以及把SP所指單元的內容送到直接定址單元中。這類指令只有兩條,下述的第一條常稱為入棧操作指令,第二條稱為出棧操作指令。需要指出的是,單片機開機復位後,(SP)默認為07H,但一般都需要重新賦值,設置新的SP首址。入棧的第一個數據必須存放於SP+1所指存儲單元,故實際的堆棧底為SP+1所指的存儲單元。
PUSH data ;(SP)+1→(SP),(data)→(SP) 堆棧指針首先加1,直接定址單元中的數據送到堆棧指針SP所指的單元中
POP data ;(SP)→(data)(SP)-1→(SP), 堆棧指針SP所指的單元數據送到直接定址單元中,堆棧指針SP再進行減1操作
[8]. 交換指令(5條)
這5條指令的功能是把累加器A中的內容與源操作數所指的數據相互交換。
XCH A,Rn ;(A)←→(Rn)累加器與工作寄存器Rn中的內容互換
XCH A,@Ri ;(A)←→((Ri))累加器與工作寄存器Ri所指的存儲單元中的內容互換
XCH A,data ;(A)←→(data)累加器與直接地址單元中的內容互換
XCHD A,@Ri ;(A 3-0 )←→((Ri) 3-0 )累加器與工作寄存器Ri所指的存儲單元中的內容低半位元組互換
SWAP A ;(A 3-0 )←→(A 7-4 )累加器中的內容高低半位元組互換
[9]. 16位數據傳送指令(1條)
這條指令的功能是把16位常數送入數據指針寄存器。
MOV DPTR,#data16 ;#dataH→(DPH),#dataL→(DPL)16位常數的高8位送到DPH,低8位送到DPL
MCS-51算術運算指令
算術運算指令共有24條,算術運算主要是執行加、減、乘、除法四則運算。另外MCS-51指令系統中有相當一部分是進行加、減1操作,BCD碼的運算和調整,我們都歸類為運算指令。雖然MCS-51單片機的算術邏輯單元ALU僅能對8位無符號整數進行運算,但利用進位標志C,則可進行多位元組無符號整數的運算。同時利用溢出標志,還可以對帶符號數進行補碼運算。需要指出的是,除加、減1指令外,這類指令大多數都會對PSW(程序狀態字)有影響。這在使用中應特別注意。
[1]. 加法指令(4條)
這4條指令的作用是把立即數,直接地址、工作寄存器及間接地址內容與累加器A的內容相加,運算結果存在A中。
ADD A,#data ;(A)+#data→(A) 累加器A中的內容與立即數#data相加,結果存在A中
ADD A,data ;(A)+(data)→(A) 累加器A中的內容與直接地址單元中的內容相加,結果存在A中
ADD A,Rn ;(A)+(Rn)→(A) 累加器A中的內容與工作寄存器Rn中的內容相加,結果存在A中
ADD A,@Ri ;(A)+((Ri))→(A) 累加器A中的內容與工作寄存器Ri所指向地址單元中的內容相加,結果存在A中
[2]. 帶進位加法指令(4條)
這4條指令除與[1]功能相同外,在進行加法運算時還需考慮進位問題。
ADDC A,data ;(A)+(data)+(C)→(A) 累加器A中的內容與直接地址單元的內容連同進位位相加,結果存在A中
ADDC A,#data ;(A)+#data +(C)→(A) 累加器A中的內容與立即數連同進位位相加,結果存在A中
ADDC A,Rn ;(A)+Rn+(C)→(A) 累加器A中的內容與工作寄存器Rn中的內容、連同進位位相加,結果存在A中
ADDC A,@Ri ;(A)+((Ri))+(C)→(A) 累加器A中的內容與工作寄存器Ri指向地址單元中的內容、連同進位位相加,結果存在A中
[3]. 帶借位減法指令(4條)
這組指令包含立即數、直接地址、間接地址及工作寄存器與累加器A連同借位位C內容相減,結果送回累加器A中。
這里我們對借位位C的狀態作出說明,在進行減法運算中,CY=1表示有借位,CY=0則無借位。OV=1聲明帶符號數相減時,從一個正數減去一個負數結果為負數,或者從一個負數中減去一個正數結果為正數的錯誤情況。在進行減法運算前,如果不知道借位標志位C的狀態,則應先對CY進行清零操作。
SUBB A,data ;(A)-(data) - (C)→(A) 累加器A中的內容與直接地址單元中的內容、連同借位位相減,結果存在A中
SUBB A,#data ;(A)-#data -(C)→(A) 累加器A中的內容與立即數、連同借位位相減,結果存在A中
SUBB A,Rn ;(A)-(Rn) -(C)→(A) 累加器A中的內容與工作寄存器中的內容、連同借位位相減,結果存在A中
SUBB A,@Ri ;(A)-((Ri)) -(C)→(A) 累加器A中的內容與工作寄存器Ri指向的地址單元中的內容、連同借位位相減,結果存在A中
[4]. 乘法指令(1條)
這個指令的作用是把累加器A和寄存器B中的8位無符號數相乘,所得到的是16位乘積,這個結果低8位存在累加器A,而高8位存在寄存器B中。如果OV=1,說明乘積大於FFH,否則OV=0,但進位標志位CY總是等於0。
MUL AB ;(A)×(B)→(A)和(B) 累加器A中的內容與寄存器B中的內容相乘,結果存在A、B中
[5]. 除法指令(1條)
這個指令的作用是把累加器A的8位無符號整數除以寄存器B中的8位無符號整數,所得到的商存在累加器A,而余數存在寄存器B中。除法運算總是使OV和進位標志位CY等於0。如果OV=1,表明寄存器B中的內容為00H,那麼執行結果為不確定值,表示除法有溢出。
DIV AB ;(A)÷(B)→(A)和(B) 累加器A中的內容除以寄存器B中的內容,所得到的商存在累加器A,而余數存在寄存器B中。
[6]. 加1指令(5條)
這5條指令的的功能均為原寄存器的內容加1,結果送回原寄存器。上述提到,加1指令不會對任何標志有影響,如果原寄存器的內容為FFH,執行加1後,結果就會是00H。這組指令共有直接、寄存器、寄存器減間址等定址方式:
INC A ;(A)+1→(A) 累加器A中的內容加1,結果存在A中
INC data ;(data)+1→(data) 直接地址單元中的內容加1,結果送回原地址單元中
INC @Ri ;((Ri))+1→((Ri)) 寄存器的內容指向的地址單元中的內容加1,結果送回原地址單元中
INC Rn ;(Rn)+1→(Rn)寄存器Rn的內容加1,結果送回原地址單元中
INC DPTR ;(DPTR)+1→(DPTR)數據指針的內容加1,結果送回數據指針中
在INC data這條指令中,如果直接地址是I/O,其功能是先讀入I/O鎖存器的內容,然後在CPU進行加1操作,再輸出到I/O上,這就是「讀—修改—寫」操作。
[7]. 減1指令(4條)
這組指令的作用是把所指的寄存器內容減1,結果送回原寄存器,若原寄存器的內容為00H,減1後即為FFH,運算結果不影響任何標志位,這組指令共有直接、寄存器、寄存器間址等定址方式,當直接地址是I/O口鎖存器時,「讀—修改—寫」操作與加1指令類似。
DEC A ;(A)-1→(A)累加器A中的內容減1,結果送回累加器A中
DEC data ;(data)-1→(data)直接地址單元中的內容減1,結果送回直接地址單元中
DEC @Ri ;((Ri))-1→((Ri))寄存器Ri指向的地址單元中的內容減1,結果送回原地址單元中
DEC Rn ;(Rn)-1→(Rn)寄存器Rn中的內容減1,結果送回寄存器Rn中
[8]. 十進制調整指令(1條)
在進行BCD碼運算時,這條指令總是跟在ADD或ADDC指令之後,其功能是將執行加法運算後存於累加器A中的結果進行調整和修正。
DA A
MCS-51邏輯運算及移位指令
邏輯運算和移位指令共有25條,有與、或、異或、求反、左右移位、清0等邏輯操作,有直接、寄存器和寄存器間址等定址方式。這類指令一般不影響程序狀態字(PSW)標志。
[1]. 循環移位指令(4條)
這4條指令的作用是將累加器中的內容循環左或右移一位,後兩條指令是連同進位位CY一起移位。
RL A ;累加器A中的內容左移一位
RR A ;累加器A中的內容右移一位
RLC A ;累加器A中的內容連同進位位CY左移一位
RRC A ;累加器A中的內容連同進位位CY右移一位
[2]. 累加器半位元組交換指令(1條)
這條指令是將累加器中的內容高低半位元組互換,這在上一節中內容已有介紹。
SWAP A ; 累加器中的內容高低半位元組互換
[3]. 求反指令(1條)
這條指令將累加器中的內容按位取反。
CPL A ; 累加器中的內容按位取反
[4]. 清零指令(1條)
這條指令將累加器中的內容清0。
CLR A ; 0→(A),累加器中的內容清0
[5]. 邏輯與操作指令(6條)
這組指令的作用是將兩個單元中的內容執行邏輯與操作。如果直接地址是I/O地址,則為「讀—修改—寫」操作。
ANL A,data ;累加器A中的內容和直接地址單元中的內容執行與邏輯操作。結果存在寄存器A中。
ANL data,#data ;直接地址單元中的內容和立即數執行與邏輯操作。結果存在直接地址單元中。
ANL A,#data ;累加器A的內容和立即數執行與邏輯操作。結果存在累加器A中。
ANL A,Rn ;累加器A的內容和寄存器Rn中的內容執行與邏輯操作。結果存在累加器A中。
ANL data,A ;直接地址單元中的內容和累加器A的內容執行與邏輯操作。結果存在直接地址單元中。
ANL A,@Ri ;累加器A的內容和工作寄存器Ri指向的地址單元中的內容執行與邏輯操作。結果存在累加器A中。
[6]. 邏輯或操作指令(6條)
這組指令的作用是將兩個單元中的內容執行邏輯或操作。如果直接地址是I/O地址,則為「讀—修改—寫」操作。
ORL A,data ;累加器A中的內容和直接地址單元中的內容執行邏輯或操作。結果存在寄存器A中。
ORL data,#data ;直接地址單元中的內容和立即數執行邏輯或操作。結果存在直接地址單元中。
ORL A,#data ;累加器A的內容和立即數執行邏輯或操作。結果存在累加器A中。
ORL A,Rn ;累加器A的內容和寄存器Rn中的內容執行邏輯或操作。結果存在累加器A中。
ORL data,A ;直接地址單元中的內容和累加器A的內容執行邏輯或操作。結果存在直接地址單元中。
ORL A,@Ri ;累加器A的內容和工作寄存器Ri指向的地址單元中的內容執行邏輯或操作。結果存在累加器A中。
[7]. 邏輯異或操作指令(6條)
這組指令的作用是將兩個單元中的內容執行邏輯異或操作。如果直接地址是I/O地址,則為「讀—修改—寫」操作。
XRL A,data ;累加器A中的內容和直接地址單元中的內容執行邏輯異或操作。結果存在寄存器A中。
XRL data,#data ;直接地址單元中的內容和立即數執行邏輯異或操作。結果存在直接地址單元中。
XRL A,#data ;累加器A的內容和立即數執行邏輯異或操作。結果存在累加器A中。
XRL A,Rn ;累加器A的內容和寄存器Rn中的內容執行邏輯異或操作。結果存在累加器A中。
XRL data,A ;直接地址單元中的內容和累加器A的內容執行邏輯異或操作。結果存在直接地址單元中。
XRL A,@Ri ;累加器A的內容和工作寄存器Ri指向的地址單元中的內容執行邏輯異或操作。結果存在累加器A中。
MCS-51控制轉移指令
控制轉移指令用於控製程序的流向,所控制的范圍即為程序存儲器區間,MCS-51系列單片機的控制轉移指令相對豐富,有可對64kB程序空間地址單元進行訪問的長調用、長轉移指令,也有可對2kB位元組進行訪問的絕對調用和絕對轉移指令,還有在一頁范圍內短相對轉移及其它無條件轉移指令,這些指令的執行一般都不會對標志位有影響。
[1]. 無條件轉移指令(4條)
這組指令執行完後,程序就會無條件轉移到指令所指向的地址上去。長轉移指令訪問的程序存儲器空間為16地址64kB,絕對轉移指令訪問的程序存儲器空間為11位地址2kB空間。
LJMP addr16 ;addr16→(PC),給程序計數器賦予新值(16位地址)
AJMP addr11 ;(PC)+2→(PC),addr11→(PC 10-0 )程序計數器賦予新值(11位地址),(PC 15-11 )不改變
SJMP rel ;(PC)+ 2 + rel→(PC)當前程序計數器先加上2再加上偏移量給程序計數器賦予新值
JMP @A+DPTR ;(A)+ (DPTR)→(PC),累加器所指向地址單元的值加上數據指針的值給程序計數器賦予新值
[2]. 條件轉移指令(8條)
程序可利用這組豐富的指令根據當前的條件進行判斷,看是否滿足某種特定的條件,從而控製程序的轉向。
JZ rel ; A=0,(PC)+ 2 + rel→(PC),累加器中的內容為0,則轉移到偏移量所指向的地址,否則程序往下執行
JNZ rel ; A≠0,(PC)+ 2 + rel→(PC),累加器中的內容不為0,則轉移到偏移量所指向的地址,否則程序往下執行
CJNE A, data, rel ; A≠(data),(PC)+ 3 + rel→(PC),累加器中的內容不等於直接地址單元的內容,則轉移到偏移量所指向的地址,否則程序往下執行
CJNE A, #data, rel ; A≠#data,(PC)+ 3 + rel→(PC),累加器中的內容不等於立即數,則轉移到偏移量所指向的地址,否則程序往下執行
CJNE Rn, #data, rel ; A≠#data,(PC)+ 3 + rel→(PC),工作寄存器Rn中的內容不等於立即數,則轉移到偏移量所指向的地址,否則程序往下執行
CJNE @Ri, #data, rel ; A≠#data,(PC)+ 3 + rel→(PC),工作寄存器Ri指向地址單元中的內容不等於立即數,則轉移到偏移量所指向的地址,否則程序往下執行
DJNZ Rn, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)工作寄存器Rn減1不等於0,則轉移到偏移量所指向的地址,否則程序往下執行
DJNZ data, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)直接地址單元中的內容減1不等於0,則轉移到偏移量所指向的地址,否則程序往下執行
[3]. 子程序調用指令(1條)
子程序是為了便於程序編寫,減少那些需反復執行的程序佔用多餘的地址空間而引入的程序分支,從而有了主程序和子程序的概念,需要反復執行的一些程序,我們在編程時一般都把它們編寫成子程序,當需要用它們時,就用一個調用命令使程序按調用的地址去執行,這就需要子程序的調用指令和返回指令。
LCALL addr16 ; 長調用指令,可在64kB空間調用子程序。此時(PC)+ 3→(PC),(SP)+ 1→(SP),(PC 7-0 )→(SP),(SP)+ 1→(SP),(PC 15-8 )→(SP),addr16→(PC),即分別從堆棧中彈出調用子程序時壓入的返回地址
ACALL addr11 ; 絕對調用指令,可在2kB空間調用子程序,此時(PC)+ 2→(PC),(SP)+ 1→(SP),(PC 7-0 )→(SP),(SP)+ 1→(SP),(PC 15-8 )→(SP),addr11→(PC 10-0 )
RET ; 子程序返回指令。此時(SP)→(PC 15-8 ),(SP)- 1→(SP),(SP)→(PC 7-0 ),(SP)- 1→(SP)
RETI ; 中斷返回指令,除具有RET功能外,還具有恢復中斷邏輯的功能,需注意的是,RETI指令不能用RET代替
[4]. 空操作指令(1條)
這條指令將累加器中的內容清0。
NOP ; 這條指令除了使PC加1,消耗一個機器周期外,沒有執行任何操作。可用於短時間的延時
MCS-51布爾變數操作指令
布爾處理功能是MCS-51系列單片機的一個重要特徵,這是出於實際應用需要而設置的。布爾變數也即開關變數,它是以位(bit)為單位進行操作的。
在物理結構上,MCS-51單片機有一個布爾處理機,它以進位標志做為累加位,以內部RAM可定址的128個為存儲位。
既然有布爾處理機功能,所以也就有相應的布爾操作指令集,下面我們分別談論。
[1]. 位傳送指令(2條)
位傳送指令就是可定址位與累加位CY之間的傳送,指令有兩條。
MOV C,bit ;bit→CY,某位數據送CY
MOV bit,C ;CY→bit,CY數據送某位
[2]. 位置位復位指令(4條)
這些指令對CY及可定址位進行置位或復位操作,共有四條指令。
CLR C ; 0→CY,清CY
CLR bit ; 0→bit,清某一位
SETB C ; 1→CY,置位CY
SETB bit ; 1→bit,置位某一位
[3]. 位運算指令(6條)
位運算都是邏輯運算,有與、或、非三種指令,共六條。
ANL C,bit ;(CY)∧(bit)→CY
ANL C,/bit ;(CY)∧( )→CY
ORL C,bit ;(CY)∨(bit)→CY
ORL C,/bit ;(CY)∧( )→CY
CPL C ;( )→CY
CPL bit ;( )→bir
[4]. 位控制轉移指令(5)
位控制轉移指令是以位的狀態作為實現程序轉移的判斷條件,介紹如下:
JC rel ; (CY)=1轉移,(PC)+2+rel→PC,否則程序往下執行,(PC)+2→PC。
JNC rel ; (CY)=0轉移,(PC)+2+rel→PC,否則程序往下執行,(PC)+2→PC。
JB bit, rel ; 位狀態為1轉移。
JNB bit, rel ; 位狀態為0轉移。
JBC bit, rel ; 位狀態為1轉移,並使該位清「0」。
後三條指令都是三位元組指令,如果條件滿足,(PC)+3+rel→PC,否則程序往下執行,(PC)+3→PC
Ⅵ 宏晶生產的所有 stc單片機 的指令集都是一樣的嗎...
是的,都是51內核,51指令集
晶宏單片機系列
89C系列:工作頻率0~40M相當於普通8051的0~80M,FLASH程序儲存4K-64K,RAM數據儲存512B-1280B,內部集成EEPROM 2K-16K及看門狗和專用復位電路,帶A/D功能. 12C系列:單時鍾/機器周期。超小封裝。2-4路PWM, 8-10位高速A/D轉換。 FLASH程序儲存512B-60K,RAM數據儲存256B-1280B,集成EEPROM及硬體WDT.產品都有為低功耗。有ISP和IAP功能,強抗干擾和降低EMI性能.15F系列有STC最少引腳8引腳的單片機.最顯著的特點就是支持ISP在線下載功能。
Ⅶ 有關單片機的指令系統,專業的來
不讓發那麼多 所有分兩次 這里接上面的4.循環移位指令(4條)
循環移位指令的功能是將累加器A中內容循環位移或者和進位位一起移位。
例 A=01H, Cy=1
若執行一次 RRC A後,結果為:A=10000000B Cy=1
若執行一次 RLC A後,結果為:A=00000011B Cy=0
5.取反、清0指令
CPL A ;累加器內容按位取反。如果1就變0,如果0就變1
CLR A ;累加器A清0 控制轉移類指令計算機運行過程中,有時因為操作的需要,程序不能按順序逐條執行指令,需要改變程序運行方向,即將程序跳轉到某個指定的地址再順序執行下去。
控制轉移類指令的功能就是根據要求修改程序計數器PC的內容,以改變程序運行方向,實現轉移。
控制轉移類指令可分為:無條件轉移、條件轉移、絕對轉移、相對轉移和調用、返回指令。下面我們將分類介紹。
1.無條件轉移指令(4條)
LJMP add16 ;add16→PC,無條件跳轉到add16地址,可在64KB范圍內
轉移,稱為長轉移指令
AJMP add11 ;add11→PC,無條件轉向add11地址,在2KB范圍內轉移
SJMP rel ;PC+2+rel→PC,相對轉移,rel是偏移量,8 位有符號
數,范圍-128~127,即可向後跳轉128,向前可跳轉127
JMP @A+DPTR ;A+DPTR→PC ,屬散轉指令,無條件轉向A與DPTR內容相
加後形成的新地址
例1 執行指令
LJMP 9100H
不管這條指令存放在哪裡,執行時將使程序轉移到9100H,和AJMP,SJMP指令是有差別的。
例2 程序
2000H MOV R0 , #10H ;10H→PC
2002H SJMP 03H ;PC+2+rel=2002H+2+03H=2007H→PC
┇ ┇
2006H ┇
2007H ┇
從說明中可見,執行SJMP 03H 指令後,馬上跳轉到2007H地址執行程序。
2.條件轉移指令(8條)
條件轉移指令是根據某種特定條件轉移的指令。條件滿足時轉移,條件不滿足時則順序
執行下面的指令。
JZ rel ;A=0轉向PC+2+rel→PC,A≠0順序執行
JNZ rel ;A≠轉向PC+2+rel→PC ,A=0順序執行
CJNE A, direct, rel ;A≠ (direct)轉向PC+3+rel→PC且當A>(direct),Cy=0
;當A<(direct),Cy=1
;否則A=(direct),PC+3→PC即順序執行
CJNE A, #data, rel ;A data P轉向PC+3+rel→PC且當A >data,Cy=0
;當A <data,Cy=1,
;A=data,PC+3→PC順序執行
CJNZ Rn, #data, rel ;Rn≠data轉向PC+3+rel→PC
;且當Rn>data,Cy=0,當Rn<data,Cy=1
;Rn=data,PC+3→PC順序執行
CJNE @Ri,#data, rel ;(Ri) ≠data ,PC+3+rel→PC
;且當(Ri)>data ,Cy=0,當(Ri)<data,Cy=1
;(Ri)=data, PC+3→PC順序執行
DJNZ Rn, rel ;Rn-1→Rn ,Rn ≠0轉向PC+2+rel→PC
;Rn=0,PC+2→PC順序執行
DJNZ direct, rel ;(direct)-1→(direct),(direct) ≠0轉向 PC+2+rel
→PC
;(direct)=0 ,PC+2→PC順序執行
注意:
1)CJNE類指令借用進位標志Cy作為比較結果的標志位。從指令中可知,目的操作數內容小於原操作數內容Cy置1,反之Cy清0,該類指令多用於分支程序。
2) DJNZ指令執行時Rn或direct先減1,然後再判斷Rn或direct內容是否等於0。不為0則轉,為0順序執行。DJNZ用在循環程序中,控制循環次數很方便。
3) JZ和JNZ的操作數只有一個,是對A的內容的進行判斷的指令。
例1 以下程序的循環次數是多少,最後(R0)=?
MOV R0 , #0
LL: ┇
DJNZ R0 , LL
分析:由於DJNZ是減1再判斷大小的,因為R0=0,所以第一次執行DJNZ R0 , LL後R0=FFH=255,則程序要執行的次數為256次,R0最後的值為0。
解:程序要循環的次數為256次,最後R0=0
3.調用、返回、控操作指令
在程序設計中,常常要把具有一定功能的公用程序編製成子程序。當主程序轉至子
程序時用調用指令,而在子程序的最後安排一條返回指令,使執行完子程序後再返回到主程序。
(1) LCALL addr16 ;調用入口地址為addr16的子程序
這是一條長調指令,可調用64KB范圍內的子程序,因此,可放在程序的任何位置。
指令的執行過程分兩步:第一步把斷點(當前執行指令的下一條指令地址)壓入堆棧。第二步將調用的子程序的入口地址裝入PC。即addr16(16位地址)→PC,轉向執行子程序。
(2) ACALL addr11 ;子程序入口地址為addr11的子程序
這是一條短調指令,只能實現2KB范圍內的子程序的調用。其指令執行過程與LCALL
指令一樣。但是需要注意的是:ACALL中addr11隻佔用PC的PC.0~PC.10位。
(3) RET ;放在子程序最後,使程序准確返回到主程序斷點處
執行過程為:(SP)→PC.8~PC.15斷點地址高位元組送入PC
SP-1→SP,(SP) →PC.0~PC.7斷點低位元組送入PC,
這時PC中為主程序斷點地址,程序准確返回到調用指令的下一條。
例 設SP=62H,(62H)=07H,(61H)=30H,執行指令RET
結果:SP=60H,(PC)=0730H,CPU從0730H開始執行程序。
(4) RETI ;中斷返回指令
該指令用於中斷服務程序,使中斷程序結束後准確返回到主程序斷點處,執行過程同RET,它還能清除優先順序狀態。
(5) NOP ;空操作
執行該指令時,CPU只進行取指令、解碼,而不進行任何操作,故稱為控操作。常用於產生一個機器周期延時。位操作指令MCS-51單片機的特色之一是具有很強的位處理功能。位操作指令又稱為布爾指令,其功能是對內部RAM中可進行位操作的區域進行位操作。
在進行位操作時,位累加器C即進位標志Cy,位地址是片內RAM位元組地址20H~2FH單元中連續的128個位(位地址00H~7FH)和部分功能寄存器。凡SFR中字元等地址能被8整除的特殊功能寄存器都具有可定址的位地址,其中ACC(位地址E0H~E7H),B(位地址F0H~F7H)和片內RAM中128個位都可作軟體標志或存儲位變數。
1. 位數據傳送類指令(2條)
MOV C , bit ;(bit) →C,定址位的狀態送入C
MOV bit , C ;C→(bit),C的狀態送入位地址中
2. 位修正指令(6條)
CLR C ;0→C, 清0累加器
CLR bit ;0→(bit);清0定址位
CPL C ;/C→C,取反
CPL bit ;(/bit) →(bit),定址位取反
SETB C ;1→C,C置1
SETB bit ;1→ (bit),定址位置1
3. 位邏輯運算指令(4條)
ANL C , bit ;C∩(bit) →C,定址位和C「與」,結果放在C
ANL C , /bit ;C∩(/bit) →C,定址位的非和C「與」,結果放在C
ORL C , bit ;C∪(bit) →C,定址位和C「或」,結果放在C
ORL C , /bit ;C∪(bit) →C,定址位和C的非「或」,結果放在C
4. 位條件轉移指令(5條)
JC rel ;C=1轉向PC+2+rel→PC
C=0順序執行PC+2→PC
JNC rel ;C=0轉向PC+2+rel→PC
C=1順序執行PC+2→PC
JB bit , rel ;(bit) =1轉向PC+3+rel→PC
(bit) =0順序執行PC+3→PC
JNB bit , rel ;(bit) =0轉向PC+3+rel→PC
(bit) =1順序執行PC+3→PC
JBC bit , rel ;(bit) =1轉向PC+3+rel→PC;同時0→(bit)
(bit) =0順序執行PC+3→PC
注意:JBC與JB指令區別,前者轉移後並把定址位清0,後者只轉移不清0定址位。
例1 設P1為輸入口,P3.0作輸出線,執行下列指令:
MOV C , P1.0 ;(P1.0) →C
ANL C , P1.1 ;(C)∩(P1.1) →C
ANL C , /P1.32 ;(C)∩(/P1.2) →C
MOV P3.0 , C ;C→P3.0
結果是:P3.0=(P1.0) ∩(P1.1) ∩(/P1.2)
例2 用位操作指令編程計算邏輯方程
P1.5=ACC.0 ∩ (B.0∪P1.2) ∪P1.3
解: MOV C , B.0 ;B.0→C
ORL C , P1.2 ;C∪P1.2→C 即B.0+P1.2→C
ANL C , ACC.0 ;C∩ACC.0→C 即ACC.0∩(B.0∪P1.2)→C
ORL C , P1.3 ;C∪P1.3→C 即 ACC.0∩(B.0∪P1.2)∪P1.3→C
MOV P1.5 , C ;C→P1.5
Ⅷ 單片機用匯編語言編程的時候才會用到指令集嗎,指令集怎麼運用
指令集怎麼運用?
--用匯編語言編程的時候,必須用指令集中的指令。
--用指令集,就像查字典一樣。
用匯編語言編程的時候才會用到指令集嗎?
--不編程的時候,也可以翻翻看。
Ⅸ 單片機與PC機有何區別
一、概念不同:
1、單片機:
單片機是一種集成電路晶元,是採用超大規模集成電路技術把具有數據處理能力的中央處理器CPU、隨機存儲器RAM、只讀存儲器ROM、多種I/O口和中斷系統、定時器/計數器等功能集成到一塊矽片上構成的一個小而完善的微型計算機系統。
2、PC機:
PC機是指一種大小、價格和性能適用於個人使用的多用途計算機。台式機、筆記本電腦到小型筆記本電腦和平板電腦以及超級本等都屬於個人計算機(PC機)。
二、作用不同:
1、單片機:
從內部的硬體到軟體有一套完整的按位操作系統,稱作位處理器,處理對象不是字或位元組而是位。不但能對片內某些特殊功能寄存器的某位進行處理,如傳送、置位、清零、測試等,還能進行位的邏輯運算,其功能十分完備,使用起來得心應手。
2、PC機:
讓PC機能夠通過網路互相鏈接。 乙太網的標准化(IEEE 802.3)是計算機互聯網的一個里程碑,個人計算機可以通過交換機或集線器互相建立起連接。區域網在各大機構和企業的網路建設中,是很重要的一環。而區域網本身也早已擴展成全球范圍內的互聯網。
(9)單片機與的指令集擴展閱讀
單片機在電子技術中的開發,主要包括CPU開發、程序開發、 存儲器開發、計算機開發及C語言程序開發,同時得到開發能夠保證單片機在十分復雜的計算機與控制環境中可以正常有序的進行,這就需要相關人員採取一定的措施。
而計算機的發展主要按照構成計算機的電子元器件來劃分,共分為四個階段,即電子管階段、晶體管階段、集成電路階段、大規模和超大規模集成電路階段(現在)。
Ⅹ 51單片機指令有哪些啊
MCS-51共有111條指令,可分為5類:
[1].數據傳送類指令(共29條)
[2].算數運算類指令(共24條)
[3].邏輯運算及移位類指令(共24條)
[4].控制轉移類指令(共17條)
[5].布爾變數操作類指令(共17條)