# ••• معماری کامپیوتر (۱۱۰–۱۱–۱۱۱) بلسهی سیزدهم



دانشگاه شهید بهشتی دانشکدهی مهندسی برق و کامپیوتر بهار ۱۳۹۱ لعمد معمودی ازناوه

#### - فهرست مطالب

- مروری بر مِلسہی پیش
- نموهی اجرای یک دستورالعمل
  - *مسیر گذار داده* 
    - واحد کنترل





### **-** پیش گفتار (ادامه...)

- در این بخش یک پیادهسازی سادهسازی شده از پردازندههای MIPS ارائه خواهد شد. که شامل دستورات زیر میباشد:
- Memory reference: 1w, sw
- Arithmetic/logical: add, sub, and, or, slt
- Control transfer: beq, j

| ор     | rs     | rt     | rd     | shamt  | funct  |
|--------|--------|--------|--------|--------|--------|
| 6 bits | 5 bits | 5 bits | 5 bits | 5 bits | 6 bits |

| ор     | rs     | rt     | constant or address |
|--------|--------|--------|---------------------|
| 6 bits | 5 bits | 5 bits | 16 bits             |

| ор     | address |
|--------|---------|
| 6 bits | 26 bits |





#### - دادهگذر همراه با واعد کنترل

 با توجه به قالب دستور، میتوان برچسب برخی سیگنالهای داده و کنترلی را مشخص نمود:







#### **–** ترکیب لجزا

- با ترکیب اجزای مختلف، که برای دستورهای متنوع لازه مستند، یک «مسیر گذار داده» ساخته خواهد شد، که برای دستورهای مختلف توسط واحد کنترل هدایت میشود.
  - ساده ترین داده گذر تماه دستورات را در یک سیکل اجرا خواهد کرد، در این صورت هیچ منبعی را نمی توان دوبار استفاده کرد.
    - در این مالت باید از برخی منابع مند نسخه قرار داد.
    - ٔ جاهایی که بیش از یک ورودی داریه، برای انتخاب از مالتی بلکسر استفاده میکنیه.





#### - ترکیب دادهگذر دستورات عسابی و منطقی و دستورات عافظه







#### **--** دادهگذر کامل شده

منت افزار مورد نیاز برای اجرای دستورالعمل ها کماده است، تنها بنشی که باقی میماند، کماده کردن میکنال های کشرنی است







مؤال ١: هر كداه از اين ميلنال ها، براى جه دستوراتي مي بيدفعال باشد؟

وال ٢: چرا بايد از دو عافظه ک متقل احتفاده كنيم؟؟

#### ولعد كنترك ALU

- در ادامه زیربخش کوچکی از دستورهای پردازندهی MIPS را پیادهسازی خواهیم کرد.
- به دادهگذر معرفی شده در بخش قبل، یک واحد
   کنترل برای اجرای دستورات زیر اضافه میکنیه:
- lw, sw
- beq
- arithmatic-logical instruction
  - add, sub, AND, OR, set on less than
    - در ادامه، «دستور ل» را هم به این طرح ساده خواهیم افزود.





## مطوط کنترلی ALU - فطوط کنترلی

| ALU control | Function         |
|-------------|------------------|
| 0000        | AND              |
| 0001        | OR               |
| 0010        | add              |
| 0110        | subtract         |
| 0111        | set-on-less-than |
| 1100        | NOR              |



#### برای دستورات مختلف از غطوط کنترل ALU استفاده میکنیم:

– Load/Store: F = add

– Branch: F = subtract

R-type: F depends on funct field





#### - ولعد كنترك ALU

ورودیهای واحد کنترل ALU:
 دارد
 دو بیتورودی به نام ALUOp دارد
 بخش funct دستورالعملهای نوع

