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



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

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

- مفاطرات کنترلی
- پیشبینی نتیجهی پرش
  - استثنائات





## - دادهگذر همراه با مدار تشنیص مفاطره



- ا مفاطرهی داده در پرش شرطی (ادامه...)
- اگریکی از ثباتهای مقایسه در مال بارگذاری از مافظه باشد:





## به یک میک احتیاج خواصیم رانت



ا مفاطرهی داده در پرش شرطی (ادامه...)

 اگریکی از ثباتهای مقایسه در مال بارگذاری از مافظه و دقیقا پیش از دستور پرش باشد:





### به رو مای احتیاج خواصم رات

### بهینه سازی دستورات انشعاب

- دستورات انشعاب، به شدت در کارایی سیستم مؤثر هستند.
- در اکثر پردازندههای امروزی برای افزایش کارایی دستورات پیشواکشی میشود.
  - پرشمای غیرشرطی
  - باعث کاهش کارایی برنامه میشوند.







### بهینه سازی دستورات انشعاب (ادامه...)

## • پرشمای شرطی

- برای تشفیص توالی دستوراتی که هنوز نتیجهی شرط مشفص نیست، از الگوریتههای پیشبینی استفاده میشود.
- پیشبینی نتیجهی شرط به صورتهای زیر انجاه میشود:
  - در پرش رو به عقب، فرض بر آن است که شرط برقرار است.
    - در پرش رو به جلو، فرض بر آنست که شرط برقرار نیست.
- دستورات پرشی که در اجرای قبلی، انجاه شدهاند، باز هم اجرا خواهند شد.
  - این فرض بر دو فرض قبل غلبه دارد.
  - BTB، برای رهگیری آخرین نتیجه مورد استفاده قرار میگیرد.







Branch Target Buffer

jns loop1

#### Dynamic Branch Prediction

## پیش بینی پویا

- در خط لولههای عمیقتر و در «سوپراسکالرها» زیان
  ناشی از پرش قابل تحمل نیست.
- در چنین حالاتی از پیشبینی پویا استفاده میشود.

Branch prediction buffer

branch history table

- میانگیر پیشبینی خطا (جدول تاریخچه)
  - نتیجهی آخرین پرش را ذخیره میکند.
- در دفعات بعدی مطابق با مالت پیش عمل خواهد کرد.





### - کاستی های پیش بینی کننده ی یک بیتی

 حلقه های تودرتو: دو بار نتیجه ی پیشبینی اشتباه خواهد بود.



یکی از راه های متداول اختصای دو دیت، برای نگهداری آخرین وضفیت ات







## انشعاب تأنير يافته

#### راه های رنگری نیز برای افزایش کارایی بیشنهاد نیره است یکی از آنها تاخیریس از پیرش نیرطی است







سی ویلری زخیره کردان آدرس دستور بیرش شرطی است

- دادهگذر نهایی --



#### الستثنائات





### **—**استثنائات (ادامه...)

#### "Unexpected" events

- موادث پیشبینی نشده، میتواند روند عادی اجرای برنامه را تغییر دهد.
  - در بسیاری از مراجع تمایزی بین وقفه و استثنا قائل نمیشوند، در برخی منابع وقفه را حالت کلی تر میدانند و استثنا را مربوط به عملکرد نادرست .
    - در X86 از واژهی وقفه استفاده شده است.
  - در MIPS، از واژهی استثنا (برای هر نوع حادثه با منشأ داخلی و خارجی) استفاده میشود. وقفه شامل حوادث با منشأ خارجی میباشند.





Trap روفاری (Spielos)

## نمونه ای از استثنائات

| واژهی رایج در MIPS | منشأ  | نوع عادثه                                            |
|--------------------|-------|------------------------------------------------------|
| وقفه               | خارجی | درغواست وامد ورودی/فروجی                             |
| استثنا             | داغلی | درغواست از سیسته <i>عامل</i> از طرف<br>برنامهی کاربر |
| استثنا             | داغلی | رغداد سرريز                                          |
| استثنا             | داغلی | استفاده از دستورالعمل نامشخص                         |
| استثنا یا وقفہ     | هردو  | <b>غرابی سختافزار</b>                                |





برخور د با استثانات ، برون قربانی کردن کارایی کاری بسار دخوار است ،

### - استثنائات (ادامه...)

- عده توجه کافی به استثنائات در هنگاه طراحی واحد کنترل میتواند موجب افت کارایی سیسته شود.
  - در ادامه به طرامی دو نوع استثناء میپردازیم:
    - دستور ناشناخته
      - سرريز

EPC (exception programmer counter)

هنگاه بروز استفاه، بیردازنده آدرس دیتورجاری را در تبات وقفه ذخیره نموده و کشرل را به بخشی خاص از میشمی مل

المنطقة المنطقة

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

### الستثنائات (ادامه...)

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

ازیک ثبات وضعیت (MIPS) در MIPS ازیک ثبات وضعیت (status register) کی نبات سبب استفاده می شود. *Cause register* 

O for undefined opcode, 1 for overflow

•در صورت بروز وقفه، مقدار PC به 8000 00180 تغییر فواهد کرد. در واقع رویهی رسید<u>گی</u>کننده به وقفه در آنمِ قرار دارد.



•ب بررسی ثبات سبب نوع استثنا و در نتیجه واکنش مناسب تشخیص داده میشود.



### استثنائات (ادامه...)

• راه دیگری نیز وجود دارد؛ پردار وقفه

OLI CS/M COLOR CS LONGOS – که پرداری از آ درسهای رویههای رسید<del>گ</del>یکننده به وقفه (interrupt handler) میباشد. در واقع در این شیوه مشخصا رویهی مورد نظر فراخوانی میشود.

| Exception type        | Exception vector address (in hex) |  |
|-----------------------|-----------------------------------|--|
| Undefined instruction | 8000 0000 <sub>hex</sub>          |  |
| Arithmetic overflow   | 8000 0180 <sub>hex</sub>          |  |





## - بروز استثنا در پردازندهی مجهز به نظ لوله

 دریک سیستم خط لوله یک استثنا، نوعی مخاطرهی کنترلی است.



- اجرای دستورات پیش از دستور add میباید کامل شود.
  - دستور add و دستورهای بعدی از خط لوله تخلیه شوند.
    - ثباتهای سبب و EPC مقدار دهی شوند.
    - *کنترل به رسیدگیکننده به وقفه سپرده شود.*









#### Exception on add

80000180 sw \$25, 1000(\$0) 80000184 sw \$26, 1004(\$0)

•••

Handler





#### ا مثال







#### , or \$13, . . . sw \$25, 1000(\$0) bubble (nop) bubble bubble EX.Flush ID.Flush Hazard detection unit ID/EX 00 EX/MEM M 000 мем/wв u Cause IF/ID<sub>58</sub> EPC Registers Instruction Data memory 13 Forwarding

IF.Flush

memory

80000180

Clock 7

### بروز همزمان چندین استثنا

- در خط لوله چند دستورالعمل همزمان اجرا میشوند.
- بنابراین امکان بروز چند استثنا به صورت همزمان وجود دارد.
- مئتوان به استثنایی که مربوط به دستورالعملهای جلوتر هستند، زودتر رسیدگی نمود.



