![一種多線程輕核處理器進程管理的硬件設計_第1頁](http://file4.renrendoc.com/view/337a3f644f44bbc36d4fabde06552261/337a3f644f44bbc36d4fabde065522611.gif)
![一種多線程輕核處理器進程管理的硬件設計_第2頁](http://file4.renrendoc.com/view/337a3f644f44bbc36d4fabde06552261/337a3f644f44bbc36d4fabde065522612.gif)
![一種多線程輕核處理器進程管理的硬件設計_第3頁](http://file4.renrendoc.com/view/337a3f644f44bbc36d4fabde06552261/337a3f644f44bbc36d4fabde065522613.gif)
![一種多線程輕核處理器進程管理的硬件設計_第4頁](http://file4.renrendoc.com/view/337a3f644f44bbc36d4fabde06552261/337a3f644f44bbc36d4fabde065522614.gif)
![一種多線程輕核處理器進程管理的硬件設計_第5頁](http://file4.renrendoc.com/view/337a3f644f44bbc36d4fabde06552261/337a3f644f44bbc36d4fabde065522615.gif)
下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
一種多線程輕核處理器進程管理的硬件設計
在過去幾十年中,摩爾定法下電路的集成密度隨著指數率的增加而增加。目前,大型芯片可以集成數十億個芯片。但是,靠提高芯片主頻來增加處理器能力的方法會帶來日益增長的功耗,致使芯片無法克服散熱問題。研究表明,內存中數據的傳輸和ILP(指令級并行)1共享存儲的監(jiān)控設計本文設計了一種新型的多線程輕核處理器,該輕核并行處理器是一個陣列機,由多個處理單元簇(cluster組成,每個簇是由處理單元(PE)組成的一個二維陣列(2DArray),是一種較常見的陣列結構。一個基本簇(basecluster)通常是16個處理單元組成的4×4陣列,如圖1所示。其特點是:采用近鄰連接的網絡拓撲結構;采用雙模式的指令集,高效實現并行處理所需的線程間通信;采用專用遠程數據傳輸指令和多播方式及相應的路由器,滿足了輸出數據的扇出需求和遠距離線程間的數據通信。上述特點需要高性能的線程管理機制鄰居共享存儲M[S]分為4個部分:Me(東)、Mw(西)、Ms(南)和Mn(北),每部分用于與相鄰處理器通信。在設計中分別為寄存器R28、R29、R30、R31。共享存儲器的存取采用阻塞模式(線程間同步),每個共享存儲地址都有一位數據有效位。當讀取數據時,如果數據無效,則當前線程需要等待;如果數據有效,則讀取數據,并將其置為無效。當寫入數據時,數據無效則直接寫入,數據有效則等待。路由器RU負責將數據傳輸到遠程處理器件,指令控制器(ICTL)模塊通過計算把指令寫入指令存儲(I-men)中,方便處理器對所需指令的讀取。ALU中的指令讀取單元含有一個程序計數器(PC)和一個進程地址寄存器(Creg)。每個進程都分配一塊數據存儲,其基地址可以放在Creg中。T_control完成進程的調度、每個進程自身的狀態(tài)跳轉、每個進程信息的存儲,以及事件檢測(路由器遠程數據傳輸和相鄰的共享存儲器中數據的檢測)。t_control根據進程表實現一步到位的上下文轉換,發(fā)送相應的PC和Creg中的當前數值給ALU來調度處理器處理當前進程。2進程的監(jiān)控設計總體設計中采用8個進程并發(fā)執(zhí)行。進程管理器由一個控制模塊(t_manager)、一個就緒隊列模塊(ready_list)、8個進程的狀態(tài)轉換模塊(t_state)、8個進程的寄存器模塊(regfile)和一個進程信息表模塊(t_table)構成(1)控制模塊(t_manager):首先創(chuàng)建進程,根據每個進程的狀態(tài)(初始態(tài)、就緒態(tài)、運行態(tài)、阻塞態(tài))創(chuàng)建就緒隊列;完成后開始采用輪詢的方法控制每個進程的調度(2)進程狀態(tài)轉換模塊(t_state):主要分為兩部分:其一是進程的自身4個狀態(tài)之間的跳轉控制部分;其二是進程阻塞后的檢測部分。一般是實現8個或者16個并發(fā)進程,圖3所示為8個進程的設計圖,每個進程需要有自己的t_state模塊,圖中可以看到8個進程狀態(tài)控制轉換模塊。(3)寄存器模塊(regfile):每個進程擁有自己獨立的32個寄存器,寄存器R0~R27每個進程自己可以讀寫,但是鄰居處理器不可以讀寫;寄存器R28~R31是處理器與鄰居4個處理器共享的寄存器,本設計的Me(東)、Mw(西)、Ms(南)、Mn(北)4個寄存器分別指的是R28、R29、R30和R31。(4)進程的相關參數的維護表(t_table):用來記錄每個進程的當前狀態(tài),并且維護進程阻塞和恢復時的數據。整個控制模塊根據這個進程表中的每個進程的當前狀態(tài)和處理器的忙閑來實現一步到位的上下文轉換。2.1進程控制模塊當創(chuàng)建一個進程時,就為進程建立了一個相應的狀態(tài)參數表,圖4所示為一個進程的狀態(tài)參數表。設計中為8個進程,需要8組如圖所示的參數表。狀態(tài)參數描述如下:(1)QT:時間片,是指系統(tǒng)給每個進程所分配的執(zhí)行時間。一旦時間片用完,當前進程就掛起,等待下次的調度。(2)PC:程序計數器,是指進程的程序在內存或者外存中的物理位置。進程掛起或者阻塞時,首先存儲當前程序執(zhí)行的PC到t_table中,再進行其他操作;進程需要執(zhí)行時,首先從t_table中讀取PC值,再進行程序的讀取和其他操作。(3)STAMP:時間戳。每次從進程開始執(zhí)行進行計數,如果STAMP==QT,則掛起進程;如果在STAMP!=QT時,進程發(fā)生阻塞,則保存當前的STAMP,待下次調度進程時,從保存的STAMP值開始計數并與時間片進行比較。(4)STATE:狀態(tài)標志。每個進程都有4個狀態(tài),即:IDLE初始狀態(tài):00,READY就緒狀態(tài):01,RUNNING初始狀態(tài):10,WAITING阻塞狀態(tài):11。(5)進程現場保護:AVAIL表示3個算子中是否有數據;MASK表示3個算子是否有用;A0,A1,AD表示進程阻塞時候的3個算子的地址。(6)ACT:表示進程是否有效。2.2確定就緒任務后的轉換電路每個進程都有自身4個狀態(tài)之間的跳轉控制,設計中8個進程采用輪詢的調度策略來控制進程的上下文轉換,并且產生與處理器之間的接口信號,狀態(tài)機如圖5所示。狀態(tài)跳轉解釋如下:(1)INIT:初始狀態(tài)。首先創(chuàng)建進程和進程的就緒隊列,就緒隊列完成后跳轉到P1狀態(tài)。(2)P1:檢測就緒隊列的空滿。如果就緒隊列空,則說明沒有就緒狀態(tài)的進程,繼續(xù)等待就緒隊列的產生;如果不空則說明有就緒的進程,采用輪詢的調度方法調度進程,即從就緒隊列中讀取第一個進程號碼。(3)P2:發(fā)送進程id號碼到進程狀態(tài)控制模塊t_state,并且發(fā)送進程處理信號id_enable為高電平給進程狀態(tài)控制模塊t_state,跳轉到P3狀態(tài)。(4)P3:發(fā)送信號cpu_enable(高電平)、cpu_creg(進程id號碼)、pc(進程的程序地址)給處理器,等待處理器的處理。一旦信號t_enbale為高電平,表示當前進程掛起或者執(zhí)行完成了,則跳轉到P1狀態(tài),cpu_enable置低。2.3進程的跳飛式操作進程狀態(tài)轉換模塊的設計分為兩部分介紹:一是進程自身4個狀態(tài)之間的跳轉控制部分的詳細設計;二是每個進程阻塞后的檢測部分的詳細設計。下面主要介紹單個進程的狀態(tài)控制。每個進程都有4個狀態(tài),跳轉如圖6所示。各狀態(tài)說明如下:(1)INIT:初始狀態(tài)。檢測進程的PCB表的act信息,一旦為高(表示進程是可用的),則跳轉到下一個狀態(tài)READY。(2)READY:就緒狀態(tài),表示進程已經具備了運行條件,但是處理器不一定是空閑的,如果不空閑,則暫時不能使用,需等待分配處理器。即檢測進程啟動信號id_enable,一旦為高(表示處理器空閑,進程可以執(zhí)行),則跳轉到RUNNING狀態(tài)。(3)RUNNING:運行狀態(tài)。首先讀取t_table中對應進程號的QT(時間片)、PC(進程的程序的計數器)和STAMP(時間戳);處理器開始執(zhí)行該進程的程序后,時間戳與時間片相等了,表示該進程的時間片結束了,則跳轉到READY狀態(tài),并且保護現場,把當前的進程號寫入就緒隊列中,等待下次的調度;當處理過程中發(fā)生了阻塞,則跳轉到WAIT狀態(tài),把當前的PC(進程的程序的計數器)、STAMP(時間戳)、MASK(3個算子中有用的算子標志)、AVAIL(3個算子中有數據的標志)、A0,A1,AD(3個算子的地址)寫入t_table中,保護現場;當進程的程序處理完時,act置低,跳轉到INIT狀態(tài),不再被調度。(4)WAIT:阻塞狀態(tài),即進程在運行過程中,因為等待某一事件(如等待一個輸入/輸出操作完成)而暫時不能運行的狀態(tài)。這種狀態(tài)下,發(fā)送t_enable高電平到進程控制模塊,同時啟動監(jiān)測模塊進行所需數據的監(jiān)測,如果t_flag為高電平,則表示監(jiān)測信號監(jiān)測到了相應的數據,此時進程恢復READY狀態(tài),并且跳轉到READY狀態(tài),等待下一次進程的啟動。3簡單的功能測試電路設計采用Verilog硬件描述語言,在Xinlinx公司的ISE環(huán)境下完成功能仿真和綜合。在陣列機的基礎上,采用指令集編寫簡單的算法完成了簡單功能測試。算法如3×3矩陣的加減法、多個數的最大公約數與最小公倍數的求解和奇偶算法。圖7所示是一個簡單的3×3陣列機,采用一個處理器和一個進程控制器組成一個pe,圖中的寄存器是相鄰處理器之間的共享寄存器。3.1pe0仿真結果測試激勵為:pe0、pe1、pe2各自包括3個進程,3個進程分別執(zhí)行不同的3×3矩陣加法。圖7所示的pe之間的寄存器(即共享寄存器)中,R30/R28是pe與左右鄰之間的共享寄存器,R31/R29是pe與上下鄰之間的共享寄存器。根據測試激勵,pe0會發(fā)生阻塞,pe1和pe3進程都是順序執(zhí)行。pe0的仿真結果圖如8所示,分析如下:(1)首先執(zhí)行0號進程。從圖中cpu_creg為000(0號進程)的信號可以看出,當執(zhí)行完成以后沒有發(fā)現阻塞,進程0順利執(zhí)行完成,信號t_over為高。3.2第三次偶排序基于奇偶原理和歸并—拆分模式(1)將6個數據分別存儲到6個pe的寄存器R0中。(2)開始進行第一次偶排序,此時pe0、pe2、pe4分別讀取R30(CPU與右鄰的共享寄存器)的數據,而pe1、pe3、pe5把數據從寄存器R0移到R28中,這樣3個pe并發(fā)地執(zhí)行第一次偶排序。(3)開始進行第一次奇排序,此時pe1、pe3通過R30讀取右鄰的pe2、pe4中的數據,pe2、pe4在上次的偶排序時已經把數據存放到自身寄存器R28中,這樣2個pe并發(fā)地執(zhí)行第一次奇排序,pe0和pe5等待下次的偶排序。(2)然后根據調度算法調度1號進程(cpu_creg為001)。信號cpu_flag為標志信號,其為1表示寄存器R8或者R31沒有數據,此時發(fā)生阻塞,則掛起1號進程,同時啟用監(jiān)測模塊對1號進程沒有數據的寄存器R31進行監(jiān)測。(3)在監(jiān)測的同時根據調度算法調度2號進程(cpu_creg為010)。若2號進程也發(fā)生了阻塞(cpu_flag為1),則掛起2號進程,同時進行2號進程所需要的數據的監(jiān)測;在2號進程的執(zhí)行過程中1號進程就緒,這時2號進程一旦掛起則調度1號進程(cpu_creg為001)繼續(xù)執(zhí)行,直到1號進程執(zhí)行完成(t_over為1);重復以上操作,處理完所有的進程。(4
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 房屋租賃合同的擔保合同
- 商砼購銷的合同
- 采購合同的主要類型
- 物流公司承運合同
- 網絡營銷執(zhí)行作業(yè)指導書
- 平面設計軟件應用作業(yè)指導書
- 公司給員工的勞動合同
- 2025年南京貨運從業(yè)資格證500道題目答案大全
- 電力分配合同(2篇)
- 2024-2025學年高中英語課時分層作業(yè)3含解析新人教版選修9
- DB4420-T 7-2021 養(yǎng)老機構突發(fā)傳染病疫情防控規(guī)范
- 四年級上冊100道口算題大全(通用版各類)
- 四川省成都市2023年中考數學真題卷+答案
- 電阻焊點焊標準參考七所提供資料
- 誡子書教案一等獎誡子書教案
- 淺析音樂課堂中如何培養(yǎng)核心素養(yǎng) 論文
- 最全螺栓扭矩表(各種標準)
- 電力安全工作規(guī)程(電網建設部分)2023年
- 呆死帳的發(fā)生與預防課件
- 10000中國普通人名大全
- 導數常見函數圖像
評論
0/150
提交評論