在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

淺析MCU的內(nèi)存分配與代碼執(zhí)行

GReq_mcu168 ? 來源:未知 ? 作者:胡薇 ? 2018-09-04 16:25 ? 次閱讀

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

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

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

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

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

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

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

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

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

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

2 程序計(jì)數(shù)器的內(nèi)容自動(dòng)加1(變?yōu)?001H);

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

4 CPU使讀控制線有效;

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

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

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

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

對于一款mcu來說,在性能描述的時(shí)候都會告訴sram,flash的容量大小,對于初學(xué)者來說,也不會去考慮和理會這些東西,拿到東西就只用。其實(shí)不然,這些量都是十分重要的,仔細(xì)想想,代碼為什么可以運(yùn)行,代碼量是多少,定義的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個(gè)量的值,如下圖1所示:

圖1:

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

2、堆區(qū)(heap):一般由程序員分配釋放, 若程序員不釋放,程序結(jié)束時(shí)可能由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,因?yàn)閷τ贛CU來說,當(dāng)其重新上電,代碼還會繼續(xù)運(yùn)行,并不會消失,所以存儲在flash中。

綜上所述,MCU的內(nèi)存分配基本如此,其中并沒有提到存儲空間所對應(yīng)的flash和sram地址,這些后面還會講到!

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

    關(guān)注

    6059

    文章

    44823

    瀏覽量

    644958
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17731

    瀏覽量

    358501
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    3102

    瀏覽量

    74900

