**Задание для группы 134 на 06.02.2022**

**Задание пересылать мне на электронную почту: param\_e@mail.ru**

**Задание** также можно найти на goole-диске по ссылке:

**https://drive.google.com/drive/folders/1so8k-nqGSs5huXCXUFHUo-Hus25OJGE7?hl=ru**

**Конспект лекции высылаете до 20-00 часов 05.02.2022 (конспект в тетради; высылаете фотографии конспекта со своей подписью на каждом листе).**

**Без подписи не принимаю конспект.**

Ответы на вопросы в конце лекции, если они есть (ответы в тетради после конспекта).

Если конспект выслан позже указанного времени, то баллы снижаются за каждый час просрочки на 0,5.

**Лекция. Классы процессоров и арифметико-логическое устройство.**

В зависимости от набора и порядка выполнения команд процессоры подразделяются на четыре класса, отражающих также последовательность развития ЭВМ. Ранее других появились процессоры **CISC.** Затем, с целью повышения быстродействия процессоров были разработаны процессоры **RISC,** которые характеризуются сокращенным набором быстро выполняемых команд. Ряд редко встречающихся команд процессора CISC выполняется последовательностями команд процессора RISC. Позже появилась концепция процессоров MISC, использующая минимальный набор длинных команд. Вслед за ними возникли процессоры VLIW, работающие со сверхдлинными командами.

**CISC** (complex instruction set computer) - традиционная архитектура, в которой ЦП использует микропрограммы для выполнения исчерпывающего набора команд. Они могут иметь различную длину, методы адресации и требуют сложных электронных цепей для декодирования и исполнения. В течение долгих лет производители компьютеров разрабатывали и воплощали в изделиях все более сложные и полные системы команд.

Основоположником CISC-архитектуры считается фирма IBM с архитектурой IBM/360. Здесь выполнение любой сколь угодно сложной команды из системы команд процессора реализовывается аппаратно, внутри самого процессора. В данной архитектуре стремятся иметь отдельную машинную команду для каждого возможного (типового) действия по обработке данных.

Совершенствование процессоров шло по пути создания ВМ, способных выполнять как можно больше разных команд. Это упрощало работу программистов, которые писали программы на языке ассемблера (то есть практически на уровне машинных команд). Использование сложных команд позволяло сократить размер и время разработки программы.

В итоге сложились следующие черты организации CISC-процессоров:

* большое количество различных машинных команд (сотни), каждая из которых выполняется за несколько тактов центрального процессора;
* устройство управления с программируемой логикой;
* небольшое количество регистров общего назначения;
* различные форматы команд с разной длиной;
* преобладание двухадресной адресации;
* развитый механизм адресации операндов, включающий различные методы косвенной адресации.

CISC-подход, однако, привел к тому, что некоторые команды стало невозможно выполнять чисто аппаратными средствами (при разумной сложности таких средств). В результате в процессорах появились блоки, «на лету» заменяющие наиболее сложные команды последовательностями из более простых команд. Из-за высокой сложности команд и их обилия устройство управления ВМ приходилось строить только на основе программируемой логики, то есть с применением «медленной» управляющей памяти. Последнее обстоятельство существенно ограничивало возможности наращивания тактовой частоты процессора.

Анализ работы процессоров показал, что в течение примерно 80 % времени выполняется лишь 20 % большого набора команд. Поэтому была поставлена задача оптимизации выполнения небольшого по числу, но часто используемых команд.

В то же время целый ряд несомненных достоинств CISC-архитектуры сохраняют ее актуальность (прежде всего, в глазах разработчиков программных приложений). Именно поэтому ведущие фирмы-производители ВМ (Intel, AMD, IBM и др.) в своих последних разработках, по-прежнему, не отказываются от CISC-подхода.

В 1974 г. John Cocke-Джон Кок (IBM Research) решил испробовать подход, который мог бы существенно уменьшить количество машинных команд в ЦП. В середине 70-х это привело многих производителей компьютеров к пересмотру своих позиций и к разработке ЦП с весьма ограниченным набором команд.

