В программах решения многих задач, особенно экономических, содержится большое число условных передач управления. Если процессор может заранее предсказывать направление перехода (ветвления), то производительность его работы значительно повысится за счет оптимизации загрузки вычислительных конвейеров. Тем не менее следует сказать, что если путь ветвления предсказан неверно, процессор должен сбросить полученные результаты, очистить конвейеры и загрузить нужные команды заново, что требует достаточно большого числа тактов. В процессоре Pentium Pro вероятность правильного предсказания 90 % против 80 % у МП Pentium.
Кэш-память емкостью 256-512 Кбайт — обязательный атрибут высокопроизводительных систем на процессорах Pentium. Однако у них встроенная кэш-память имеет небольшую емкость (16 Кбайт), а основная ее часть находится вне процессора на материнской плате. Поэтому обмен данными с ней происходит не на внутренней частоте МП, а на частоте тактового генератора, которая обычно в 2-5 раз ниже, что снижает общее быстродействие компьютера. В МП Pentium Pro есть и кэш память 1-го уровня (по 8 Кбайт для команд и данных) и кристалл кэш-памяти 2-го уровня емкостью 256 или 512 Кбайт, находящийся тоже на плате самого микропроцессора и работающий на внутренней частоте МП.
Микропроцессоры Pentium MMX и Pentium II
В январе и июне 1997 года прошли презентацию модернизированные для работы в мультимедийной технологии микропроцессоры Pentium и Pentium Pro, получившие торговые марки соответственно Pentium MMX (MMX — MultiMedia eXtention) и Pentium И. МП Pentium MMX содержит дополнительные 57 команд, ориентированные на обработку аудио - и видеоинформации, увеличенную вдвое (до 32 Кбайт) кэш-память, дополнительные восемь 64-битных регистров, новый блок предсказания ветвлений, заимствованный у МП Pentium Pro и т. д. Вследствие этого у него на 1 млн транзисторных элементов больше, чем у МП Pentium.
Для эффективного использования этих микропроцессоров во все старые программы (в том числе и в операционные системы Windows 95, Windows NT) необходимо включить согласующие программные фрагменты; правда и без них МП Реп tium MMX несколько производительнее просто МП Pentium. При выполнении обычных приложений МП Pentium MMX на 10-15 % быстрее МП Pentium, а при выполнении мультимедийных приложений с использованием новых 57 команд он уже быстрее на 30 % (для сравнения: МП Pentium Pro быстрее МП Pentium при выполнении обычных приложений примерно на 20 %). Программы, написанные с учетом специфики Pentium MMX, не будут работать на ПК с обычным МП Pentium. Для МП Pentium MMX требуется системная плата с разъемом Socket 7, с новым BIOS, поддерживающим ММХ, и с двумя напряжениями питания (3,5 и 2,8 В).
МП Pentium II имеет иную конструкцию, нежели все остальные МП, в частности он выполнен в виде небольшой платы-картриджа (корпус SECC), на которой размещены сам процессор (содержащий 7,5 млн транзисторов, против 5,5 млн в МП Pentium Pro) и четыре микросхемы кэш-памяти 2-го уровня, общим объемом 512 Кбайт. Кэш-память 1-го уровня, находящаяся в микросхеме самого процессора, имеет емкость 32 Кбайта против 16 Кбайт, имевшихся в МП Pentium Pro, но кэш-память 2-го уровня работает не на внутренней частоте МП, а на вдвое меньшей частоте.
Важным отличием Pentium II является архитектура двойной независимой шины (первые варианты введения такой шины были уже у МП Pentium Pro). Процессор обменивается данными с кэшем L2 по специализированной высокоскоростной шине (иногда называемой «backside» — задней), отделенной от системной шины («frontside» — передней). Системная шина работает на частоте материнской платы, и это существенно снижает эффективное быстродействие машины. Наличие же backside-шины ускоряет обмен с кэш-памятью.
МП Pentium II поддерживает двухпроцессорную конфигурацию ПК. В МП Pentium Pro и Pentium II появилась качественно новая перспектива: начали внедряться так называемые SIMD (Single Instruction Multiply Data — сравните со структурами многопроцессорных систем) инструкции, в которых одно и то же действие совершается над многими данными (эта технология получит развитие в следующих моделях МП). МП производится на основе 0,35-мкм технологии и использует напряжение питания 2,8 В. Для него, естественно, требуется иная системная плата, нежели для всех других Pentium. Микропроцессоры Pentium II имеют много модификаций: Klamath, Dechutes, Katmai, Tanga; МП средней группы Celeron — Covington, Mendosino, Dixon.
Для более дешевых компьютеров предложили облегченный вариант процессора, названный Celeron. Первые процессоры Celeron имели частоты 266 и 300 МГц. Вторичный кэш исключили, что заметно отразилось на производительности ПК (системные платы с разъемом Slot 1 вторичного кэша не имеют), и машина оказалась малоэффективной. Выпустили процессоры CeleronA, которые имеют небольшой (128 Кбайт) вторичный кэш, установленный на плате МП и работающий уже на полной частоте МП. Эти процессоры, известные также под названием Mendocino, стали очень популярными.
Кроме широко известных особенностей вторичного кэша (либо его нет, либо 128 Кбайт), процессор Celeron имеет следующие отличия от Pentium II:
а разрядность шины адреса сокращена с 36 до 32 бит (адресуемая память — 4 Гбайт);
Q несколько ослаблены процедуры контроля достоверности преобразования информации;
□ Celeron предназначен только для однопроцессорных конфигураций.
Процессоры CeleronA являются самыми популярными из недорогих компьютеров и в настоящее время. Большинство МП Pentium II, в том числе и CeleronA, поддерживают частоту шины системной платы 100, 133 и более мегагерц (предыдущие модели — только 66 МГц).
Микропроцессоры Pentium III
Новинка 1999 года — процессоры Pentium III (Coppermine) — являются дальнейшим развитием Pentium П. Их главным отличием является основанное на новом блоке 128-разрядных регистров расширение набора SIMD-инструкций, ориентированных на форматы данных с плавающей запятой — SSE (Streaming SIMD Extensions). По возможностям мультипроцессорных конфигураций эти процессоры аналогичны своим предшественникам Pentium П. .
Кэш 2-го уровня у МП Pentium III имеет размер 256 Кбайт, работает на полной частоте МП и обслуживается быстродействующей backcide шиной, что во много раз ускоряет как работу с кэшем, так и производительность ПК в целом. МП предназначены для работы с материнскими платами, имеющими чипсеты (набор микросхем, связывающих процессор с остальной системой) Intel: 440BX, 440ZX, 440GX, 810, 815,820, 840 и более новые; поддерживают частоту шины материнской платы 100, 133, 150 МГц и выше. «Простые» Pentium III устанавливаются в Слот 1, Pentium HI Xeon — в Slot 2. Процессоры Pentium HI Xeon (и последующие модели Tanner, Cascades) являются продолжением линии МП Pentium Pro и отличаются увеличенным кэшем 2-го уровня (512, 1024 и 2048 Кбайт), работающим на полной частоте МП.
Микропроцессоры Pentium 4
Последняя на 2001 год модификация МП Pentium — Pentium 4. Она предназначена для высокопроизводительных компьютеров, в первую очередь серверов, рабочих станций класса high-end и мультимедийных игровых ПК. Рассмотрим основные особенности Pentium 4.
Добавлены 144 новые потоковые инструкции, расширяющие набор SIMD-инструкций, ориентированных на форматы данных с плавающей запятой — SSE (Streaming SIMD Extensions). Модуль вычислений с плавающей запятой и потоковый модуль оптимизированы для работы с видео - и аудиопотоками, ЗО-технологиями.
Имееется кэш 2-го уровня размером 256 Кбайт; он работает на полной частоте МП, использует встроенную программу коррекции ошибок и обслуживается быстродействующей шириной 256 бит (32 байта) шиной, работающей на частоте МП. Это для Pentium 4 с частотой 1500 МГц, например, обеспечивает скорость обмена с кэшем (трансфер) 48 Гбайт/с.
Есть возможность работы с системной шиной с эквивалентной частотой 400 МГц (Quard-Pumped Bus no 100 МГц), обеспечивая скорость обмена 3,2 Гбайт/с. Вновь улучшена система «динамического исполнения» (dinamic execution), что, в первую очередь, связано с наличием 20-ступенной (у МП Pentium III конвейер имел 10 ступеней) суперконвейерной структуры (superpipelining), лучшего предсказания ветвлений программы при условных передачах управления (branch prediction) и параллельного спекулятивного исполнения команд по нескольким предполагаемым путям ветвления (speculative execution). Поясним это. Динамическое исполнение позволяет процессору предсказывать порядок выполнения инструкций при помощи технологии можественного предсказания ветвлений, которая прогнозирует прохождение программы по нескольким ветвям. Это оказывается возможным, поскольку в процессе исполнения инструкции процессор просматривает программу на несколько шагов вперед. Технология анализа потока данных позволяет проанализировать программу и составить ожидаемую последовательность исполнения инструкций независимо от порядка их следования в тексте программы. И наконец, спекулятивное выполнение повышает скорость выполнения программы за счет выполнения нескольких инструкций одновременно, по мере их поступления в ожидаемой последовательности. Поскольку выполнение инструкций происходит на основе предсказания ветвлений, результаты сохраняются как «спекулятивные» с последующим удалением тех, которые вызваны промахами в предсказании. На конечном этапе порядок инструкций и результатов их выполнения восстанавливается до первоначального.
Используется новая микроархитектура, базирующаяся на двух параллельных 32-битных конвейерах и поддерживающая технологию поточной обработки Hyper Pipelined. Это позволило сделать эффективным длинный конвейер. Суть в том, что при длинном конвейере в задачах с частыми условными переходами его эффективность снижается. Два параллельных конвейера снижение эффективности уменьшают. Теперь реальна ситуация, когда в каждый момент времени одна инструкция загружается, другая декодируется, для третьей (или нескольких) формируется пакет данных, четвертая инструкция (или несколько) исполняется, для пятой записывается результат. И если при строго последовательном исполнении инструкций даже самые короткие операции исполнялись за 5 тактов, то при такой поточной обработке многие инструкции могут быть выполнены за такт. Используется новая технология ускоренных вычислений (Rapid Execution Engine), использующая два быстрых, работающих на удвоенной частоте процессора АЛУ, выполняющие короткие арифметические и логические операции за 0,5 такта, и третье медленное АЛУ, исполняющее длинные операции (умножение, деление и т. д.).
Процессор имеет площадь кристалла 217 кв. мм, потребляет 52 Вт при частоте 1500 МГц, содержит 42 млн транзисторов. На базе Pentium 4 можно создать высокоэффективную ММХ-систему, но для этого необходимо наличие:
· программного обеспечения, ориентированного на использование дополнительных команд этого процессора;
· системной платы с чипсетами, поддерживающими данные микропроцессоры.
Микропроцессоры Over Drive
Интерес представляют МП Over Drive, по существу являющиеся своеобразными сопроцессорами, обеспечивающими для МП 80486 режимы работы и эффективное быстродействие, характерные для МП Pentium, а для МП Pentium — увеличение их производительности (в частности, Over Drive 125, 150 и 166 соответственно для Pentium 75,90 и 100, увеличивающие их внутреннюю частоту до указанных при Over Drive величин).
Микропроцессоры типа RISC
Микропроцессоры типа RISC содержат только набор простых, чаще всего встречающихся в программах команд. При необходимости выполнения более сложных команд в микропроцессоре производится их автоматическая сборка из простых. В этих МП все простые команды имеют один размер и на выполнение каждой из них тратится один машинный такт (на выполнение даже самой короткой команды из системы CISC обычно тратится четыре такта). Один из первых МП типа RISC — ARM (на его основе был создан ПК IBM PC RT): 32 разрядный МП, имеющий 118 различных команд. Современные 64-разрядные RISC МП выпускаются многими фирмами: Apple (Power PC), IBM (PPC), DEC (Alpha), HP (PA), Sun (Ultra SPARC) и т. д.
Микропроцессоры Power PC (Performance Optimized With Enhanced PC) весьма перспективны и уже сейчас широко применяются в машинах-серверах и в ПК типа Macintosh. Микропроцессоры Power PC имеют тактовую частоту до 800 МГц, а микропроцессоры Alpha имеет модели с тактовой частотой 1800 МГц. Микропроцессоры типа RISC имеют очень высокое быстродействие, но программно не совместимы с CISC-процессорами: при выполнении программ, разработанных для ПК типа IBM PC, они могут лишь эмулировать (моделировать, имитировать) МП типа CISC на программном уровне, что приводит к резкому уменьшению их эффективной производительности.
Микропроцессоры типа VLIW
Это новый и весьма перспективный тип МП. Микропроцессоры типа VLIW выпускают фирмы: Transmeta — это микропроцессор Crusoe моделей ТМ3120, ТМ5400, ТМ5600 (технология 0,18 мкм, тактовые частоты до 700 МГц), Intel — модель Mersed (торговая марка Itanium, 800 МГц) и Hewlett-Packard — модель McKinley. Следует заметить, что при более глубоком анализе технология EPIC (Explicitly Parallel Instruction Computing — вычисления с явной параллельностью инструкций), которой придерживаются фирмы Intel и HP, незначительно отличается от технологии VLIW, которой придерживается фирма Transmeta. Но эти отличия несущественны, поэтому микропроцессоры VLIM и EPIC можно отнести к одной группе.
МП Merced — первый процессор, использующий полный набор 64-битных инструкций (Intel Architecture-64, IA-64; именно эта технология называется EPIC). К VLIW-типу можно отнести и ожидаемый в 2002 году МП Elbrus 2000 (Е2К),
разработанный российской компанией «Эльбрус». Микропроцессор с тактовой частотой 1200 МГц изготавливается по технологии 0,18 мкм.
Программисты доступа к внутренним VLIW-командам не имеют: все программы (даже операционная система) работают поверх специального низкоуровневого программного обеспечения (Code Morphing), которое ответственно за трансляцию команд CISC микропроцессоров в команды VLIW. МП типа VLIW вместо сложной схемной логики, обеспечивающей в современных суперскалярных микропроцессорах параллельное исполнение команд, используют программное обеспечение. Упрощение аппаратуры позволило уменьшить габариты МП и потребление энергии (эти МП иногда называют «холодными»).
Архитектура CISC появилась в 1978 году. Тогда процессоры представляли собой скалярные устройства (то есть могли в каждый момент времени выполнять только одну команду), при этом конвейеров практически не было. Процессоры содержали десятки тысяч транзисторов. МП RISC были разработаны в 1986 году, когда технология суперскалярных конвейеров только начала развиваться. Процессоры содержали сотни тысяч транзисторов. В конце 90-х наиболее совершенные процессоры содержали миллионы, десятки миллионов транзисторов. Уже первые МП архитектуры IA-64 содержат десятки миллионов транзисторов. В дальнейших модификациях их число, вероятно, увеличится до сотен миллионов.
Архитектура IA-64 не является ни 64-разрядным расширением архитектуры CISC, ни переработкой архитектуры RISC. IA-64 представляет собой новую архитектуру, использующую длинные слова команд (LIW), предикаты команд (instruction predication), устранение ветвлений (branch elimination), предварительную загрузку данных (speculative loading) и другие ухищрения для того, чтобы обеспечить больший параллелизм выполнения программ. Но тем не менее IA-64 — это компромисс между CISC и RISC, попытка сделать их совместимыми: существует два режима декодирования команд — VLIW и старый CISC. Программы автоматически переключаются в необходимый режим исполнения. Для работы с VLIW операционные системы должны содержать и 64-разрядную часть на IA-64, и старую 32-разрядную.
Все новые МП создаются на основе технологий, обеспечивающих формирование элементов с линейным размером порядка 0,25 мкм и ниже (традиционные МП 80486 и Pentium использовали 0,8-мкм элементы).
Уменьшение размеров элементов обеспечивает возможность:
· увеличения тактовой частоты МП до сотен мегагерц и выше;
· уменьшения перегрева МП, что позволяет использовать пониженное напряжение питания 1-2 В (вместо 5 В).
Физическая и функциональная структура микропроцессора
Физическая структура микропроцессора достаточно сложна. Ядро процессора содержит главный управляющий модуль и исполняющие модули — блоки выполнения операций над целочисленными данными. К локальным управляющим схемам относятся: блок плавающей точки, модуль предсказания ветвлений, модуль преобразования CISC инструкций во внутренний RISC микрокод, регистры микропроцессорной памяти (в МП типа VLIW до 256 регистров), регистры кэш-памяти 1-го уровня (отдельно для данных и инструкций), шинный интерфейс и многое другое.
В состав микропроцессора Pentium обычно входят следующие физические компоненты:
· Соте — ядро МП;
· Execution Unit — исполняющий модуль;
· Integer ALU — АЛУ для операций с целыми числами (с фиксированной запятой);
· Registers — регистры;
· Floating Point Unit — блок для работы с числами с плавающей запятой;
· Primary Cache — кэш первого уровня, в том числе кэш данных (Data Cache) и кэш команд (Code Cache);
· Instruction Decode and Prefetch Unit и Branch Predictor — блоки декодирования инструкций, спекулятивного их исполнения и предсказания ветвлений;
· Bus Interface — интерфейсные шины, в том числе 64-битная (64-bit Bus) и 32-битная (32-bit Bus) шины, и выход на системную шину к оперативной памяти(То RAM).
Функционально МП можно разделить на две части:
· операционную, содержащую устройство управления (УУ), арифметикологическое устройство (АЛУ) и микропроцессорную память (МПП) (за исключением нескольких адресных регистров);
· интерфейсную, содержащую адресные регистры МПП; блок регистров команд — регистры памяти для хранения кодов команд, выполняемых в ближайшие так ты работы машины; схемы управления шиной и портами.
Обе части МП работают параллельно, причем интерфейсная часть опережает операционную, так что выборка очередной команды из памяти (ее запись в блок регистров команд и предварительный анализ) выполняется во время выполнения операционной частью предыдущей команды^ Современные микропроцессоры имеют несколько групп регистров в интерфейсной: части, работающих с различной степенью опережения, что позволяет выполнять операции в конвейерном режиме. Такая организация МП позволяет существенно повысить его эффективное быстродействие.
Устройство управления
Устройство управления (УУ) является функционально наиболее сложным устройством ПК — оно вырабатывает управляющие сигналы, поступающие по кодовым шинам инструкций (КШИ) во все блоки машины. Упрощенная функциональная схема У У показана на рис. 5.1.

