



## درس طراحی در سطح سیستم

تکلیف کامپیوتری ۴ : پیاده‌سازی پردازنده Leros به کمک Chisel

دانشکدگان فنی دانشگاه تهران

دانشکده مهندسی برق و کامپیوتر

دکتر بیژن علیزاده

نیم‌سال دوم سال تحصیلی ۱۴۰۳-۰۴

نگارش: امید قلی‌زاده (omdgzade1380@gmail.com)

### مقدمه

در تکلیف کامپیوتری ۳، با نحوه راهاندازی و استفاده از کتابخانه Chisel به کمک محیط توسعه یکپارچه (IDE) IntelliJ IDEA آشنا شدید. در این تمرین می‌خواهیم با به کارگیری مازول ALU که در تمرین قبلی پیاده‌سازی شد، سخت افزار پردازنده Leros را بصورت سطح بالا توصیف کنیم.

### ساختار پردازنده Leros

این پردازنده که مبنی بر معماری انباشتگری<sup>۱</sup> است، در دهه‌های ۵۰ و ۶۰ میلادی بسیار استفاده می‌شد. در این پردازنده‌ها، یک رجیستر انباشتگر<sup>۲</sup> وجود دارد که خروجی عملیات پردازشی را در خود ذخیره می‌نماید. بنابراین، در دستورات این پردازنده، ورودی اول همواره مقدار رجیستر انباشتگر است و فقط باید ورودی دوم واحد ALU و نوع عملیات مشخص شود.

<sup>۳</sup> این پردازنده، دستورات با تعداد بیت ثابت ۱۶ بیت و داده‌های ۱۶، ۳۲ و ۶۴ بیتی را پشتیبانی می‌کند. در این تمرین، قصد پیاده‌سازی نسخه ۱۶ بیتی این پردازنده را داریم.

با توجه به دستورات این پردازنده، ۸ بیت بالایی آن (MSB) تعیین‌کننده Opcode، و ۸ بیت پایینی آن (LSB) آدرس خانه رجیستر فایل یا مقدار فوری<sup>۴</sup> است (مطابق جدول ۱).

جدول ۱- قالب دستورات پردازنده Leros

| Instruction                                                                                                                    | Rn/Imm                                                                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| b <sub>15</sub> b <sub>14</sub> b <sub>13</sub> b <sub>12</sub> b <sub>11</sub> b <sub>10</sub> .b <sub>9</sub> b <sub>8</sub> | b <sub>7</sub> b <sub>6</sub> b <sub>5</sub> b <sub>4</sub> b <sub>3</sub> b <sub>2</sub> b <sub>1</sub> b <sub>0</sub> |

<sup>1</sup> Accumulator-based

<sup>2</sup> Accumulator

<sup>3</sup> Instruction Set Architecture

<sup>4</sup> Immediate Value



این پردازنده دارای یک رجیستر فایل با اندازه ۲۵۶ است و همچنین حاوی یک رجیستر مخصوص به نام Address Register یا به اختصار (AR) است که آدرس پایه خانه‌ای از رجیستر که می‌خواهد خوانده شود، در آن ذخیره می‌شود. لازم به ذکر است که در دستورات فوری، مقدار ۸ بیت فوری، Sign Extend می‌شوند. لیست دستوراتی که در این تمرین قصد پیاده‌سازی آنها را داریم در جدول ۲ ذکر شده است.

جدول ۲- دستورات مورد نیاز پردازنده Leros