| opcode | ALUOp | Operation        | funct  | ALU function     | ALU control |
|--------|-------|------------------|--------|------------------|-------------|
| lw     | 00    | load word        | XXXXXX | add              | 0010        |
| sw     | 00    | store word       | XXXXXX | add              | 0010        |
| beq    | 01    | branch equal     | XXXXXX | subtract         | 0110        |
| R-type | 10    | add              | 100000 | add              | 0010        |
|        |       | subtract         | 100010 | subtract         | 0110        |
|        |       | AND              | 100100 | AND              | 0000        |
|        |       | OR               | 100101 | OR               | 0001        |
|        |       | set-on-less-than | 101010 | set-on-less-than | 0111        |





### - ولعد كنترك ALU (ادامه...)

- استفاده از «واحد کنترل چندسطمی»، باعث کوچک شدن واحد کنترل اصلی میشود.
- چنین کاری میتواند باعث افزایش سرعت واحد کنترل شود.
  - سرعت وامد کنترل در تعیین سرعت پالس ساعت سیسته اهمیت دارد.
- در گاه بعد، واحد کنترل ALU ساخته خواهد شد.
   به نظر شما بهترین شیوهی پیادهسازی چیست؟





## م بدول درستی واحد کنترل ALU جدول

| Instruction opcode | ALUOp | Instruction operation | Funct field | Desired<br>ALU action | ALU control input |
|--------------------|-------|-----------------------|-------------|-----------------------|-------------------|
| LW                 | 00    | load word             | XXXXXX      | add                   | 0010              |
| SW                 | 00    | store word            | XXXXXX      | add                   | 0010              |
| Branch equal       | 01    | branch equal          | XXXXXX      | subtract              | 0110              |
| R-type             | 10    | add                   | 100000      | add                   | 0010              |
| R-type             | 10    | subtract              | 100010      | subtract              | 0110              |
| R-type             | 10    | AND                   | 100100      | AND                   | 0000              |
| R-type             | 10    | OR                    | 100101      | OR                    | 0001              |
| R-type             | 10    | set on less than      | 101010      | set on less than      | 0111              |







### واحد کنترل اصلی

14

- در ادامه، واحد کنترل اصلی شرح داده خواهد شد.
- سیگنالهای کنترلی که از دستورالعمل گرفته میشوند:

|          |                                          |                                                          |                                                                                                                                                                                   |                                                                                    |                                                                                        |                                                                                                                                                                                                                                                   | .                                                                                                                                                                                                                                                           |
|----------|------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | rs                                       | rt                                                       |                                                                                                                                                                                   | rd                                                                                 | shamt                                                                                  | funct                                                                                                                                                                                                                                             | دستورات نوم R                                                                                                                                                                                                                                               |
| 31:26    | 25:21                                    | 20:16                                                    | 1                                                                                                                                                                                 | 15:11                                                                              | 10:6                                                                                   | 5:0                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                             |
|          | <u> </u>                                 |                                                          | $\perp$                                                                                                                                                                           |                                                                                    |                                                                                        |                                                                                                                                                                                                                                                   | فاناء                                                                                                                                                                                                                                                       |
| 35 or 43 | rs                                       | rt                                                       |                                                                                                                                                                                   |                                                                                    | address                                                                                | 5                                                                                                                                                                                                                                                 | خواندن و<br>نوختن در حافظہ                                                                                                                                                                                                                                  |
| 31:26    | 25:21                                    | 20:16                                                    | \                                                                                                                                                                                 |                                                                                    | 15:0                                                                                   | <u>†</u>                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                             |
|          |                                          |                                                          |                                                                                                                                                                                   |                                                                                    |                                                                                        |                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                             |
| 4        | rs                                       | rt                                                       |                                                                                                                                                                                   |                                                                                    | address                                                                                | 3                                                                                                                                                                                                                                                 | پرخ شرطی                                                                                                                                                                                                                                                    |
| 31:26    | 25:21                                    | 20:16                                                    |                                                                                                                                                                                   |                                                                                    | 15:0                                                                                   | 1                                                                                                                                                                                                                                                 | HOUSE !                                                                                                                                                                                                                                                     |
|          |                                          |                                                          |                                                                                                                                                                                   |                                                                                    |                                                                                        |                                                                                                                                                                                                                                                   | ن الآياز                                                                                                                                                                                                                                                    |
| opcode   | تبات منبع                                | تبات منبع                                                |                                                                                                                                                                                   | معصد                                                                               | こん                                                                                     | عقواک ای <u>ن</u>                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                             |
|          | ( ھمیتہ)                                 | به جز دستور                                              |                                                                                                                                                                                   | ع زه ع                                                                             | برا د<br>د میران                                                                       | يىرىن كارى ار                                                                                                                                                                                                                                     | بهييني ا                                                                                                                                                                                                                                                    |
|          | 31:26<br>35 or 43<br>31:26<br>4<br>31:26 | 31:26 25:21  35 or 43 rs  31:26 25:21  4 rs  31:26 25:21 | 31:26     25:21     20:16       35 or 43     rs     rt       31:26     25:21     20:16       4     rs     rt       31:26     25:21     20:16       opcode     منح منع     منع منع | 31:26 25:21 20:16 1  35 or 43 rs rt  31:26 25:21 20:16  4 rs rt  31:26 25:21 20:16 | 31:26 25:21 20:16 15:11  35 or 43 rs rt  31:26 25:21 20:16  4 rs rt  31:26 25:21 20:16 | 31:26       25:21       20:16       15:11       10:6         35 or 43       rs       rt       address         31:26       25:21       20:16       15:0         4       rs       rt       address         31:26       25:21       20:16       15:0 | 31:26       25:21       20:16       15:11       10:6       5:0         35 or 43       rs       rt       address         31:26       25:21       20:16       15:0         4       rs       rt       address         31:26       25:21       20:16       15:0 |