**RISC** (Redused Instuction Set Computer) - процессор, функционирующий с сокращенным набором команд, т.е. наиболее употребляемыми простейшими командами. Так, в процессоре CISC для выполнения одной команды необходимо в большинстве случаев 10 и более тактов. Что же касается процессоров RISC, то они близки к тому, чтобы выполнять по одной команде в каждом такте. Следует также иметь в виду, что благодаря своей простоте процессоры RISC не патентуются. Это также способствует их быстрой разработке и широкому производству. Между тем, в сокращенный набор RISC вошли только наиболее часто используемые команды.

Первый процессор RISC был создан корпорацией IBM в 1979 г. и имел шифр IBM 801. В настоящее время процессоры RISC получили широкое распространение. Современные процессоры RISC характеризуются следующим:

• упрощенный набор команд, имеющих одинаковую длину;

• большинство команд выполняются за один такт процессора;

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

• взаимодействие с оперативной памятью ограничивается операциями пересылки данных;

• резко уменьшено число способов адресации памяти (не используется косвенная адресация);

• используется *конвейер* команд, позволяющий обрабатывать несколько из них одновременно;

• применяется высокоскоростная память

• простая структура устройства управления.

Новый подход к архитектуре процессора значительно сократил площадь, требуемую для него на кристалле интегральной схемы. Это позволило резко увеличить число регистров. В современном процессоре RISC уже используется более 100 регистров. В результате процессор на 20÷30 % реже обращается к оперативной памяти, что также повысило скорость обработки данных. Упростилась топология процессора, выполняемого в виде одной интегральной схемы, сократились сроки ее разработки, она стала дешевле.

Начиная с процессора Pentium корпорация Intel начала внедрять элементы RISC-технологий в свои изделия.

Недостатки RISC прямо связаны с некоторыми преимуществами этой архитектуры. Принципиальный недостаток - сокращенное число команд: на выполнение ряда функций приходится тратить несколько команд вместо одной в CISC. Это удлиняет код программы, увеличивает загрузку памяти и трафик команд между памятью и ЦП. Исследования показали, что RISC-программа в среднем на 30% длиннее CISC-программы, реализующей те же функции.  
Хотя большое число регистров дает существенные преимущества, само по себе оно усложняет схему декодирования номера регистра, тем самым увеличивается время доступа к регистрам.  
Устройство управления с аппаратной логикой, реализованное в большинстве RISC-систем, менее гибко, более склонно к ошибкам, затрудняет поиск и исправление ошибок, уступает при выполнении сложных команд.

**Процессор VLIW** (Very Long Instruction Word - очень длинная машинная команда) - процессор, работающий с системой команд сверхбольшой разрядности.

Идея технологии VLIW заключается в том, что создается специальный компилятор планирования, который перед выполнением прикладной программы проводит ее анализ, и по множеству ветвей последовательности операций определяет группу команд, которые могут выполняться параллельно. Каждая такая группа образует одну сверхдлинную команду. Это позволяет решать две важные задачи. Во-первых, в течение одного такта выполнять группу коротких («обычных») команд. И, во-вторых, упростить структуру процессора. Этим технология VLIW отличается от суперскалярности. В последнем случае отбор групп одновременно выполняемых команд происходит непосредственно в ходе выполнения прикладной программы (а не заранее). Из-за чего усложняется структура процессора и замедляется скорость его работы.

Технология VLIW появилась в результате работ, проведенных корпорациями HP и Intel.

**Процессор MISC** - MISC processor, работающий с минимальным набором длинных команд.

Увеличение разрядности процессоров привело к идее укладки нескольких команд в одно слово (связку, bound) размером 128 бит. Оперируя с одним словом, процессор получил возможность обрабатывать сразу несколько команд. Это позволило использовать возросшую производительность компьютера и его возможность обрабатывать одновременно несколько потоков данных.

