主頁 >  其他 > 【XJTUSE 計算機組成與結構筆記】 第十二章 CPU結構和功能

【XJTUSE 計算機組成與結構筆記】 第十二章 CPU結構和功能

2021-12-28 11:52:01 其他

第十二章 CPU結構和功能

1、處理器內部結構,了解就行

2、暫存器組織,暫存器分類、用戶可見和控制狀態暫存器,通用暫存器能存什么,資料和地址暫存器是否區分,長度如何確定,條件代碼用來干什么,存在哪里

3、控制和狀態暫存器了解就行

4、指令周期,包括哪幾個部分,子周期關系,前后關系,哪些必須,哪些可能

5、流水線

為什么要采用流水線,流水策略有哪些,分段,?? 指令流水操作時序圖

哪些因素影響流水線性能、流水線性能衡量標準:加速比與吞吐量要掌握

5、指令流水線處理條件轉移指令的幾種方式

12.1 CPU組成

CPU執行指令的步驟:

取指令

解釋指令

取資料

處理資料

寫資料

為了執行指令,CPU必須包括ALU和CU,同時,CPU需要臨時存盤一些資料,包括下一條指令的位置,因此,CPU需要一個小的內部記憶體——暫存器

12.2 暫存器組織

暫存器:CPU中用于暫存的一小塊作業空間(I/O中也有)

是CPU設計需要考慮的一個重要因素

1?? 用戶可見暫存器User-visible registers

允許機器語言或匯編語言的編程人員通過優化暫存器的使用而減少對主存的訪問

2?? 控制和狀態暫存器Control and status registers

由控制器來控制CPU的操作,并由擁有特權的作業系統來控制程式的執行

用戶可見暫存器

通用目的暫存器general purpose register

也許真的是通用的

可能是受限制的

可能有用于浮點和堆疊操作的專用暫存器

可用于資料或尋址

資料暫存器

累加器

地址暫存器

段指標、堆疊指標

條件碼暫存器

由CPU硬體設定的位,作為最后一次操作的結果

COAPZS

正,負,零,溢位,等等,

在存盤最后一個操作的結果之后,還會設定一個條件代碼,這個代碼可以用于條件分支

可以被程式隱式地讀取、通常不能被程式設定

對程式員部分可見

采用更多的通用暫存器/專用暫存器?

1?? 采用更多的通用暫存器

增加靈活性,給程式員提供了更大的自由,尋址方式也可以更豐富

增加指令的長度和復雜度

2?? 采用更多地專用暫存器

更短的指令

靈活性變差

控制和狀態暫存器

程式暫存器PC:存有待取指令地地址

指令暫存器IR:存有最近取來的指令

存盤器地址暫存器MAR:存有存盤器位置的地址

存盤緩沖暫存器MBR:存有將被寫入存盤器的資料字或最近被存盤器讀出的字

很多CPU設計都包括程式狀態字PSW的一個或一組暫存器,一般含有條件碼和其他狀態資訊,大多對程式員不可見

符號sign

進位carry

等于equal

溢位overflow

中斷允許\禁止

監管supervisor(CPU處在監管模式還是用戶模式)

子程式呼叫,不需要保存現場,就是一段代碼的替換

設計控制暫存器時要考慮兩個因素

1?? 作業系統支持

CPU設計與作業系統設計是緊密聯系在一起的,二者應該相互配合

2?? 控制資訊分配在記憶體和暫存器

控制資訊也可以存盤在主存的前幾百個字中,設計者必須決定有多少在暫存器中,有多少在記憶體中

微處理器暫存器舉例

12.3 指令周期

間接尋址周期

可能需要記憶體訪問才能獲取操作

間接處理需要更多的記憶體訪問

可視為附加指令子周期

一旦取來一個指令,它的運算元指定符必須被識別,然后讀取存盤器中的每個運算元,這個程序可能要求間接尋址,暫存器運算元不需要從存盤器讀取,一旦操作完成,可能需要一個類似的程序將結果存入主存,

資料流

假定一個CPU中有一個MAR、一個MBR、一個PC、一個IR

取指周期

