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

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

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

cpu執(zhí)行指令的過程詳解

h1654155282.3538 ? 來源:網(wǎng)絡(luò)整理 ? 2018-03-09 16:30 ? 次閱讀

cpu執(zhí)行指令的過程詳解

計(jì)算機(jī)每執(zhí)行一條指令都可分為三個(gè)階段進(jìn)行。即取指令-----分析指令-----執(zhí)行指令。

取指令的任務(wù)是:根據(jù)程序計(jì)數(shù)器PC中的值從程序存儲(chǔ)器讀出現(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ù)總線送入到存儲(chǔ)器,然后逐條取出執(zhí)行。但單片機(jī)中的程序一般事先我們都已通過寫入器固化在片內(nèi)或片外程序存儲(chǔ)器中。因而一開機(jī)即可執(zhí)行指令。

cpu執(zhí)行指令的過程詳解

CPU指令執(zhí)行流程圖

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

開機(jī)時(shí),程序計(jì)算器PC變?yōu)?000H。然后單片機(jī)在時(shí)序電路作用下自動(dòng)進(jìn)入執(zhí)行程序過程。執(zhí)行過程實(shí)際上就是取出指令(取出存儲(chǔ)器中事先存放的指令階段)和執(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)部地址總線送到存儲(chǔ)器,以存儲(chǔ)器中地址譯碼電跟,使地址為0000H的單元被選中;

4、CPU使讀控制線有效;

