版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、2020/7/25,3.5 CPU與CPU寄存器,3.5.1 本單元的目標(biāo),1)明白CPU的工作原理 2)知道CPU包含那些寄存器 3)掌握每個(gè)寄存器的功能及訪問(wèn)方式 4)了解與各個(gè)寄存器相關(guān)的一些指令,3.5.2 CPU組成部分,CPU Control 控制單元(調(diào)度中心),ALU 運(yùn)算單元(加工車(chē)間),CPU Register CPU寄存器(倉(cāng)庫(kù)),3.5.3 CPU的工作原理炒飯,一盤(pán)揚(yáng)州炒飯是如何做出來(lái)的?,3.5.3 CPU的工作原理炒飯,主料: 青豆、胡蘿卜、火腿、雞蛋、米飯(最好是隔夜飯)、蒜籽、蔥; 調(diào)料 色拉油、鹽、雞精 ;,3.5.3 CPU的工作原理炒飯,制作: 1、首先
2、將胡蘿卜、火腿洗凈切成小丁塊狀,越小越好,當(dāng)然了不能切成沫狀。再將輔料洗凈切成沫狀,將雞蛋攪碎放入少許蔥沫在內(nèi)。 2、將鍋內(nèi)放上少許色拉油加至8成熱,將切好的主料,同時(shí)也放入切好的蒜沫,放入鍋里炒拌,炒到可以聞到香味時(shí)(此過(guò)程只需幾秒鐘)再將雞蛋放入鍋內(nèi)炒拌,(這時(shí)需加大火候,這樣雞蛋會(huì)很松軟,也不易炒糊),當(dāng)雞蛋炒至金黃色時(shí),將其裝盤(pán)。 3、再放入少許色拉油加熱至八成,將米飯放入鍋內(nèi)翻抄。此時(shí),需將飯中加放少許食鹽和雞精,(雞精不宜放太多,否則太鮮也不好吃)當(dāng)米飯炒到在鍋里可以蹦起飯粒時(shí),再將剛才炒好的主料及輔料全部返鍋炒拌,直到飯粒松軟不粘為起鍋?zhàn)罴褧r(shí)間。,3.5.3 CPU的工作原理炒飯
3、,做一盤(pán)揚(yáng)州炒飯的大概過(guò)程: 1)廚房中事先準(zhǔn)備好了做各種菜式的各種配料; 2)廚師從所有的配料中選擇炒飯需要的配料; 3)廚師把挑選的配料按照一定的時(shí)間順序放到鍋里,然后廚師利用他高超的廚藝炒出美味的炒飯; 4)廚師把做好的炒飯裝在盤(pán)中。,3.5.3 CPU的工作原理工廠加工,工廠的加工過(guò)程 1)準(zhǔn)備好加工產(chǎn)品的各種原材料; 2)物資調(diào)配部分對(duì)各種原材料進(jìn)行調(diào)度分配,把它們送到生產(chǎn)線; 3)生產(chǎn)線對(duì)各種原材料進(jìn)行加工,生產(chǎn)出成品; 4)生產(chǎn)出來(lái)的成品被送到倉(cāng)庫(kù)中存儲(chǔ)。,3.5.3 CPU的工作原理,CPU的工作原理: 1)單片機(jī)運(yùn)行后,CPU控制單元從存儲(chǔ)器中提取指令; 2)控制單元把指令送
4、到邏輯算術(shù)運(yùn)算單元中; 3)邏輯算術(shù)運(yùn)算單元對(duì)這些指令進(jìn)行處理,得到相應(yīng)的數(shù)據(jù); 4)控制單元再把運(yùn)算單元處理后的數(shù)據(jù)存儲(chǔ)到存儲(chǔ)器中。,3.5.3 CPU的工作原理:23,CPU如何處理23?,3.5.4.1 CPU內(nèi)部寄存器,五個(gè)內(nèi)部寄存器 A、H:X 、SP、PC、CCR,3.5.4.1 CPU內(nèi)部寄存器:A,累加器A(Accumulator):8位寄存器 作用大,被訪問(wèn)的頻率高 主要作用: 存放CPU的操作數(shù) 保存運(yùn)算的結(jié)果,3.5.4.1 A作用1:存放操作數(shù),有些直接操作累加器A的單目指令,或者一些不是直接操作累加器A的雙目指令,需要把操作數(shù)先存放在A中。 例1:?jiǎn)文恐噶?LDA #
5、%00000011 ;(A)=#% 00000011 LSLA ;(A)=#%00000110 例2:雙目指令 LDA #1T ;(A)=#1T ADD #2T ;(A)=#3T,實(shí)例程序:cpu_demo_累加器A,3.5.4.1 A作用2:保存結(jié)果,累加器A還可以保存計(jì)算的結(jié)果 例3:加法中保存結(jié)果 LDA #1T ;(A)=#1T ADD #2T ;(A)=#3T 例4:乘法中保存乘積的低八位(高八位存在X中) LDX #2T LDA #3T ;(A)=#3T MUL ;(A)=#6T,實(shí)例程序:cpu_demo_累加器A,3.5.4.1 與A有關(guān)的常用指令,CLRA LDA STA,A
6、DD SUB MUL INCA DECA CMP,3.5.4.2 CPU內(nèi)部寄存器:變址寄存器,變址寄存器(Index register):由H和X兩個(gè)8位寄存器構(gòu)成的16位寄存器,標(biāo)志為H:X,H為高八位,X為低八位。,主要作用: H:X用于64KB存儲(chǔ)空間尋址 暫存數(shù)據(jù)和計(jì)算結(jié)果,3.5.4.2 存儲(chǔ)空間尋址,例5:變址尋址 CLR $8F ;($8F)=0 LDHX #$008F ;(X)=#$8F LDA ,X ;(A)=(#$8F),實(shí)例程序:cpu_demo_變址寄存器,3.5.4.2 存放計(jì)算結(jié)果,例6:8位乘法運(yùn)算中存放結(jié)果的高8位 已知:$31 * $6 = $126 LDX
7、 #$31;(X)=#$31 LDA #$06 MUL;(X)=#$01,實(shí)例程序:cpu_demo_變址寄存器,3.5.4.2 與H:X相關(guān)的常用指令,CLRX CLRH LDX STX LDHX STHX TAX TXA TXS,INCX DECX AIX MUL CPX CPHX TSTX,3.5.4.3 CPU內(nèi)部寄存器:PC,程序計(jì)數(shù)器(Program Pointer):16位寄存器,指向存放下一個(gè)指令或預(yù)取操作數(shù)的地址,指令碼或操作數(shù)預(yù)取后,PC地址會(huì)自動(dòng)增量指向下一個(gè)。“先取后增”。,復(fù)位后,自動(dòng)裝入$FFFE(高位)和$FFFF(低位)中的值作為程序入口,即$FFFE和$FFF
8、F存放的為地址,非操作碼。,運(yùn)行實(shí)際的程序,看PC如何變化,3.5.4.4 CPU內(nèi)部寄存器:CCR,條件碼寄存器(Condition Code Register):8位寄存器:5個(gè)狀態(tài)位、1個(gè)中斷屏蔽位,兩個(gè)未用置1,實(shí)例 cpu_demo_條件碼寄存器CCR, 演示各個(gè)狀態(tài)的變化,3.5.4.4 CCR中各位狀態(tài)的改變1,;在AC16中,復(fù)位時(shí),禁止中斷,I=1, CCR的初始狀態(tài)為:V=0,H=0,I=1,N=0,Z=0,C=0 LDA #$80 ;V=0,H=0,I=1,N=1,Z=0,C=0 ;裝入一個(gè)負(fù)數(shù),N=1 NEGA ;V=1,H=0,I=1,N=1,Z=0,C=1 ;0-(
9、A)=0-(-128)=128,一個(gè)8位的有符號(hào)數(shù)所能表示的范圍:-128127,128超出能表示的范圍,故溢出,V=1 CLRA ;V=0,H=0,I=1,N=0,Z=1,C=1 ;將累加器中的值清零,故Z=1,條件碼寄存器中各位的狀態(tài)會(huì)受到多種指令操作的影響。,3.5.4.4 CCR中各位狀態(tài)的改變2,LDA #%00001000 ;V=0,H=0,I=1,N=0,Z=0,C=1 ADD #%00001001 ;V=0,H=1,I=1,N=0,Z=0,C=0 ;#%00001000 + #%00001001 = #%00010001 ;3位向4位進(jìn)位,故H=1 CLI ;V=0,H=1,I
10、=0,N=0,Z=0,C=0 ;開(kāi)中斷,不再禁止中斷,故I=0 LDA #3T SUB #4T ;V=0,H=1,I=0,N=1,Z=0,C=1 ;3 - 4 = -1,結(jié)果為負(fù)數(shù),且有借位,故N=1,C=1,3.5.4.4 利用CCR中的標(biāo)志進(jìn)行跳轉(zhuǎn),預(yù)備知識(shí):邏輯左移指令LSLA,0,A,C,3.5.4.4 利用CCR中的標(biāo)志進(jìn)行跳轉(zhuǎn),程序中也往往會(huì)根據(jù)各個(gè)狀態(tài)位的狀態(tài)作出適當(dāng)?shù)奶D(zhuǎn)。 例7: LDA #%01000010 ;(A)#%01000000 LSLA ;把A中的值左移1位,移出的值放在標(biāo) ;志C中.移位后(A)=#%10000100,C=0 BCS C_High ;如果C=1,
11、則轉(zhuǎn)到標(biāo)志C_High ;所在的位置 C_Low: MOV #0T, Var LSLA ;移位后(A)=#%000001000,C=1 BCS C_High BRA C_Low ;轉(zhuǎn)移到標(biāo)志C_Low所在的位置 C_High: MOV #1T, Var,3.5.4.4 利用CCR中的標(biāo)志進(jìn)行跳轉(zhuǎn),程序中也往往會(huì)根據(jù)各個(gè)狀態(tài)位的狀態(tài)作出適當(dāng)?shù)奶D(zhuǎn)。 例7: LDA #%01000010 LSLA BCS C_High C_Low: MOV #0T,Var LSLA BCS C_High BRA C_Low C_High: MOV #1T,Var,LDA,LSLA,LSLA,C=1?,C=1?,3.5.4.4 直接操作CCR的指
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 沈陽(yáng)高中語(yǔ)文試題及答案
- 融媒體招聘考試試題及答案
- 輔警入警培訓(xùn)課件模板
- 輔助生殖技術(shù)176號(hào)文件
- 《GAT 1400.2-2017公安視頻圖像信息應(yīng)用系統(tǒng) 第2部分:應(yīng)用平臺(tái)技術(shù)要求》專(zhuān)題研究報(bào)告
- 2026 年初中英語(yǔ)《形容詞》專(zhuān)項(xiàng)練習(xí)與答案 (100 題)
- 《GAT 167-2019法醫(yī)學(xué) 中毒尸體檢驗(yàn)規(guī)范》專(zhuān)題研究報(bào)告
- 2026年深圳中考英語(yǔ)拔尖培優(yōu)特訓(xùn)試卷(附答案可下載)
- 2026年大學(xué)大二(交通運(yùn)輸)交通規(guī)劃理論階段測(cè)試試題及答案
- 2026年深圳中考數(shù)學(xué)沖刺實(shí)驗(yàn)班專(zhuān)項(xiàng)試卷(附答案可下載)
- 安全監(jiān)理生產(chǎn)責(zé)任制度
- 2026年云南保山電力股份有限公司校園招聘(50人)考試參考試題及答案解析
- 2026年云南保山電力股份有限公司校園招聘(50人)筆試備考題庫(kù)及答案解析
- 網(wǎng)絡(luò)輿情態(tài)勢(shì)感知系統(tǒng)-洞察分析
- 高思導(dǎo)引3-6年級(jí)分類(lèi)題目-數(shù)字謎02-三下02-簡(jiǎn)單乘除法豎式
- 情侶自愿轉(zhuǎn)賬贈(zèng)與協(xié)議書(shū)范本
- 2024-2030年中國(guó)異辛烷行業(yè)市場(chǎng)發(fā)展趨勢(shì)與前景展望戰(zhàn)略分析報(bào)告
- 力士樂(lè)液壓培訓(xùn)教材
- JJG 692-2010無(wú)創(chuàng)自動(dòng)測(cè)量血壓計(jì)
- 人教版四年級(jí)數(shù)學(xué)下冊(cè)第四單元大單元教學(xué)任務(wù)單
- 旋挖鉆孔灌注樁施工記錄表(新)
評(píng)論
0/150
提交評(píng)論