PC存有待取的下一條指令的地址

地址被送到MAR

地址放在地址總線中

控制器發出一個存盤器讀的請求

存盤器將結果放在資料總線中,CPU將其復制到MBR,然后傳送到IR

同時,PC+1

一旦經歷過取指周期,控制器會檢查IR中的內容

間接周期

一旦經歷取指周期,檢查器檢查IR的內容,確定是否有一個使用間接尋址的運算元指定符,若是則進入間接周期

MBR最右邊的N位是一個地址參考,被送入MAR

控制器發一個存盤器讀,得到運算元地址

送入MBR

執行周期

沒有固定地形式,取決于實際執行的指令

中斷周期

PC的當前的內容被保存,以便在中斷之后CPU能恢復先前的動作

PC的內容被送到MBR,寫入存盤器

一個專門的存盤器位置被控制器裝入MAR(可能是一個堆疊指標)

中斷子程式的地址裝入PC

可獲取下一個指令(中斷處理程式的第一個指令)

12.4 指令流水線(重點)

指令預取

可以將指令處理分為兩個階段:取指令和執行指令,在指令執行程序中,主存可能沒有存取操作,可以在解碼和執行當前指令時獲取下一個指令,

這種方式需要指令快取,需要更多的暫存器

預取可以提速,但是速度不會翻一番,若指令之間有關系,會造成無效快取以及速度降低

指令流水線instruction pipelining

處理相關任務時,資源能錯開使用,不均等分段會降低流水線的效率

指令流水線可將指令處理分解如下:

取指令FI:從cache中讀下一條指令

譯碼指令DI:decode instruction

計算運算元CO:計算每個源運算元的有效地址,涉及偏移尋址、暫存器間接尋址等

取運算元FO:從存盤器中取出運算元,暫存器中的數不需要取

執行指令EI

寫運算元WO

實際運行中,指令之間肯定會有依賴,條件轉移也會降低速度,有條件轉移是在執行階段知道轉還是不轉

C語言中的goto是無條件轉移、for回圈是條件轉移

流水線性能

指令流水線的周期 τ \tau τ,是在流水線中將一組指令推進一段所需的時間,表示公式如下(掌握定義):
τ = m a x i [ τ i ] + d = τ m + d 1 ≤ i ≤ k \tau=max_i[\tau_i]+d=\tau_m+d\qquad 1\le i\le k τ=maxi?[τi?]+d=τm?+d1ik
其中:

τ i = 流 水 線 第 i 段 的 電 路 延 遲 時 間 \tau_i=流水線第i段的電路延遲時間 τi?=i

τ m = 最 大 段 延 遲 \tau_m=最大段延遲 τm?=

k = 指 令 流 水 段 數 k=指令流水段數 k=

d = 鎖 存 延 時 d=鎖存延時 d=

通常延時d等于時鐘脈沖的寬度而且 τ m > > d \tau_m>>d τm?>>d

假設現有n條指令在進行,無轉移發生,令 T k , n T_{k,n} Tk,n?為k階段流水線執行所有n條指令所需的總時間,則有:
T k , n = [ k + ( n ? 1 ) ] τ T_{k,n}=[k+(n-1)]\tau Tk,n?=[k+(n?1)]τ
提速比
s k = n k τ [ k + ( n ? 1 ) ] τ = n k k + ( n ? 1 ) s_k=\frac{nk\tau}{[k+(n-1)]\tau}=\frac{nk}{k+(n-1)} sk?=[k+(n?1)]τnkτ?=k+(n?1)nk?
吞吐率 T p T_p Tp?流水線單位時間內產生的指令數掌握定義
T p = n [ k + ( n ? 1 ) ] τ T_p=\frac{n}{[k+(n-1)]\tau} Tp?=[k+(n?1)]τn?

T p m a x = 1 τ T_{pmax}=\frac{1}{\tau} Tpmax?=τ1?

n > > k , T p ≈ T p m a x n>>k,T_p\thickapprox T_{pmax} n>>kTp?Tpmax?

舉例

