## به نام خداوند بخشنده بخشایشگر

402105813 و 402106604 شماره دانشجویی:

عرفان تیموری و محمدرضا منعمیان



## Practical 5



## شرح پیاده سازی:

در این تمرین مدار تمرین 4 را کاملتر کردیم و تعدادی دستور را به این مدار اضافه کردیم؛ همچنین امکان اجرای دستوری که اجرای آن به چند کلاک نیاز دارد (دستور div) را به مدار اضافه کردیم. ابتدا در قسمت main تغییراتی به وجود آوردیم که امکان اجرای دستورات جدید فراهم شود:





با توجه به اضافه شدن سیگنال inst\_done مجبور به اضافه کردن ماژول handle\_inst\_done شدیم. در این ماژول مواره div می اسیکل احتیاج دارد. در inst\_done = 1 خواهد بود، مگر اینکه دستور div وارد شود؛ چون اجرای آن به div کلاک سایکل احتیاج دارد. در اینصورت inst\_done به مدت div کلاک div می شود و پس از اتمام اجرای دستور div دوباره مقدار آن div می شود.



برای مدیریت واحد کنترلی و اینکه هنگام دریافت Opcode هر دستور چه عملیاتی در ALU انجام شود، دو ماژول Control\_ALU و Control\_unit به مدار اضافه شدند. در این دو ماژول از مدارهای ترکیبی برای ساختن بیتهای کنترلی استفاده می کنیم. در واقع با استفاده از جدول کارنو هر بیت کنترلی را به صورت یک sum of product نوشته و مدار آن را به کمک گیتهای AND, OR می سازیم.







در آخر مدار را تست می کنیم:

load 000001f8
ipc : 62
mem : [1f9] : 0[1fa] : 10[1fb] : 34[1fc] : 55[
ACCEPTED
425 / 425
mohamamdreza@mylove:~/CA/SUT\_CA\_4032\_ProfAsadi\_Judgement\_System-master\$