5、在讀命令控制下被選中存儲(chǔ)器單元的內(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ī)就會(huì)知道該指令是要將一個(gè)數(shù)送到A累加器,而該數(shù)是在這個(gè)代碼的下一個(gè)存儲(chǔ)單元。所以,執(zhí)行該指令還必須把數(shù)據(jù)(E0H)從存儲(chǔ)器中取出送到CPU,即還要在存儲(chǔ)器中取第二個(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每次向存儲(chǔ)器取指或取數(shù)時(shí)自動(dòng)加1,單片機(jī)又進(jìn)入下一取指階段。這一過程一直重復(fù)下去,直至收到暫停指令或循環(huán)等待指令暫停。CPU就是這樣一條一條地執(zhí)行指令,完成所有規(guī)定。

cpu執(zhí)行指令步驟詳解

1、第一步我們首先看一下cpu的內(nèi)部結(jié)構(gòu),主要包括寄存器,控制器,ALU算數(shù)邏輯運(yùn)算單元,控制器里面又含有操作控制器,計(jì)數(shù)器,寄存器等,如下圖所示:

cpu執(zhí)行指令的過程詳解

2、第二步我們了解了cpu的內(nèi)部結(jié)構(gòu)之后,就比較容易理解cpu是如何執(zhí)行指令的,cpu執(zhí)行指令主要分為5個(gè)階段,從取指令,導(dǎo)進(jìn)行指令譯碼,執(zhí)行指令,訪問主存,最后回寫結(jié)果,具體cpu執(zhí)行過程如下圖所示:

cpu執(zhí)行指令的過程詳解

3、第三步我們首先來看cpu執(zhí)行指令的一、二階段,cpu是怎么取指令和進(jìn)行指令譯碼,將指令先從主存里面取出,然后放到寄存器,最后進(jìn)行指令譯碼,這樣就完成cpu執(zhí)行指令的一、二階段,具體如下圖所示:

cpu執(zhí)行指令的過程詳解

4、第四步cpu執(zhí)行指令的三、四階段,首先根據(jù)指令規(guī)定的操作,完成具體功能,最后訪問主存,操作數(shù),得到物理地址,就完成了執(zhí)行指令和訪問主存的三、四階段,如下圖所示:

cpu執(zhí)行指令的過程詳解

5、第五步在cpu第四階段訪問主存的時(shí)候,需要得到物理地址,具體讀寫過程如下圖所示:

cpu執(zhí)行指令的過程詳解

6、第六步我們也可以看一下cpu是怎么讀指令的,下面是cpu的工作原理,如下圖所示:

cpu執(zhí)行指令的過程詳解

7、第七步cpu執(zhí)行指令進(jìn)去到了第五個(gè)階段,也是最后一個(gè)階段回寫結(jié)果,把第三階段執(zhí)行指令的運(yùn)行結(jié)果數(shù)據(jù)回寫到一種存儲(chǔ)形式,cpu這樣就成功執(zhí)行完了一條指令,如下圖所示

cpu執(zhí)行指令的過程詳解

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

    關(guān)注

    68

    文章

    10863

    瀏覽量

    211781
收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

    ,單片機(jī)又進(jìn)入下一取指階段。這一過程一直重復(fù)下去,直至收到暫停指令或循環(huán)等待指令暫停。CPU就是這樣一條一條地執(zhí)行
    的頭像 發(fā)表于 02-15 09:53 ?1.9w次閱讀

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

    單片機(jī)就會(huì)知道該指令是要將一個(gè)數(shù)送到A累加器,而該數(shù)是在這個(gè)代碼的下一個(gè)存儲(chǔ)單元。所以,執(zhí)行指令還必須把數(shù)據(jù)(E0H)從存儲(chǔ)器中取出送到CPU,即還要在存儲(chǔ)器中取第二個(gè)字節(jié)。其
    發(fā)表于 06-07 14:05

    單片機(jī)執(zhí)行指令過程是怎樣的

    單片機(jī)執(zhí)行指令過程詳解單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行
    發(fā)表于 11-25 08:02

    計(jì)算機(jī)執(zhí)行指令過程分析

    計(jì)算機(jī)指令就是指揮機(jī)器工作的指示和命令,程序就是一系列按一定順序排列的指令,執(zhí)行程序的過程就是計(jì)算機(jī)的工作過程。控制器靠
    發(fā)表于 11-17 10:37 ?1.3w次閱讀
    計(jì)算機(jī)<b class='flag-5'>執(zhí)行</b><b class='flag-5'>指令</b>的<b class='flag-5'>過程</b>分析

    51單片機(jī)執(zhí)行指令過程的分析解釋

    單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行我們所編制程序的過程。即逐條指令過程。計(jì)算機(jī)每
    的頭像 發(fā)表于 03-16 16:41 ?7403次閱讀

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

    單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行我們所編制程序的過程。即逐條指令過程。計(jì)算機(jī)每
    發(fā)表于 04-16 11:20 ?6297次閱讀
    淺談51單片機(jī)<b class='flag-5'>指令</b><b class='flag-5'>執(zhí)行</b>的<b class='flag-5'>過程</b>

    ARM程序的執(zhí)行過程詳解

    本文主要詳解ARM程序的執(zhí)行過程,首先介紹了ARM程序的組成及ARM映像文件的組成,其次闡述了ARM程序的執(zhí)行過程,最后介紹了RO、RW、Z
    發(fā)表于 04-26 11:34 ?7215次閱讀

    單片機(jī)是如何執(zhí)行指令過程?MCU內(nèi)存又是如何分配的?

    單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行我們所編制程序的過程。即逐條指令過程。計(jì)算機(jī)每
    發(fā)表于 08-25 09:10 ?5237次閱讀

    CPU操作指令詳解

    CPU將CS:IP指向的內(nèi)存單元中的內(nèi)容看作指令,因?yàn)?,在任何時(shí)候,CPU將CS,IP中的內(nèi)容當(dāng)作指令的段地址和偏移地址,用它們合成指令的物
    的頭像 發(fā)表于 09-24 17:52 ?9875次閱讀

    80C51單片機(jī)指令的取指和執(zhí)行時(shí)序詳細(xì)說明

    現(xiàn)按4類指令介紹CPU時(shí)序。因?yàn)?b class='flag-5'>CPU工作的過程就是取指令執(zhí)行
    發(fā)表于 09-27 17:16 ?1次下載
    80C51單片機(jī)<b class='flag-5'>指令</b>的取指和<b class='flag-5'>執(zhí)行</b>時(shí)序詳細(xì)說明

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

    單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行我們所編制程序的過程。即逐條指令過程
    的頭像 發(fā)表于 08-07 14:47 ?5608次閱讀

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

    單片機(jī)執(zhí)行指令過程詳解單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行
    發(fā)表于 11-17 09:36 ?19次下載
    單片機(jī)<b class='flag-5'>執(zhí)行</b><b class='flag-5'>指令</b><b class='flag-5'>過程</b><b class='flag-5'>詳解</b>

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

    單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行我們所編制程序的過程。即逐條指令過程。計(jì)算機(jī)每
    發(fā)表于 02-11 15:26 ?4次下載
    單片機(jī)<b class='flag-5'>執(zhí)行</b><b class='flag-5'>指令</b>的<b class='flag-5'>過程</b>

    CPU指令執(zhí)行過程 CPU指令流水線

    幾乎所有的馮·諾伊曼型計(jì)算機(jī)的 CPU,其工作都可以分為 5 個(gè)階段:取指令指令譯碼、執(zhí)行指令、訪存取數(shù)、結(jié)果寫回。
    發(fā)表于 05-09 17:29 ?1.9w次閱讀
    <b class='flag-5'>CPU</b><b class='flag-5'>指令</b>的<b class='flag-5'>執(zhí)行</b><b class='flag-5'>過程</b> <b class='flag-5'>CPU</b><b class='flag-5'>指令</b>流水線

    證明CPU指令是亂序執(zhí)行

    雙擊QQ.exe從磁盤加載到內(nèi)存里面,內(nèi)存里面就會(huì)有了一個(gè)進(jìn)程,進(jìn)程產(chǎn)生的時(shí)候會(huì)產(chǎn)生一個(gè)主線程,就是main方法所在的線程,cpu會(huì)找到main開始的地方,把它的指令讀取過來放到程序計(jì)數(shù)器,把數(shù)據(jù)放到寄存器,然后ALU開始做計(jì)算,一步一步來
    的頭像 發(fā)表于 03-15 09:13 ?965次閱讀