Рис. 5.1. Укрупненная функциональная схема УУ
На рисунке представлены:
· регистр команд — запоминающий регистр, в котором хранится код команды: код выполняемой операции (КОП) и адреса операндов, участвующих в операции; регистр команд расположен в интерфейсной части МП, в блоке регистров команд;
· дешифратор операций — логический блок, выбирающий в соответствии с поступающим из регистра команд КОП один из множества имеющихся у него выходов;
· постоянное запоминающее устройство (ПЗУ) микропрограмм хранит в своих ячейках управляющие сигналы (импульсы), необходимые для выполнения в блоках ПК процедур операций обработки информации; импульс по выбранному дешифратором операций в соответствии с КОП проводу считывает из ПЗУ микропрограмм необходимую последовательность управляющих сигналов;
· узел формирования адреса (находится в интерфейсной части МП) — устройство, вычисляющее полный адрес ячейки памяти (регистра) по реквизитам, поступающим из регистра команд и регистров МПП;
· кодовые шины данных, адреса и инструкций — часть внутренней интерфейсной
· шины микропроцессора.
· В общем случае УУ формирует управляющие сигналы для выполнения следующих основных процедур:
· выборки из регистра-«счетчика адреса команды» МПП адреса ячейки ОЗУ, где
хранится очередная команда программы;
· выборки из ячеек ОЗУ кода очередной команды и приема считанной команды
в регистр команд;
· расшифровки КОП и признаков выбранной команды;
·
считывания из соответствующих расшифрованному КОП ячеек ПЗУ микропрограмм управляющих сигналов (импульсов), определяющих во, всех блоках машины процедуры выполнения заданной операции, и пересылки управляющих сигналов в эти блоки;
· считывания из регистра команд и регистров МПП отдельных составляющих адресов операндов (чисел), участвующих в вычислениях, и формирование полных адресов операндов;
· выборки операндов (по сформированным адресам) и выполнения заданной операции обработки этих операндов;
· записи результатов операции в память; формирования адреса следующей команды программы.
Арифметико-логическое устройство
Арифметико-логическое устройство (АЛУ) предназначено для выполнения арифметических и логических операций преобразования информации. Функционально АЛУ (рис. 5.2) состоит обычно из двух регистров, сумматора и схем управления (местного устройства управления).

