КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Архитектурные особенности микропроцессора
Продуктивність комп’ютера вимірюється числом машинних команд, що виконуються за одну секунду. Саме рівень мікроархітектури розв’язує задачу реалізації системи команд машини. На цьому рівні йдеться про управління суматорами, регістрами, окремими розрядами регістрової пам’яті, вентилями, сигналами синхронізації та інше. Реалізація цього рівня архітектури може бути чисто апаратною, або через мікропрограмування. Мікропрограмування будується на тих самих основних принципах, що і класичне програмування, але оперує з більш низьким по ієрархії рівнем апаратного забезпечення і крім того суттєво враховуває часові відношення щодо взаємодії апаратури.
При розробці мікроархітектури необхідно враховувати цілий ряд важливих характеристик комп’ютера: продуктивність, вартість, надійність, енергоспоживання, фізичні розміри та інш. Ці вимоги характерні для всіх рівнів архітектури, але саме на рівні мікроархітектури існують найбільші можливості для пошуку оптимальних компромісів.
Найбільш показовим є конфлікт і пошук оптимального рішення між продуктивністю і вартістю. Існує три основних підходи, що дозволяють збільшити продуктивність виконання операцій:
1. Скорочення кількості циклів, необхідних для використання команди. 2. Скорочення циклів 3. Одночасне використання декількох операцій.
Перший підхід зазвичай реалізується за рахунок ускладнення апаратної реалізації потужних команд, наприклад апаратної реалізації операції множення за один цикл.
• 8086 і 8088. У цих процесорах на виконання однієї команди йде приблизно 12 тактів. • 286 і 386. Ці процесори зменшили час на виконання команд приблизно до 4,5 тактів. • Процесор 486 і велика частина Intel-сумісних процесорів четвертого покоління, таких, як AMD 5x86, зменшили цей параметр до 2 тактів. • Серія Pentium, Кб. Архітектура процесорів Pentium і інших Intel-сумісних процесорів п'ятого покоління, створених в AMD і Cyrix, включаюча двійні конвейєри команд і інші удосконалення, забезпечила виконання однієї або двох команд за один такт. • Pentium Pro, Pentium П/Ш/Celeron і Athlon/Duron. Процесори класу Р6, а також другі процесори шостого покоління, створені компаніями AMD і Cyrix, дозволяють виконати мінімум три команди за один такт. Скорочення циклів вдається досягнути в основному за рахунок фізичної швидкодії електронних компонент, про що говорилося вище. Цей підхід пов'язаний з удосконаленням технології інтегральних схем і на сьогоднішній день практично вичерпаний.
Одночасне виконання декількох операцій – самий продуктивний підхід. Він дає змогу значно підвищити швидкість роботи комп’ютера. Навіть просте перекриття виклику і виконання команди досить ефективне. Взагалі ідея паралелізму є основною в побудові сучасних швидкісних комп’ютерів.
На одній чаші терезів знаходиться швидкодія, на другій – вартість. Точна оцінка вартості і відношення швидкодія/вартість задача дуже непроста і в значній мірі залежить від призначення пристроїв. Наприклад, були розроблені тисячі (!) варіантів двійкових суматорів різної швидкодії і вартості і вибір конкретного суматора залежить від умов його використання.
Таким чином, подальше зростання швидкодії буде проводиться В основному за рахунок структурних засобів. Одним з таких засобів є конвейєрна обробка даних, яка дозволяє виконувати декілька команд одночасно (Рис. 5.4).
С1–С5 – блоки обробки інформації. Впродовж цикла 1 С1 працює над командою 1. Впродовж цикла 2 С2 працює над декодуванням команди 1, в той же самий час С1 визиває команду 2 і так далі. В решті решт паралельно обробляється п’ять команд. Некоторые современные процессоры имеют более 30 ступеней в конвейере, что увеличивает производительность процессора, однако приводит к большому времени простоя (например, в случае ошибки в предсказании условного перехода). Не существует единого мнения по поводу оптимальной длины конвейера: различные программы могут иметь существенно различные требования. Один конвейєр – добре, а два – ще краще. Одна з можливих схем процесора з двома конвейєрами наведена на Рис.5.5.
Рис. 5.5
Щоб виконуватись паралельно, дві команди не повинні конфліктувати із-за ресурсів (наприклад, регістрів) і жодна з них не повинна залежить від результату виконання другої. Конфлікти усуваються за рахунок допоміжної апаратури. Процесор 80486 має один такий п’ятиступінчастий конвейєр, а Pentium – два. Подальше збільшення конвеєрів технічно можливо, але потребує громіздкої апаратури. Замість цього використовують інший підхід – один конвеєр з великою кількістю функціональних блоків (Рис.5.6). Таку структуру, яка одержала назву суперскалярної архітектури, має, наприклад, Pentium 4.
Рис.5.6
Структурна схема МП Pentium 4 Способность выполнения нескольких машинных инструкций за один такт процессора путем увеличения числа исполнительных устройств. Появление этой технологии привело к существенному увеличению производительности. В то же время существует определенный предел роста числа исполнительных устройств, при превышении которого производительность практические перестает расти, а исполнительные устройства простаивают.
Окрім скалярних операцій існує значна кількість завдань, коли опрацюванню за одними процедурами підлягають великі масиви (вектори) даних. Операції, орієнтовані на опрацювання векторних даних, дістали назву векторних. Різницю між виконанням скалярної та векторної операції наглядно відображає Рис. 5.7.
Рис.5.7
Дата добавления: 2014-01-11; Просмотров: 740; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |