cpu執(zhí)行指令的過程詳解
計算機每執(zhí)行一條指令都可分為三個階段進行。即取指令-----分析指令-----執(zhí)行指令。
取指令的任務是:根據(jù)程序計數(shù)器PC中的值從程序存儲器讀出現(xiàn)行指令,送到指令寄存器。
分析指令階段的任務是:將指令寄存器中的指令操作碼取出后進行譯碼,分析其指令性質。如指令要求操作數(shù),則尋找操作數(shù)地址。
計算機執(zhí)行程序的過程實際上就是逐條指令地重復上述操作過程,直至遇到停機指令可循環(huán)等待指令。
一般計算機進行工作時,首先要通過外部設備把程序和數(shù)據(jù)通過輸入接口電路和數(shù)據(jù)總線送入到存儲器,然后逐條取出執(zhí)行。但單片機中的程序一般事先我們都已通過寫入器固化在片內或片外程序存儲器中。因而一開機即可執(zhí)行指令。
CPU指令執(zhí)行流程圖
下面我們將舉個實例來說明指令的執(zhí)行過程:
開機時,程序計算器PC變?yōu)?000H。然后單片機在時序電路作用下自動進入執(zhí)行程序過程。執(zhí)行過程實際上就是取出指令(取出存儲器中事先存放的指令階段)和執(zhí)行指令(分析和執(zhí)行指令)的循環(huán)過程。
例如執(zhí)行指令:MOV A,#0E0H,其機器碼為“74H E0H”,該指令的功能是把操作數(shù)E0H送入累加器,
0000H單元中已存放74H,0001H單元中已存放E0H。當單片機開始運行時,首先是進入取指階段,其次序是:
1、程序計數(shù)器的內容(這時是0000H)送到地址寄存器;
2、程序計數(shù)器的內容自動加1(變?yōu)?001H);
3、地址寄存器的內容(0000H)通過內部地址總線送到存儲器,以存儲器中地址譯碼電跟,使地址為0000H的單元被選中;
4、CPU使讀控制線有效;
5、在讀命令控制下被選中存儲器單元的內容(此時應為74H)送到內部數(shù)據(jù)總線上,因為是取指階段,所以該內容通過數(shù)據(jù)總線被送到指令寄存器。至此,取指階段完成,進入譯碼分析和執(zhí)行指令階段。
由于本次進入指令寄存器中的內容是74H(操作碼),以譯碼器譯碼后單片機就會知道該指令是要將一個數(shù)送到A累加器,而該數(shù)是在這個代碼的下一個存儲單元。所以,執(zhí)行該指令還必須把數(shù)據(jù)(E0H)從存儲器中取出送到CPU,即還要在存儲器中取第二個字節(jié)。其過程與取指階段很相似,只是此時PC已為0001H。指令譯碼器結合時序部件,產生74H操作碼的微操作系列,使數(shù)字E0H從0001H單元取出。因為指令是要求把取得的數(shù)送到A累加器,所以取出的數(shù)字經內部數(shù)據(jù)總線進入A累加器,而不是進入指令寄存器。至此,一條指令的執(zhí)行完畢。單片機中PC=“0002H”,PC在CPU每次向存儲器取指或取數(shù)時自動加1,單片機又進入下一取指階段。這一過程一直重復下去,直至收到暫停指令或循環(huán)等待指令暫停。CPU就是這樣一條一條地執(zhí)行指令,完成所有規(guī)定。
cpu執(zhí)行指令步驟詳解
1、第一步我們首先看一下cpu的內部結構,主要包括寄存器,控制器,ALU算數(shù)邏輯運算單元,控制器里面又含有操作控制器,計數(shù)器,寄存器等,如下圖所示:
2、第二步我們了解了cpu的內部結構之后,就比較容易理解cpu是如何執(zhí)行指令的,cpu執(zhí)行指令主要分為5個階段,從取指令,導進行指令譯碼,執(zhí)行指令,訪問主存,最后回寫結果,具體cpu執(zhí)行過程如下圖所示:
3、第三步我們首先來看cpu執(zhí)行指令的一、二階段,cpu是怎么取指令和進行指令譯碼,將指令先從主存里面取出,然后放到寄存器,最后進行指令譯碼,這樣就完成cpu執(zhí)行指令的一、二階段,具體如下圖所示:
4、第四步cpu執(zhí)行指令的三、四階段,首先根據(jù)指令規(guī)定的操作,完成具體功能,最后訪問主存,操作數(shù),得到物理地址,就完成了執(zhí)行指令和訪問主存的三、四階段,如下圖所示:
5、第五步在cpu第四階段訪問主存的時候,需要得到物理地址,具體讀寫過程如下圖所示:
6、第六步我們也可以看一下cpu是怎么讀指令的,下面是cpu的工作原理,如下圖所示:
7、第七步cpu執(zhí)行指令進去到了第五個階段,也是最后一個階段回寫結果,把第三階段執(zhí)行指令的運行結果數(shù)據(jù)回寫到一種存儲形式,cpu這樣就成功執(zhí)行完了一條指令,如下圖所示
-
cpu
+關注
關注
68文章
11065瀏覽量
216571
發(fā)布評論請先 登錄
單片機執(zhí)行指令過程詳解
計算機執(zhí)行指令的過程分析

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

ARM程序的執(zhí)行過程詳解
單片機是如何執(zhí)行指令過程?MCU內存又是如何分配的?
CPU操作指令詳解
CPU指令的執(zhí)行過程 CPU指令流水線

評論