Сумматор — вычислительная схема, выполняющая процедуру сложения поступающих на ее вход двоичных кодов; сумматор имеет разрядность двойного машинного слова.
Регистры — быстродействующие ячейки памяти различной длины: Регистр 1 (Рг1) имеет разрядность двойного слова, а Регистр 2 (Рг2) — разрядность слова. При выполнении операций в Рг1 помещается первое число, участвующее в операции, а по завершении операции — результат; в Рг2 — второе число, участвующее в операции (по завершении операции информация в нем не изменяется). Регистр 1 может и принимать информацию с кодовых шин данных, и выдавать информацию на них; регистр 2 только получает информацию с этих шин.
Схемы управления принимают по кодовым шинам инструкций управляющие сигналы от устройства управления и преобразуют их в сигналы для управления работой регистров и сумматора АЛ У.
АЛУ выполняет арифметические операции «+», «-», « • » и «:» только над двоичной информацией с запятой, фиксированной после последнего разряда, то есть только над целыми двоичными числами. Выполнение операций над двоичными числами с плавающей запятой и над двоично-кодированными десятичными числами осуществляется с привлечением математического сопроцессора или по специально составленным программам.
Рассмотрим в качестве примера выполнения команды умножения. Перемножаются числа 1101 и 1011 (числа для простоты взяты 4-битными). Множимое находится в регистре 1, имеющем удвоенную по отношению к регистру 2 разрядность; множитель находится в регистре 2. Операция умножения требует для своего выполнения нескольких тактов. В каждом такте число из регистра 1 проходит в сумматор (имеющий также удвоенную разрядность) только в том случае, если в младшем разряде регистра 2 находится 1. В данном примере в первом такте число 1101 пройдет в сумматор, и в этом же первом такте число в регистре 1 сдвигается на один разряд влево, а число в регистре 2 на один разряд вправо. В конце такта после сдвигов в регистре 1 будет находиться число 11010, а в регистре 2 — число 101. Во втором такте число из регистра 1 пройдет в сумматор, так как младший разряд в регистре 2 равен 1; в конце такта числа в регистрах опять будут сдвинуты влево и вправо, так что в регистре 1 окажется число а в регистре 2 — число 10. В третьем такте число из регистра 1 не пройдет в сумматор, так как младший разряд в регистре 2 равен 0; в конце такта числа в регистрах будут сдвинуты влево и вправо, так что в регистре 1 окажется число 1 а в регистре 2 — число 1. В четвертом такте число из регистра 1 пройдет в сумматор, так как младший разряд в регистре 2 равен 1; в конце такта числа в регистрах будут сдвинуты влево и вправо, так что в регистре 1 окажется число , а в регистре 2 — число 0. Так как множитель в регистре 2 стал равным 0, операция умножения заканчивается. В результате в сумматор последовательно поступят и будут сложены числа: 1101, 11010, 1101000; их сумма 10001десятичное) и будет равна произведению чисел 1101x1011(13x11 десятичные).
Микропроцессорная память
Микропроцессорная память (МПП) базового МП 8088 включает в себя четырнадцать 2-байтовых запоминающих регистров. У МП 80286 и выше имеются дополнительные регистры, например у МП типа VLIW есть 256 регистров, из которых 128 — регистры общего назначения. У МП 80386 и выше некоторые регистры, в том числе и регистры общего назначения, — 4-байтовые (у МП Pentium есть и 8-байтовые регистры). Но в качестве базовой модели, в частности для языка программирования ассемблер и отладчика программ DEBUG, используется 14-регистровая система МПП.
Все регистры можно разделить на четыре группы:
· универсальные регистры: АХ, DX, CX, DX;
· сегментные регистры: CS, DS, SS, ES;
· регистры смещения: IP, SP, BP, SI, DI; Q регистр флагов: FL.
Если регистры 4-байтные или 8-байтные, их имена несколько изменяются, например, 4-байтные универсальные регистры АХ, ВХ, СХ, DX именуются соответственно Е АХ, ЕВХ, ЕСХ, EDX. При этом если используется их 2-байтовая или 1-байтовая часть, наименования этих частей регистров соответствуют рассматриваемым ниже.
Универсальные регистры
Регистры АХ, ВХ, СХ и DX являются универсальными (их часто называют регистрами общего назначения — РОН); каждый из них может использоваться для временного хранения любых данных, при этом можно работать с каждым регистром целиком, а можно отдельно и с каждой его половиной (регистры АН, ВН, СН, DH — старшие (Hight) байты, а регистры AL, BL, CL, DL — младшие (Low) байты соответствующих 2-байтовых регистров). Но каждый из универсальных регистров может использоваться и как специальный при выполнении некоторых конкретных команд программы. В частности:
· регистр АХ — регистр-аккумулятор, через его порты осуществляется ввод-вывод данных в МП, а при выполнении операций умножения и деления АХ используется для хранения первого числа, участвующего в операции (множимого, делимого), и результата операции (произведения, частного) после ее завершения;
· регистр ВХ часто используется для хранения адреса базы в сегменте данных и начального адреса поля памяти при работе с массивами;
· регистр СХ — регистр-счетчик, используется как счетчик числа повторений при циклических операциях;
· регистр DX используется как расширение регистра-аккумулятора при работе с 32-разрядными числами и при выполнении операций умножения и деления, используется для хранения номера порта при операциях ввода-вывода и т. д.
Сегментные регистры
Сегментные регистры CS, DS, SS, ES используются для хранения начальных адресов полей памяти (сегментов), отведенных в программах для хранения:
· команд программы (сегмент кода — CS);
данных (сегмент данных — DS);
· стековой области памяти (сегмент стека — SS);
· дополнительной области памяти данных при межсегментных пересылках (расширенный сегмент — ES), поскольку размер сегмента в реальном режиме работы МП ограничен величиной 64 Кбайт.
Регистры смещений
Регистры смещений IP, SP, BP, SI, DI используются для хранения относительных адресов ячеек памяти внутри сегментов (смещений относительно начала сегментов):
· регистр IP (Instruction Pointer) хранит смещение адреса текущей команды программы;
· регистр SP (Stack Pointer) — смещение вершины стека (текущего адреса стека);
· регистр ВР (Base Pointer) — смещение начального адреса поля памяти, непосредственно отведенного под стек;
· регистры SI, DI (Source Index и Destination Index соответственно) предназначены для хранения адресов индекса источника и приемника данных при операциях над строками и им подобных.
Регистр флагов
Регистр флагов FL содержит условные одноразрядные признаки-маски или флаги, управляющие прохождением программы в ПК; флаги работают независимо друг от друга и лишь для удобства они помещены в единый регистр. Всего в регистре содержится 9 флагов: 6 из них статусные, отражают результаты операций, выполненных в компьютере (их значения используются, например, при выполнении команд условной передачи управления — команд ветвления программы), а три других — управляющие, непосредственно определяют режим исполнения программы. Статусные флаги:
· CF (Carry Flag) — флаг переноса. Содержит значение «переносов» (0 или 1) из старшего разряда при арифметических операциях и некоторых операциях сдвига и циклического сдвига;
· PF (Parity Flag) — флаг четности. Проверяет младшие 8 битов результатов операций над данными. Нечетное число единичных битов приводит к установке этого флага в 0, а четное — в 1;
· AF (Auxiliary Carry Flag) — флаг логического переноса при двоично-десятичной арифметике. Вспомогательный флаг переноса устанавливается в 1, если арифметическая операция приводит к переносу или заему четвертого справа бита однобайтового операнда. Этот флаг используется при арифметических операциях над двоично-десятичными кодами и кодами ASCII;
· ZF (Zero Flag) — флаг нуля. Устанавливается в 1, если результат операции равен 0; если результат не равен 0, то ZF обнуляется;
· SF (Sign Flag) — флаг знака. Устанавливается в соответствии со знаком результата после арифметических операций: положительный результат устанавливает флаг в 0, отрицательный — в 1;
· OF (Overflow Flag) — флаг переполнения. Устанавливается в 1 при арифметическом переполнении: если возник перенос в знаковый разряд при выполнении знаковых арифметических операций, если частное от деления слишком велико и переполняет регистр результата и т. д.
Управляющие флаги:
· TF (Trap Flag) — флаг системного прерывания (трассировки). Единичное состояние этого флага переводит процессор в режим пошагового выполнения программы (режим трассировки);
· IF (Interrupt Flag) — флаг прерываний. При нулевом состоянии этого флага прерывания запрещены, при единичном — разрешены;
· DF (Direction Flag) — флаг направления. Используется в строковых операциях для задания направления обработки данных. При нулевом состоянии флага команда увеличивает содержимое регистров SI и DI на 1, обусловливая обработку строки «слева направо»; при единичном — «справа налево».
Интерфейсная часть МП
Интерфейсная часть МП предназначена для связи и согласования МП с системной шиной ПК, а также для приема, предварительного анализа команд выполняемой программы и формирования полных адресов операндов и команд. Интерфейсная часть включает в свой состав:
· адресные регистры МПП;
· узел формирования адреса;
· блок регистров команд, являющийся буфером команд в МП;
· внутреннюю интерфейсную шину МП;
· схемы управления шиной и портами ввода-вывода.
Некоторые из названных устройств, такие как узел формирования адреса и регистр команды, непосредственно выполняемой МП, функционально входят в состав устройства управления.
Порты ввода-вывода — это пункты системного интерфейса ПК, через которые МП обменивается информацией с другими устройствами. Всего портов у МП может бытьравно количеству разных адресов, которые можно представить числом формата слово). Каждый порт имеет адрес — номер порта; по существу, это адрес ячейки памяти, являющейся частью устройства ввода-вывода, использующего этот порт, а не частью основной памяти компьютера.
Порт устройства содержит аппаратуру сопряжения и два регистра памяти — для обмена данными и обмена управляющей информацией. Некоторые внешние устройства используют и основную память для хранения больших объемов информации, подлежащей обмену. Многие стандартные устройства (НЖМД, НГМД, клавиатура, принтер, сопроцессор и т. д.) имеют постоянно закрепленные за ними порты ввода-вывода.
Схема управления шиной и портами выполняет следующие функции:
· формирование адреса порта и управляющей информации для него (переключение порта на прием или передачу и т. д.);
· прием управляющей информации от порта, информации о готовности порта и его состоянии;
· организация сквозного канала в системном интерфейсе для передачи данных между портом устройства ввода-вывода и МП.
Схема управления шиной и портами использует для связи с портами кодовые шины инструкций, адреса и данных системной шины: при доступе к порту МП посылает сигнал по КШИ, который оповещает все устройства ввода-вывода, что адрес на

