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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

淺析單片機(jī)指令執(zhí)行過程

貿(mào)澤電子設(shè)計圈 ? 來源:YXQ ? 2019-08-07 14:47 ? 次閱讀

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

1、取指令—2、分析指令 — 3、執(zhí)行指令

1、取指令

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

2、分析指令

將指令寄存器中的指令操作碼取出后進(jìn)行譯碼,分析其指令性質(zhì)。如指令要求操作數(shù),則尋找操作數(shù)地址。

3、執(zhí)行指令

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

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

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

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

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

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

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

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

4、CPU使讀控制線有效。

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

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

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

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

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

首先單片機(jī)的內(nèi)存可以大體上分為ram和rom,這里就不再解釋ram和rom的區(qū)別了,我們可以將其等效為flash和sram,其中根據(jù)flash和sram的定義可得,flash里面的數(shù)據(jù)掉電可保存,sram中的并不可以,但是sram的執(zhí)行速度要快于flash。單片機(jī)的程序分為code(代碼存儲區(qū))、RO-data(只讀數(shù)據(jù)存儲區(qū))、RW-data(讀寫數(shù)據(jù)存儲區(qū))和ZI-data(零初始化數(shù)據(jù)區(qū))。在MDK編譯器下可以觀察到在代碼中這4個量的值。其中code和RO-data存儲在flash中,所以兩者之和為單片機(jī)中flash需要分配給它們的空間大?。ú⑶业扔诖a所生成的.bin文件大小),另外RW-data和ZI-data存儲在sram中,同樣兩者之和為單片機(jī)中sram需要分配給它們的空間大小。

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

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

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

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

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

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

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

    關(guān)注

    6037

    文章

    44558

    瀏覽量

    635405
  • 指令
    +關(guān)注

    關(guān)注

    1

    文章

    607

    瀏覽量

    35716

原文標(biāo)題:單片機(jī)執(zhí)行指令過程詳解

文章出處:【微信號:Mouser-Community,微信公眾號:貿(mào)澤電子設(shè)計圈】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機(jī)Debug工具性能對比 單片機(jī)調(diào)試常用命令

    。以下是對單片機(jī)調(diào)試工具性能的簡要對比以及一些常用的調(diào)試命令。 單片機(jī)Debug工具性能對比 Keil uVision 性能 :Keil uVision 是一款功能強(qiáng)大的集成開發(fā)環(huán)境(IDE),支持多種單片機(jī),特別是ARM Co
    的頭像 發(fā)表于 12-19 09:56 ?228次閱讀

    單片機(jī)有哪些中斷類型

    單片機(jī)中斷是指在單片機(jī)執(zhí)行程序的過程中,當(dāng)外部設(shè)備或內(nèi)部條件發(fā)生某個特定事件時,能夠暫停當(dāng)前正在執(zhí)行的程序,轉(zhuǎn)而去
    的頭像 發(fā)表于 10-17 18:12 ?709次閱讀

    單片機(jī)的中斷機(jī)制

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

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

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

    國產(chǎn)主流8位單片機(jī)-RISC架構(gòu)精簡指令單片機(jī)

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

    PIC單片機(jī)的優(yōu)勢和不足之處

    的核心優(yōu)勢在于其CPU采用的RISC結(jié)構(gòu),這一結(jié)構(gòu)精簡而高效,分別包含33、35、58條指令,構(gòu)成了精簡指令集。這種設(shè)計不僅減少了指令的數(shù)量,還提高了指令
    的頭像 發(fā)表于 09-25 17:22 ?374次閱讀

    msp430單片機(jī)的優(yōu)缺點介紹

    贏得了工程師們的青睞。 MSP430單片機(jī)的優(yōu)點 MSP430單片機(jī)的核心優(yōu)勢在于其強(qiáng)大的處理能力和豐富的指令集。它采用了精簡指令集(RISC)結(jié)構(gòu),這一設(shè)計不僅減少了
    的頭像 發(fā)表于 09-25 17:12 ?637次閱讀

    單片機(jī)基本io功能調(diào)試過程

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

    單片機(jī)燒錄程序可以重新燒嗎

    好的程序代碼通過特定的方式寫入單片機(jī)的存儲器中,使其能夠按照預(yù)定的邏輯執(zhí)行任務(wù)。單片機(jī)燒錄程序可以重新燒錄,這是單片機(jī)編程和開發(fā)過程中的一個
    的頭像 發(fā)表于 09-02 10:04 ?1248次閱讀

    單片機(jī)燒錄程序的線比單片機(jī)上的少還能燒錄嗎

    單片機(jī)燒錄原理 單片機(jī)燒錄是指將編寫好的程序代碼通過一定的方式傳輸?shù)?b class='flag-5'>單片機(jī)的存儲器中,使其能夠按照程序的指令運行。這個過程通常需要使用燒錄器
    的頭像 發(fā)表于 09-02 09:54 ?504次閱讀

    單片機(jī)燒錄程序的基本步驟是什么

    單片機(jī)燒錄程序是單片機(jī)開發(fā)過程中非常重要的一步,它涉及到將編寫好的程序代碼通過一定的方式傳輸?shù)?b class='flag-5'>單片機(jī)內(nèi)部的存儲器中,使單片機(jī)能夠按照預(yù)定的邏
    的頭像 發(fā)表于 09-02 09:47 ?1065次閱讀

    單片機(jī)中斷功能及其應(yīng)用

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

    單片機(jī)原理及應(yīng)用有哪些

    廣泛應(yīng)用于各個領(lǐng)域,如家電、汽車、通信、醫(yī)療等。 單片機(jī)的原理主要包括內(nèi)部結(jié)構(gòu)和工作原理。其內(nèi)部結(jié)構(gòu)通常包括CPU、存儲器、I/O接口和定時/計數(shù)器等模塊。CPU是單片機(jī)的核心,負(fù)責(zé)指令執(zhí)行
    的頭像 發(fā)表于 01-15 16:25 ?1991次閱讀

    單片機(jī)原理及應(yīng)用是什么

    能力。單片機(jī)被廣泛應(yīng)用于各個領(lǐng)域,包括家電、汽車、通信、電子設(shè)備及工業(yè)自動化等。本文將詳細(xì)介紹單片機(jī)的原理及應(yīng)用。 核心部分:單片機(jī)的核心是中央處理器(CPU)。它負(fù)責(zé)執(zhí)行程序
    的頭像 發(fā)表于 01-12 15:28 ?2168次閱讀

    單片機(jī)if是什么語句

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