原文標(biāo)題:單片機(jī)如何執(zhí)行代碼命令,單片MCU內(nèi)存如何分配?

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

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

    C語言知識總結(jié):動(dòng)態(tài)內(nèi)存分配

    動(dòng)態(tài)內(nèi)存分配就 是指在程序執(zhí)行的過程中動(dòng)態(tài)地分配或者回收存儲空間的分配內(nèi)存的方法。動(dòng)態(tài)
    發(fā)表于 10-24 15:52 ?980次閱讀

    CYT4BF通過分配ITCM內(nèi)存來使用經(jīng)常執(zhí)行代碼,下載程序時(shí)報(bào)錯(cuò)的原因?

    我正在使用 CYT4BF,我想通過分配 ITCM 內(nèi)存來使用經(jīng)常執(zhí)行代碼。 SDL 的 tcm 示例中似乎沒有 itcm 示例。 我在 linker_directives.ld 文件
    發(fā)表于 01-31 06:34

    C語言內(nèi)存分配-通俗理解

    可以看出程序在未運(yùn)行前,沒有調(diào)入到內(nèi)存時(shí),分為三個(gè)部分:代碼區(qū)(text)、數(shù)據(jù)區(qū)(data)、未初始化數(shù)據(jù)區(qū)(bss)。(1) 代碼區(qū)(text)存放CPU可執(zhí)行的機(jī)器指令,由于程序
    發(fā)表于 10-08 14:57

    單片機(jī)如何執(zhí)行代碼命令,單片MCU內(nèi)存如何分配?

    是只讀的,分配在RO-data(只讀數(shù)據(jù)存儲區(qū)),則被包含在flash中。 5.程序代碼區(qū):存放函數(shù)體的二進(jìn)制代碼,可以想象也是被包含在flash,因?yàn)閷τ?b class='flag-5'>MCU來說,當(dāng)其重新上電,
    發(fā)表于 06-20 14:19

    MCU內(nèi)存分配方法,錯(cuò)過絕對后悔

    MCU內(nèi)存分配參考ram(即SRAM)和rom(即Flash)參考http://www.eeworld.com.cn/mcu/2014/1212/article_17648.htmlr
    發(fā)表于 11-01 06:56

    動(dòng)態(tài)內(nèi)存分配是什么意思

    所謂動(dòng)態(tài)內(nèi)存分配(Dynamic Memory Allocation)就是指在程序執(zhí)行的過程中動(dòng)態(tài)地分配或者回收存儲空間的分配
    發(fā)表于 12-17 08:17

    PSD813F和其它MCU組合內(nèi)存分配圖的舉例

    PSD813F和其它MCU組合內(nèi)存分配圖的舉例
    發(fā)表于 05-13 11:20 ?9次下載
    PSD813F和其它<b class='flag-5'>MCU</b>組合<b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>圖的舉例

    單片機(jī)如何執(zhí)行代碼命令,單片MCU內(nèi)存如何分配?

    由于本次進(jìn)入指令寄存器中的內(nèi)容是74H(操作碼),以譯碼器譯碼后單片機(jī)就會知道該指令是要將一個(gè)數(shù)送到A累加器,而該數(shù)是在這個(gè)代碼的下一個(gè)存儲單元。所以,執(zhí)行該指令還必須把數(shù)據(jù)(E0H)從存儲器中取出
    發(fā)表于 05-04 10:55 ?1684次閱讀

    MCU內(nèi)存分配詳解

    其中code和RO-data存儲在flash中,所以兩者之和為單片機(jī)中flash需要分配給它們的空間大小(并且等于代碼所生成的.bin文件大小),另外RW-data和ZI-data存儲在sram中,同樣兩者之和為單片機(jī)中sram需要分配
    發(fā)表于 11-04 11:24 ?6382次閱讀

    進(jìn)程虛擬內(nèi)存布局以及進(jìn)程的虛擬內(nèi)存分配釋放流程,涉及的代碼

    我們計(jì)劃通過一系列文章來介紹虛擬內(nèi)存分配/釋放,缺頁處理,內(nèi)存壓縮/回收,內(nèi)存分配器等知識,梳理虛擬內(nèi)存
    的頭像 發(fā)表于 06-28 09:38 ?4478次閱讀

    什么是堆內(nèi)存?堆內(nèi)存是如何分配的?

    在一般的編譯系統(tǒng)中,堆內(nèi)存分配方向和棧內(nèi)存是相反的。當(dāng)棧內(nèi)存從高地址向低地址增長的時(shí)候,堆內(nèi)存從低地址向高地址
    的頭像 發(fā)表于 07-05 17:58 ?1w次閱讀

    MCU內(nèi)存分配

    MCU內(nèi)存分配參考ram(即SRAM)和rom(即Flash)參考http://www.eeworld.com.cn/mcu/2014/1212/article_17648.htmlr
    發(fā)表于 10-25 11:51 ?7次下載
    <b class='flag-5'>MCU</b><b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>

    MCU內(nèi)存分配與管理

    從事嵌入式產(chǎn)品開發(fā)已有十余年了,從最開始的8051一直用到現(xiàn)在流行的Cortex M系列的內(nèi)核的單片機(jī)。從最開始用VC6.0開發(fā)PC端的軟件到現(xiàn)在使用Mircrosoft WPF框架進(jìn)行PC端的軟件開發(fā)。發(fā)現(xiàn)現(xiàn)在的新人對MCU內(nèi)存管理與
    發(fā)表于 11-01 16:24 ?10次下載
    <b class='flag-5'>MCU</b><b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>與管理

    C語言程序編譯后內(nèi)存地址的分配

    本文目的是簡要介紹C語言編譯得到的可執(zhí)行文件加載到內(nèi)存運(yùn)行時(shí)不同變量分配的存儲位置,并通過在Ubuntu 18.04系統(tǒng)和STM32系統(tǒng)上進(jìn)行編程驗(yàn)證C語言編譯后內(nèi)存地址
    發(fā)表于 01-13 14:23 ?1次下載
    C語言程序編譯后<b class='flag-5'>內(nèi)存</b>地址的<b class='flag-5'>分配</b>

    如何高效管理MCU內(nèi)存? 多種分配算法對比?

    如何高效管理MCU內(nèi)存? 多種分配算法對比?
    的頭像 發(fā)表于 10-17 18:21 ?1477次閱讀
    如何高效管理<b class='flag-5'>MCU</b><b class='flag-5'>內(nèi)存</b>? 多種<b class='flag-5'>分配</b>算法對比?
    主站蜘蛛池模板: 久久伦子沙发 | 日本一区二区三区在线观看视频 | 中文天堂在线观看 | 看片久久 | 天天天天天天操 | 99成人 | 黄色免费的视频 | 国产在线播放你懂的 | 久久青草国产手机看片福利盒子 | 56pao强力打造| 日欧毛片 | 精品少妇一区二区三区视频 | 中文字幕一区在线播放 | 国产女同| 四虎永久在线免费观看 | 日本黄色视屏 | 91一区二区三区四区五区 | gay超刺激污文 | 亚洲资源最新版在线观看 | 在线免费影视 | 在线视频观看你懂的 | 亚洲免费网站在线观看 | 欧美乱xxxxxxxxx| 欧美色爱综合网 | 久久国产免费观看精品1 | 国产理论在线 | 亚洲网站www | 狠狠色噜噜狠狠狠狠奇米777 | 18满xo影院视频免费体验区 | 拍拍拍交性免费视频 | 99热色| 日本www色 | 看黄网站在线 | www.91大神| 美女免费观看一区二区三区 | 亚洲一级毛片中文字幕 | 4455亚洲 | 啪啪网免费视频 | 轻点灬大ji巴太粗太长了h | 亚洲天堂二区 | 欧美性色xo影院永久禁欲 |