<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 51單片機匯編基礎

          51單片機匯編基礎

          作者: 時間:2016-11-13 來源:網(wǎng)絡 收藏

          本文引用地址:http://www.ex-cimer.com/article/201611/316243.htm

          一個單片機所需執(zhí)行指令的集合即為單片機的指令系統(tǒng)。單片機使用的機器語言、匯編語言及高級語言,但不管使用是何種語言,最終還是要“翻譯”成為機器碼,單片機才能執(zhí)行之?,F(xiàn)在有很多半導體廠商都推出了自己的單片機,單片機種類繁多,品種數(shù)不勝數(shù),值得注意的是不同的單片機它們的指令系統(tǒng)不一定相同,或不完全相同。但不管是使用機器語言、匯編語言還是高級語言都是使用指令編寫程序的。

            所謂機器語言即指令的二進制編碼,而匯編語言則是指令的表示符號 。在指令的表達式上也不會直接使用二進制機器碼,最常用的是十六進制的形式。但單片機并不能直接執(zhí)行匯編語言和高級語言,都必須通過匯編器“翻譯”成為二進制機器碼方能執(zhí)行,但如果直接使用二進制來編寫程序,那將十分不便,也很難記憶和識別,不易編寫、難于辨讀,極易出錯,同時出錯了也相當難查找。所以現(xiàn)在基本上都不會直接使用機器語言來編寫單片機的程序。最好的辦法就是使用易于閱讀和辨認的指令符號來代替機器碼,我們常稱這些符號為助記符,用助記符的形式表示的單片機指令就是匯編語言,為便于記憶和閱讀,助記符號通常都使用易于理解的英文單詞和拼音字母來表示。

            每種單片機都有自己獨特的指令系統(tǒng),那么指令系統(tǒng)是開發(fā)和生產(chǎn)廠商定義的,如要使用其單片機,用戶就必須理解和遵循這些指令標準,要掌握某種(類)單片機,指令系統(tǒng)的學習是必須的。

            MCS-51共有111條指令,可分為5類:

            [1].數(shù)據(jù)傳送類指令(共29條)

            [2].算數(shù)運算類指令(共24條)

            [3].邏輯運算及移位類指令(共24條)

            [4].控制轉(zhuǎn)移類指令(共17條)

            [5].布爾變量操作類指令(共17條)

            一些特殊符號的意義

            在介紹指令系統(tǒng)前,我們先了解一些特殊符號的意義,這對今后程序的編寫都是相當有用的。

            Rn——當前選中的寄存器區(qū)的8個工作寄存器R0—R7(n=0-7)。

            Ri——當前選中的寄存器區(qū)中可作為地址寄存器的兩個寄存器R0和R1(i=0,1)

            direct—內(nèi)部數(shù)據(jù)存儲單元的8位地址。包含0—127(255)內(nèi)部存儲單元地址和特殊功能寄存地址。

            #data—指令中的8位常數(shù)。

            #data16—指令中的16位常數(shù)。

            addr16—用于LCALL和LJMP指令中的16目的地地址,目的地址的空間為64kB程序存儲器地址。

            #addr11—用于ACALL和AJMP指令中的11目的地地址,目的地址必須放在與下條指令第一個字節(jié)同一個2kB程序存儲器空間之中。

            rel—8位帶符號的偏移字節(jié),用于所有的條件轉(zhuǎn)移和SJMP等指令中,偏移字節(jié)對于下條指令的第一個字節(jié)開始的-128——+127范圍內(nèi)。

            @—間接寄存器尋址或基址寄存器的前綴。

            /—為操作的前綴,聲明對該位操作書取反。

            DPTR—數(shù)據(jù)指針。

            bit—內(nèi)部RAM和特殊功能寄存器的直接尋址位。

            A—累加器。

            B—累加器B。用于乘法和除法指令中。

            C—進位標志位。

            (x)—某地址單元中的內(nèi)容。

            ((x))—由X尋址單元中的內(nèi)容。

            MCS-51的尋址方式

            尋址的“地址”即為操作數(shù)所在單元的地址,絕大部分指令執(zhí)行時都需要用到操作數(shù),那么到哪里去取得操作數(shù)呢?最易想到的就是告訴CPU操作數(shù)所在的地址單元,從那里可取得響應的操作數(shù),這便是“尋址”之意。MCS-51的尋址方式很多,使用起來也相當方便,功能也很強大,靈活性強。這便是MCS-51指令系統(tǒng)“好用”的原因之一。下面我們分別討論幾種尋址方式的原理。

            [1].直接尋址

            指令中操作數(shù)直接以單元地址形式出現(xiàn),例如:

            MOV A,68H

            這條指令的意義是把內(nèi)部RAM中的68H單元中的數(shù)據(jù)內(nèi)容傳送到累加器A中。值得注意的是直接尋址方式只能使用8位二進制地址,因此這種尋址方式僅限于內(nèi)部RAM進行尋址。低128位單元在指令中直接以單元地址的形式給出。對于特殊功能寄存器可以使用其直接地址進行訪問,還可以以它們的符號形式給出,只是特殊功能寄存器只能用直接尋址方式訪問,而無其它方法。

            [2].寄存器尋址

            寄存器尋址對選定的8個工作寄存器R0-R7進行操作,也就是操作數(shù)在寄存器中,因此指定了寄存器就得到了操作數(shù),寄存器尋址的指令中以寄存器的符號來表示寄存器,例如:

            MOV A,R1

            這條指令的意義是把所用的工作寄存器組中的R3的內(nèi)容送到累加器A中。

          值得一提的是工作狀態(tài)寄存器的選擇是通過程序狀態(tài)字寄存器來控制的,在這條指令前,應通過PSW設定當前工作寄存器組。

            [3].寄存器間接尋址

            寄存器尋址方式,寄存器中存放的是操作數(shù),而寄存器間接尋址方式,寄存器中存放的則為操作數(shù)的地址,也即操作數(shù)是通過寄存器指向的地址單元得到的,這便是寄存器間接尋址名稱的由來。

          例如指令:

            MOV A,@R0

            這條指令的意義是R0寄存器指向地址單元中的內(nèi)容送到累加器A中。假如R0=#56H,那么是將56H單元中的數(shù)據(jù)送到累加器A中。

          寄存器間接尋址方式可用于訪問內(nèi)部RAM或外部數(shù)據(jù)存儲器。訪問內(nèi)部RAM或外部數(shù)據(jù)存儲器的低256字節(jié)時,可通過R0和R1作為間接寄存器。然而有必要指出,內(nèi)部RAM的高128字節(jié)地址與專用積存器的地址是重疊的,所以這種尋址方式不能用于訪問特殊功能寄存器。

            外部數(shù)據(jù)存儲器的空間為64kB,這時可采用DPTR作為間址寄存器進行訪問,指令如下:

            MOVX A,@DPTR

            這條指令的意義是與上述類似,不再贅述。

            [4].立即尋址

            立即尋址就是把操作數(shù)直接在指令中給出,即操作數(shù)包含在指令中,指令操作碼的后面緊跟著操作數(shù),一般把指令中的操作數(shù)稱為立即數(shù),因此而得名。為了與直接尋址方式相區(qū)別,在立即數(shù)前加上“#”符號,例如:

            MOVX A,#0EH

            這條指令的意義是將0EH這個操作數(shù)送到累加器A中。

            [5].變址尋址

            變址尋址是以DPTR或PC作為基址寄存器,以累加器A作為變址寄存器,將兩寄存器的內(nèi)容相加形成16位地址形成操作數(shù)的實際地址。例如:

            MOV A,@A+DPTR

            MOVX A,@A+PC

            JMP @A+DPTR

            在這三條指令中,A作為偏移量寄存器,DPTR或PC作為變址寄存器,A作為無符號數(shù)與DPTR或PC的內(nèi)容相加,得到訪問的實際地址。其中前兩條是程序存儲器讀指令,后一條是無條件轉(zhuǎn)移指令。

            [6].位尋址

            在MCS-51單片機中,RAM中的20H—2FH字節(jié)單元對應的位地址為00H—7FH,特殊功能寄存器中的某些位也可進行為尋址,這些單元既可以采用字節(jié)方式訪問它們,也可采用位尋址的方式訪問它們。

            [7].相對尋址

            相對尋址方式是為了程序的相對轉(zhuǎn)移而設計的,其夜里是以PC的內(nèi)容為基址,加上給出的偏移量作為轉(zhuǎn)移地址,從而實現(xiàn)程序的轉(zhuǎn)移。轉(zhuǎn)移的目的地址可參見如下表達式:

            目的地址=轉(zhuǎn)移指令地址+轉(zhuǎn)移指令字接數(shù)+偏移量

            值得注意的是,偏移量是有正負號之分的,偏移量的取值范圍是當前PC值的-128—+127之間。

            MCS-51數(shù)據(jù)傳送指令

            數(shù)據(jù)傳送指令共有29條,數(shù)據(jù)傳送指令一般的操作是把源操作數(shù)傳送到目的操作數(shù),指令執(zhí)行完成后,源操作數(shù)不變,目的操作數(shù)等于源操作數(shù)。如果要求在進行數(shù)據(jù)傳送時,目的操作數(shù)不丟失,則不能用直接傳送指令,而采用交換型的數(shù)據(jù)傳送指令,數(shù)據(jù)傳送指令不影響標志C,AC和OV,但可能會對奇偶標志P有影響。

            [1]. 以累加器A為目的操作數(shù)類指令(4條)

            這4條指令的作用是把源操作數(shù)指向的內(nèi)容送到累加器A。有直接、立即數(shù)、寄存器和寄存器間接尋址方式:

            MOV A,data ;(data)→(A) 直接單元地址中的內(nèi)容送到累加器A

            MOV A,#data ;#data→(A) 立即數(shù)送到累加器A中

            MOV A,Rn ;(Rn)→(A) Rn中的內(nèi)容送到累加器A中

            MOV A,@Ri ;((Ri))→(A) Ri內(nèi)容指向的地址單元中的內(nèi)容送到累加器A

            [2]. 以寄存器Rn為目的操作數(shù)的指令(3條)

          這3條指令的功能是把源操作數(shù)指定的內(nèi)容送到所選定的工作寄存器Rn中。有直接、立即和寄存器尋址方式:

            MOV Rn,data ;(data)→(Rn) 直接尋址單元中的內(nèi)容送到寄存器Rn中

            MOV Rn,#data ;#data→(Rn) 立即數(shù)直接送到寄存器Rn中

            MOV Rn,A ;(A)→(Rn) 累加器A中的內(nèi)容送到寄存器Rn中

            [3]. 以直接地址為目的操作數(shù)的指令(5條)

            這組指令的功能是把源操作數(shù)指定的內(nèi)容送到由直接地址data所選定的片內(nèi)RAM中。有直接、立即、寄存器和寄存器間接4種尋址方式:

            MOV data,data ;(data)→(data) 直接地址單元中的內(nèi)容送到直接地址單元

            MOV data,#data ;#data→(data) 立即數(shù)送到直接地址單元

            MOV data,A ;(A)→(data) 累加器A中的內(nèi)容送到直接地址單元

            MOV data,Rn ;(Rn)→(data) 寄存器Rn中的內(nèi)容送到直接地址單元

            MOV data,@Ri ;((Ri))→(data) 寄存器Ri中的內(nèi)容指定的地址單元中數(shù)據(jù)送到直接地址單元

            [4]. 以間接地址為目的操作數(shù)的指令(3條)

            這組指令的功能是把源操作數(shù)指定的內(nèi)容送到以Ri中的內(nèi)容為地址的片內(nèi)RAM中。有直接、立即和寄存器3種尋址方式:

            MOV @Ri,data ;(data)→((Ri)) 直接地址單元中的內(nèi)容送到以Ri中的內(nèi)容為地址的RAM單元

            MOV @Ri,#data ;#data→((Ri)) 立即數(shù)送到以Ri中的內(nèi)容為地址的RAM單元

            MOV @Ri,A ;(A)→((Ri)) 累加器A中的內(nèi)容送到以Ri中的內(nèi)容為地址的RAM單元

            [5]. 查表指令(2條)

            這組指令的功能是對存放于程序存儲器中的數(shù)據(jù)表格進行查找傳送,使用變址尋址方式:

            MOVC A,@A+DPTR ;((A))+(DPTR)→(A) 表格地址單元中的內(nèi)容送到累加器A中

            MOVC A,@A+PC ;((PC))+1→(A),((A))+(PC)→(A) 表格地址單元中的內(nèi)容送到累加器A中

            [6]. 累加器A與片外數(shù)據(jù)存儲器RAM傳送指令(4條)

            這4條指令的作用是累加器A與片外RAM間的數(shù)據(jù)傳送。使用寄存器尋址方式:

            MOVX @DPTR,A ;(A)→((DPTR)) 累加器中的內(nèi)容送到數(shù)據(jù)指針指向片外RAM地址中

            MOVX A, @DPTR ;((DPTR))→(A) 數(shù)據(jù)指針指向片外RAM地址中的內(nèi)容送到累加器A中

            MOVX A, @Ri ;((Ri))→(A) 寄存器Ri指向片外RAM地址中的內(nèi)容送到累加器A中

            MOVX @Ri,A ;(A)→((Ri)) 累加器中的內(nèi)容送到寄存器Ri指向片外RAM地址中

            [7]. 堆棧操作類指令(2條)

            這4類指令的作用是把直接尋址單元的內(nèi)容傳送到堆棧指針SP所指的單元中,以及把SP所指單元的內(nèi)容送到直接尋址單元中。這類指令只有兩條,下述的第一條常稱為入棧操作指令,第二條稱為出棧操作指令。需要指出的是,單片機開機復位后,(SP)默認為07H,但一般都需要重新賦值,設置新的SP首址。入棧的第一個數(shù)據(jù)必須存放于SP+1所指存儲單元,故實際的堆棧底為SP+1所指的存儲單元。

            PUSH data ;(SP)+1→(SP),(data)→(SP) 堆棧指針首先加1,直接尋址單元中的數(shù)據(jù)送到堆棧指針SP所指的單元中

            POP data ;(SP)→(data)(SP)-1→(SP), 堆棧指針SP所指的單元數(shù)據(jù)送到直接尋址單元中,堆棧指針SP再進行減1操作

            [8]. 交換指令(5條)

            這5條指令的功能是把累加器A中的內(nèi)容與源操作數(shù)所指的數(shù)據(jù)相互交換。

            XCH A,Rn ;(A)←→(Rn)累加器與工作寄存器Rn中的內(nèi)容互換

            XCH A,@Ri ;(A)←→((Ri))累加器與工作寄存器Ri所指的存儲單元中的內(nèi)容互換

            XCH A,data ;(A)←→(data)累加器與直接地址單元中的內(nèi)容互換

            XCHD A,@Ri ;(A3-0)←→((Ri)3-0)累加器與工作寄存器Ri所指的存儲單元中的內(nèi)容低半字節(jié)互換

            SWAP A ;(A3-0)←→(A7-4)累加器中的內(nèi)容高低半字節(jié)互換

            [9]. 16位數(shù)據(jù)傳送指令(1條)

            這條指令的功能是把16位常數(shù)送入數(shù)據(jù)指針寄存器。

            MOV DPTR,#data16 ;#dataH→(DPH),#dataL→(DPL)16位常數(shù)的高8位送到DPH,低8位送到DPL

            MCS-51算術(shù)運算指令

            算術(shù)運算指令共有24條,算術(shù)運算主要是執(zhí)行加、減、乘、除法四則運算。另外MCS-51指令系統(tǒng)中有相當一部分是進行加、減1操作,BCD碼的運算和調(diào)整,我們都歸類為運算指令。雖然MCS-51單片機的算術(shù)邏輯單元ALU僅能對8位無符號整數(shù)進行運算,但利用進位標志C,則可進行多字節(jié)無符號整數(shù)的運算。同時利用溢出標志,還可以對帶符號數(shù)進行補碼運算。需要指出的是,除加、減1指令外,這類指令大多數(shù)都會對PSW(程序狀態(tài)字)有影響。這在使用中應特別注意。

            [1]. 加法指令(4條)

            這4條指令的作用是把立即數(shù),直接地址、工作寄存器及間接地址內(nèi)容與累加器A的內(nèi)容相加,運算結(jié)果存在A中。

            ADD A,#data ;(A)+#data→(A) 累加器A中的內(nèi)容與立即數(shù)#data相加,結(jié)果存在A中

            ADD A,data ;(A)+(data)→(A) 累加器A中的內(nèi)容與直接地址單元中的內(nèi)容相加,結(jié)果存在A中

            ADD A,Rn ;(A)+(Rn)→(A) 累加器A中的內(nèi)容與工作寄存器Rn中的內(nèi)容相加,結(jié)果存在A中

            ADD A,@Ri ;(A)+((Ri))→(A) 累加器A中的內(nèi)容與工作寄存器Ri所指向地址單元中的內(nèi)容相加,結(jié)果存在A中

            [2]. 帶進位加法指令(4條)

            這4條指令除與[1]功能相同外,在進行加法運算時還需考慮進位問題。

            ADDC A,data ;(A)+(data)+(C)→(A) 累加器A中的內(nèi)容與直接地址單元的內(nèi)容連同進位位相加,結(jié)果存在A中

            ADDC A,#data ;(A)+#data +(C)→(A) 累加器A中的內(nèi)容與立即數(shù)連同進位位相加,結(jié)果存在A中

            ADDC A,Rn ;(A)+Rn+(C)→(A) 累加器A中的內(nèi)容與工作寄存器Rn中的內(nèi)容、連同進位位相加,結(jié)果存在A中

            ADDC A,@Ri ;(A)+((Ri))+(C)→(A) 累加器A中的內(nèi)容與工作寄存器Ri指向地址單元中的內(nèi)容、連同進位位相加,結(jié)果存在A中

            [3]. 帶借位減法指令(4條)

            這組指令包含立即數(shù)、直接地址、間接地址及工作寄存器與累加器A連同借位位C內(nèi)容相減,結(jié)果送回累加器A中。

            

            這里我們對借位位C的狀態(tài)作出說明,在進行減法運算中,CY=1表示有借位,CY=0則無借位。OV=1聲明帶符號數(shù)相減時,從一個正數(shù)減去一個負數(shù)結(jié)果為負數(shù),或者從一個負數(shù)中減去一個正數(shù)結(jié)果為正數(shù)的錯誤情況。在進行減法運算前,如果不知道借位標志位C的狀態(tài),則應先對CY進行清零操作。

            SUBB A,data ;(A)-(data) - (C)→(A) 累加器A中的內(nèi)容與直接地址單元中的內(nèi)容、連同借位位相減,結(jié)果存在A中

            SUBB A,#data ;(A)-#data -(C)→(A) 累加器A中的內(nèi)容與立即數(shù)、連同借位位相減,結(jié)果存在A中

            SUBB A,Rn ;(A)-(Rn) -(C)→(A) 累加器A中的內(nèi)容與工作寄存器中的內(nèi)容、連同借位位相減,結(jié)果存在A中

            SUBB A,@Ri ;(A)-((Ri)) -(C)→(A) 累加器A中的內(nèi)容與工作寄存器Ri指向的地址單元中的內(nèi)容、連同借位位相減,結(jié)果存在A中

            [4]. 乘法指令(1條)

            這個指令的作用是把累加器A和寄存器B中的8位無符號數(shù)相乘,所得到的是16位乘積,這個結(jié)果低8位存在累加器A,而高8位存在寄存器B中。如果OV=1,說明乘積大于FFH,否則OV=0,但進位標志位CY總是等于0。

            MUL AB ;(A)×(B)→(A)和(B) 累加器A中的內(nèi)容與寄存器B中的內(nèi)容相乘,結(jié)果存在A、B中

            [5]. 除法指令(1條)

            這個指令的作用是把累加器A的8位無符號整數(shù)除以寄存器B中的8位無符號整數(shù),所得到的商存在累加器A,而余數(shù)存在寄存器B中。除法運算總是使OV和進位標志位CY等于0。如果OV=1,表明寄存器B中的內(nèi)容為00H,那么執(zhí)行結(jié)果為不確定值,表示除法有溢出。

            DIV AB ;(A)÷(B)→(A)和(B) 累加器A中的內(nèi)容除以寄存器B中的內(nèi)容,所得到的商存在累加器A,而余數(shù)存在寄存器B中。

            [6]. 加1指令(5條)

            這5條指令的的功能均為原寄存器的內(nèi)容加1,結(jié)果送回原寄存器。上述提到,加1指令不會對任何標志有影響,如果原寄存器的內(nèi)容為FFH,執(zhí)行加1后,結(jié)果就會是00H。這組指令共有直接、寄存器、寄存器減間址等尋址方式:

            INC A ;(A)+1→(A) 累加器A中的內(nèi)容加1,結(jié)果存在A中

            INC data ;(data)+1→(data) 直接地址單元中的內(nèi)容加1,結(jié)果送回原地址單元中

            INC @Ri ;((Ri))+1→((Ri)) 寄存器的內(nèi)容指向的地址單元中的內(nèi)容加1,結(jié)果送回原地址單元中

            INC Rn ;(Rn)+1→(Rn)寄存器Rn的內(nèi)容加1,結(jié)果送回原地址單元中

            INC DPTR ;(DPTR)+1→(DPTR)數(shù)據(jù)指針的內(nèi)容加1,結(jié)果送回數(shù)據(jù)指針中

            在INC data這條指令中,如果直接地址是I/O,其功能是先讀入I/O鎖存器的內(nèi)容,然后在CPU進行加1操作,再輸出到I/O上,這就是“讀—修改—寫”操作。

            [7]. 減1指令(4條)

            這組指令的作用是把所指的寄存器內(nèi)容減1,結(jié)果送回原寄存器,若原寄存器的內(nèi)容為00H,減1后即為FFH,運算結(jié)果不影響任何標志位,這組指令共有直接、寄存器、寄存器間址等尋址方式,當直接地址是I/O口鎖存器時,“讀—修改—寫”操作與加1指令類似。

            DEC A ;(A)-1→(A)累加器A中的內(nèi)容減1,結(jié)果送回累加器A中

            DEC data ;(data)-1→(data)直接地址單元中的內(nèi)容減1,結(jié)果送回直接地址單元中

            DEC @Ri ;((Ri))-1→((Ri))寄存器Ri指向的地址單元中的內(nèi)容減1,結(jié)果送回原地址單元中

            DEC Rn ;(Rn)-1→(Rn)寄存器Rn中的內(nèi)容減1,結(jié)果送回寄存器Rn中

            [8]. 十進制調(diào)整指令(1條)

            在進行BCD碼運算時,這條指令總是跟在ADD或ADDC指令之后,其功能是將執(zhí)行加法運算后存于累加器A中的結(jié)果進行調(diào)整和修正。

            DA A

            MCS-51邏輯運算及移位指令

            邏輯運算和移位指令共有25條,有與、或、異或、求反、左右移位、清0等邏輯操作,有直接、寄存器和寄存器間址等尋址方式。這類指令一般不影響程序狀態(tài)字(PSW)標志。

            [1]. 循環(huán)移位指令(4條)

            這4條指令的作用是將累加器中的內(nèi)容循環(huán)左或右移一位,后兩條指令是連同進位位CY一起移位。

            RL A ;累加器A中的內(nèi)容左移一位

            RR A ;累加器A中的內(nèi)容右移一位

            RLC A ;累加器A中的內(nèi)容連同進位位CY左移一位

            RRC A ;累加器A中的內(nèi)容連同進位位CY右移一位

            [2]. 累加器半字節(jié)交換指令(1條)

            這條指令是將累加器中的內(nèi)容高低半字節(jié)互換,這在上一節(jié)中內(nèi)容已有介紹。

            SWAP A ; 累加器中的內(nèi)容高低半字節(jié)互換

            [3]. 求反指令(1條)

            這條指令將累加器中的內(nèi)容按位取反。

            CPL A ; 累加器中的內(nèi)容按位取反

            [4]. 清零指令(1條)

            這條指令將累加器中的內(nèi)容清0。

            CLR A ; 0→(A),累加器中的內(nèi)容清0

            [5]. 邏輯與操作指令(6條)

            這組指令的作用是將兩個單元中的內(nèi)容執(zhí)行邏輯與操作。如果直接地址是I/O地址,則為“讀—修改—寫”操作。

            ANL A,data ;累加器A中的內(nèi)容和直接地址單元中的內(nèi)容執(zhí)行與邏輯操作。結(jié)果存在寄存器A中。

            ANL data,#data ;直接地址單元中的內(nèi)容和立即數(shù)執(zhí)行與邏輯操作。結(jié)果存在直接地址單元中。

            ANL A,#data ;累加器A的內(nèi)容和立即數(shù)執(zhí)行與邏輯操作。結(jié)果存在累加器A中。

            ANL A,Rn ;累加器A的內(nèi)容和寄存器Rn中的內(nèi)容執(zhí)行與邏輯操作。結(jié)果存在累加器A中。

            ANL data,A ;直接地址單元中的內(nèi)容和累加器A的內(nèi)容執(zhí)行與邏輯操作。結(jié)果存在直接地址單元中。

            ANL A,@Ri ;累加器A的內(nèi)容和工作寄存器Ri指向的地址單元中的內(nèi)容執(zhí)行與邏輯操作。結(jié)果存在累加器A中。

            [6]. 邏輯或操作指令(6條)

            這組指令的作用是將兩個單元中的內(nèi)容執(zhí)行邏輯或操作。如果直接地址是I/O地址,則為“讀—修改—寫”操作。

            ORL A,data ;累加器A中的內(nèi)容和直接地址單元中的內(nèi)容執(zhí)行邏輯或操作。結(jié)果存在寄存器A中。

            ORL data,#data ;直接地址單元中的內(nèi)容和立即數(shù)執(zhí)行邏輯或操作。結(jié)果存在直接地址單元中。

            ORL A,#data ;累加器A的內(nèi)容和立即數(shù)執(zhí)行邏輯或操作。結(jié)果存在累加器A中。

            ORL A,Rn ;累加器A的內(nèi)容和寄存器Rn中的內(nèi)容執(zhí)行邏輯或操作。結(jié)果存在累加器A中。

            ORL data,A ;直接地址單元中的內(nèi)容和累加器A的內(nèi)容執(zhí)行邏輯或操作。結(jié)果存在直接地址單元中。

            ORL A,@Ri ;累加器A的內(nèi)容和工作寄存器Ri指向的地址單元中的內(nèi)容執(zhí)行邏輯或操作。結(jié)果存在累加器A中。

            [7]. 邏輯異或操作指令(6條)

            這組指令的作用是將兩個單元中的內(nèi)容執(zhí)行邏輯異或操作。如果直接地址是I/O地址,則為“讀—修改—寫”操作。

            XRL A,data ;累加器A中的內(nèi)容和直接地址單元中的內(nèi)容執(zhí)行邏輯異或操作。結(jié)果存在寄存器A中。

            XRL data,#data ;直接地址單元中的內(nèi)容和立即數(shù)執(zhí)行邏輯異或操作。結(jié)果存在直接地址單元中。

            XRL A,#data ;累加器A的內(nèi)容和立即數(shù)執(zhí)行邏輯異或操作。結(jié)果存在累加器A中。

            XRL A,Rn ;累加器A的內(nèi)容和寄存器Rn中的內(nèi)容執(zhí)行邏輯異或操作。結(jié)果存在累加器A中。

            XRL data,A ;直接地址單元中的內(nèi)容和累加器A的內(nèi)容執(zhí)行邏輯異或操作。結(jié)果存在直接地址單元中。

            XRL A,@Ri ;累加器A的內(nèi)容和工作寄存器Ri指向的地址單元中的內(nèi)容執(zhí)行邏輯異或操作。結(jié)果存在累加器A中。

            MCS-51控制轉(zhuǎn)移指令

           

            控制轉(zhuǎn)移指令用于控制程序的流向,所控制的范圍即為程序存儲器區(qū)間,MCS-51系列單片機的控制轉(zhuǎn)移指令相對豐富,有可對64kB程序空間地址單元進行訪問的長調(diào)用、長轉(zhuǎn)移指令,也有可對2kB字節(jié)進行訪問的絕對調(diào)用和絕對轉(zhuǎn)移指令,還有在一頁范圍內(nèi)短相對轉(zhuǎn)移及其它無條件轉(zhuǎn)移指令,這些指令的執(zhí)行一般都不會對標志位有影響。

            [1]. 無條件轉(zhuǎn)移指令(4條)

            這組指令執(zhí)行完后,程序就會無條件轉(zhuǎn)移到指令所指向的地址上去。長轉(zhuǎn)移指令訪問的程序存儲器空間為16地址64kB,絕對轉(zhuǎn)移指令訪問的程序存儲器空間為11位地址2kB空間。

            LJMP addr16 ;addr16→(PC),給程序計數(shù)器賦予新值(16位地址)

            AJMP addr11 ;(PC)+2→(PC),addr11→(PC10-0)程序計數(shù)器賦予新值(11位地址),(PC15-11)不改變

            SJMP rel ;(PC)+ 2 + rel→(PC)當前程序計數(shù)器先加上2再加上偏移量給程序計數(shù)器賦予新值

            JMP @A+DPTR ;(A)+ (DPTR)→(PC),累加器所指向地址單元的值加上數(shù)據(jù)指針的值給程序計數(shù)器賦予新值

            [2]. 條件轉(zhuǎn)移指令(8條)

            程序可利用這組豐富的指令根據(jù)當前的條件進行判斷,看是否滿足某種特定的條件,從而控制程序的轉(zhuǎn)向。

            JZ rel ; A=0,(PC)+ 2 + rel→(PC),累加器中的內(nèi)容為0,則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            JNZ rel ; A≠0,(PC)+ 2 + rel→(PC),累加器中的內(nèi)容不為0,則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            CJNE A, data, rel ; A≠(data),(PC)+ 3 + rel→(PC),累加器中的內(nèi)容不等于直接地址單元的內(nèi)容,則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            CJNE A, #data, rel ; A≠#data,(PC)+ 3 + rel→(PC),累加器中的內(nèi)容不等于立即數(shù),則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            CJNE Rn, #data, rel ; A≠#data,(PC)+ 3 + rel→(PC),工作寄存器Rn中的內(nèi)容不等于立即數(shù),則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            CJNE @Ri, #data, rel ; A≠#data,(PC)+ 3 + rel→(PC),工作寄存器Ri指向地址單元中的內(nèi)容不等于立即數(shù),則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            DJNZ Rn, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)工作寄存器Rn減1不等于0,則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            DJNZ data, rel ; (Rn)-1→(Rn),(Rn)≠0,(PC)+ 2 + rel→(PC)直接地址單元中的內(nèi)容減1不等于0,則轉(zhuǎn)移到偏移量所指向的地址,否則程序往下執(zhí)行

            [3]. 子程序調(diào)用指令(1條)

            子程序是為了便于程序編寫,減少那些需反復執(zhí)行的程序占用多余的地址空間而引入的程序分支,從而有了主程序和子程序的概念,需要反復執(zhí)行的一些程序,我們在編程時一般都把它們編寫成子程序,當需要用它們時,就用一個調(diào)用命令使程序按調(diào)用的地址去執(zhí)行,這就需要子程序的調(diào)用指令和返回指令。

            LCALL addr16 ; 長調(diào)用指令,可在64kB空間調(diào)用子程序。此時(PC)+ 3→(PC),(SP)+ 1→(SP),(PC7-0)→(SP),(SP)+ 1→(SP),(PC15-8)→(SP),addr16→(PC),即分別從堆棧中彈出調(diào)用子程序時壓入的返回地址

            ACALL addr11 ; 絕對調(diào)用指令,可在2kB空間調(diào)用子程序,此時(PC)+ 2→(PC),(SP)+ 1→(SP),(PC7-0)→(SP),(SP)+ 1→(SP),(PC15-8)→(SP),addr11→(PC10-0)

            RET ; 子程序返回指令。此時(SP)→(PC15-8),(SP)- 1→(SP),(SP)→(PC7-0),(SP)- 1→(SP)

            RETI ; 中斷返回指令,除具有RET功能外,還具有恢復中斷邏輯的功能,需注意的是,RETI指令不能用RET代替

            [4]. 空操作指令(1條)

          這條指令將累加器中的內(nèi)容清0。

            NOP ; 這條指令除了使PC加1,消耗一個機器周期外,沒有執(zhí)行任何操作。可用于短時間的延時

            MCS-51布爾變量操作指令

            布爾處理功能是MCS-51系列單片機的一個重要特征,這是出于實際應用需要而設置的。布爾變量也即開關(guān)變量,它是以位(bit)為單位進行操作的。

            在物理結(jié)構(gòu)上,MCS-51單片機有一個布爾處理機,它以進位標志做為累加位,以內(nèi)部RAM可尋址的128個為存儲位。

            既然有布爾處理機功能,所以也就有相應的布爾操作指令集,下面我們分別談論。

            [1]. 位傳送指令(2條)

            位傳送指令就是可尋址位與累加位CY之間的傳送,指令有兩條。

            MOV C,bit ;bit→CY,某位數(shù)據(jù)送CY

            MOV bit,C ;CY→bit,CY數(shù)據(jù)送某位

            [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]. 位控制轉(zhuǎn)移指令(5)

            位控制轉(zhuǎn)移指令是以位的狀態(tài)作為實現(xiàn)程序轉(zhuǎn)移的判斷條件,介紹如下:

            JC rel ; (CY)=1轉(zhuǎn)移,(PC)+2+rel→PC,否則程序往下執(zhí)行,(PC)+2→PC。

           

            JNC rel ; (CY)=0轉(zhuǎn)移,(PC)+2+rel→PC,否則程序往下執(zhí)行,(PC)+2→PC。

            JB bit, rel ; 位狀態(tài)為1轉(zhuǎn)移。

            JNB bit, rel ; 位狀態(tài)為0轉(zhuǎn)移。

            JBC bit, rel ; 位狀態(tài)為1轉(zhuǎn)移,并使該位清“0”。

            后三條指令都是三字節(jié)指令,如果條件滿足,(PC)+3+rel→PC,否則程序往下執(zhí)行,(PC)+3→PC。




          關(guān)鍵詞: 51單片機匯編基

          評論


          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();