衡阳派盒市场营销有限公司

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

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

3天內不再提示

淺析單片機指令執行過程

貿澤電子設計圈 ? 來源:YXQ ? 2019-08-07 14:47 ? 次閱讀

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

1、取指令—2、分析指令 — 3、執行指令

1、取指令

根據程序計數器PC中的值從程序存儲器讀出現行指令,送到指令寄存器

2、分析指令

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

3、執行指令

執行程序的過程實際上就是逐條指令地重復上述操作過程,直至遇到停機指令或循環等待指令。

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

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

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

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

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

2、程序計數器的內容自動加1(變為0001H)。

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

4、CPU使讀控制線有效。

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

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

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

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

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

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

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

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

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

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

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

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

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

    關注

    6043

    文章

    44622

    瀏覽量

    638524
  • 指令
    +關注

    關注

    1

    文章

    611

    瀏覽量

    35812

原文標題:單片機執行指令過程詳解

文章出處:【微信號:Mouser-Community,微信公眾號:貿澤電子設計圈】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    單片機中斷技術詳解

    在現代電子設備中,單片機作為控制核心發揮著舉足輕重的作用。而在其高效運作的背后,中斷機制是推動單片機實現實時響應與高效執行的關鍵因素。本文將深入探討單片機中的中斷概念、中斷系統的結構、
    的頭像 發表于 02-02 15:57 ?126次閱讀

    怎么提升單片機代碼執行效率

    ? 提升單片機代碼執行效率需要從多個方面入手,包括代碼優化、硬件資源利用、編譯器設置、中斷處理優化以及其他技巧等。在實際應用中,需要根據具體需求和硬件條件綜合考慮這些因素,以實現最佳的性能表現。 ?
    的頭像 發表于 01-10 11:06 ?156次閱讀

    單片機Debug工具性能對比 單片機調試常用命令

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

    單片機有哪些中斷類型

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

    單片機的中斷機制

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

    微處理器執行指令的基本過程

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

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

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

    PIC單片機的優勢和不足之處

    的核心優勢在于其CPU采用的RISC結構,這一結構精簡而高效,分別包含33、35、58條指令,構成了精簡指令集。這種設計不僅減少了指令的數量,還提高了指令
    的頭像 發表于 09-25 17:22 ?445次閱讀

    msp430單片機的優缺點介紹

    贏得了工程師們的青睞。 MSP430單片機的優點 MSP430單片機的核心優勢在于其強大的處理能力和豐富的指令集。它采用了精簡指令集(RISC)結構,這一設計不僅減少了
    的頭像 發表于 09-25 17:12 ?807次閱讀

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

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

    十天學會單片機可能嗎?單片機入門需要多久?

    學習單片機過程,就像學習任何其他技能一樣,不僅在于書本上的知識,更在于實踐和應用的能力。許多人可能會問:十天能學會單片機嗎?答案是:可以,但這取決于你所定義的“學會”到什么程度。首先,讓我們明確
    的頭像 發表于 09-05 08:00 ?1312次閱讀
    十天學會<b class='flag-5'>單片機</b>可能嗎?<b class='flag-5'>單片機</b>入門需要多久?

    單片機燒錄程序可以重新燒嗎

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

    單片機燒錄程序的線比單片機上的少還能燒錄嗎

    單片機燒錄原理 單片機燒錄是指將編寫好的程序代碼通過一定的方式傳輸到單片機的存儲器中,使其能夠按照程序的指令運行。這個過程通常需要使用燒錄器
    的頭像 發表于 09-02 09:54 ?612次閱讀

    單片機燒錄程序的基本步驟是什么

    單片機燒錄程序是單片機開發過程中非常重要的一步,它涉及到將編寫好的程序代碼通過一定的方式傳輸到單片機內部的存儲器中,使單片機能夠按照預定的邏
    的頭像 發表于 09-02 09:47 ?1435次閱讀

    51單片機流水燈制作

    ?流水燈是學習51單片機的一個基本項目,是我們對單片機IO口輸出認識的基本項目。當然學會了花樣流水燈也很好玩。 下面就分享一種51單片機流水燈制作的方法。 一、流水燈原理圖 二、相關知識 1
    的頭像 發表于 02-26 10:06 ?1705次閱讀
    51<b class='flag-5'>單片機</b>流水燈制作
    百家乐官网园小区户型图| 免费百家乐规律| 线上百家乐官网试玩| 百家乐官网代打是真的吗| 百家乐官网已破解的书籍| 玩百家乐官网怎么才能赢| 最大的百家乐官网网站| 什么事百家乐官网的路单| 乐天堂百家乐官网娱乐场| 网上真钱麻将| 分宜县| 余干县| 百家乐官网浴盆博彩通排名| 百家乐官网群sun811.com| 竞咪百家乐官网的玩法技巧和规则 | 大发888在线官方| 尊龙国际娱乐| 优博家百家乐官网娱乐城| 百家乐官网透明发牌靴| 百家乐路单用处| 百家乐犯法| 澳门百家乐玩法与游戏规则| 二爷百家乐的玩法技巧和规则| 免费百家乐的玩法技巧和规则| 全讯网12580a.com| 索罗门百家乐的玩法技巧和规则 | 怎么玩百家乐官网能赢钱| 可信百家乐官网的玩法技巧和规则| 百家乐最佳投注法下载| 巴宝莉百家乐的玩法技巧和规则 | 百家乐官网稳赢技法| 24山飞星图| 百家乐赌场娱乐网规则| 香港六合彩资料| 百家乐官网庄闲局部失衡| 百家乐官网平注法到656| 庞博百家乐官网的玩法技巧和规则| 网上百家乐真的假的| 金冠百家乐的玩法技巧和规则| 97玩棋牌游戏中心| 澳门百家乐官网家用保险柜|