

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

دكتر ميثم عبداللهي

بهار ۱۴۰۰

تمرین سری دوم

طراحى كامپيوترى سيستمهاى ديجيتال

پارسا کنگاوری – شایان موسوی نیا

تاریخ تحویل: جمعه ۱۹ فروردین ساعت ۲۳:۵۹:۵۹

### قوانين:

- ♣ سوالات این تمرین از مبحث «طراحی Behavioural» میباشد. لذا برای پاسخ به سوالات این تمرین، نیاز به دانش نسبی درمورد این مبحث دارید.
  - این تمرین شامل ۳ سوال منحصرا عملی میباشد.
- 🖊 🥕 درصورت وجود هرگونه سوال، در کلاس درس و یا در گروه تلگرامی درس بپرسید. (لطفا پیوی پیام ندهید.)
- ♣ هرگونه ایده گرفتن از تمرین دیگران و کدهای موجود در اینترنت که موجب تشابه غیرعادی و بالای کد شما با دیگری شود، تقلب محسوب می شود. در صورت مشاهده ی تقلب، نمره ی تمرین برای هر دو دانشجوی متخلف <u>صغو</u> منظور خواهد شد.
  - برای هر سوال باید Testbench نیز طراحی کنید.
- الطفا برای انجام تمرین، زمان مناسب اختصاص دهید و انجام آن را به روزهای پایانی موکول نکنید. دقت کنید تمرین به هیچ عنوان تمدید نخواهد شد.
- پاسخ ارسالی شما باید علاوه بر کدهای مربوطه و فایل Proteus از مدار طراحی شده برای هر سوال، شامل یک گزارش در قالب یک فایل PDF باشد که محتوای گزارش مربوطه توضیحات تکمیلی شما درخصوص هر سوال و اسکرین شات از نتیجه اجرای کدهای شما باشد.
- ♣ تمامی فایل های موردنیاز برای تمرین را به صــورت یک فایل ZIP با فرمت شــماره دانشــجویی\_نام و نام خانوادگی\_HW2 نامگذاری کرده و ارسال کنید. (برای مثال HW2\_NameFamily\_98000000)
- ا تأخیر در ارسال تمرینها براساس نمودار زیر محاسبه خواهد شد. محور افقی نمودار، مقدار تاخیر به ثانیه و محور عمودی، ضریب اعمالی در نمره تمرین است.



## سوال اول

#### ALU ساده

در این مسئله قصد داریم با بهمبندی ماژولهای ساخته شده، یک ALU بسیار ساده با قابلیت انجام چند عملیات پردازشی محدود را انجام دهد. در ابتدا ماژولهای زیر را طراحی و پیاده سازی کنید:

- ماژولی طراحی کنید که با دریافت دو عدد صحیح، حاصل جمع آن دو را خروجی دهد.
- ماژولی طراحی کنید که با دریافت دو عدد صحیح، حاصل تفریق عدد اول از عدد دوم را خروجی دهد.
  - ماژولی طراحی کنید که با دریافت دو عدد صحیح، حاصل ضرب آن دو را خروجی دهد.
- ماژولی طراحی کنید که با دریافت دو عدد صحیح، حاصل تقسیم عدد اول بر عدد دوم را خروجی دهد.
  - ماژولی طراحی کنید که با دریافت دو عدد صحیح، ب.م.م آن دو را خروجی دهد.
  - ماژولی طراحی کنید که با دریافت دو عدد صحیح، حاصل عدد اول به توان عدد دوم را خروجی دهد.

در ادامه یک مالتیپلکسر 8\*3 پیاده سازی کنید. توجه فرمایید که این مالتیپلکسر باید با استفاده از روش behavioral پیادهسازی شده باشد نه با استفاده از گیتهای منطقی.

در نهایت با توجه به جدول زیر، ALU را طوری پیادهسازی کنید که با دریافت ۲ عدد صحیح و ۳ bit به عنوان selector عملیات مناسب را انجام دهد:

| Selector | عمليات |
|----------|--------|
| "000"    | جمع    |
| "001"    | تفريق  |
| "010"    | ضرب    |
| "011"    | تقسيم  |
| "100"    | ب.م.م  |
| "101"    | توان   |

توجه فرمایید که اعداد ورودی و خروجی نمایش بیتی ندارند و اعداد صحیح هستند و این سوال صرفا یک شبیهسازی است.

## سوال دوم

#### Cache

یک حافظه Cache و یک Cache Controller را با توجه به نکات زیر پیاده سازی نمایید.

- اندازه حافظه Cache برابر ۶۴ کیلوبایت خواهد بود.
- هر Block حافظه ۴ word را ذخیره می کند. (هر word ۳۲ بیت را در خود جای می دهد.)
- حافظه Cache دارای valid bit می باشد تا نشان دهد داده درون یک Block معتبر است یا خیر.
  - Address Bus حافظه اصلی ۳۲ ببیت است و Data Bus حافظه اصلی ۱ Word می باشد.
- به ازای هر عملیات Read از Cache میبایست مرتبه Hit Signal را تعیین نمایید. (سیگنال hit یک سیگنال خروجی است و وقتی داده درون Cache پیدا شد این سیگنال باید ۱ شود و در غیر این صورت ۰.)

### 64KB Cache with 4-word (16-byte) blocks



# سوال سوم

### صف اولویت

با استفاده از زبان Verilog یک صف اولویت بسازید. این صف ۱۶ خانه دارد که هر کدام از خانهها ۸ بیت را در خود ذخیره می کند. این صف دو سیگنال جهت عملیاتهای Enqueue و Dequeue به منظور وارد کردن داده و خارج کردن داده از صف را دارد. در صف اولویت، هر بسته دارای اولویت است؛ بدین شکل که بسته ای با اولویت بیشتر جلوتر از بسته با اولویت کمتر قرار می گیرد. مقدار قطعی هر بسته اولویت آن را تعیین می کند. (هر چه عدد بزرگ تر، اولویت بیشتر) فرض کنید مقادیر بستهها اعداد Unsigned هستند.

موفق باشيد.