Процессор MISC, как и процессор RISC, характеризуется небольшим набором чаще всего встречающихся команд. Вместе с этим принцип команд VLIW обеспечивает выполнение группы команд за один цикл работы процессора. Порядок выполнения команд распределяется таким образом, чтобы в максимальной степени загрузить маршруты, по которым проходят потоки данных. Таким образом, архитектура MISC объединила вместе суперскалярную (много­поточную) и VLIW концепции. Компоненты процессора просты и работают с высокими скоростями.

**Арифметико-логическое устройство (АЛУ)**

Arithmetic and Logical Unit (ALU) - компонента процессора, выполняющая арифметические и логические операции над данными.

АЛУ реализует важную часть процесса обработки данных. Она заключается в выполнении набора простых операций. Арифметической операцией называют процедуру обработки данных, аргументы и результат которой являются числами (сложение, вычитание, умножение, деление). Логической операцией именуют процедуру, осуществляющую построение сложного высказывания (операции И, ИЛИ, НЕ, ...). АЛУ состоит из регистров, сумматора с соответствующими логическими схемами и блока управления выполняемым процессом. Устройство работает в соответствии с сообщаемыми ему именами (кодами) операций, которые при пересылке данных нужно выполнить над переменными, помещенными в регистр.

АЛУ классифицируются следующим образом:

*1. По способу действий над операндами:*

• АЛУ последовательного действия;

• параллельного действия.

В последовательных АЛУ действия над операндами производятся последовательно разряд за разрядом начиная с младшего. В параллельных АЛУ все разряды операндов обрабатываются одновременно.

*2. По виду обрабатываемых чисел* АЛУ могут производить операции над двоичными числами с фиксированной или плавающей запятой и над двоично-десятичными числами. В последнем случае каждая десятичная цифра записывается четырьмя разрядами двоичного кода:

2003 - 0010 0000 0000 0011

АЛУ при действии над двоично-десятичными числами должны содержать схему десятичной коррекции. Схема десятичной коррекции преобразует полученный результат таким образом, чтобы каждый двоично-десятичный разряд не содержал цифру больше 9.

При записи числа с фиксированной запятой запятая фиксируется после младшего разряда, если число целое, и перед старшим, если число меньше 1.

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

*3. По организации действий над операндами:*

• блочные;

• многофункциональные АЛУ.

В блочных АЛУ отдельные блоки предназначены для действий над двоично-десятичными числами, отдельно для действий над числами с фиксированной запятой, отдельно с плавающей запятой.

![](data:image/png;base64,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)В многофункциональных АЛУ одни и те же блоки обрабатывают числа с фиксированной запятой, плавающей запятой и двоично-десятичные числа (рис. 1).

Рис. 1. Многофункциональное АЛУ.

Клапаны К1 и К2 объединяют сумматоры 1, 2 и 3 для действий над числами с фиксированной запятой.

Для действий над числами с плавающей запятой клапан К2 объединяет сумматоры 2 и 3 для обработки мантисс, а клапан К1 отсоединяет первый сумматор от второго. Сумматор 1 обрабатывает порядки.

*4. По структуре:*

• АЛУ с непосредственными связями;

• многосвязные.

В многосвязных АЛУ входы и выходы регистров приемников и источников информации подсоединяются к одной шине. Распределение входных и выходных сигналов происходит под действием управляющих сигналов.

![](data:image/png;base64,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)В АЛУ с непосредственной связью вход регистра приемника связан с выходом регистра источника операндов и регистра, в котором происходит обработка (рис. 2).

Рис. 2. АЛУ с непосредственной связью.

В этой схеме суммирование происходит так: операнды подаются в регистр 1. Регистр 2 является накапливающим сумматором или автоматом с памятью. Он суммирует слагаемые, поступающие в разные моменты времени, и передает результат в регистр 3.

Умножение в этом АЛУ происходит так: множимое помещают в регистр 4, множитель - в регистр 1. Регистры 2 и 3 являются, кроме того, сдвигающими регистрами. В зависимости от содержимого разряда множителя, множимое сдвигается на один разряд, если множитель содержит 1, и на два, если множитель содержит 0. Эти частные произведения суммируются в регистре 2.