0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

單片機執(zhí)行指令過程詳解

GReq_mcu168 ? 來源:lq ? 2019-02-15 09:53 ? 次閱讀

單片機執(zhí)行指令過程詳解

單片機執(zhí)行程序的過程,實際上就是執(zhí)行我們所編制程序的過程。即逐條指令的過程。計算機每執(zhí)行一條指令都可分為三個階段進行。即取指令-----分析指令-----執(zhí)行指令。

取指令的任務是:根據程序計數(shù)器PC中的值從程序存儲器讀出現(xiàn)行指令,送到指令寄存器。

分析指令階段的任務是:將指令寄存器中的指令操作碼取出后進行譯碼,分析其指令性質。如指令要求操作數(shù),則尋找操作數(shù)地址。

計算機執(zhí)行程序的過程實際上就是逐條指令地重復上述操作過程,直至遇到停機指令可循環(huán)等待指令。

一般計算機進行工作時,首先要通過外部設備把程序和數(shù)據通過輸入接口電路和數(shù)據總線送入到存儲器,然后逐條取出執(zhí)行。但單片機中的程序一般事先我們都已通過寫入器固化在片內或片外程序存儲器中。因而一開機即可執(zhí)行指令。

下面我們將舉個實例來說明指令的執(zhí)行過程:

開機時,程序計算器PC變?yōu)?000H。然后單片機在時序電路作用下自動進入執(zhí)行程序過程。執(zhí)行過程實際上就是取出指令(取出存儲器中事先存放的指令階段)和執(zhí)行指令(分析和執(zhí)行指令)的循環(huán)過程。

例如執(zhí)行指令:MOV A,#0E0H,其機器碼為“74H E0H”,該指令的功能是把操作數(shù)E0H送入累加器,0000H單元中已存放74H,0001H單元中已存放E0H。當單片機開始運行時,首先是進入取指階段,其次序是:

1 程序計數(shù)器的內容(這時是0000H)送到地址寄存器;

2 程序計數(shù)器的內容自動加1(變?yōu)?001H);

3 地址寄存器的內容(0000H)通過內部地址總線送到存儲器,以存儲器中地址譯碼電跟,使地址為0000H的單元被選中;

4 CPU使讀控制線有效;

5 在讀命令控制下被選中存儲器單元的內容(此時應為74H)送到內部數(shù)據總線上,因為是取指階段,所以該內容通過數(shù)據總線被送到指令寄存器。

至此,取指階段完成,進入譯碼分析和執(zhí)行指令階段。

由于本次進入指令寄存器中的內容是74H(操作碼),以譯碼器譯碼后單片機就會知道該指令是要將一個數(shù)送到A累加器,而該數(shù)是在這個代碼的下一個存儲單元。所以,執(zhí)行該指令還必須把數(shù)據(E0H)從存儲器中取出送到CPU,即還要在存儲器中取第二個字節(jié)。其過程與取指階段很相似,只是此時PC已為0001H。指令譯碼器結合時序部件,產生74H操作碼的微操作系列,使數(shù)字E0H從0001H單元取出。

因為指令是要求把取得的數(shù)送到A累加器,所以取出的數(shù)字經內部數(shù)據總線進入A累加器,而不是進入指令寄存器。至此,一條指令的執(zhí)行完畢。單片機中PC=0002H,PC在CPU每次向存儲器取指或取數(shù)時自動加1,單片機又進入下一取指階段。這一過程一直重復下去,直至收到暫停指令或循環(huán)等待指令暫停。CPU就是這樣一條一條地執(zhí)行指令,完成所有規(guī)定的功能。

對于一款mcu來說,在性能描述的時候都會告訴sram,flash的容量大小,對于初學者來說,也不會去考慮和理會這些東西,拿到東西就只用。其實不然,這些量都是十分重要的,仔細想想,代碼為什么可以運行,代碼量是多少,定義的int、short等等類型的變量究竟是怎么分配和存儲的,這些問題都和內寸有關系。