| Opcode | Instruction | Function                      |
|--------|-------------|-------------------------------|
| ADD    | 000010x0    | $A = A + Rn$                  |
| ADDI   | 000010x1    | $A = A + Imm$                 |
| SUB    | 000011x0    | $A = A - Rn$                  |
| SUBI   | 000011x1    | $A = A - Imm$                 |
| SHR    | 00010xxx    | $A = A >>> 1$                 |
| AND    | 00100010    | $A = A \text{ AND } Rn$       |
| ANDI   | 00100011    | $A = A \text{ AND } Imm$      |
| OR     | 00100100    | $A = A \text{ OR } Rn$        |
| ORI    | 00100101    | $A = A \text{ OR } Imm$       |
| XOR    | 00100110    | $A = A \text{ XOR } Rn$       |
| XORI   | 00100111    | $A = A \text{ XOR } Imm$      |
| Ld     | 00100000    | $A = Rn$                      |
| LdI    | 00100001    | $A = Imm$                     |
| Str    | 00110xxx    | $Rn = A$                      |
| JAL    | 01000xxx    | $PC = A, Rn = PC + 2$         |
| LdAddr | 01010xxx    | $AR = A$                      |
| LdInd  | 01100x00    | $A = MEM[AR + (Imm << 1)]$    |
| StrInd | 01110x00    | $MEM[AR + (Imm << 1)] = A$    |
| Br     | 1000xxxx    | $PC = PC + Imm$               |
| BrZ    | 1001xxxx    | If $A == 0$ , $PC = PC + Imm$ |

برای مثال، دستور ”00001001\_00000010“ مقدار فوری ۲ را به رجیستر انباستگر اضافه کرده و نتیجه را در همان رجیستر ذخیره می‌کند. دستور ”00001000\_00000011“ مقدار ذخیره شده در خانه چهارم (R<sup>۳</sup>) رجیستر فایل را به مقدار رجیستر انباستگر اضافه کرده و نتیجه را در رجیستر انباستگر ذخیره می‌کند.

یکی از ویژگی‌های این پردازنده این است که دستورات پردازنده ممکن است از هر ۸ بیت opcode استفاده نکنند. در واقع صفر یا یک بودن بیت‌های Don't Care که با نماد ”x“ مشخص شده‌اند تاثیری بر انتخاب واحد کنترل ندارند. برای مثال، ”10000000“ و ”10001111“ هر دو دستور Br را انجام می‌دهند.

## بخش اول) طراحی پردازنده Leros

برای طراحی این پردازنده، ابتدا مسیر داده<sup>۵</sup> مشخص شده در شکل ۱ را با استفاده از Chisel مدل سازی کنید. سپس با توجه به آن، واحد کنترل<sup>۶</sup> را طراحی کنید. همانطور که پیشتر نیز ذکر شد، برای واحد ALU می‌توانید از پاسخ تمرین کامپیوتري سوم استفاده کنید. (لازم به ذکر است که Byte Addressable بودن حافظه باید در طراحی لحاظ شود).



شکل ۱- مسیر داده پردازنده Leros

## بخش دوم) درستی سنجی طراحی

پس از مدل سازی پردازنده، نیاز به درستی سنجی آن است. برای این کار باید یک برنامه آزمون<sup>۷</sup> بنویسید که در آن جمع تمامی مقادیر موجود در یک آرایه حاوی ۵ عدد محاسبه شود. لازم به ذکر است که آرایه باید در حافظه ذخیره شده و برای انجام عملیات، مقادیر در رجیستر فایل ذخیره شوند.

برای مقداردهی اولیه حافظه داده از طریق فایل خارجی، از دستورات گفته شده در کلاس درس استفاده کنید.

<sup>5</sup> Datapath

<sup>6</sup> Control Unit

<sup>7</sup> TestBench



## نکات پایانی

۱. پوشه src، فایل build.sbt، خروجی pdf و فایل گزارش کار خود را در یک فایل زیپ شده به نام ESL\_CA4\_<StudentId>.zip ارسال نمایید که در آن <StudentId> همان شماره دانشجویی شماست.
۲. در فایل Build.sbt، متغیر name را به صورت CA4\_<StudentId> مقدار داده که در آن <StudentId> همان شماره دانشجویی شماست.
۳. تمامی کد ها باید خوانا بوده و کامنت گذاری مناسب داشته باشد.
۴. در صورت داشتن هرگونه ابهام یا سوال، می توانید از طریق ایمیل(omdgzade1380@gmail.com) و یا تلگرام (@OMD\_Gzade) با من در ارتباط باشید.

## بارمبنده سوالات

- بخش اول: ۶۵ نمره
- سؤال دوم: ۳۵ نمره
- تمیزی گزارش و مرتب بودن فایل های آپلود شده نمره امتیازی دارد.

موفق و سلامت باشید.