Системные платы
Системная, или материнская (motherboard — MB), плата — это важнейшая часть компьютера, содержащая основные электронные компоненты машины. С помощью материнской платы осуществляется взаимодействие между большинством устройств машины.
Конструктивно МБ представляет собой печатную плату площадью 100-150 кв. см, на которой размещается большое число различных микросхем, разъемов и других элементов. Существует две основные разновидности конструкции системной платы (СП):
Q на плате жестко закреплены все необходимые для работы микросхемы — сейчас такие платы используются лишь в простейших домашних компьютерах, называемых одноплатными;
Q непосредственно на системной плате размещается лишь минимальное количество микросхем, а все остальные компоненты объединяются при помощи системной шины и конструктивно устанавливаются на дополнительных платах (платахрасширения), устанавливаемых в специальные разъемы (слоты), имеющиеся на материнской плате; компьютеры, использующие такую технологию, относятся к вычислительным системам с шинной архитектурой.
Современные профессиональные персональные компьютеры имеют именно шинную архитектуру. На системной плате непосредственно расположены:
· разъем для подключения микропроцессора;
· набор системных микросхем (чипсет, chipset), обеспечивающих работу микропроцессора и других узлов машины;
· микросхема постоянного запоминающего устройства, содержащего программы базовой системы ввода-вывода (basic input-output system — BIOS);
· микросхема энергонезависимой памяти (питается от автономного, расположенного на MB аккумулятора), по технологии изготовления называемая CMOS;
· микросхемы кэш-памяти 2-го уровня (если они отсутствуют на плате микропроцессора);
· разъемы (слоты) для подключения модулей оперативной памяти;
· наборы микросхем и разъемы для системных, локальных и периферийных интерфейсов;
· микросхемы мультимедийных устройств и т. д.
В качестве примера на рис. 5.4 показано размещение основных компонентов на мультимедийной системной плате ТС430НХ.
На рисунке показаны:
|
Из за большого объема этот материал размещен на нескольких страницах:
1 2 3 4 |