考慮一個時鐘周期為50ns的單流水線處理器有5個流水線階段:FI、DI、FO、EX和WB,假設每個階段的持續時間相等,需要2個時鐘周期,它需要執行8個連續指令,

繪制流水線各功能階段時序圖,計算提速和吞吐量,假設在執行指令期間沒有沖突、依賴或分支,

如果指令4是一個條件轉移指令,并且轉移的目標是指令7,在此執行中,結果是進行分支,繪制流水線各功能階段時序圖,計算提速和吞吐量,假設在指令8之后,沒有其他指令要執行,

流水線相關性pipeline hazard

流水線相關性發生在流水線,因為某些條件不允許流水線亟需運行,而必須停頓,也稱為流水線空泡pipeline bubble,有三種型別:

結構相關(資源沖突)resource hazard

發生在兩條(或多條)已進入流水線的指令需要使用相同資源的時候

就意味著某些指令的處理程序需要停滯

資料沖突data hazard

資料沖突發生在對一個運算元位置的訪問出現沖突的時候,

程式中的兩條指令是依次執行,并且都將訪問同一個記憶體或者暫存器運算元,如果這兩條指令是嚴格執行的,那么沒問題發生,如果在流水線中運行,可能會使運算元不按次序更新,從而產生不正確的結果

舉例:

第一條指令將暫存器EAX和EBX中的內容相加,并將結果保存在EAX暫存器;

第二條指令從ECX中減去EAX,并將結果存回ECX;

ADD指令

1?? 寫后讀相關或真實資料相關(RAW)

一條指令改寫一個暫存器或記憶體地址

而后續的指令從所改寫的暫存器或記憶體地址讀取資料

如果在寫操作完成之前,讀操作就開始進行,那么就會發生相關

2?? 讀后寫相關或反相關(WAR)

一條指令讀一個暫存器或記憶體地址

而后續的指令又將改寫該暫存器或記憶體地址的內容

如果在讀操作完成之前,寫操作就開始執行,那么就會發生相關

3?? 寫后寫相關或輸出相關(WAW)

兩條指令要改寫同一個暫存器或記憶體地址

如果這兩條指令的寫操作發生次序與期望的次序相反,那么就會發生相關

在按序流動的流水線中,只可能出現RAW相關

控制沖突Control Hazards

也稱為分支沖突,發生在流水線對分支轉移做出了錯誤的預測,因此讀取了后期必須取消的指令的時候,處理辦法如下:

1?? 多個指令流multiple streams

使用兩個流水線

每個分支預取到單獨的流水線中執行

最終依據條件轉移指令結果選擇保留其中一條流水線的結果

問題

導致暫存器和存盤器訪問的競爭延遲

多個分支導致需要更多的流水線

應用

由IBM370,3033使用

2?? 預取分支目標prefetch branch target

除了取條件分支指令之后的指令外,分支目標處的指令也被預取

預取的結果會放到一個特殊的暫存器

目標被保存直到分支指令被執行

應用:IBM 360/91使用

3?? 回圈緩沖器loop buffer

維護一個小的但極高速的存盤器,含有n條最近順序取來的指令

流水線取指階段維護

若一個轉移將要發生,硬體首先檢查轉移目標是否在此緩沖器中

非常適合小的回圈

類似于指令高速快取,不同在于它只保留順序的指令,因而容量較小,成本也較低

應用:CRAY-1使用

4?? 分支預測

包括

預測絕不發生

預測總是發生

依據操作碼

假定對某些條件轉移指令總是預測發生轉移,對另外的一些轉移總是預測不發生轉移

發送/不發生切換

Bits (1~2bits):記錄執行轉移情況

適合回圈和迭代

轉移歷史表

是一個小容量的Cache — BTB/BHT

前三種靜態,后兩種動態:取決于執行的歷史

5?? 延遲轉移

插入NULL操作

阻塞流水線

使用在早期CPU上

重排序指令

亂序執行

目前機器常用

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/395371.html

標籤:其他

上一篇:【C語言初級】給定兩個整形變數的值,將兩個值的內容進行交換的兩種方法

下一篇:facebook鏈接的檢查串列是FB頁面還是FB個人資料?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more