# به نام خدا

# فاز سوم پروژه معماری کامپیوتر



نيمسال دوم سال تحصيلي ۱۴۰۰–۱۴۰۱

دانشگاه صنعتی شریف

دانشكده مهندسي كامپيوتر

### توضيحات فاز

در این فاز ما باید به پردازندهای که طراحی کردیم، پایپلاین اضافه کنیم. در این فاز نیازی نیست که data dependency و در این فاز نیازی نیست که طراحی میشود باید در این فاز نیازی نیست که طراحی میشود باید قابلیت stall داشته باشد چرا که مموری لزوما در یک کلاک جواب ما را حاضر نمیکند.

## اعضای تیم:

- سهیل نظری مندجین
  - بنیامین ملکی
  - هيربد بهنام
  - هیراد داوری

## دیتافلو پردازنده:

در شکل زیر میتوانید dataflow پردازنده را مشاهده کنید. همان طور که مشخص است ما pipeline مرحلهای که در پردازندههای میپس متداول است را پیاده سازی کردهایم.



این عکس از اسلایدهای استاد برداشته شده است که کمی تغییر کرده است. به عنوان مثال برای انجام دستور jr مجبور شده بودیم (از فاز یک) که یکی از ورودیهای احتمالی pc را برابر اولین رجیستر قرار دهیم. یا مثلا 4+pc را یکی از ورودیهای احتمالی pc را برابر اولین رجیستر قرار دهیم.

### رجیسترهای استفاده شده:

از آنجا که پایپلاین ما ۵ مرحلهای است به ۴ نوع رجیستر در جایگاههای مختلف نیاز داریم. این رجیسترها در dataflow و فایل mips\_core.v با پسوندهای exmem ،idex ،ifid و میتوانید در کامنت جا پسوندهای exmem ،idex ،ifid و تک تک کاربرد آنها را میتوانید در کامنت جلوی این خطها مشاهده کنید.

#### :Branch Prediction

با اینکه در این فاز گفته شده بود که نیازی به هندل کردن control dependency و stall کردن pipeline نیست، اما با صحبتهایی که branch prediction با اعضای گروه داشتیم تصمیم گرفتیم که یک static branch perdition برای پردازنده پیاده سازی کنیم. این نوع

#### فاز سوم پروژه معماری کامپیوتر

از نوع not-taken است و همیشه pc = pc + 4 قرار داده می شود مگر زمانی که در استیت مموری تشخیص داده شود که باید branch یا pc = pc + 4 قرار داده می قرفته است. در صورتی که تشخیص بر این موضوع باشد، باید تمامی رجیسترهای IF/ID و EX/MEM و EX/MEM را خالی کرد (به اصطلاح فلاش کرد) و  $pc = new\_address$  قرار داد.

برای فلاش کردن ماکرو FLUSH\_PIPELINE تعریف شده است که یک ورودی میگیرد. در صورتی که ورودی آن یک باشد تمامی pipeline bufferها پاک میشود و در غیر این صورت MEM/WB دست نخورده باقی میماند.

دقت کنید که data dependency هندل نشده است و نیاز است که nop بین دستورات قرار داده شود. این موضوع در تست کیسها رعایت شده است.