首先單片機的內存可以大小分為ram和rom,這里就不再解釋ram和rom的區(qū)別了,我們可以將其等效為flash和sram,其中根據flash和sram的定義可得,flash里面的數(shù)據掉電可保存,sram中的并不可以,但是sram的執(zhí)行速度要快于flash,可以將單片機的程序分為code(代碼存儲區(qū))、RO-data(只讀數(shù)據存儲區(qū))、RW-data(讀寫數(shù)據存儲區(qū))和ZI-data(零初始化數(shù)據區(qū))。在MDK編譯器下可以觀察到在代碼中這4個量的值,如下圖1所示:

其中code和RO-data存儲在flash中,所以兩者之和為單片機中flash需要分配給它們的空間大?。ú⑶业扔诖a所生成的.bin文件大?。?,另外RW-data和ZI-data存儲在sram中,同樣兩者之和為單片機中sram需要分配給它們的空間大小。

另外,我們必然會想到棧區(qū)(stack)、堆區(qū)(heap)、全局區(qū)(靜態(tài)區(qū))(staTIc)、文字常量區(qū)和程序代碼區(qū)和上面所介紹的code、RO-data等的關系。

1、棧區(qū)(stack):由編譯器自動分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等。其操作方式類似于數(shù)據結構中的棧。 這些值是可讀寫的,那么stack應該被包含在RW-data(讀寫數(shù)據存儲區(qū)),也就是單片機的sram中。

2、堆區(qū)(heap):一般由程序員分配釋放, 若程序員不釋放,程序結束時可能由OS回收 ??梢岳斫?,這些也是被包含在單片機的sram中的。

3、全局區(qū)(靜態(tài)區(qū))(staTIc):全局變量和靜態(tài)變量的存儲是放在一塊的,初始化的全局變量和靜態(tài)變量在一塊區(qū)域, 未初始化的全局變量和未初始化的靜態(tài)變量在相鄰的另一塊區(qū)域,程序結束后由系統(tǒng)釋放。這些數(shù)據也是可讀可寫的,和stack、heap一樣,被包含在sram中。

4、文字常量區(qū):常量字符串就是放在這里的。這些數(shù)據是只讀的,分配在RO-data(只讀數(shù)據存儲區(qū)),則被包含在flash中。

5、程序代碼區(qū):存放函數(shù)體的二進制代碼,可以想象也是被包含在flash,因為對于MCU來說,當其重新上電,代碼還會繼續(xù)運行,并不會消失,所以存儲在flash中。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關注

    關注

    6026

    文章

    44455

    瀏覽量

    630894
  • 寄存器
    +關注

    關注

    31

    文章

    5271

    瀏覽量

    119648
  • 存儲器
    +關注

    關注

    38

    文章

    7403

    瀏覽量

    163393
