作業名稱: LAB5 The Arithmetic Logic Unit

## 系統架構:



## 設計模組分析:

在 pipe\_cpu\_1 裡這個 module 主要是要讓我們接線,而這次比上次多了幾個 module也就是hazard detection unit還有forwarding unit這兩個module,hazard detection unit主要是在偵測load-use的情況,如果遇到load-use就stall the pipeline,而 forwarding unit這個module是用來控制mux,用forwarding回來的值。

## 設計結果與功能說明:

hazard detection unit主要是在偵測load-use的情況,如果遇到load-use就stall the pipeline,而forwarding unit這個module是用來控制mux,用forwarding回來的值,如果是在ex這一級遇到hazard也就是ex/mem.regwrite是1,而且ex/mem.registerrd!=0,而且ex/mem.registerrd==id/ex.registerrs,就讓這裡的mux選擇forearding回來的值,而在mem這一級遇到hazard,為了防止遇到和前述一樣的情況,使得mux不知道要填哪一個值,所以不等於前述情況外,mem/wd. regwrite是1,而且mem/WB.registerrd!=0,而且mem/wb.registerrd==id/ex.registerrs,如果符合上述情况,就讓mux選擇wb forwarding回來得值。



遭遇困難與解決方法:

在此次遭遇的困難就是因為多增加了 hazard detection unit 的 if flush,id flush 之類的東西,讓每一級和每一級之間的 register 多增加了幾個 bits,而我們是利用 lab4 再來擴增的,所以導致有些 bit 數算錯,在 debug 這方面有一點困難。作業心得討論:

這次的 lab 讓我們更了解了 hazard detection unit 與 forwarding unit 的運作情況,像是當什麼情況要 forwarding 哪一級回傳的值,才不會導致 alu 運算出錯,還有什麼情況要 stall the pipline,都讓我們有更深一層的了解。