Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Особенности развития и структурной организации современных моделей микропроцессоров

Содержание

Характерными чертами современных универсальных микропроцессоров являются: Суперскалярная архитектура, обеспечивающая одновременное выполнение нескольких команд в параллельно работающих исполнительных устройствах.Динамическое изменение последовательности команд (выполнение команд с опережением – спекулятивное выполнение).Конвейерное исполнение команд.Предсказание направления ветвлений.Предварительная выборка команд и
Особенности развития и структурной организации современных моделей микропроцессоров. Характерными чертами современных универсальных микропроцессоров являются: Суперскалярная архитектура, обеспечивающая одновременное выполнение Стратегия развития процессоров Intel  Стратегия развития Intel заключается во внедрении Особенности многоядерной процессорной микроархитектуры Intel Core    Микроархитектура Intel Технология Intel Wide Dynamic Execution  В новой архитектуре с Технология Intel Advanced Digital Media Boost Технология Intel Advanced Smart Cache  Процессоры с микроархитектурой Core Технология Intel Smart Memory Access  Под этим названием объединены Технология Intel Intelligent Power Capability  Главная особенность микроархитектуры Core Недостатки микроархитектуры Intel Core Существенным недостатком процессоров микроархитектуры Intel Core Микроархитектура Intel Nehalem   Микроархитектура Nehalem является дальнейшим развитием Микроархитектура Intel Nehalem 5. Новая шина QPI с топологией точка-точка Усовершенствования вычислительного ядра   Несмотря на то, что процессоры Рис.1Рис.1 Усовершенствования вычислительного ядраРазделенные на простые и сложные х86 инструкции (Pre Decode) организуются В Nehalem увеличилось число пар x86 команд, декодируемых в рамках этой технологии Иными словами, теперь в буфере LSD сохраняются циклы в декодированном виде, из-за Усовершенствования вычислительного ядраТакже как Core 2, в каждом ядре процессора Intel Nehalem Усовершенствования вычислительного ядраВ микроархитектуре Nehalem Intel продолжила взятый ранее курс на увеличение Новая структура кэш-памяти От двухуровневой структуры кэш-памяти в Intel Core Реализация многопоточности Возвращение в Nehalem технологии SMT – одно из Интегрированный в процессор контроллер памяти Nehalem стала первой интеловской микроархитектурой, предполагающей Новая процессорная шина QPI Микроархитектура Nehalem универсальна, она используется как в Модульная структура процессора  Важным нововведением в Nehalem стал модульный Модульная структура процессора  Рис. 2 Управление питанием процессора  Микроархитектура Nehalem предполагает наличие в процессоре Технология Turbo Boost  Эта технология вводит понятие турбо-режима, в Процессоры Nehalem      Первыми серийными процессорами, Процессоры Intel Clarkdale Процессоры Intel Bloomfield, Intel Lynnfield Семейство процессоров Intel Westmere  Новые процессоры Intel семейства Westmere Семейство процессоров Intel Westmere  16 LanesРис. 3DMIFDI Микроархитектура AMD K10 Микроархитектура AMD К10 является логическим продолжением вполне Микроархитектура AMD K10Впрочем, компоновка четырех процессорных ядер на одном кристалле имела и Структура ядра процессора AMD K10Каждое ядро процессора имеет выделенный кэш L1 данных Рис. 4 Структура ядра процессора AMD K10В К10 предсказание переходов (Branch Prediction Unit) существенно Структура ядра процессора AMD K10В процессоре К10 внешние х86-команды декодируются во внутренние Структура ядра процессора AMD K10Аппаратный декодер Direct Path является трехканальным и может Структура ядра процессора AMD K10Микрооперации, полученные в результате декодирования инструкций в декодерах Структура ядра процессора AMD K10Если посмотреть на схему декодера в микроархитектурах К8 Структура ядра процессора AMD K10После прохождения декодера микрооперации (по три за каждый Структура ядра процессора AMD K10Просматривая все 36 поступающих инструкций, FP-Renamer переупорядочивает следование Структура ядра процессора AMD K10После того, как все микрооперации прошли диспетчеризацию и Структура ядра процессора AMD K10В процессоре К8 после вычисления на AGU адресов Структура ядра процессора AMD K10Для работы с вещественными числами реализовано три функциональных Структура ядра процессора AMD K10Одной из основных составляющих микроархитектур К8, К10 является
Слайды презентации

Слайд 2 Характерными чертами современных универсальных микропроцессоров являются:
Суперскалярная архитектура, обеспечивающая

Характерными чертами современных универсальных микропроцессоров являются: Суперскалярная архитектура, обеспечивающая одновременное

одновременное выполнение нескольких команд в параллельно работающих исполнительных устройствах.
Динамическое

изменение последовательности команд (выполнение команд с опережением – спекулятивное выполнение).
Конвейерное исполнение команд.
Предсказание направления ветвлений.
Предварительная выборка команд и данных.
Параллельная обработка потоков данных.
Многоядерная структура.
Многопотоковая обработка команд.
Пониженное энергопотребление.

Слайд 3 Стратегия развития процессоров Intel
Стратегия развития Intel заключается

Стратегия развития процессоров Intel Стратегия развития Intel заключается во внедрении

во внедрении новых микроархитектур процессоров, основанных на новых поколениях

полупроводниковой производственной технологии. Темпы выпуска инновационных микроархитектур и полупроводниковых технологий основаны на принципе, который корпорация Intel называет моделью «TICK-TOCK». Этот цикл, как правило, повторяется каждые 2 года.

Слайд 4 Особенности многоядерной процессорной микроархитектуры Intel Core

Особенности многоядерной процессорной микроархитектуры Intel Core  Микроархитектура Intel Core

Микроархитектура Intel Core содержит сотни нововведений, но основные из

них сводятся к пяти технологическим решениям:

Технология Intel Wide Dynamic Execution (широкое динамическое исполнение).
Технология Intel Advanced Digital Media Boost (улучшенные цифровые медиа возможности).
Технология Intel Advanced Smart Cache (улучшенный интеллектуальный кэш).
Технология Intel Smart Memory Access (интеллектуальный доступ к памяти).
Технология Intel Intelligent Power Capability (интерактивное подключение подсистем).

Слайд 5 Технология Intel Wide Dynamic Execution
В новой

Технология Intel Wide Dynamic Execution В новой архитектуре с «широким»

архитектуре с «широким» динамическим исполнением связывают:
возможность исполнения большего

числа операций за такт, чем это было раньше. Благодаря добавлению в каждое ядро декодеров и исполнительных устройств, каждое из ядер сможет выбирать из программного кода и исполнять до четырех х86 инструкций одновременно с помощью 14-стадийных конвейеров;
в дополнении к весьма удачной технологии micro-ops fusion (x86 инструкция распадается на последовательность микрокоманд, которые выполняются процессором в этой же последовательности) микроархитектура Core получила технологию macro fusion.

Слайд 6 Технология Intel Advanced Digital Media Boost

Технология Intel Advanced Digital Media Boost   Микроархитектура Intel

Микроархитектура Intel Core позволяет ускорить работу

с SSE инструкциями в два раза. Блоки SSE в данных процессорах полностью 128-битные, что дает возможность увеличить количество данных, обрабатываемых процессором за такт.
Кроме этого Intel в очередной раз провел ревизию системы команд SSE. Результатом стало расширение SSSE3 еще 32-мя новыми командами, а для процессоров (Penryn), выполненных по 45-нм технологическому процессу, использование нового набора команд SSE4.1, в который добавлено 47 новых команд, позволяющих ускорить, в том числе, кодирование видеозаписей с высоким разрешением и обработку фотоизображений.


Слайд 7 Технология Intel Advanced Smart Cache
Процессоры с

Технология Intel Advanced Smart Cache Процессоры с микроархитектурой Core имеют

микроархитектурой Core имеют разделяемый между двумя ядрами L2 кэш.

Плюсов такого подхода несколько:
1. Доступ ко всему объему L2 кэша может получить любое из ядер процессора (когда одно из ядер бездействует). Если же одновременно работают два ядра, то кэш делится между ними пропорционально, в зависимости от частоты обращений каждого ядра к оперативной памяти (ОП).
Если оба ядра работают синхронно с одними и теми же данными, то хранятся они в общем L2 кэше только однократно. Таким образом, разделяемый интеллектуальный L2 кэш, более вместителен, чем два отдельных кэша.
2. Значительно снижается нагрузка на ОП системы и на процессорную шину. В этом случае перед системой не стоит задача контроля и обеспечения когерентности кэш-памяти различных ядер.


Слайд 8 Технология Intel Smart Memory Access
Под этим

Технология Intel Smart Memory Access Под этим названием объединены несколько

названием объединены несколько технологий:
1. Усовершенствованный алгоритм предварительной выборки данных.

В процессоре реализовано 6 независимых блоков предварительной выборки данных. Два блока осуществляют выборку данных из памяти в общий L2 кэш, два блока работают с кэшами L1 каждого ядра. Каждый блок отслеживает обращения исполнительных устройств к данным. Базируясь на собранной статистике, блоки предварительной выборки стремятся подгружать данные из памяти в процессорный кэш еще до того, как к ним последует обращение.
2. Memory disambiguation (устранение противоречий при доступе к памяти). Данная технология направлена на повышение эффективности работы алгоритмов внеочередного исполнения инструкций, осуществляющих выгрузку и сохранение данных в память.


Слайд 9 Технология Intel Intelligent Power Capability
Главная особенность

Технология Intel Intelligent Power Capability Главная особенность микроархитектуры Core в

микроархитектуры Core в том, что процессоры получили возможность интерактивного

подключения тех собственных подсистем, которые используются в данный момент. Причем речь в данном случае идет не о ядрах целиком. Декомпозиция процессора на отдельные функциональные узлы выполнена на гораздо более низком уровне. Каждое из процессорных ядер поделено на большое количество блоков и внутренних шин, питание которыми управляется раздельно посредством специализированных дополнительных логических схем.


Слайд 10 Недостатки микроархитектуры Intel Core
Существенным недостатком процессоров микроархитектуры

Недостатки микроархитектуры Intel Core Существенным недостатком процессоров микроархитектуры Intel Core

Intel Core стал их немодульный дизайн (немодульное проектирование). Они

изначально проектировались как двухъядерные полупроводниковые кристаллы. Последующий же переход к выпуску многоядерных представителей Core 2 стал выявлять слабые места такого подхода. Так, 4-х ядерные и 6-ти ядерные представители микроархитектуры Intel Core просто собирались из нескольких 2-х ядерных кристаллов, что приводило к затруднению взаимодействия между ними. Обмен данными между разрозненными ядрами организовывался через системную память, что порой вызывало большие задержки, обусловленные ограниченной пропускной способностью процессорной шины.
Еще одно узкое место возникало в многопроцессорных системах при использовании системной шины FSB.

Слайд 11 Микроархитектура Intel Nehalem
Микроархитектура Nehalem является

Микроархитектура Intel Nehalem  Микроархитектура Nehalem является дальнейшим развитием рассмотренной

дальнейшим развитием рассмотренной выше микроархитектуры Intel Core.
Основными

отличительными чертами данной микроархитектуры являются :
Усовершенствованное по сравнению с Core вычислительное ядро.
Многопоточная технология SMT (Simultaneous Multi-Threading), позволяющая исполнять одновременно два вычислительных потока на одном ядре.
Три уровня кэш-памяти: L1 кэш размером 64 Кбайта на каждое ядро, L2 кэш размером 256 Кбайт на каждое ядро, общий разделяемый L3 кэш размером 4, 8 до 24 Мбайт.
Интегрированный в процессор контроллер памяти с поддержкой нескольких каналов DDR3 SDRAM.



Слайд 12 Микроархитектура Intel Nehalem
5. Новая шина QPI с

Микроархитектура Intel Nehalem 5. Новая шина QPI с топологией точка-точка

топологией точка-точка для связи процессора с чипсетом и процессоров

между собой.
6. Модульная структура.
7. Монолитная конструкция – процессор состоит из одного полупроводникового кристалла.
8. Технологический процесс с нормами производства не менее 45 нм.
9. Использование двух, четырех или восьми ядер.
10. Управление питанием и Turbo-режим.


Слайд 13 Усовершенствования вычислительного ядра
Несмотря на то, что процессоры

Усовершенствования вычислительного ядра  Несмотря на то, что процессоры семейства

семейства Nehalem преподносятся Intel, как носители новой микроархитектуры, основная

их часть – вычислительное ядро – по сравнению с Core изменилась не столь значительно, наибольшие улучшения кроются в инфраструктуре.
В рассматриваемом ядре (рис. 1) так называемый предпроцессор содержит следующие блоки: блок выборки команд и преддекодирования; блок предсказания переходов (ветвлений); блок очередей инструкций; декодер инструкций; блок обнаружения циклов в программе.
В дополнение к уже имеющемуся в Intel Core блоку предсказания переходов был добавлен в Nehalem ещё один «предсказатель» второго уровня. Он работает медленнее, чем первый, но зато благодаря более вместительному буферу, накапливающему статистику переходов, обладает лучшей глубиной анализа.


Слайд 14

Рис.1
Рис.1

Рис.1Рис.1

Слайд 15 Усовершенствования вычислительного ядра
Разделенные на простые и сложные х86

Усовершенствования вычислительного ядраРазделенные на простые и сложные х86 инструкции (Pre Decode)

инструкции (Pre Decode) организуются в виде очередей (Instruction Queues)

на входах четырех декодеров. Декодеры преобразуют х86 команды в микрокоманды, под управлением которых в процессоре выполняются элементарные операции (микрооперации). Как в Intel Core, три декодера используются для обработки простых инструкций, один – для сложных. Каждая простая х86 инструкция преобразуется в 1–2 микрокоманды, а для сложной инструкции из памяти микрокода (u Code ROM) выбирается последовательность микрокоманд (микропрограмма), которая содержит более двух микрокоманд (технология micro-ops fusion). Используя технологию macro fusion, четыре декодера могут обработать одновременно пять х86 команд, преобразуя их в четыре микрокоманды. Данная технология заключается в том, что ряд пар связанных между собой последовательных х86 инструкций, таких как, например, сравнение со следующим за ним условным переходом, представляются декодером одной микрокомандой.


Слайд 16 В Nehalem увеличилось число пар x86 команд, декодируемых

В Nehalem увеличилось число пар x86 команд, декодируемых в рамках этой

в рамках этой технологии «одним махом». Кроме того, технология

macro fusion стала работать и в 64-битном режиме, в то время как в процессорах семейства Core 2 она могла активироваться лишь при работе процессора с 32-битным кодом.
Следующее усовершенствование, связанное с повышением продуктивности начальной части исполнительного конвейера, коснулось блока обнаружения циклов в программе Loop Stream Detector. Этот блок появился впервые в процессорах с микроархитектурой Core и предназначался для ускорения обработки циклов. Определяя в программе циклы небольшой длины, Loop Stream Detector (LSD) сохранял их в специальном буфере, что давало возможность процессору обходиться без их многократной выборки из кэша и предсказания переходов внутри этих циклов. В процессорах Nehalem блок LSD стал ещё более эффективен благодаря его переносу за стадию декодирования инструкций.

Усовершенствования вычислительного ядра


Слайд 17 Иными словами, теперь в буфере LSD сохраняются циклы

Иными словами, теперь в буфере LSD сохраняются циклы в декодированном виде,

в декодированном виде, из-за чего этот блок стал несколько

похож на Trace Cache процессоров Pentium 4. Однако, Loop Stream Detector в Nehalem – это особенный кэш. Во-первых, он имеет очень небольшой размер, всего 28 микроопераций, во-вторых, в нём сохраняются исключительно циклы.
После декодирования производится переименование регистров, переупорядочение (Retirement Unit) и сохранение до момента выполнения 128 микрокоманд в буфере (Reorder Buffer). Это количество микрокоманд на 33% больше, чем в Intel Core (96 микрокоманд).
На следующем этапе планировщик (Scheduler) через станцию резервирования (Reservation Station – RES), вместимостью до 36 инструкций (Intel Core – 32 инструкции), отправляет микрокоманды непосредственно на исполнительные устройства.

Усовершенствования вычислительного ядра


Слайд 18 Усовершенствования вычислительного ядра
Также как Core 2, в каждом

Усовершенствования вычислительного ядраТакже как Core 2, в каждом ядре процессора Intel

ядре процессора Intel Nehalem используются три универсальных порта (Port0,

Port1, Port5) для связи с различными исполнительными устройствами, два порта (Port3, Port4) для организации записи/загрузки (Store) адреса и данных в память и один (Port2) для организации чтения/выгрузки (Load) данных из памяти. Универсальные порты осуществляют связь с тремя блоками для обработки целочисленных 64-битных данных (ALU), выполнения сдвигов (Shift) и операций сравнения (LEA); с тремя блоками для обработки чисел с плавающей точкой (FAdd, FMul, FPShuffes); с тремя 128-битными блоками для обработки потоковых данных (SSE); с одним блоком для исполнения переходов (Branch); со специальными блоками Divide (деление), Complex Integer (сложные целочисленные операции).


Слайд 19 Усовершенствования вычислительного ядра
В микроархитектуре Nehalem Intel продолжила взятый

Усовершенствования вычислительного ядраВ микроархитектуре Nehalem Intel продолжила взятый ранее курс на

ранее курс на увеличение числа поддерживаемых SIMD инструкций. Пополненный

набор команд расширился за счет семи новых инструкций и получил название SSE4.2. В SSE4.2 добавлено пять инструкций, предназначенных для ускорения синтаксического анализа XML-файлов. Также с помощью этих же инструкций возможно увеличение скорости обработки строк и текстов. Ещё две новые инструкции из набора SSE4.2 нацелены на совершенно иные приложения. Первая из них аккумулирует контрольную сумму, а вторая подсчитывает число ненулевых бит в источнике.


Слайд 20 Новая структура кэш-памяти
От двухуровневой структуры кэш-памяти в Intel

Новая структура кэш-памяти От двухуровневой структуры кэш-памяти в Intel Core

Core с общим на каждые два ядра L2 кэшем

в процессорах Nehalem остался только кэш первого уровня суммарным объёмом 64 Кб, который делится на две равные части для хранения инструкций и данных. Использование разделяемого L2 кэша оказалось весьма проблематичным при увеличении количества ядер. Поэтому в микроархитектуре Nehalem, предполагающей наличие в процессоре до 8 ядер, кэш второго уровня не является разделяемым. Каждое из ядер получило свой собственный L2 кэш со сравнительно небольшим объёмом 256 Кбайт.
К двум уровням кэша в Nehalem добавился и L3 кэш, который объединяет ядра между собой и является разделяемым. В результате, L2 кэш выступает буфером при обращениях процессорных ядер в разделяемую кэш-память, имеющую достаточно большой объём.


Слайд 21 Реализация многопоточности
Возвращение в Nehalem технологии SMT – одно

Реализация многопоточности Возвращение в Nehalem технологии SMT – одно из

из самых существенных нововведений, способных положительно повлиять на производительность

(в процессорах Pentium 4, эта же технология преподносилась под маркетинговым именем Hyper-Threading).
Внедрение SMT в Nehalem не потребовало существенного увеличения сложности процессора. Продублированы в ядре, фактически, лишь процессорные регистры. Все остальные ресурсы при включении SMT разделяются в процессоре между потоками динамически (например, Reservation Station или кэш-память), либо жёстко пополам (например, Reorder Buffer). Как и в процессорах Pentium 4, активация SMT в Nehalem приводит к тому, что каждое физическое ядро видится операционной системой как пара логических ядер. Например, четырёхъядерный Nehalem будет распознаваться программным обеспечением как процессор с восемью ядрами.


Слайд 22 Интегрированный в процессор контроллер памяти
Nehalem стала первой интеловской

Интегрированный в процессор контроллер памяти Nehalem стала первой интеловской микроархитектурой,

микроархитектурой, предполагающей интеграцию контроллера памяти внутрь процессора. Главное свойство

контроллера памяти процессоров семейства Nehalem – гибкость. Учитывая модульный дизайн всего семейства процессоров, которое может содержать сильно различающиеся по характеристикам и рыночному позиционированию продукты, Intel предусмотрела возможность не только включать или отключать поддержку буферизированных модулей, но и варьировать число каналов и скорость памяти.
Основное преимущество переноса контроллера DRAM в процессор заключается не столько в росте пропускной способности, сколько в уменьшении латентности подсистемы памяти. Ещё одно косвенное преимущество встроенного в процессор контроллера памяти заключается в том, что его функционирование теперь не зависит ни от чипсета, ни от материнской платы.


Слайд 23 Новая процессорная шина QPI
Микроархитектура Nehalem универсальна, она используется

Новая процессорная шина QPI Микроархитектура Nehalem универсальна, она используется как

как в настольных, мобильных, так и в серверных продуктах.

Поэтому при разработке данной микроархитектуры было уделено внимание проектированию новой процессорной шины, которая оказалась бы применима в многопроцессорных системах, обеспечивая необходимую пропускную способность и масштабируемость.
Для решения этой задачи был построен специальный интерфейс QPI с топологией точка-точка (QuickPath Interconnect). С технической точки зрения шина QPI представляет собой два 20-битных соединения, ориентированных на передачу данных в прямом и обратном направлении. 16 бит предназначаются для передачи данных, оставшиеся четыре – носят вспомогательный характер. Эта шина имеет пропускную способность 12,8 Гбайт/с в каждую сторону или 25,6 Гбайт/с суммарно. В зависимости от рыночного ориентирования, процессоры с микроархитектурой Nehalem могут комплектоваться одним или несколькими интерфейсами QPI.

Слайд 24 Модульная структура процессора
Важным нововведением в Nehalem

Модульная структура процессора Важным нововведением в Nehalem стал модульный дизайн

стал модульный дизайн процессора. Фактически, микроархитектура сама по себе

включает лишь несколько «строительных блоков», из которых на этапе конечного проектирования и производства может быть собран итоговый процессор. Этот набор строительных блоков включает в себя (рис. 2) процессорное ядро с L2 кэшем (Core), L3 кэш, контроллер шины (QPIC), контроллер памяти (MC), графическое ядро (GPU), контроллер потребляемой энергии (PCU) и т. д.
Необходимые «кубики» собираются в едином полупроводниковом кристалле и преподносятся в качестве решения для того или иного рыночного сегмента. Например, процессор Bloomfield, включает в себя четыре ядра, L3 кэш, контроллер памяти и один контроллер шины QPI.
Серверные же процессоры с той же архитектурой будут включать до восьми ядер, до четырёх контроллеров QPI для объединения в многопроцессорные системы, L3 кэш и контроллер памяти.


Слайд 25 Модульная структура процессора
Рис. 2

Модульная структура процессора Рис. 2

Слайд 26 Управление питанием процессора
Микроархитектура Nehalem предполагает наличие

Управление питанием процессора Микроархитектура Nehalem предполагает наличие в процессоре важного

в процессоре важного блока – PCU (Power Control Unit).

Этот блок представляет собой встроенный в процессор программируемый микроконтроллер, целью которого является «интеллектуальное» управление потреблением энергии. Неудивительно, что при этом PCU имеет достаточно сложную конструкцию.
Основным предназначением PCU является управление частотой и напряжением питания отдельных ядер, для чего этот блок имеет все необходимые средства. Он получает от всех ядер со встроенных в них датчиков всю информацию о температуре, напряжении и силе тока. Основываясь на этих данных, PCU может переводить отдельные ядра в энергосберегающие состояния, а также управлять их частотой и напряжением питания. В частности, PCU может независимо друг от друга отключать неактивные ядра, переводя их в состояние глубокого сна, в котором энергопотребление ядра приближается к нулевой отметке.

Слайд 27 Технология Turbo Boost
Эта технология вводит понятие

Технология Turbo Boost Эта технология вводит понятие турбо-режима, в котором

турбо-режима, в котором отдельные ядра могут работать на частоте,

превосходящей номинальную, то есть разгоняться. Основной принцип Turbo Boost Technology состоит в том, что при переходе отдельных ядер в энергосберегающие состояния снижается общее энергопотребление и тепловыделение процессора, а это в свою очередь позволяет нарастить частоты остальных ядер без риска выйти за установленные рамки TDP.
В новых процессорах, если нет риска выйти за границу типичного энергопотребления и тепловыделения, PCU может повышать частоты процессорных ядер на один шаг выше номинала (133 МГц). Это может происходить, например, при слабо распараллеленной нагрузке, когда часть ядер находится в состоянии простоя. Более того, при соблюдении описанных условий, частота одного из ядер может быть увеличена и на два шага выше номинала (266 МГц).
Большим преимуществом Turbo Boost Technology является ее полная прозрачность для операционной системы. Эта технология реализована исключительно аппаратными средствами и не требует использования никаких программных утилит для своей активации.


Слайд 28 Процессоры Nehalem
Первыми

Процессоры Nehalem   Первыми серийными процессорами, основанными на новой

серийными процессорами, основанными на новой микроархитектуре Nehalem, стали настольные

модели, известные под кодовым именем Bloomfield (Core i7-9хх, табл. 1). Эти процессоры имеют четырехядерное строение. Помимо процессорных ядер, в полупроводниковый кристалл Bloomfield включен кэш третьего уровня объёмом 8 Мбайт, трёхканальный контроллер памяти с поддержкой DDR3 SDRAM и один интерфейс QPI. Новые процессоры используют разъём LGA1366, существенно превосходящий по числу контактов и габаритам привычный LGA775. Стал массивнее и сам процессор.
Следующая линейка процессоров Intel Core i7-8хх с ядром Lynnfield отличается от предыдущей двухканальным интегрированным контроллером памяти, уменьшенным TDP, увеличенной частотой шины памяти 1066/1333 МГц, встроенным в процессор контроллером шины графического адаптера PCI Express x16, использованием системной шины DMI для связи процессора с южным мостом чипсета, более агрессивной реализацией технологии Turbo Boost.

Слайд 29 Процессоры Intel Clarkdale

Процессоры Intel Clarkdale

Слайд 30 Процессоры Intel Bloomfield, Intel Lynnfield

Процессоры Intel Bloomfield, Intel Lynnfield

Слайд 31 Семейство процессоров Intel Westmere
Новые процессоры Intel

Семейство процессоров Intel Westmere Новые процессоры Intel семейства Westmere стали

семейства Westmere стали первыми процессорами, созданными по нормам 32-нм

техпроцесса. Эти процессоры известны под кодовыми названиями Clarkdale и Arrandale, предназначены для применения, соответственно, в настольных компьютерах и ноутбуках, и входят в модельные линейки Intel Core i3, i5, i7. Процессоры Intel Westmere представляют собой двухъядерные решения. Кроме того, в их конструкции присутствуют два несущих кристалла (рис. 3), один из которых, выпускаемый по 32-нм техпроцессу, включает в себя два вычислительных ядра, разделяемую L3 кэш-память, контроллер шины QPI. Второй, более крупный кристалл, изготавливаемый по 45-нм технологии, содержит графический процессор GPU, двухканальный контроллер памяти DDR3, контроллер интерфейса PCI Express 2.0 и контроллер шин DMI и FDI (Flexible Display Interface). Взаимодействие между двумя кристаллами происходит по высокоскоростной шине QPI.

Слайд 32 Семейство процессоров Intel Westmere
16
Lanes
Рис. 3
DMI
FDI

Семейство процессоров Intel Westmere 16 LanesРис. 3DMIFDI

Слайд 33 Микроархитектура AMD K10
Микроархитектура AMD К10 является логическим

Микроархитектура AMD K10 Микроархитектура AMD К10 является логическим продолжением вполне

продолжением вполне удачной в свое время (2003 г.) микроархитектуры

К8 (AMD Athlon 64), обладавшей двумя важными достоинствами: встроенным в кристалл процессора контроллером памяти и независимой шиной Hyper-Transport. Микроархитектура К8 использовалась для построения только первого поколения двухъядерных процессоров. Для создания последующих поколений двухъядерных и четырехъядерных процессоров AMD использовала микроархитектуру К9 (AMD Athlon 64 Х2), а с 2007 года – К10. Тогда AMD удалось опередить Intel в выпуске настоящего четырехъядерного процессора (AMD Phenom). В то время, как CPU семейства Core 2 Quad представляли собой склейку пары двухъядерных CPU, выполненных в одном процессорном корпусе, AMD Phenom являлся полноценным четырехъядерным решением.

Слайд 34 Микроархитектура AMD K10
Впрочем, компоновка четырех процессорных ядер на

Микроархитектура AMD K10Впрочем, компоновка четырех процессорных ядер на одном кристалле имела

одном кристалле имела и обратную сторону. Дело в том,

что такие полупроводниковые кристаллы, произведенные по 65-нм технологии, получили достаточно большие геометрические размеры. Это, естественно, привело к ощутимому снижению выхода годных кристаллов и повышению себестоимости производства. Однако, AMD смогла придумать, каким образом можно избавиться от значительной части отбраковки. Компания начала поставки трёхъядерных и двухъядерных процессоров, которые изготавливались из кристаллов Phenom с одним или двумя бракованными ядрами (AMD Phenom X3, Phenom X2). Другая проблема, вытекающая из большого размера кристалла процессоров первого поколения К10 – относительно невысокие тактовые частоты, диктуемые необходимостью держать тепловыделение CPU в приемлемых рамках. Эта проблема частично решена AMD в процессорах второго поколения Phenom II и Athlon II, когда производство CPU встало на более современный 45-нм техпроцесс.


Слайд 35 Структура ядра процессора AMD K10
Каждое ядро процессора имеет

Структура ядра процессора AMD K10Каждое ядро процессора имеет выделенный кэш L1

выделенный кэш L1 данных и инструкций размером по 64

Кбайт (КВ) каждый, а также выделенный кэш L2 размером 512 КВ (рис. 4). Кроме того реализован разделяемый между всеми ядрами кэш L3 размером 2 МВ (такой кэш отсутствовал в микроархитектуре AMD K8).
Процессор К10 производит выборку инструкций (Instruction Fetch Unit) из кэша команд L1 выровненными 32-байтными блоками, в отличие от процессоров К8 и Intel Core, которые производили выборку 16- байтными блоками.
В архитектуре AMD K8 длина блока выборки инструкций была согласована с возможностями декодера. В архитектуре К10 возможности декодера изменились, в результате чего потребовалось изменить и размер блока выборки, чтобы темп выборки инструкций был сбалансирован со скоростью работы декодера.


Слайд 36
Рис. 4

Рис. 4

Слайд 37 Структура ядра процессора AMD K10
В К10 предсказание переходов

Структура ядра процессора AMD K10В К10 предсказание переходов (Branch Prediction Unit)

(Branch Prediction Unit) существенно улучшено.
Во-первых, появился механизм предсказания косвенных

переходов, т. е. переходов, которые производятся по указателю, динамически вычисляемому при выполнении кода программы.
Во-вторых, предсказание выполняется на основе анализа 12 предыдущих переходов, что повышает точность предсказаний. В-третьих, вдвое (с 12 до 24 элементов) увеличена глубина стека возврата.


Слайд 38 Структура ядра процессора AMD K10
В процессоре К10 внешние

Структура ядра процессора AMD K10В процессоре К10 внешние х86-команды декодируются во

х86-команды декодируются во внутренние RISC-инструкции, для чего используется декодер

команд. Процесс декодирования состоит из двух этапов. На первом этапе выбранные из кэша L1 блоки инструкций длиной 32 байта (256 бит) помещаются в специальный буфер преддекодирования (Predecode / Pick Buffer), где происходит выделение инструкций из блоков, определение их типов и отсылка в соответствующие каналы декодера. Декодер транслирует х86-инструкции в простейшие машинные команды (микрооперации), называемые micro-ops (µOp). Сами х86-команды могут быть переменной длины, а вот длина микроопераций уже фиксированная. Инструкции х86 разделяются на простые и сложные. Простые инструкции при декодировании представляются с помощью одной-двух микроопераций, а сложные команды – тремя и более микрооперациями. Простые инструкции отсылаются в аппаратный декодер, построенный на логических схемах и называемый Direct Path, а сложные – в микропрограммный декодер, называемый Vector Path. Он содержит память микрокода, в которой хранятся последовательности микроопераций.


Слайд 39 Структура ядра процессора AMD K10
Аппаратный декодер Direct Path

Структура ядра процессора AMD K10Аппаратный декодер Direct Path является трехканальным и

является трехканальным и может декодировать за один такт: три

простые инструкции, если каждая из них транслируется в одну микрооперацию; либо одну простую инструкцию, транслируемую в две микрооперации, и одну простую инструкцию, транслируемую в одну микрооперацию; либо две простые инструкции за два такта, если каждая инструкция транслируется в две микрооперации (полторы инструкции за такт). Таким образом, за каждый такт аппаратный декодер выдает три микрооперации.
Микропрограммный декодер Vector Path также способен выдавать по три микрооперации за такт при декодировании сложных инструкций. При этом сложные инструкции не могут декодироваться одновременно с простыми, т. е. при работе трехканального аппаратного декодера микропрограммный декодер не используется, а при декодировании сложных инструкций, наоборот, бездействует аппаратный декодер.

Слайд 40 Структура ядра процессора AMD K10
Микрооперации, полученные в результате

Структура ядра процессора AMD K10Микрооперации, полученные в результате декодирования инструкций в

декодирования инструкций в декодерах Vector Path и Direct Path

поступают в буфер Pack Buffer, где они объединяются в группы по три микрооперации.
В том случае, когда за один такт в буфер поступает не три, а одна или две микрооперации (в результате задержек с выбором инструкций), группы заполняются пустыми микрооперациями, но так, чтобы в каждой группе было ровно три микрооперации.
Далее группы микроинструкций отправляются на исполнение.


Слайд 41 Структура ядра процессора AMD K10
Если посмотреть на схему

Структура ядра процессора AMD K10Если посмотреть на схему декодера в микроархитектурах

декодера в микроархитектурах К8 и К10, то видимых различий

казалось бы нет. Действительно, схема работы декодера осталась без изменений. Разница в данном случае заключается в том, какие инструкции считаются сложными, а какие простыми, а также в том, как декодируются различные инструкции. Так, в микроархитектуре К8 128-битные SSE-инструкции разбиваются на две микрооперации, а в микроархитектуре К10 большинство SSE-инструкций декодируется в аппаратном декодере как одна микрооперация. Кроме того, часть SSE-инструкций, которые в микроархитектуре К8 декодировались через микропрограммный декодер, в микроархитектуре К10 декодируются через аппаратный декодер.
Кроме того в микроархитектуре К10 в декодер добавлен специальный блок, называемый Sideband Stack Optimizer. Он повышает эффективность декодирования инструкций работы со стеком и, таким образом, позволяет переупорядочивать микрооперации, получаемые в результате декодирования, чтобы они могли выполняться параллельно.


Слайд 42 Структура ядра процессора AMD K10
После прохождения декодера микрооперации

Структура ядра процессора AMD K10После прохождения декодера микрооперации (по три за

(по три за каждый такт) поступают в блок управления

командами, называемый Instruction Control Unit (ICU). Главная задача ICU заключается в диспетчеризации трех микроопераций за такт по функциональным устройствам, т. е. ICU распределяет инструкции в зависимости от их назначения. Для этого используется буфер переупорядочивания Reorder Buffer (ROB), который рассчитан на хранение 72 микроопераций. Из буфера переупорядочивания микрооперации поступают в очереди планировщиков целочисленных (Int Scheduler) и вещественных (FP Mapper) исполнительных устройств в том порядке, в котором они вышли из декодера.
Планировщик для работы с вещественными числами образован тремя станциями резервирования (RS), каждая из которых рассчитана на 12 инструкций. Его основная задача заключается в том, чтобы распределять команды по исполнительным блокам по мере их готовности.

Слайд 43 Структура ядра процессора AMD K10
Просматривая все 36 поступающих

Структура ядра процессора AMD K10Просматривая все 36 поступающих инструкций, FP-Renamer переупорядочивает

инструкций, FP-Renamer переупорядочивает следование команд, строя спекулятивные предположения о

дальнейшем ходе программы, чтобы создать несколько полностью независимых друг от друга очередей инструкций, которые можно выполнять параллельно. В микроархитектурах К8 и К10 имеется 3 исполнительных блока для работы с вещественными числами, поэтому FP-планировщик должен формировать по три инструкции за такт, направляя их на исполнительные блоки.
Планировщик инструкций для работы с целыми числами (Int Scheduler) образован тремя станциями резервирования, каждая из которых рассчитана на 8 инструкций. Все три станции таким образом образуют планировщик на 24 инструкции. Этот планировщик выполняет те же, функции, что и FP-планировщик. Различие между ними заключается в том, что в процессоре имеется 7 функциональных исполнительных блоков для работы с целыми числами (три устройства ALU, три устройства AGU и одно устройство IMUL).


Слайд 44 Структура ядра процессора AMD K10
После того, как все

Структура ядра процессора AMD K10После того, как все микрооперации прошли диспетчеризацию

микрооперации прошли диспетчеризацию и переупорядочивание, они могут быть выполнены

в соответствующих исполнительных устройствах. Блок операций с целыми числами состоит из трех распараллеленных частей.
По мере готовности данных планировщик может запускать на исполнение из каждой очереди одну целочисленную операцию в устройстве ALU и одну адресную операцию в устройстве AGU (устройство генерации адреса).
Количество одновременных обращений к памяти ограничено двумя. Таким образом, за каждый такт может запускаться на исполнение три целочисленных операции, обрабатываемых в устройствах ALU, и две операции с памятью, обрабатываемых в устройствах AGU.


Слайд 45 Структура ядра процессора AMD K10
В процессоре К8 после

Структура ядра процессора AMD K10В процессоре К8 после вычисления на AGU

вычисления на AGU адресов обращения к памяти операции загрузки

и сохранения направляются в LSU (Load/Store Unit) – устройство загрузки/сохранения. В LSU находятся две очереди LS1 и LS2. Сначала операции загрузки и сохранения попадают в очередь LS1 глубиной 12 элементов. Из очереди LS1 в программном порядке по две операции за такт производятся обращения к кэш-памяти первого уровня. В случае кэш-промаха операции перемещаются во вторую очередь LS2 глубиной 32 элемента, откуда выполняются обращения к кэш-памяти второго уровня и оперативной памяти. В процессоре К10 в LSU были внесены изменения. Теперь в очередь LS1 попадают только операции загрузки, а операции сохранения направляются в очередь LS2. Операции загрузки из LS1 теперь могут исполняться во внеочередном порядке с учетом адресов операций сохранения в очереди LS2. 128-,битные операции сохранения обрабатываются в процессоре К10 как две 64-битные, поэтому в очереди LS2 они занимают по две позиции.


Слайд 46 Структура ядра процессора AMD K10
Для работы с вещественными

Структура ядра процессора AMD K10Для работы с вещественными числами реализовано три

числами реализовано три функциональных устройства FPU: FADD – для

вещественного сложения, FMUL – для вещественного умножения и FMISC (он же FSTORE) – для команд сохранения в памяти и вспомогательных операций преобразования.
В микроархитектурах К8 и К10 планировщик для работы с вещественными числами каждый такт может запускать на исполнение по одной операции в каждом функциональном устройстве FPU.
Подобная реализация блока FPU теоретически позволяет выполнять до трех вещественных операций за такт. В микроархитектуре К10 устройства FPU являются 128-битными. Соответственно 128-битные SSE-команды обрабатываются с помощью одной микрооперации, что теоретически увеличивает темп выполнения векторных SSE-команд в два раза, по сравнению с микроархитектурой К8.


  • Имя файла: osobennosti-razvitiya-i-strukturnoy-organizatsii-sovremennyh-modeley-mikroprotsessorov.pptx
  • Количество просмотров: 95
  • Количество скачиваний: 0