收藏 人收藏

    評論

    相關推薦

    單片機的中斷機制

    單片機的中斷機制是一種重要的處理方式,它允許單片機執(zhí)行主程序的過程中,能夠暫停當前任務,轉而處理外部或內部緊急事件。這種機制極大地提高了系統(tǒng)的響應速度和處理能力,使得
    的頭像 發(fā)表于 10-17 18:03 ?154次閱讀

    微處理器執(zhí)行指令的基本過程

    微處理器,作為現(xiàn)代計算機的核心部件,負責執(zhí)行存儲在內存中的指令,完成各種計算和控制任務。指令執(zhí)行過程不僅體現(xiàn)了微處理器的設計思想和架構特點
    的頭像 發(fā)表于 10-05 15:07 ?127次閱讀

    國產主流8位單片機-RISC架構精簡指令單片機

    、儀器儀表、汽車電子、物聯(lián)網等領域電子產品的應用 英銳恩科技的8位單片機采用RISC架構設計,優(yōu)化了指令執(zhí)行流程,顯著提升了處理效率。此外,結合高可靠性和低成本,EN8F18系列成為了開發(fā)者的熱門
    發(fā)表于 09-27 10:15

    單片機基本io功能調試過程

    單片機基本IO功能的調試過程涉及多個步驟,旨在確保IO口能夠正確地執(zhí)行輸入和輸出操作。以下是一個調試過程,涵蓋了從準備階段到實際測試的關鍵步驟: 一、準備階段 確定
    的頭像 發(fā)表于 09-14 14:38 ?322次閱讀

    單片機中斷功能及其應用

    單片機中斷功能及其應用? 單片機中斷是指在程序執(zhí)行過程中,根據特定的條件或事件自動暫時中斷當前程序的執(zhí)行,轉而
    的頭像 發(fā)表于 01-30 14:45 ?4377次閱讀

    單片機if是什么語句

    單片機中的if語句是一種條件語句,用于根據不同的條件執(zhí)行不同的代碼塊。在程序執(zhí)行過程中,條件語句用來決定是否執(zhí)行特定的代碼段。在
    的頭像 發(fā)表于 01-05 14:04 ?1445次閱讀

    AvR單片機for循環(huán)需要幾個指令周期

    在AvR單片機中,for循環(huán)語句的執(zhí)行需要多個指令周期。指令周期是一個基本的處理器時鐘周期,用于執(zhí)行一條
    的頭像 發(fā)表于 12-26 14:03 ?955次閱讀

    單片機解析g代碼的方法

    的運動。 解析G代碼是將其轉化為單片機能夠理解和執(zhí)行指令集。單片機解析G代碼的方法主要包括以下幾個方面:G代碼的格式解析、指令的解析和
    的頭像 發(fā)表于 12-22 14:15 ?1432次閱讀

    單片機中并行是什么意思

    單片機中的并行是指能夠同時執(zhí)行多個操作或指令的能力。傳統(tǒng)的計算機體系結構中,處理器通常是按照順序執(zhí)行指令,即一條
    的頭像 發(fā)表于 12-20 09:33 ?1064次閱讀

    51單片機中斷執(zhí)行的相關過程筆記介紹

    電子發(fā)燒友網站提供《51單片機中斷執(zhí)行的相關過程筆記介紹》資料免費下載
    發(fā)表于 12-05 09:17 ?0次下載

    8051單片機中斷系統(tǒng)過程

    8051單片機是一種經典的8位微控制器,它具有一個靈活的中斷系統(tǒng)。在8051單片機中,中斷是一種非常重要的功能,它允許處理器在執(zhí)行主程序的過程中,響應外部或內部事件的請求,暫停當前的任
    發(fā)表于 12-05 09:15 ?0次下載

    單片機中斷系統(tǒng)詳解

    單片機中斷是指在單片機執(zhí)行程序的過程中,當外部設備或內部條件發(fā)生某個特定事件時,能夠暫停當前正在執(zhí)行的程序,轉而去
    的頭像 發(fā)表于 12-05 09:09 ?2580次閱讀

    FPGA和單片機的區(qū)別

    能滿足,所以在很多應用場合被稱為范圍更廣的微控制器。 單片機的工作原理 單片機自動完成賦予它的任務的過程,也就是單片機執(zhí)行程序的
    發(fā)表于 11-14 15:30

    什么是中斷?單片機中斷處理過程詳解

    如果單片機沒有中斷,那么,單片機將失去靈魂。
    的頭像 發(fā)表于 11-09 11:28 ?4591次閱讀
    什么是中斷?<b class='flag-5'>單片機</b>中斷處理<b class='flag-5'>過程</b><b class='flag-5'>詳解</b>

    系統(tǒng)復位后單片機從哪個單元開始取指令執(zhí)行程序?

    大佬幫忙解答下,系統(tǒng)復位后單片機從哪個單元開始取指令執(zhí)行程序?
    發(fā)表于 10-31 07:10