Load , R

Load

#### -مسیر گذار داده همراه با واحد کنترل

 با توجه به قالب دستور، میتوان برچسب برخی سیگنالهای داده و کنترلی را مشخص نمود:







#### -سیگنالهای کنترلی

- سایر سیگنالهای کنترلی، با توجه به opcode تعیین میشود.
- تنها PCSrc استثناست که به نتیجهی ALU وابسته است.

| Signal<br>name | Effect when deasserted                                                                       | Effect when asserted                                                                                    |
|----------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| RegDst         | The register destination number for the Write register comes from the rt field (bits 20:16). | The register destination number for the Write register comes from the rd field (bits 15:11).            |
| RegWrite       | None.                                                                                        | The register on the Write register input is written with the value on the Write data input.             |
| ALUSrc         | The second ALU operand comes from the second register file output (Read data 2).             | The second ALU operand is the sign-<br>extended, lower 16 bits of the instruction.                      |
| PCSrc          | The PC is replaced by the output of the adder that computes the value of PC + 4.             | The PC is replaced by the output of the adder that computes the branch target.                          |
| MemRead        | None.                                                                                        | Data memory contents designated by the address input are put on the Read data output.                   |
| MemWrite       | None.                                                                                        | Data memory contents designated by the address input are replaced by the value on the Write data input. |
| MemtoReg       | The value fed to the register Write data input comes from the ALU.                           | The value fed to the register Write data input comes from the data memory.                              |





## - ندوهی لجرای دستورات نوع R







### $\mathbf{R}$ نووی اجرای دستورات نوع $\mathbf{R}$ (ادامه...)

• هرچند همهی دستورها در یک گاه اجرا میشوند، میتوان مرامل اجرای یک دستور را در چهار گاه تصور نمود:

add \$t1,\$t2,\$t3

- واکشی دستور و افزایش مقدار PC
- خواندن ثباتهای \$t2 و \$t3 از بانک ثبات
- وامد کنترل ALU از روی بیتهای funct فطوط کنترلی را برای انتفاب عمل مناسب انتفاب میکند.
  - نتیجهی محاسبات در ثبات مقصد (\$t1) نوشته میشود.





### - ندوهی اجرای دستورات فواندن(نوشتن) از(در) مافظه







#### الجرای دستورات فواندن از مافظه (ادامه...)

#### lw \$t1,offset(\$t2)

