在執(zhí)行程序及產(chǎn)生中斷時(shí)CPU內(nèi)會(huì)發(fā)生什么變化?資料下載
2021-04-04 |
pdf |
311.96KB |
次下載 |
2積分
資料介紹
上期我們已經(jīng)學(xué)習(xí)了將程序放在地址空間中,并在向量表中顯示保存位置的內(nèi)容。本期將介紹在執(zhí)行程序及產(chǎn)生中斷時(shí)CPU內(nèi)會(huì)發(fā)生什么變化。
引導(dǎo)程序的運(yùn)行―程序計(jì)數(shù)器
一般來說,程序就是計(jì)算機(jī)將所要進(jìn)行的處理按順序排列的指令集。在單片機(jī)中,將程序保存在地址空間(存儲(chǔ)器 空間)中(上期曾介紹過),并由CPU來執(zhí)行(處理)指令。假設(shè)地址空間中的一個(gè)地址保存一條指令,先執(zhí)行某個(gè)地址中的指令(如“將值置位到CPU中”處理),接著執(zhí)行下一個(gè)地址中的指令,接下來再執(zhí)行下一個(gè)地址中的指令……,像這樣通過連續(xù)執(zhí)行指令,便可執(zhí)行程序。
那么,CPU是如何判斷執(zhí)行指令的順序呢?在單片機(jī)中,程序被執(zhí)行的時(shí)候“程序計(jì)數(shù)器(PC)”的值也同時(shí)被更新。存放在CPU內(nèi)的指令地址中,程序計(jì)數(shù)器存儲(chǔ)有下一條CPU將要執(zhí)行的指令所在的地址。執(zhí)行了某個(gè)地址的指令后,下一個(gè)該執(zhí)行哪個(gè)地址中的指令呢?這個(gè)答案由程序計(jì)數(shù)器來告訴你。
一般來說,程序被保存在連續(xù)的地址中, 再由CPU按順序執(zhí)行存放在各個(gè)地址中的指令。圖1為程序計(jì)數(shù)器的示意圖。圖中,假定(1)執(zhí)行地址1000h中的指令,(2)執(zhí)行地址1000h中的指令后,程序計(jì)數(shù)器的値自動(dòng)增加一個(gè)量并顯示出下一個(gè)地址1001h,接下來,(3)CPU執(zhí)行地址1001h中的指令。
圖1:程序計(jì)數(shù)器
那么,CPU執(zhí)行最初的指 令時(shí)是一種什么狀況呢?單片機(jī)在接通電源或是復(fù)位時(shí),如上期所說明的,保存在向量表的復(fù)位地址中的値(程序的起始地址)將被轉(zhuǎn)移到程序計(jì)數(shù)器中,該地址中的指令便得到執(zhí)行(請(qǐng)參照上期的圖2)。
?關(guān)于地址空間及向量表的內(nèi)容,請(qǐng)參照本系列的第五期:
改變程序的運(yùn)行路徑―轉(zhuǎn)移指令
編寫程序時(shí),在執(zhí)行完某個(gè)指令的處理后有時(shí)必須先執(zhí)行保存“(非連續(xù))的下一個(gè)地址”中的指令。此時(shí),程序計(jì)數(shù)器的值將被改寫,而所用的指令被稱為“轉(zhuǎn)移指令”。
圖2所示是轉(zhuǎn)移指令的示意圖。圖2示例中,(1)地址1000h中存放有轉(zhuǎn)移指令,即將(2)程序計(jì)數(shù)器的值改寫為下一個(gè)應(yīng)執(zhí)行的地址 (1100h)的指令。即CPU執(zhí)行完1000h地址的指令(轉(zhuǎn)移指令)后,接下來不是執(zhí)行1001h地址的指令,而是執(zhí)行(3)1100h地址的指令。
圖2:轉(zhuǎn)移指令
另外,在轉(zhuǎn)移指令中,能夠利用“從當(dāng)前的程序計(jì)數(shù)器的值向前(更大的地址)/向后(更小的地址)移動(dòng)”的方法來設(shè)定程序計(jì)數(shù)器的值 。
信息的暫時(shí)存放處―堆棧
執(zhí)行程序時(shí),在運(yùn)算過程中僅僅依靠CPU內(nèi)的數(shù)據(jù)保存位置(CPU內(nèi)部寄存器)是不夠的,有時(shí)需在主存儲(chǔ)器中暫時(shí)存放信息。這種信息的暫時(shí)存放位置被稱為“堆?!?而存放“下一個(gè)(暫時(shí))存放的信息地址”的就是“堆棧指針(SP)”。如果一開始就設(shè)定好堆棧的地址,那么堆棧指針將自動(dòng)更新,且總是指示“下一個(gè)(暫時(shí))存放的信息地址”。
?CPU內(nèi)部寄存器等單片機(jī)的結(jié)構(gòu)請(qǐng)參照。
如果執(zhí)行“將該信息存放(有時(shí)也用 “堆積”)在堆棧”的指令,那么被指定的信息將會(huì)被寫入堆棧指針?biāo)付ǖ牡刂分?,且堆棧指針的值也將被更新為新的地址(一般為一個(gè)小地址)。該情形如圖3所示。如果(1)CPU將信息存放在堆棧指針?biāo)傅牡刂分?,則(2)堆棧指針的値將被更新,然后(3)堆棧指針指向下一個(gè)存放信息的位置。
圖3:將信息存放在堆棧中"
將存放在堆棧中的信息返回CPU時(shí),也將用到堆棧指針。圖4所示的是將信息返回時(shí)的情形。(1)更新堆棧指針的値(更新為 一個(gè)大的地址),(2)將暫時(shí)存放在堆棧中的信息返送回CPU。此時(shí),(3)堆棧指針指向下一個(gè)寫入地址(先前將信息返回CPU后空出的地址)。
圖4:將信息從堆棧返回
但是堆棧中并非可無限制地保存信息。由于堆棧能使用的范圍僅限于可改寫的被稱為RAM的存儲(chǔ)器。如果信息存放量過多而導(dǎo)致堆棧超出了RAM的區(qū)域,程序?qū)o法正常運(yùn)行。
理解中斷處理
本期是《活學(xué)活用單片機(jī)基礎(chǔ)篇 學(xué)習(xí)“外設(shè)功能”》系列的最后一期。下面我們將以前介紹過的內(nèi)容進(jìn)行一個(gè)總結(jié),并以此來理解單片機(jī)是如何運(yùn)行(處理)的。
我們將以發(fā)生中斷時(shí)的處理為例來進(jìn)行思考(圖5)。中斷處理就是指在執(zhí)行某個(gè)程序的過程中,由于某種原因(產(chǎn)生中斷)而導(dǎo)致開始執(zhí)行完全不同的程序。我們以來自外設(shè)功能之一的獨(dú)立的看門狗計(jì)時(shí)器(WDT、所謂的Watch Dog即看門狗的意思)的中斷為例來進(jìn)行分析。在程序正常運(yùn)行時(shí)獨(dú)立的看門狗定時(shí)器將什么也不做,但是在程序失去控制,且沒有按必要的步驟進(jìn)行處理時(shí)就會(huì)產(chǎn)生中斷。使失去控制的程序停下并讓系統(tǒng)穩(wěn)定停止的處理是由通過中斷開始的程序來執(zhí)行的。中斷處理的流程請(qǐng)參照本系列第四期《中斷功能》的圖2。
?關(guān)于中斷的結(jié)構(gòu)和處理流程請(qǐng)參照本系列第四期的內(nèi)容。
?關(guān)于看門狗定時(shí)器請(qǐng)參照本系列的第二期的內(nèi)容。
圖5:中斷處理的流程
1、首先,在產(chǎn)生中斷時(shí),必須使運(yùn)行中的程序入棧。
2、在中斷處理 “入?!睍r(shí),將信息存放在堆棧指針指向的地址(堆棧)中。進(jìn)行中斷處理時(shí)存放在堆棧中的信息就是正 在執(zhí)行的原先的程序(被中斷的程序)時(shí)的程序計(jì)數(shù)器的值,即原先的程序執(zhí)行到哪一步的信息(地址)。另外,顯示CPU內(nèi)部狀態(tài)的信息和暫時(shí)保存的值也存放 在堆棧中。
3、如果CPU內(nèi)部的信息存放在堆棧中且完成“交付”準(zhǔn)備(入棧)后,將執(zhí)行中斷程序。中斷程序與正在執(zhí)行的程序不同且所保 存的地址空間也不同,所以程序計(jì)數(shù)器的值與原先程序也完全不同。中斷程序的起始位置將被寫入向量表中。起始位置該寫在向量表中的哪一項(xiàng)取決于所產(chǎn)生 的中斷。
例如,如果存在不可屏蔽中斷(NMI,即CPU不能屏蔽的中斷),那就從寫有NMI項(xiàng)的地址開始進(jìn)行處理(請(qǐng)參照本系列第五期《程序設(shè)計(jì)(上)》的圖 2及圖3)。
?使用向量表進(jìn)行處理的流程在本系列的第五期中進(jìn)行解說。
4、如上所述,向量表的NMI項(xiàng)中的值(地址)將轉(zhuǎn)移到程序計(jì)數(shù)器中, 并從該處開始執(zhí)行。此外,如將數(shù)值設(shè)為0而產(chǎn)生錯(cuò)誤時(shí),或者欲存取到無存儲(chǔ)器的位置時(shí),CPU本身將產(chǎn)生中斷并從向量表中讀取開始處理的地址。此例中, 由于在檢測到程序失控時(shí)是通過獨(dú)立的看門狗定時(shí)器進(jìn)行中斷處理的,所以中斷程序?qū)⑹瓜到y(tǒng)停止下來。
5、如為一般的周期性中斷,那么,中斷處理一結(jié)束,且在入棧時(shí)將存放在堆棧中的“執(zhí)行原先執(zhí)行程序時(shí)的信息”返回到CPU。最后返回程序計(jì)數(shù)器的值,并結(jié)束從中斷返回的處理“出棧”。
開始中斷程序時(shí),通過來自外部的信號(hào)或從CPU本身發(fā)出的指令來開始入棧。出棧時(shí)使用“來自中斷的出棧指令”,因此編程人員無需考慮“堆棧 中存放有什么信息又是按什么順序來存放的?”等問題,僅需一條指令便可進(jìn)行出棧處理。
結(jié)合上期《程序設(shè)計(jì)(上)》的內(nèi)容,從執(zhí)行程序的觀點(diǎn)來分析 ,本期對(duì)于CPU中到底產(chǎn)生了什么變化進(jìn)行了說明。程序存放在地址空間中,且在向量表中保存有起始地址,而且還有將信息暫時(shí)存放的被稱為堆棧的內(nèi)容等 等……,在進(jìn)行嵌入式編程時(shí),必須同時(shí)考慮這些內(nèi)部動(dòng)作后再進(jìn)行編程。如果可通過程序?qū)τ诟?xì)微的部分發(fā)出指示,且能發(fā)揮出該單片機(jī)的能力的話,編程將變得更加容易。
本系列共分6期,本期為最后一期。盡管每一期都只介紹非常基礎(chǔ)的內(nèi)容,對(duì)于那些內(nèi)容,我們也盡量做到即使對(duì)于完全不具備相關(guān)知識(shí)的讀者也能看得懂。所以,請(qǐng)您也反復(fù)閱讀,我們相信您一定會(huì)完全理解其內(nèi)容的。?
(mbbeetchina)
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 中斷服務(wù)子程序是如何被執(zhí)行的 ?
- 單片機(jī)中斷系統(tǒng)(51為例)
- C51教程 第四個(gè)51程序:中斷控制--外部中斷0
- 探討高頻高速信號(hào)線在PCB的板邊時(shí)會(huì)發(fā)生什么情況?資料下載
- 32位CPU中執(zhí)行單元總體結(jié)構(gòu)資料下載
- 使用C51實(shí)現(xiàn)單片機(jī)中斷的資料和程序講解
- 單片機(jī)中斷的基本概念及中斷系統(tǒng)有什么優(yōu)點(diǎn)
- 51單片機(jī)的中斷系統(tǒng)詳細(xì)資料概述
- 51單片機(jī)中斷的資料和使用程序免費(fèi)下載
- 51單片機(jī)中斷系統(tǒng)的詳細(xì)資料和程序免費(fèi)下載
- 使用單片機(jī)進(jìn)行中斷的應(yīng)用資料和程序免費(fèi)下載
- Setup軟件安裝可執(zhí)行程序工具免費(fèi)下載 11次下載
- LED燈中斷C語言程序資料免費(fèi)下載 8次下載
- PLL電路的研究及在信號(hào)產(chǎn)生中的應(yīng)用資料 16次下載
- DDS在二相碼產(chǎn)生中的應(yīng)用
- 軟硬件交互的角度將中斷的知識(shí)梳理 2104次閱讀
- PLC中斷的概念 2245次閱讀
- 中斷指令及程序的講解 5077次閱讀
- 在標(biāo)準(zhǔn)C語言中編譯出來的可執(zhí)行程序 1934次閱讀
- 鴻蒙內(nèi)核源碼分析:引起中斷的事件或原因 1902次閱讀
- ARM異常中斷的原因及處理措施 8162次閱讀
- 單片機(jī)的中斷程序如何運(yùn)行 1.1w次閱讀
- 在處理PIC單片機(jī)的中斷服務(wù)程序時(shí)需要注意哪些問題 2688次閱讀
- 探究硬中斷和軟中斷的原理和區(qū)別 1w次閱讀
- 淺析硬中斷和軟中斷的區(qū)別 5596次閱讀
- 中斷的含義是什么?如何設(shè)置ARM處理器的中斷? 7496次閱讀
- MM32如何使用比較器產(chǎn)生中斷 8142次閱讀
- 單片機(jī)中斷系統(tǒng)介紹_51單片機(jī)中斷系統(tǒng)結(jié)構(gòu) 1.2w次閱讀
- ZedBoard之中斷原理及過程詳解 4842次閱讀
- 單片機(jī)與程序設(shè)計(jì)(下) 2919次閱讀
下載排行
本周
- 1EMC電路設(shè)計(jì)工程師必備的EMC基礎(chǔ)
- 0.42 MB | 4次下載 | 2 積分
- 2AU3116 2×60W模擬輸入雙通道Class-D 音頻功率放大器數(shù)據(jù)手冊
- 1.19 MB | 1次下載 | 免費(fèi)
- 3低壓降肖特基整流管SR340L數(shù)據(jù)手冊
- 0.78 MB | 1次下載 | 免費(fèi)
- 4ZX8002E 觸摸調(diào)光LED集成IC數(shù)據(jù)手冊
- 2.27 MB | 次下載 | 免費(fèi)
- 5SOD-323塑料封裝ESD保護(hù)二極管SD05T系列規(guī)格書
- 1.07 MB | 次下載 | 免費(fèi)
- 6SOT-23塑料封裝ESD保護(hù)二極管SMxx Series系列規(guī)格書
- 0.93 MB | 次下載 | 免費(fèi)
- 7高效率整流二極管HER151 THRU HER158數(shù)據(jù)手冊
- 0.54 MB | 次下載 | 免費(fèi)
- 8低壓降肖特基整流管SL22 THRU SL210數(shù)據(jù)手冊
- 1.03 MB | 次下載 | 免費(fèi)
本月
- 1三相逆變主電路的原理圖和PCB資料合集免費(fèi)下載
- 27.35 MB | 111次下載 | 1 積分
- 2運(yùn)算放大器基本電路中文資料
- 1.30 MB | 16次下載 | 免費(fèi)
- 3蘋果iphone 11電路原理圖
- 4.98 MB | 11次下載 | 5 積分
- 4TL494工業(yè)用開關(guān)電源原理圖資料
- 0.22 MB | 10次下載 | 1 積分
- 5常用電子元器件介紹
- 3.21 MB | 8次下載 | 免費(fèi)
- 6QW2893應(yīng)急燈專用檢測芯片
- 590.40 KB | 4次下載 | 免費(fèi)
- 7相關(guān)協(xié)議信號(hào)總結(jié)
- 0.94 MB | 4次下載 | 免費(fèi)
- 8EMC電路設(shè)計(jì)工程師必備的EMC基礎(chǔ)
- 0.42 MB | 4次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935130次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191390次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183344次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81591次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評(píng)論