




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、微機原理與接口技術復習參考資料教師:萬顯榮復習資料說明:1、標有紅色星號“%”的內容為重點內容3、本資料末尾附有“微機原理與接口技術綜合練習題與答案錯誤修正”和“微機原理與接口技術綜合練習題與答案中不作要求的部分”,請注意查看。第一章 概 述一、計算機中的數制1、無符號數的表示方法:(1)十進制計數的表示法特點:以十為底,逢十進一;共有0-9十個數字符號。(2)二進制計數表示方法:特點:以2為底,逢2進位;只有0和1兩個符號。(3)十六進制數的表示法:特點:以16為底,逢16進位;有0-9及AF(表示1015)共16個數字符號。 2、各種數制之間的轉換(1)非十進制數到十進制數的轉換按相應進位
2、計數制的權表達式展開,再按十進制求和。(見書本1.2.3,1.2.4)(2)十進制數制轉換為二進制數制l十進制二進制的轉換:整數部分:除2取余;小數部分:乘2取整。l十進制十六進制的轉換:整數部分:除16取余;小數部分:乘16取整。以小數點為起點求得整數和小數的各個位。(3)二進制與十六進制數之間的轉換用4位二進制數表示1位十六進制數3、無符號數二進制的運算(見教材P5)4、二進制數的邏輯運算特點:按位運算,無進借位(1)與運算只有A、B變量皆為1時,與運算的結果就是1(2)或運算A、B變量中,只要有一個為1,或運算的結果就是1(3)非運算(4)異或運算A、B兩個變量只要不同,異或運算的結果就
3、是1二、計算機中的碼制(重點%)1、對于符號數,機器數常用的表示方法有原碼、反碼和補碼三種。數X的原碼記作X原,反碼記作X反,補碼記作X補。1、注意:對正數,三種表示法均相同。它們的差別在于對負數的表示。(1)原碼定義:符號位:0表示正,1表示負;數值位:真值的絕對值。注意:數0的原碼不唯一 (2)反碼定義:若X0 ,則 X反=X原若X0,則X補= X反= X原若X0,則X補= X反+1注意:機器字長為8時,數0的補碼唯一,同為000000002、8位二進制的表示范圍:原碼:-127+127反碼:-127+127補碼:-128+1273、特殊數10000000l該數在原碼中定義為: -0l在反
4、碼中定義為: -127l在補碼中定義為: -128l對無符號數:(10000000)= 128三、信息的編碼1、 十進制數的二進制數編碼用4位二進制數表示一位十進制數。有兩種表示法:壓縮BCD碼和非壓縮BCD碼。(1)壓縮BCD碼的每一位用4位二進制表示,00001001表示09,一個字節表示兩位十進制數。(2)非壓縮BCD碼用一個字節表示一位十進制數,高4位總是0000,低4位的00001001表示092、 字符的編碼計算機采用7位二進制代碼對字符進行編碼(1)數字09的編碼是01100000111001,它們的高3位均是011,后4位正好與其對 應的二進制代碼(BCD碼)相符。(2)英文字
5、母AZ的ASCII碼從1000001(41H)開始順序遞增,字母az的ASCII碼從1100001(61H)開始順序遞增,這樣的排列對信息檢索十分有利。第二章 微機組成原理第一節、微機的結構1、計算機的經典結構馮.諾依曼結構(1)計算機由運算器、控制器、輸入設備和輸出設備五大部分組成(運算器和控制器又稱為CPU)(2)數據和程序以二進制代碼形式不加區分地存放在存儲器總,存放位置由地址指定,數制為二進制。(3)控制器是根據存放在存儲器中的指令序列來操作的,并由一個程序計數器控制指令的執行。3、 系統總線的分類(1)數據總線(Data Bus),它決定了處理器的字長。(2)地址總線(Address
6、 Bus),它決定系統所能直接訪問的存儲器空間的容量。(3)控制總線(Control Bus)第二節、8086微處理器1、8086是一種單片微處理芯片,其內部數據總線的寬度是16位,外部數據總線寬度也是16位,片內包含有控制計算機所有功能的各種電路。8086地址總線的寬度為20位,有1MB(220)尋址空間。2、 8086CPU由總線接口部件BIU和執行部件EU組成。BIU和EU的操作是異步的,為8086取指令和執行指令的并行操作體統硬件支持。3、 8086處理器的啟動4、寄存器結構(重點%)8086微處理器包含有13個16位的寄存器和9位標志位。4個通用寄存器(AX,BX,CX,DX)4個段
7、寄存器(CS,DS,SS,ES)4個指針和變址寄存器(SP,BP,SI,DI)指令指針(IP)1)、通用寄存器(1)8086含4個16位數據寄存器,它們又可分為8個8位寄存器,即:lAX AH,ALlBXBH,BLlCXCH,CLlDXDH,DL常用來存放參與運算的操作數或運算結果(2)數據寄存器特有的習慣用法lAX:累加器。多用于存放中間運算結果。所有I/O指令必須都通過AX與接口傳送信息;lBX:基址寄存器。在間接尋址中用于存放基地址;lCX:計數寄存器。用于在循環或串操作指令中存放循環次數或重復次數;lDX:數據寄存器。在32位乘除法運算時,存放高16位數;在間接尋址的I/O指令中存放I
8、/O端口地址。2)、指針和變址寄存器lSP:堆棧指針寄存器,其內容為棧頂的偏移地址;lBP:基址指針寄存器,常用于在訪問內存時存放內存單元的偏移地址。lSI:源變址寄存器lDI:目標變址寄存器變址寄存器常用于指令的間接尋址或變址尋址。3)、段寄存器CS:代碼段寄存器,代碼段用于存放指令代碼DS:數據段寄存器ES:附加段寄存器,數據段和附加段用來存放操作數SS:堆棧段寄存器,堆棧段用于存放返回地址,保存寄存器內容,傳遞參數4)、指令指針(IP)16位指令指針寄存器,其內容為下一條要執行的指令的偏移地址。5)、標志寄存器(1)狀態標志:l進位標志位(CF):運算結果的最高位有進位或有借位,則CF=
9、1l輔助進位標志位(AF):運算結果的低四位有進位或借位,則AF=1l溢出標志位(OF):運算結果有溢出,則OF=1l零標志位(ZF):反映指令的執行是否產生一個為零的結果l符號標志位(SF):指出該指令的執行是否產生一個負的結果l奇偶標志位(PF):表示指令運算結果的低8位“1”個數是否為偶數(2)控制標志位l中斷允許標志位(IF):表示CPU是否能夠響應外部可屏蔽中斷請求l跟蹤標志(TF):CPU單步執行5、8086的引腳及其功能(重點掌握以下引腳)lAD15AD0:雙向三態的地址總線,輸入/輸出信號lINTR:可屏蔽中斷請求輸入信號,高電平有效。可通過設置IF的值來控制。lNMI:非屏蔽
10、中斷輸入信號。不能用軟件進行屏蔽。lRESET:復位輸入信號,高電平有效。復位的初始狀態見P21lMN/MX:最小最大模式輸入控制信號。第三章 8086指令系統說明:8086指令系統這章為重點章節,對下面列出的指令都要求掌握。第一節 8086尋址方式一、數據尋址方式(重點%)1、立即尋址操作數(為一常數)直接由指令給出 (此操作數稱為立即數)立即尋址只能用于源操作數例:MOV AX, 1C8FHMOV BYTE PTR2A00H, 8FH錯誤例: MOV 2A00H,AX ; 錯誤!指令操作例:MOV AX,3102H; AX3102H執行后,(AH) = 31H,(AL) = 02H2、寄存
11、器尋址(1)操作數放在某個寄存器中(2)源操作數與目的操作數字長要相同(3)寄存器尋址與段地址無關例: MOV AX, BX MOV 3F00H, AX MOV CL, AL錯誤例: MOV AX,BL ; 字長不同 MOV ES:AX,DX ; 寄存器與段無關3、直接尋址(1)指令中直接給出操作數的16位偏移地址偏移地址也稱為有效地址(EA, Effective Address)(2)默認的段寄存器為DS,但也可以顯式地指定其他段寄存器稱為段超越前綴(3)偏移地址也可用符號地址來表示,如ADDR、VAR例:MOV AX ,2A00H MOV DX ,ES:2A00HMOV SI,TABLE_
12、PTR4、間接尋址l操作數的偏移地址(有效地址EA)放在寄存器中l只有SI、DI、BX和BP可作間址寄存器l例: MOV AX,BX MOV CL,CS:DI錯誤例: MOV AX, DX MOV CL, AX5、寄存器相對尋址lEA=間址寄存器的內容加上一個8/16位的位移量l例: MOV AX, BX+8 MOV CX, TABLESI MOV AX, BP; 默認段寄存器為SSl指令操作例:MOV AX,DATABX若(DS)=6000H, (BX)=1000H, DATA=2A00H, (63A00H)=66H, (63A01H)=55H則物理地址 = 60000H + 1000H +
13、 2A00H = 63A00H指令執行后:(AX)=5566H6、基址變址尋址l若操作數的偏移地址:由基址寄存器(BX或BP)給出基址尋址方式由變址寄存器(SI或DI)給出變址尋址方式由一個基址寄存器的內容和一個變址寄存器的內容相加而形成操作數的偏移地址,稱為基址-變址尋址。EA=(BX)+(SI)或(DI);EA=(BP)+(SI)或(DI)同一組內的寄存器不能同時出現。注意:除了有段跨越前綴的情況外,當基址寄存器為BX時,操作數應該存放在數據段DS中,當基址寄存器為BP時,操作數應放在堆棧段SS中。例: MOV AX, BX SI MOV AX, BX+SI MOV AX, DS: BP
14、DI錯誤例: MOV AX, BX BP MOV AX, DI SI指令操作例:MOV AX,BXSI假定:(DS)=8000H, (BX)=2000H, SI=1000H則物理地址 = 80000H + 2000H + 1000H = 83000H指令執行后: (AL)=83000H(AH)=83001H7、相對基址變址尋址l在基址-變址尋址的基礎上再加上一個相對位移量EA=(BX)+(SI)或(DI)+8位或16位位移量;EA=(BP)+(SI)或(DI)+8位或16位位移量指令操作例:MOV AX,DATADIBX若(DS)=8000H, (BX)=2000H, (DI)=1000H,
15、DATA=200H則指令執行后(AH)=83021H, (AL)=83020H寄存器間接、寄存器相對、基址變址、相對基址變址四種尋址方式的比較:尋址方式指令操作數形式n寄存器間接 只有一個寄存器(BX/BP/SI/DI之一)n寄存器相對一個寄存器加上位移量n基址變址 兩個不同類別的寄存器n相對基址-變址 兩個不同類別的寄存器加上位移量二、地址尋址方式(了解有4類,能判斷)簡要判斷依據(指令中間的單詞):段內直接 short,near段內間接 word段間直接 far段間間接 dword第二節 8086指令系統一、數據傳送指令(重點%)1、通用傳送指令(1) MOV dest,src; dest
16、src傳送的是字節還是字取決于指令中涉及的寄存器是8位還是16位。具體來說可實現: MOV mem/reg1,mem/reg2指令中兩操作數中至少有一個為寄存器 MOV reg,data ;立即數送寄存器 MOV mem,data ;立即數送存儲單元 MOV acc,mem ;存儲單元送累加器 MOV mem,acc ;累加器送存儲單元 MOV segreg,mem/reg ;存儲單元/寄存器送段寄存器 MOV mem/reg,segreg ;段寄存器送存儲單元/寄存器MOV指令的使用規則IP不能作目的寄存器不允許memmem不允許segregsegreg立即數不允許作為目的操作數不允許seg
17、reg立即數源操作數與目的操作數類型要一致當源操作數為單字節的立即數,而目的操作數為間址、變址、基址+變址的內存數時,必須用PTR說明數據類型。如:MOV BX,12H 是錯誤的。(2)、堆棧指令什么是堆棧?按“后進先出(LIFO)”方式工作的存儲區域。堆棧以字為單位進行壓入彈出操作。規定由SS指示堆棧段的段基址,堆棧指針SP始終指向堆棧的頂部,SP的初值規定了所用堆棧區的大小。堆棧的最高地址叫棧底。 壓棧指令PUSHPUSH src ; src為16位操作數例:PUSHAX;將AX內容壓棧執行操作:(SP)-1高字節AH(SP)-2低字節AL(SP)(SP)- 2注意進棧方向是高地址向低地址
18、發展。 彈出指令POPPOPdest 例:POP BX;將棧頂內容彈至BX執行操作:(BL)(SP)(BH)(SP)+1(SP)(SP)+2堆棧指令在使用時需注意的幾點: 堆棧操作總是按字進行 不能從棧頂彈出一個字給CS 堆棧指針為SS:SP,SP永遠指向棧頂SP自動進行增減量(-2,+2)(3)、交換指令XCHG格式:XCHG reg,mem/reg功能:交換兩操作數的內容。要求:兩操作數中必須有一個在寄存器中;操作數不能為段寄存器和立即數;源和目地操作數類型要一致。舉例: XCHGAX,BXXCHG2000,CL(4)查表指令XLAT執行的操作:AL(BX)+(AL)又叫查表轉換指令,它可
19、根據表項序號查出表中對應代碼的內容。執行時先將表的首地址(偏移地址)送到BX中,表項序號存于AL中。2、輸入輸出指令只限于用累加器AL或AX來傳送信息。功能: (累加器)I/O端口(1) 輸入指令IN格式:IN acc,PORT ;PORT端口號0255HIN acc,DX ;DX表示的端口范圍達64K例:IN AL,80H ;(AL)(80H端口)IN AL,DX ;(AL)(DX)(2) 輸出指令OUT格式:OUT port,accOUT DX,acc例:OUT 68H,AX ;(69H,68H)(AX)OUT DX,AL ;(DX)(AL)在使用間接尋址的IN/OUT指令時,要事先用傳送
20、指令把I/O端口號設置到DX寄存器如:MOV DX,220HIN AL,DX;將220H端口內容讀入AL3、目標地址傳送指令(1) LEA傳送偏移地址格式:LEA reg,mem ; 將指定內存單元的偏移地址送到指定寄存器要求:1) 源操作數必須是一個存儲器操作數;2) 目的操作數必須是一個16位的通用寄存器。例:LEA BX,SI+10H設:(SI)=1000H則執行該指令后,(BX)=1010Hl注意以下二條指令差別:LEA BX,BUFFER MOV BX,BUFFER前者表示將符號地址為BUFFER的存儲單元的偏移地址取到BX中;后者表示將BUFFER存儲單元中的內容取到BX中。下面兩
21、條指令等效:LEA BX,BUFFERMOV BX, OFFSET BUFFER其中OFFSET BUFFER表示存儲器單元BUFFER的偏移地址。二者都可用于取存儲器單元的偏移地址,但LEA指令可以取動態的地址,OFFSET只能取靜態的地址。二、算術運算指令1、 加法指令(1) 不帶進位的加法指令ADD格式: ADD acc,dataADD mem/reg,dataADD mem/reg1,mem/reg2實例:ADD AL,30HADD SI,BX+20HADD CX,SIADD DI,200HADD指令對6個狀態標志均產生影響。例:已知(BX)=D75FH指令ADD BX,8046H執行
22、后,狀態標志各是多少?D75FH = 1110 0111 0101 11118046H = 1000 0000 0100 01101 1 11 11 0110 0111 1010 0101結果:C=1, Z=0, P=0, A=1, O=1, S=0判斷溢出與進位(重點%)從硬件的角度:默認參與運算的操作數都是有符號數,當兩數的符號位相同,而和的結果相異時有溢出,則OF=1,否則OF=0(2) 帶進位的加法ADCADC指令在形式上和功能上與ADD類似,只是相加時還要包括進位標志CF的內容,例如:ADC AL,68H ;AL(AL)+68H+(CF)ADC AX,CX ;AX(AX)+(CX)+
23、(CF)ADC BX,DI ;BX(BX)+DI+1DI+(CF)(3)加1指令INC格式:INC reg/mem功能:類似于C語言中的+操作:對指定的操作數加1例: INC ALINC SIINC BYTE PTRBX+4注:本指令不影響CF標志。(4)非壓縮BCD碼加法調整指令AAAAAA指令的操作:如果AL的低4位9或AF=1,則: AL(AL)+6,(AH)(AH)+1,AF1 AL高4位清零 CFAF否則AL高4位清零(5)壓縮BCD碼加法調整指令DAAl兩個壓縮BCD碼相加結果在AL中,通過DAA調整得到一個正確的壓縮BCD碼.l指令操作(調整方法):若AL的低4位9或AF=1則(
24、AL)(AL)+6,AF1若AL的高4位9或CF=1則(AL)(AL)+60H,CF1l除OF外,DAA指令影響所有其它標志。lDAA指令應緊跟在ADD或ADC指令之后。2、 減法指令(1)不考慮借位的減法指令SUB格式: SUB dest, src操作: dest(dest)-(src)注:1.源和目的操作數不能同時為存儲器操作數2.立即數不能作為目的操作數指令例子:SUB AL,60HSUB BX+20H,DXSUB AX,CX(2)考慮借位的減法指令SBBSBB指令主要用于多字節的減法。格式: SBB dest, src操作: dest(dest)-(src)-(CF)指令例子:SBB
25、AX,CXSBB WORD PTRSI,2080HSBB SI,DX(3)減1指令DEC作用類似于C語言中的”操作符。格式:DEC opr操作:opr(opr)-1指令例子:DEC CLDEC BYTE PTRDI+2DEC SI (4)求補指令NEG格式: NEG opr操作: opr 0-(opr)對一個操作數取補碼相當于用0減去此操作數,故利用NEG指令可得到負數的絕對值。例:若(AL)=0FCH,則執行 NEG AL后,(AL)=04H,CF=1(5)比較指令CMP格式: CMP dest, src操作: (dest)-(src)CMP也是執行兩個操作數相減,但結果不送目標操作數,其結
26、果只反映在標志位上。指令例子:CMP AL,0AHCMP CX,SICMP DI,BX+03(6)非壓縮BCD碼減法調整指令AAS對AL中由兩個非壓縮的BCD碼相減的結果進行調整。調整操作為:若AL的低4位9或AF=1,則: AL(AL)-6,AH(AH)-1,AF1 AL的高4位清零 CFAF否則:AL的高4位清零(7)壓縮BCD碼減法調整指令DAS對AL中由兩個壓縮BCD碼相減的結果進行調整。調整操作為:若AL的低4位9或AF=1,則:AL(AL)-6, 且AF1若AL的高4位9或CF=1,則:AL(AL)-60H,且CF1DAS對OF無定義,但影響其余標志位。DAS指令要求跟在減法指令之
27、后。3、 乘法指令進行乘法時:8位*8位16位乘積16位*16位32位乘積(1) 無符號數的乘法指令MUL(MEM/REG)格式: MUL src操作:字節操作數 (AX)(AL) (src)字操作數 (DX, AX)(AX) (src)指令例子:MUL BL ;(AL)(BL),乘積在AX中MUL CX ;(AX)(CX),乘積在DX,AX中MUL BYTE PTRBX(2)有符號數乘法指令IMUL格式與MUL指令類似,只是要求兩操作數均為有符號數。指令例子:IMUL BL ;(AX)(AL)(BL)IMUL WORD PTRSI;(DX,AX)(AX)(SI+1SI)注意:MUL/IMUL
28、指令中AL(AX)為隱含的乘數寄存器;AX(DX,AX)為隱含的乘積寄存器; SRC不能為立即數;除CF和OF外,對其它標志位無定義。4、除法指令進行除法時:16位/8位8位商32位/16位16位商對被除數、商及余數存放有如下規定:被除數 商余數字節除法 AXAL AH字除法 DX:AXAXDX(1)無符號數除法指令DIV格式: DIV src操作:字節操作 (AL)(AX) / (SRC) 的商(AH)(AX) / (SRC) 的余數字操作(AX) (DX, AX) / (SRC) 的商(DX) (DX, AX) / (SRC) 的余數指令例子:DIV CLDIV WORD PTRBX(2)
29、有符號數除法指令IDIV格式: IDIV src操作與DIV類似。商及余數均為有符號數,且余數符號總是與被除數符號相同。注意: 對于DIV/IDIV指令AX(DX,AX)為隱含的被除數寄存器。AL(AX)為隱含的商寄存器。AH(DX)為隱含的余數寄存器。src不能為立即數。對所有條件標志位均無定關于除法操作中的字長擴展問題除法運算要求被除數字長是除數字長的兩倍,若不滿足則需對被除數進行擴展,否則產生錯誤。對于無符號數除法擴展,只需將AH或DX清零即可。對有符號數而言,則是符號位的擴展。可使用前面介紹過的符號擴展指令CBW和CWD三、邏輯運算和移位指令1、邏輯運算指令(1)邏輯與AND對兩個操作
30、數進行按位邏輯“與”操作。格式:AND dest, src用途:保留操作數的某幾位,清零其他位。例1:保留AL中低4位,高4位清0。AND AL,0FH(2)邏輯或OR對兩個操作數進行按位邏輯”或”操作。格式:OR dest, src用途:對操作數的某幾位置1;對兩操作數進行組合。例1:把AL中的非壓縮BCD碼變成相應十進制數的ASCII碼。OR AL, 30H(3)邏輯非NOT對操作數進行按位邏輯”非”操作。格式:NOT mem/reg例:NOT CXNOT BYTE PTRDI(4)邏輯異或XOR對兩個操作數按位進行”異或”操作。格式:XOR dest, src用途:對reg清零(自身異或
31、)把reg/mem的某幾位變反(與1異或)例1:把AX寄存器清零。MOV AX,0XOR AX,AXAND AX,0SUB AX,AX(5)測試指令TEST操作與AND指令類似,但不將”與”的結果送回,只影響標志位。TEST指令常用于位測試,與條件轉移指令一起用。例:測試AL的內容是否為負數。 TEST AL,80H ;檢查AL中D7=1? JNZ MINUS ;是1(負數),轉MINUS ;否則為正數2、移位指令(1)非循環移位指令(重點%)算術左移指令SAL(Shift Arithmetic Left)算術右移指令SAR(Shift Arithmetic Right)邏輯左移指令SHL(S
32、hift Left)邏輯右移指令SHR(Shift Right)這4條指令的格式相同,以SAL為例:CL ;移位位數大于1時SAL mem/reg1 ;移位位數等于1時算術移位把操作數看做有符號數;邏輯移位把操作數看做無符號數。移位位數放在CL寄存器中,如果只移1位,也可以直接寫在指令中。例如: MOV CL,4 SHR AL,CL ;AL中的內容右移4位影響C,P,S,Z,O標志。結果未溢出時:左移1位操作數*2右移1位操作數/2例:把AL中的數x乘10因為10=8+2=23+21,所以可用移位實現乘10操作。程序如下:MOV CL,3SAL AL,1 ; 2xMOV AH,AL SAL A
33、L,1 ; 4xSAL AL,1 ; 8xADD AL,AH ; 8x+2x = 10x四、控制轉移指令4、 轉移指令(1)無條件轉移指令JMP 格式:JMP label本指令無條件轉移到指定的目標地址,以執行從該地址開始的程序段。(2)條件轉移指令(補充內容)(重點%)根據單個標志位設置的條件轉移指令JB/JC ;低于,或CF=1,則轉移JNB/JNC/JAE ;高于或等于,或CF=0,則轉移JP/JPE ;奇偶標志PF=1(偶),則轉移JNP/JPO ;奇偶標志PF=0(奇),則轉移JZ/JE ;結果為零(ZF=1),則轉移JNZ/JNE ;結果不為零(ZF=0),則轉移JS ;SF=1,
34、則轉移JNS ;SF=0,則轉移JO ;OF=1,則轉移JNO ;OF=0,則轉移根據組合條件設置的條件轉移指令這類指令主要用來判斷兩個數的大小。判斷無符號數的大小lJA 高于則轉移條件為: CF=0ZF=0,即ABlJNA/JBE 低于或等于則轉移條件為: CF=1ZF=1,即ABlJB AB則轉移lJNB AB則轉移判斷有符號數的大小lJG ;大于則轉移(AB) 條件為:(SFOF=0)ZF=0lJGE;大于或等于則轉移(AB)條件為:(SFOF=0)ZF=1lJLE;小于或等于則轉移(AB)條件為:(SFOF=1)ZF=1lJL;小于則轉移(AB條件為:(SFOF=1)ZF=02、循環控
35、制指令l用在循環程序中以確定是否要繼續循環。l循環次數通常置于CX中。l轉移的目標應在距離本指令-128+127的范圍之內。l循環控制指令不影響標志位。(1)LOOP格式:LOOP label操作:(CX)-1CX;若(CX)0,則轉至label處執行;否則退出循環,執行LOOP后面的指令。LOOP指令與下面的指令段等價: DEC CX JNZ label3、過程調用指令(1)調用指令CALL一般格式:CALLsub ;sub為子程序的入口4、中斷指令(1)INT n 執行類型n的中斷服務程序,N=0255五、處理器控制指令1、標志位操作(1)CF設置指令 CLC0CF STC1CF CMCC
36、F變反(2)DF設置指令 CLD0DF (串操作的指針移動方向從低到高)STD1DF (串操作的指針移動方向從高到低)(3)IF設置指令CLI0IF (禁止INTR中斷)STI1IF (開放INTR中斷)5、 HLT(halt)執行HLT指令后,CPU進入暫停狀態。第四章 8086匯編語言程序設計第一節 偽指令(重點%)CPU指令與偽指令之間的區別:(1)CPU指令是給CPU的命令,在運行時由CPU執行,每條指令對應CPU的一種特定的操作。而偽指令是給匯編程序的命令,在匯編過程中由匯編程序進行處理。(2)匯編以后,每條CPU指令產生一一對應的目標代碼;而偽指令則不產生與之相應的目標代碼。1、數
37、據定義偽指令(1)數據定義偽指令的一般格式為:l變量名 偽指令操作數,操作數 DB 用來定義字節(BYTE)DW 用來定義字(WORD)DD 用來定義雙字(DWORD)(2)操作數的類型可以是:常數或常數表達式l例如:DATA_BYTE DB 10,5,10HDATA_WORD DW 100H,100,-4DATA_DW DD 2*30,0FFFBH可以為字符串(定義字符串最好使用DB)l例如:char1 DB AB可以為變量可以為?號操作符例如:X DB 5,?,6?號只是為了給變量保留相應的存儲單元,而不賦予變量某個確定的初值。重復次數:N DUP(初值,初值)l例如:ZERO DB 2
38、DUP(3,5)XYZ DB 2 DUP(0,2 DUP(1,3),5)在偽操作的操作數字段中若使用$,則表示的是地址計數器的當前值。2、補充內容:(1)類型 PTR 地址表達式例如:MOV BYTE PTR BX,12HINC BYTE PTR BX注意:單操作數指令,當操作數為基址、變址、基+變的時候必須定義3、符號定義偽指令(1)EQU格式:名字 EQU 表達式EQU偽指令將表達式的值賦予一個名字,以后可用這個名字來代替上述表達式。例:CONSTANT EQU 100NEW_PORT EQU PORT_VAL+1(2) =(等號)與EQU類似,但允許重新定義例:EMP=7;值為7EMP=
39、EMP+1;值為8(3)LABELLABEL偽指令的用途是定義標號或變量的類型格式:名字 LABEL 類型變量的類型可以是BYTE,WORD,DWORD。標號的類型可以是NEAR或FAR4、段定義偽指令與段有關的偽指令有:SEGMENT、ENDS、ASSUME、ORG(1)段定義偽指令的格式如下:段名 SEGMENT 定位類型 組合類型 類別段名 ENDSSEGMENT和ENDS 這兩個偽指令總是成對出現,二者前面的段名一致。二者之間的刪節部分,對數據段、附加段及堆棧段,一般是符號、變量定義等偽指令。對于代碼段則是指令及偽指令。此外,還必須明確段和段寄存器的關系,這可由ASSUME語句來實現。
40、(2)ASSUME格式:ASSUME 段寄存器名:段名,段寄存器名:段名,ASSUME偽指令告訴匯編程序,將某一個段寄存器設置為某一個邏輯段址,即明確指出源程序中邏輯段與物理段之間的關系。(3)ORG偽指令ORG規定了段內的起始地址或偏移地址,其格式為:ORG表達式的值即為段內的起始地址或偏移地址,從此地址起連續存放程序或數據。5、匯編程序的一般結構(重點%)(記住)DATA SEGMENTDATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATABGN: MOV AX ,DATA MOV DS,AX .MOV AH,4CHINT 21HCODE ENDSEND B
41、GN第三節 程序設計(3) 順序程序的設計(略)(4) 分支程序的設計典型例題:1 X0Y = 0 X=0-1 X0l程序為:MOV AL ,XCMP AL,0JGE BIGMOV Y,-1JMP EXITBIG:JE EQULMOV Y,1JMP EXIT本章知識要點數制二進制數(B)八進制數(Q)十六進制數(H)十進制數(D)B)碼制帶符號數編碼奇偶校驗碼字符編碼原碼反碼補碼奇校驗碼偶校驗碼ASCII碼BCD碼數字編碼規則字母編碼規則壓縮BCD碼非壓縮BCD碼計算機系統組成計算機系統組成硬件主機外部設備中央處理器(CPU)半導體存儲器控制器運算器ROMRAM輸入設備輸出設備軟件系統軟件應用
42、軟件操作系統:如DOS、Windows、Unix、Linux等其他系統軟件用戶應用軟件其他應用軟件各種計算機語言處理軟件:如匯編、解釋、編譯等軟件EQUL:MOV Y,0EXIT:.(5) 循環程序見講義。l用計數控制循環第一章 計算機基礎知識本章的主要內容為不同進位計數制計數方法、不同進位制數之間相互轉換的方法、數和字符在計算機中的表示方法、簡單的算術運算以及計算機系統的組成。下邊將本章的知識點作了歸類,圖1為本章的知識要點圖,圖1.2為計算機系統組成的示意圖。第二章 8086微處理器本章要從應用角度上理解8086CPU的內部組成、編程結構、引腳信號功能、最小工作模式的系統配置、8086的存
43、儲器組織、基本時序等概念。下面這一章知識的結構圖。本章知識要點Intel 8086微處理器時鐘發生器(8284)地址鎖存器(74LS373、8282)存儲器組織存儲器邏輯分段存儲器分體三總線(DB、AB、CB)時序時鐘周期(T狀態)基本讀總線周期系統配置(最小模式)8086CPU數據收發器(8286、74LS245)邏輯地址物理地址奇地址存儲體(BHE)偶地址存儲體(A0)總線周期指令周期基本寫總線周期復位操作時序中斷響應時序寄存器的復位值執行單元EU(AX、BX、CX、DX、SP、BP、SI、DI、標志寄存器)內部組成總線接口單元BIU(CS、DS、SS、ES、IP)地址/數據控制負責地址B
44、HE/S7、ALE引腳功能(最小模式)地址/狀態數據允許和收發 DEN、DT/R負責讀寫RD、WR、M/IO負責中斷INTR、NMI、INTA負責總線HOLD、HLDA協調CLK、READY、TEST模式選擇MN/MX=5V第三章 8086的指令系統本章重點是8086CPU指令的尋址方式,每條指令的格式、功能及標志的影響;同時還涉及到存儲器單元的物理地址計算、標志位填寫和堆棧操作。下圖為本章知識結構圖。立即數尋址、寄存器尋址、存儲器尋址.操作數尋址方式本章知識要點邏輯地址、物理地址指令功能指令格式對標志位影響填寫標志位堆棧操作(入棧、出棧)堆棧指針(SP)堆棧結構(后進先出)直接尋址立即數尋址
45、寄存器間接尋址寄存器尋址寄存器相對尋址存儲器尋址尋址方式基址變址尋址串操作尋址相對基址變址尋址I/O端口尋址隱含尋址指令功能數據傳送類(通用數據傳送指令、堆棧指令、交換指令、I/O傳送指令、換碼指令、有效地址傳送指令、標志寄存器傳送指令)算術運算類指令(加法指令,減法指令, 乘法指令,除法指令,BCD碼調整指令)邏輯類指令(邏輯運算指令、邏輯移位操作指令)串操作類指令(串傳送、比較、掃描、串存和取指令)控制轉移類指令(條件和無條件轉移、子程序調用和返回指令、子程序調用和返回、中斷)、)處理器控制類指令其他應用軟件用戶應用軟件應用軟件第四章 匯編語言程序設計本章主要內容是匯編語言類別、偽指令語句
46、格式和作用、基本程序結構、調用程序和被調用程序之間數據傳遞途徑以及匯編源程序上機調試過程。本章重點是閱讀程序和編寫程序。下邊是本章的知識結構圖。匯編語言語句類別程序基本結構順序結構本章知識要點實指令語句分支結構循環結構過程(子程序)偽指令語句宏指令語句參數傳遞途徑寄存器約定存儲器約定堆棧傳遞程序開發步驟:編 輯匯 編鏈 接調試運行符號定義偽指令 EQU、=偽指令語句數據定義偽指令 DB、DW、DD段定義偽指令 SEGMENTENDS過程定義偽指令 PROC、ENDP段指派偽指令 ASSUME程序定位偽指令 ORG匯編結束偽指令 END其他偽指令.第五章 半導體存儲器半導體存儲器是用半導體器件作
47、為存儲介質的存儲器。本章討論半導體存儲器芯片的類型、存儲原理、引腳功能、如何與CPU(或系統總線)連接等問題。本章知識結構圖如下。只存放二進制數存放程序和數據SRAMRAMDRAM存儲器作用本章知識要點掩模ROM半導體存儲器芯片分類PROMROM線譯碼部分譯碼與系統連接地址分配、片選邏輯、控制選擇全譯碼計算芯片數主存儲器設計引腳功能存儲容量存儲器芯片EEROMEPROMPROM第六章 輸入輸出接口本章討論輸入/輸出接口的基本概念,包括輸入/輸出接口的作用、內部結構、傳送信息的分析、IO端口編址以及主機通過接口與外設之間數據傳送的方式。下邊是本章的知識結構圖。IO接口概念主機通過接口與外設數據傳送方式本章知識要點接口作用接口傳送信息的種類IO端口數據傳送方式程序控制方式控制信息狀態信息數據信息(開關量、脈沖量、數據量、模擬量)IO端口編址方式單獨編址統一編址IO端口號簡單的I/O芯片的使用中斷控制方式直接存儲器存取控制方式(DMA)無條件傳送有條件傳送(查詢)第七章 中斷與中斷控制器本章主要內容:中斷的
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 工程運輸分包合同范本
- 改造陽臺施工合同范本
- 機構合作伙伴合同范本
- 單位幫員工買社保協議書
- 司機學生乘車安全協議書
- 房屋出租解除合同范本
- 土地租賃合同免責協議書
- 借用公司名義合作協議書
- 母子之間天價賠償協議書
- 公司加工業務轉讓協議書
- 雇人包工免責協議書
- 2025屆高三5月份全國各地聯考文言文閱讀分類匯編(解析版)
- 土建項目分包協議書
- 吐魯番市高昌區招聘社區工作者考試真題2024
- 山東省濟南市2025屆高三三模歷史試卷(含答案)
- 2025年中考道法答題技巧與模板構建專題08主觀題答題技巧(觀點概括類試)(學生版+解析)
- 2024-2025學年廣東省深圳市高一數學下學期7月期末考試(附答案)
- “教-學-評”一體化下初中英語寫作教學評價措施
- 2025團員考試試題及答案
- 2025年軟件測試工程師考試題及答案
- 血管內導管相關性血流感染預防與診治指南(2025)解讀課件
評論
0/150
提交評論