- واکشی دستور و افزایش مقدار PC
  - خواندن ثبات \$t2 از بانک ثبات
- ALU ممتوای ثبات را با offset جمع میکند.
- ماصل به عنوان آدرس مافظه مورد استفاده قرار میگیرد.
- دادهی خوانده شد در حافظه در ثبات مقصد (\$t1) نوشته میشود.







Mary Jane Irwin ( www.cse.psu.edu/~mji )



### - ندوهی اجرای دستورات پرش شرطی (ادامه...)



### - ندوهی اجرای دستورات پرش شرطی (ادامه...)

#### beq \$t1,\$t2,offset

- واکشی دستور و افزایش مقدار PC
- خواندن ثباتهای \$t1 و \$t2 از بانک ثبات
- ALU عمل تفریق را انجاه میدهد، بخش ثابت پس از گسترش علامت و شیفت به چپ به PC+4 اضافه می شود
  - بر اساس خروجی zero در ALU در مورد این آدرس PC چه باشد، تصمیهگیری میشود.



#### ولدد كنترل اصلى

- خروجی واحد کنترل، سیگنالهای کنترلی هستند.
- شش بیت opcode، ورودی واحد کنترل محسوب میشوند.

| Instruction | RegDst | ALUSrc | Memto-<br>Reg | Reg-<br>Write | Mem-<br>Read |   | Branch | ALUOp1 | ALUOp0 |
|-------------|--------|--------|---------------|---------------|--------------|---|--------|--------|--------|
| R-format    | 1      | 0      | 0             | 1             | 0            | 0 | 0      | 1      | 0      |
| 1 w         | 0      | 1      | 1             | 1             | 1            | 0 | 0      | 0      | 0      |
| SW          | Х      | 1      | X             | 0             | 0            | 1 | 0      | 0      | 0      |
| beq         | X      | 0      | Х             | 0             | 0            | 0 | 1      | 0      | 1      |





### ولعد كنترل لصلى (ادامه...)

| Input or output | Signal name | R-format | 1 w | SW | beq |
|-----------------|-------------|----------|-----|----|-----|
| Inputs          | Op5         | 0        | 1   | 1  | 0   |
|                 | Op4         | 0        | 0   | 0  | 0   |
|                 | Op3         | 0        | 0   | 1  | 0   |
|                 | Op2         | 0        | 0   | 0  | 1   |
|                 | Op1         | 0        | 1   | 1  | 0   |
|                 | Op0         | 0        | 1   | 1  | 0   |
| Outputs         | RegDst      | 1        | 0   | Χ  | X   |
|                 | ALUSrc      | 0        | 1   | 1  | 0   |
|                 | MemtoReg    | 0        | 1   | Χ  | X   |
|                 | RegWrite    | 1        | 1   | 0  | 0   |
|                 | MemRead     | 0        | 1   | 0  | 0   |
|                 | MemWrite    | 0        | 0   | 1  | 0   |
|                 | Branch      | 0        | 0   | 0  | 1   |
|                 | ALUOp1      | 1        | 0   | 0  | 0   |
|                 | ALUOp0      | 0        | 0   | 0  | 1   |







## - افزودن دستور پرش (Jump)

| Jump | 2     | address |
|------|-------|---------|
|      | 31:26 | 25:0    |

- چهار بیت پرارزش آدرس از PC+4 گرفته میشود.
  - در دو بیت کهارزش 00 قرار میگیرد.
  - بیست و شش بیت دیگر از بخش آدرس دستورالعمل گرفته میشود.





### **-**لفزودن دستور پرش (ادامه...)







### معایب اجرای همهی دستورها در یک سیکل

- کامپیوترهای اولیه از چنین ساختار تبعیت میکردند.
- طول سیکل ساعت باید با توجه به کندترین دستور انتخاب شود. Making the common case fast
  - این مسأله با اصول طراحی در تناقض است.
  - ۰ در بخش بعدی شیوهای دیگر، به ناه خط لوله را بررسی خواهیه کرد.



