您好,歡迎來到易龍商務網!
發布時間:2020-08-09 14:12  
【廣告】





程序的運行過程,實際上是程序涉及到的、未涉及到的一大堆的指令的執行過程。當程序要執行的部分被裝載到內存后,CPU要從內存中取出指令,然后指令解了碼(以便知道類型和操作數,簡單的理解為CPU要知道這是什么指令),然后執行該指令。再然后取下一個指令、解了碼、執行,以此類推直到程序退出。
CPU出現于大規模集成電路時代,處理器架構設計的迭代更新以及集成電路工藝的不斷提升促使其不斷發展完善。從初專用于數學計算到廣泛應用于通用計算,從4位到8位、16位、32位處理器,后到64位處理器,從各廠商互不兼容到不同指令集架構規范的出現,CPU 自誕生以來一直在飛速發展。
為了改善性能,CPU已經不是單條取指-->解了碼-->執行的路線,而是分別為這3個過程分別提供獨立的取值單元,解了碼單元以及執行單元。這樣就形成了流水線模式。
用戶態的CPU,只允許執行指令集中的部分指令。一般而言,IO相關和把內存保護相關的所有執行在用戶態下都是被禁止的,此外其它一些特權指令也是被禁止的,比如用戶態下不能將PSW的模式設置控制位設置成內核態。
控制器之所以知道數據放哪里、做什么運算(比如是做加法還是邏輯運算?)都是由指令告訴控制器的,每個指令對應一個基本操作,比如加法運算對應一個指令。例如,將兩個MDR寄存器(保存了來自內存的兩個數據)中的值拷貝到ALU中,然后根據的操作指令執行加法運算,將運算結果拷貝會一個MDR寄存器中,后寫入到內存。