日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

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

GReq_mcu168 ? 來源:lq ? 2019-02-15 09:53 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

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

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

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ù)總線被送到指令寄存器。

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

由于本次進入指令寄存器中的內(nèi)容是74H(操作碼),以譯碼器譯碼后單片機就會知道該指令是要將一個數(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ù)總線進入A累加器,而不是進入指令寄存器。至此,一條指令的執(zhí)行完畢。單片機中PC=0002H,PC在CPU每次向存儲器取指或取數(shù)時自動加1,單片機又進入下一取指階段。這一過程一直重復(fù)下去,直至收到暫停指令或循環(huán)等待指令暫停。CPU就是這樣一條一條地執(zhí)行指令,完成所有規(guī)定的功能。

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

首先單片機的內(nèi)存可以大小分為ram和rom,這里就不再解釋ram和rom的區(qū)別了,我們可以將其等效為flash和sram,其中根據(jù)flash和sram的定義可得,flash里面的數(shù)據(jù)掉電可保存,sram中的并不可以,但是sram的執(zhí)行速度要快于flash,可以將單片機的程序分為code(代碼存儲區(qū))、RO-data(只讀數(shù)據(jù)存儲區(qū))、RW-data(讀寫數(shù)據(jù)存儲區(qū))和ZI-data(零初始化數(shù)據(jù)區(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等的關(guān)系。

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

2、堆區(qū)(heap):一般由程序員分配釋放, 若程序員不釋放,程序結(jié)束時可能由OS回收 ??梢岳斫?,這些也是被包含在單片機的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ù)體的二進制代碼,可以想象也是被包含在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)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6078

    文章

    45589

    瀏覽量

    673937
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5620

    瀏覽量

    130451
  • 存儲器
    +關(guān)注

    關(guān)注

    39

    文章

    7758

    瀏覽量

    172259
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    V850ES/FE3 32 - bit 單片機硬件設(shè)計詳解

    V850ES/FE3 32 - bit 單片機硬件設(shè)計詳解 在電子工程領(lǐng)域,單片機的應(yīng)用無處不在,而 V850ES/FE3 32 - bit 單片機以其獨特的性能和特性,成為眾多工程師
    的頭像 發(fā)表于 04-14 10:50 ?221次閱讀

    瑞薩8位單片機740族:指令系統(tǒng)與使用要點解析

    瑞薩8位單片機740族:指令系統(tǒng)與使用要點解析 在單片機領(lǐng)域,瑞薩8位單片機740族以其高效的指令群和豐富的尋址方式,在眾多應(yīng)用場景中展現(xiàn)出
    的頭像 發(fā)表于 04-13 15:10 ?166次閱讀

    瑞薩8位單片機740族:指令與應(yīng)用全解析

    ,受到了眾多電子工程師的青睞。本文將深入探討瑞薩8位單片機740族的特點、中央處理器、指令系統(tǒng)以及使用注意事項,希望能為電子工程師們在設(shè)計和開發(fā)過程中提供有價值的參考。 文件下載: R5F211A1DSP#U0.pdf 一、公司
    的頭像 發(fā)表于 04-13 15:05 ?151次閱讀

    Infineon XC886/888CLM 8位單片機:特性與應(yīng)用詳解

    Infineon XC886/888CLM 8位單片機:特性與應(yīng)用詳解 在電子設(shè)計領(lǐng)域,單片機作為核心部件,其性能和功能直接影響著整個系統(tǒng)的表現(xiàn)。英飛凌(Infineon)的 XC886
    的頭像 發(fā)表于 03-30 14:40 ?740次閱讀

    瑞薩 8 位單片機 740 族指令系統(tǒng)與設(shè)計要點解析

    深入探討一下 740 族單片機指令系統(tǒng)以及設(shè)計過程中的注意事項。 文件下載: R5F211B1SP#W4.pdf 740 族指令特點概述 指令
    的頭像 發(fā)表于 02-09 16:40 ?319次閱讀

    單片機的條件轉(zhuǎn)移指令

    ,L1 MOV R1,#0FFH AJMP L3 L1: JC L2 MOV R1,#0AAH AJMP L3 L2: MOV R1,#0FFH L3: SJMP L3 上面的程序中有一條單片機指令
    發(fā)表于 12-15 08:01

    單片機程序的執(zhí)行

    上是不是只要Flash就可以了呢(直接相當(dāng)于PC上的DDRRAM)?這樣成本也會比一個RAM,一個Flash低,更節(jié)省成本,對于生產(chǎn)商更劃算)。 對于單片機的程序執(zhí)行指令和數(shù)據(jù)的存放與讀取,理解如下
    發(fā)表于 12-04 06:20

    從代碼執(zhí)行單片機內(nèi)存的分配

    單片機執(zhí)行指令過程詳解 單片機執(zhí)行程序的
    發(fā)表于 12-02 07:58

    NICE指令的完整執(zhí)行過程

    NICE指令的完整執(zhí)行過程如下: 1、主處理器的譯碼單元提供EXU級譯碼得到指令的操作碼,以判斷其是否屬于默認(rèn)的自定義指令組。 如果該
    發(fā)表于 10-23 07:25

    單片機原理及應(yīng)用詳解

    單片機(Microcontroller Unit, MCC) ?是一種集成計算機核心功能(CPU、存儲器、I/O接口等)的微型芯片,廣泛應(yīng)用于嵌入式系統(tǒng)中。以下是其原理及應(yīng)用的詳細(xì)介紹: 一、單片機
    的頭像 發(fā)表于 08-11 13:57 ?2833次閱讀

    單片機板跟上位進行串口發(fā)收數(shù)據(jù)時,每次上位下發(fā)指令,為什么?

    單片機板跟上位進行串口發(fā)收數(shù)據(jù)時,每次上位下發(fā)指令,出現(xiàn)問題都是在第一條指令后,有時在單片機
    發(fā)表于 08-08 08:20

    單片機怎么驅(qū)動電機?

    在各類自動化設(shè)備和智能裝置中,電機是重要的執(zhí)行部件,而單片機作為控制核心,需要通過特定的方式驅(qū)動電機運轉(zhuǎn)。單片機驅(qū)動電機并非直接連接即可,而是要根據(jù)電機類型和功率,搭配合適的驅(qū)動電路,才能實現(xiàn)穩(wěn)定
    的頭像 發(fā)表于 07-25 09:31 ?1348次閱讀

    單片機是怎么控制的

    單片機作為電子系統(tǒng)的控制核心,通過接收外部信號、執(zhí)行預(yù)設(shè)程序、驅(qū)動外部設(shè)備的方式實現(xiàn)控制功能,其控制過程涉及信號輸入、數(shù)據(jù)處理和指令輸出三個關(guān)鍵環(huán)節(jié),每個環(huán)節(jié)的協(xié)同配合決定了整體控制效
    的頭像 發(fā)表于 07-23 13:59 ?1044次閱讀

    單片機怎么燒程序

    單片機燒程序是將編寫好的程序代碼寫入單片機內(nèi)部存儲單元,讓單片機按照預(yù)設(shè)邏輯工作的過程,是單片機應(yīng)用開發(fā)中不可或缺的環(huán)節(jié)。無論是簡單的燈光控
    的頭像 發(fā)表于 07-23 11:47 ?2061次閱讀

    給予單片機的溫度控制系統(tǒng)設(shè)計

    執(zhí)行機構(gòu)、顯示模塊和電源模塊組成。單片機是系統(tǒng)的核心,負(fù)責(zé)處理溫度信息并發(fā)出控制指令;溫度傳感器用于實時采集環(huán)境或物體的溫度數(shù)據(jù),將物理量轉(zhuǎn)化為電信號傳輸給單片機;
    的頭像 發(fā)表于 07-16 10:57 ?842次閱讀
    灵武市| 肇庆市| 九龙城区| 车险| 正安县| 武义县| 嵩明县| 城步| 信丰县| 天柱县| 伊金霍洛旗| 湖北省| 丘北县| 绥德县| 从化市| 天镇县| 南丹县| 巴马| 平和县| 肥乡县| 安图县| 沅江市| 大港区| 黄骅市| 井陉县| 阿勒泰市| 达日县| 铁岭市| 永丰县| 霍林郭勒市| 毕节市| 汉寿县| 海安县| 卓资县| 左云县| 平谷区| 高碑店市| 衡南县| 陕西省| 哈尔滨市| 灯塔市|