Из скольки частей состоит команда для эвм. Структура и форматы команд эвм

    КОМАНДА ЭВМ, указание, записанное на машинном языке конкретной вычислительной машины и определяющее ее действия при выполнении отдельной операции или части вычислительного процесса … Энциклопедический словарь

    Указание, записанное на машинном языке конкретной вычислит, машины и определяющее её действия при выполнении отд. операции или части вычислит. процесса … Естествознание. Энциклопедический словарь

    - (фр., от лат. commendare поручать). 1) небольшой отряд войска. 2) приказание начальствующего. 3) начальствование. Словарь иностранных слов, вошедших в состав русского языка. Чудинов А.Н., 1910. КОМАНДА 1) военные отряд под начальством отдельного… … Словарь иностранных слов русского языка

    команда визуализации - Команда, которая изменяет состояние или управляет действием графического устройства. Примечание Под графическим устройством понимают устройство, обеспечивающее ввод в ЭВМ и (или) вывод из ЭВМ графических данных. [ГОСТ 27459 87] Тематики машинная… …

    команда типа «память-память» - Команда, операнды и результат которой размещаются в ОЗУ. [Е.С.Алексеев, А.А.Мячев. Англо русский толковый словарь по системотехнике ЭВМ. Москва 1993] Тематики информационные технологии в целом EN storage to storage instructionSS instruction … Справочник технического переводчика

    команда (внутреннего) прерывания (с указанным номером) - — [Е.С.Алексеев, А.А.Мячев. Англо русский толковый словарь по системотехнике ЭВМ. Москва 1993] Тематики информационные технологии в целом EN trap instruction … Справочник технического переводчика

    команда вывода файлов на экран в алфавитном порядке их расширений - — [Е.С.Алексеев, А.А.Мячев. Англо русский толковый словарь по системотехнике ЭВМ. Москва 1993] Тематики информационные технологии в целом EN extension … Справочник технического переводчика

    команда переноса файлов на другой дисковод - — [Е.С.Алексеев, А.А.Мячев. Англо русский толковый словарь по системотехнике ЭВМ. Москва 1993] Тематики информационные технологии в целом EN drive … Справочник технического переводчика

    команда подсистемы - — [Е.С.Алексеев, А.А.Мячев. Англо русский толковый словарь по системотехнике ЭВМ. Москва 1993] Тематики информационные технологии в целом EN subcommand … Справочник технического переводчика

    команда пропуска (следующей команды) - — [Е.С.Алексеев, А.А.Мячев. Англо русский толковый словарь по системотехнике ЭВМ. Москва 1993] Тематики информационные технологии в целом EN skip instruction … Справочник технического переводчика

Федеральное агентство по образованию

Рособразование

Архангельский государственный технический университет

Вычислительных систем и телекоммуникаций

КОНТРОЛЬНАЯ РАБОТА

по дисциплине

Архитектура ЭВМ и систем

Система команд ЭВМ

Шевченко Олег Николаевич

Факультет ОНОТ, курс 3, группа 7261

Руководитель О.Л. Полончик

Архангельск 2009 г.

ВВЕДЕНИЕ

ОБЩИЕ ПОНЯТИЯ

ФОРМАТ КОМАНД ОБРАБОТКИ ДАННЫХ

МЕТОДЫ ПРЯМОЙ АДРЕСАЦИИ

1 Регистровый метод адресации

2 Автоинкрементный метод адресации

МЕТОДЫ КОСВЕННОЙ АДРЕСАЦИИ

ИСПОЛЬЗОВАНИЕ СЧЕТЧИКА КОМАНД (РС) В КАЧЕСТВЕ РОН

1 Непосредственный метод адресации

2 Абсолютный метод адресации

3 Относительный метод адресации

4 Косвенно-относительный метод адресации

ЗАКЛЮЧЕНИЕ

СПИСОК ИСПОЛЬЗУЕМОЙ ЛИТЕРАТУРЫ

ВВЕДЕНИЕ

С середины 60-х годов кардинально изменился подход к созданию вычислительных машин. Вместо разработки аппаратуры и средств математического обеспечения стала проектироваться система, состоящая из синтеза аппаратных (hardware) и программных (software) средств. При этом на главный план выдвинулась концепция взаимодействия. Так возникло новое понятие - архитектура ЭВМ.

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

Архитектура ЭВМ охватывает обширный круг проблем, связанных с созданием комплекса аппаратных и программных средств и учитывающих большое количество определяющих факторов. Среди этих факторов самыми главными являются: стоимость, сфера применения, функциональные возможности, удобство в эксплуатации, а одним из основных компонентов архитектуры считаются аппаратные средства.

1. ОБЩИЕ ПОНЯТИЯ

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

Способы адресации можно классифицировать на прямые и косвенные. При прямом способе адресации исполнительный адрес берется непосредственно из команды или вычисляется с использованием значения указанного в команде и содержимого какого-либо регистра.

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

При реализации методов адресации ЭВМ существенным образом используются регистры центрального процессора (РОН). Далее мы будем использовать термин адресный регистр для обозначения любого регистра центрального процессора, содержащего адрес.

2. ФОРМАТ КОМАНД ОБРАБОТКИ ДАННЫХ

Форматом команды называется заранее обговоренная структура полей в её кодах, позволяющая ЭВМ распознавать составные части кода.

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

Безадресные

Одноадресные, двухадресные и более

При этом обычно различают операнд-источник и операнд-приемник. Операнд - источник это содержимое ячейки памяти или регистра, которое используется при выполнении указанной в команде операции и которое в процессе выполнения команды не изменяется. Операнд-приемник это ячейка памяти или РОН, содержимое которых также может быть использовано при выполнении команды и в которые помещается результат выполненной операции (приемник результата). Ниже в приведенных примерах адресат-источник обозначается буквами src или S (source - источник), а операнд-приемник dst или D (destination - приемник). Поле команды, содержащее код операции, будет обозначаться аббревиатурой КОП.

Формат одноадресных команд (HALT, CLR …) имеет следующий вид:

Рисунок 1 - Формат одноадресных команд

Разряды 15-06 содержат код операции, который определяет выполняемую команду. Разряды 05-00 образуют шестиразрядное поле, именуемое полем адресации операнда приемника, которое в свою очередь состоит из двух подполей:

1) Разряды 02-00 определяют один из восьми РОН, который использует данная команда;

2) Разряды 05-03 определяют способ использования выбранного регистра (метод адресации). Причем, разряд 03 определяет прямую или косвенную адресации.

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

Рисунок 2 - формат двухадресной команды

Поле адресации операнда источника используется для выборки операнда источника. Поле адресации операнда приемника используется для выборки операнда приемника и занесения результата. Например, по команде ADD A,B содержимое ячейки "A" (операнда источника) складывается с содержимым ячейки "B" (операнд приемника). После выполнения операции сложения в ячейке "В" будет находиться результат операции, а содержимое ячейки "A" не изменится.

3. МЕТОДЫ ПРЯМОЙ АДРЕСАЦИИ

На рисунке 3 показаны последовательности операций при выполнении команд с каждым из четырех методов прямой адресации. При регистровом методе адресации операнд находится в выбранном регистре, который может быть использован как накопитель. Так как РОН аппаратно реализованы в ИС центрального процессора, они обладают более высоким быстродействием, чем любая другая память, работающая под управлением процессора. Это их преимущество особенно проявляется при операциях с переменными, к которым необходимо часто обращаться.

Рисунок 3 - методы прямой адресации

3.1 Регистровый метод адресации

При регистровом методе адресации операнд находится непосредственно в указанном в команде регистре.

Таблица 1

Регистровый метод адресации


Действие: к содержимому R3 прибавляется единица.

3.2 Автоинкрементный метод адресации

При автоинкрементном методе адресации содержимое выбранного регистра является адресом операнда. После выборки операнда содержимое этого регистра автоматически наращивается для обеспечения возможности обращения в дальнейшем к последующей ячейке. При байтовых операциях наращивание происходит на 1, при операциях с полными словами - на 2. Содержимое R6, R7 всегда наращивается на 2. Автоинкрементный метод адресации особенно удобен при операциях с массивами и стеками. С помощью этого метода можно выбрать элемент таблицы, а затем нарастить указатель для обращения к следующему элементу в таблице. Хотя этот метод наиболее удобен при работе с таблицами, он может быть использован как общий метод для различных целей.

Таблица 2

Автоинкрементный метод адресации

3.3 Автодекрементный метод

Также используется для обработки табулированных данных. Однако в отличие от автоинкрементного метода, адресация к ячейкам массива идет в противоположном направлении. При этом методе адресации содержимое выбранного РОН вначале уменьшается (для байтовых команд - на единицу, для команд с полными словами - на два), а затем используется как исполнительный адрес.

Сочетание автоинкрементного и автодекрементного методов адресации может быть эффективно использовано при работе со стеком.

Таблица 3

Автодекрементный метод адресации


Действие: содержимое R0 уменьшается на 2 и используется как исполнительный адрес. К операнду, выбранному из ячейки по этому адресу, прибавляется единица.

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

Таблица 3.1

Автодекрементный метод адресации

3.4 Индексный метод адресации

При индексном методе адресации исполнительный адрес определяется как сумма содержимого выбранного РОН с индексным словом. Этот метод позволяет осуществлять произвольный доступ к элементам структуры данных. Индексное слово содержится в следующей за командным словом ячейке памяти. При индексном методе адресации содержимое выбранного регистра может быть использовано в качестве базы для вычисления серии адресов.

Таблица 4

Индексный метод адресации

5. МЕТОДЫ КОСВЕННОЙ АДРЕСАЦИИ

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

Рисунок 4 - методы косвенной адресации

Таблица 5

Индексный метод адресации

Действие: содержимое ячейки, адрес которой находится в R2, используется как адрес операнда, операнд увеличивается на единицу, а содержимое R2 - на 2.

Таблица 5.1

Индексный метод адресации

После выполнения операции

6. ИСПОЛЬЗОВАНИЕ СЧЕТЧИКА КОМАНД (РС) В КАЧЕСТВЕ РОН

Счетчик команд R7 может быть использован со всеми методами адресации, применяемыми в микро-ЭВМ. Однако наиболее эффективно он используется только с четырьмя. Эти методы адресации получили специальные наименования: непосредственный, абсолютный, относительный и косвенно - относительный. Использование этих методов дает возможность построения программ, работоспособность которых не теряется при перемещении их в любую область памяти. В таблице ниже приведены методы адресации с использованием R7. Необходимо понимать, что эти четыре метода аналогичны описанным выше, но в качестве РОН используется R7. Методы адресации с использованием счетчика команд в значительной мере упрощают обработку данных, не сформированных в массивы.

Таблица 6

Методы адресации

Восьмеричный код

Двоичный код

Название

Непосредственный

Операнд выбирается из ячейки, следующей за командным словом.

Абсолютный

Из ячейки, следующей за командным словом, выбирается адрес операнда.

Относительный

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

Косвенно-относительный

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

6.1

Непосредственный метод адресации имеет символическое обозначение #N. Он эквивалентен автоинкрементному методу адресации через счетчик команд R7. Этот метод обеспечивает экономию времени программиста при составлении программы за счет возможности помещения константы в ячейку памяти вслед за командным словом.

Таблица 7

Непосредственный метод адресации


Действие: содержимое R0 складывается с числом 10. Результат записывается в R0.

Таблица 7.1

Непосредственный метод адресации


После выборки команды содержимое R7 (адрес этой команды) увеличивается на 2. Так в поле адреса операнда источника записан код 27, R7 используется как указатель адреса при выборке операнда, после чего содержимое его вновь увеличивается на 2 для указания на следующую команду.

6.2 Абсолютный метод адресации

Абсолютный метод адресации имеет символическое обозначение @#A. Он эквивалентен косвенно-автоинкрементной адресации через R7. Этот метод удобен тем, что адрес операнда является его абсолютным адресом (т.е. он остается постоянным независимо от места расположения программы в памяти).

Таблица 8

Абсолютный метод адресации

6.3 Относительный метод адресации

Относительный метод адресации имеет символическое обозначение X(PC) или А, где X-исполнительный адрес по отношению к счетчику команд. Этот метод эквивалентен индексной адресации через R7. Индексное слово хранится в следующей за командным словом ячейке и, будучи сложенным с содержимым R7, дает адрес операнда. Этот метод полезен при написании программы, которая может располагаться в различных местах памяти, так как адрес операнда фиксируется по отношению к содержимому R7. При необходимости перемещения программы в памяти операнд перемещается на то же число ячеек, что и сама команда.

Таблица 9

Относительный метод адресации


Действие: к операнду, адрес которого определяется сложением содержимого R7 и индексного слова (000054), прибавляется "1".

Таблица 9.1

Относительный метод адресации

6.4 Косвенно-относительный метод адресации

Косвенно-относительный метод адресации имеет символическое обозначение @X(PC) или @A, где X-адрес ячейки, содержащей исполнительный адрес, по отношению к счетчику команд. Этот метод эквивалентен косвенно - индексной адресации через СК.

ЗАКЛЮЧЕНИЕ

Архитектуру вычислительного средства необходимо отличать от его структуры. Структура вычислительного средства определяет его текущий состав на определенном уровне детализации и описывает связи внутри средства. Архитектура же определяет основные правила взаимодействия составных элементов вычислительного средства, описание которых выполняется в той мере, в какой необходимо для формирования правил их взаимодействия. Она устанавливает не все связи, а наиболее необходимые, которые должны быть известны для более грамотного использования применяемого средства.

Так, пользователю ЭВМ не важно, на каких элементах выполнены электронные схемы, схемно или программно исполняются команды и т. д. Важно несколько другое: как те или иные структурные особенности ЭВМ связаны с возможностями, предоставляемыми пользователю, какие альтернативные решения реализованы при создании машины и по каким критериям принимались решения, как связаны между собой характеристики устройств, входящих в состав ЭВМ, и какое действие они оказывают на общие характеристики компьютера. Другими словами, архитектура ЭВМ действительно отражает круг проблем, которые относятся к общему проектированию и построению вычислительных машин и их программного обеспечения.

СПИСОК ИСПОЛЬЗУЕМОЙ ЛИТЕРАТУРЫ

1. Таненбаум, Эндрю. Архитектура компьютера, Питер, 2007.

2. А.С. Коваль, А.В. Сычев. Архитектура ЭВМ и систем, Воронеж 2007

Френк Т.С. PDP-11: Архитектура и программирование, Радио и связь, 1986.

4. Википедия -

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

1. Команды передачи данных (перепись) , копирующие информацию из одного места в другое.

2. Арифметические операции , которым фактически обязана своим рождением вычислительная техника. Конечно, доля вычислительных действий в современном компьютере заметно уменьшилась, но они по-прежнему играют в программах важную роль. Отметим, что к основным арифметическим действиям обычно относятся сложение и вычитание (последнее внутри процессора чаще всего тем или иным способом также сводится к сложению). Что касается умножения и деления, то они во многих ЭВМ выполняются по специальным программам.

3. Логические операции , позволяющие компьютеру производить анализ получаемой информации. После выполнения такой команды, с помощью условного перехода ЭВМ способна выбрать дальнейший ход выполнения программы. Простейшими примерами команд рассматриваемой группы могут служить сравнение, а также известные логические операции И, ИЛИ, НЕ (инверсия), описанные ранее в п.1.4. Кроме того к ним часто добавляются анализ отдельных битов кода, их сброс и установка.

4. Сдвиги двоичного кода влево и вправо. Для доказательства важности этой группы команд достаточно вспомнить правило умножения столбиком: каждое последующее произведение записывается в такой схеме со сдвигом на одну цифру влево. В некоторых частных случаях умножение и деление вообще может быть заменено сдвигом (вспомните, что дописав или убрав ноль справа, т.е. фактически осуществляя сдвиг числа, можно увеличить или уменьшить его в 10 раз).

5. Команды ввода и вывода информации для обмена с внешними устройствами. В некоторых ЭВМ внешние устройства являются специальными служебными адресами памяти, поэтому ввод и вывод осуществляется с помощью команд переписи.

6. Команды управления , реализующие нелинейные алгоритмы. Сюда прежде всего следует отнести условный и безусловный переход, а также команды обращения к подпрограмме (переход с возвратом). Некоторые ЭВМ имеют специальные команды для организации циклов, но это не обязательно: любой цикл может быть сведен к той или иной комбинации условного и безусловного переходов.

Часто к этой же группе команд относят операции по управлению процессором типа останов или НОП - нет операции. Иногда их выделяют в особую группу. С ростом сложности устройства процессора количество такого рода команд увеличивается.

Любая команда ЭВМ обычно состоит из двух частей - операционной и адресной . Операционная часть (иначе она еще называется кодом операции - КОП ) указывает, какое действие необходимо выполнить с информацией. Адресная часть описывает, где используемая информация хранится и куда поместить результат. У некоторых немногочисленных команд управления работой машины адресная часть может отсутствовать, например, в команде останова; операционная часть имеется всегда.

Код операции можно представить себе как некоторый условный номер в общем списке системы команд. В основном этот список построен в соответствии с определенными внутренними закономерностями, хотя они не всегда очевидны.

Адресная часть обладает значительно большим разнообразием и ее следует рассмотреть подробнее.

Прежде всего отметим, что команды могут быть одно-, двух- и трехадресные в зависимости от количества возможных операндов.

Первые ЭВМ имели наиболее простую и наглядную трехадресную систему команд. Например: взять числа из адресов памяти А1 и А2, сложить их и сумму поместить в адрес А3. Если для операции требовалось меньшее количество адресов, то лишние просто не использовались. Скажем, в операции переписи указывались лишь ячейки источника и приемника информации А1 и А3, а содержимое А2 не имело никакого значения.

Трехадресная команда легко расшифровывалась и была удобна в использовании, но с ростом объемов ОЗУ ее длина становилась непомерно большой. Действительно, длина такой команды складывается из длины трех адресов и кода операции. Отсюда следует, например, что для скромного ОЗУ из 1024 ячеек только для записи адресной части требуется 3*10=30 двоичных разрядов, что для технической реализации не очень удобно. Поэтому появились двухадресные машины, длина команды в которых сокращалась за счет исключения адреса записи результата. В таких ЭВМ результат операции оставался в специальном регистре (сумматоре ) и был пригоден для использования в последующих вычислениях. В некоторых машинах результат записывался вместо одного из операндов.

Дальнейшее упрощение команды привело к созданию одноадресных машин. Рассмотрим систему команд такой ЭВМ на конкретном простом примере. Пусть надо сложить числа, хранящиеся в адресах ОЗУ А1 и А2, а сумму поместить в А3. Для решения этой задачи одноадресной машине потребуется выполнить три команды:

  1. извлечь содержимое ячейки А1 в сумматор;
  2. сложить сумматор с числом из А2;
  3. записать результат из сумматора в А3.

Может показаться, что одноадресной машине для решения задачи потребуется втрое больше команд, чем трехадресной. На самом деле это далеко не всегда так. Попробуйте самостоятельно спланировать программу вычисления выражения Y=(X1+X2)*X3/X4 и вы с удивлением обнаружите, что потребуется 3 трехадресных команды и всего 5 одноадресных. Таким образом, одноадресная машина в чем-то даже эффективнее, т.к. она не производит ненужной записи в память промежуточных результатов.

Ради полноты изложения следует сказать о возможности реализации безадресной (нульадресной) машины, использующей особый способ организации памяти - стек . Понимание принципов устройства такой машины потребовало бы некоторых достаточно подробных разъяснений; в то же время сейчас безадресные ЭВМ практически не применяются. Поэтому ограничимся лишь упоминанием того факта, что устроенная подобным образом система команд лежала в основе некоторых программируемых микрокалькуляторов типа "Б3-21" и "Б3-34" и им подобным.

© Е.А.Еремин , 1997
Из книги:
Еремин Е.А. Как работает современный компьютер . - Пермь: изд-во ПРИПИТ, 1997. 176 с.

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

Исходя из логики выполнения, команды разбиты на следующие группы: пересылки данных, арифметические, сдвига, логические, передачи управления, ввода-вывода и работы со строками.

Под адресацией данных в МП подразумеваются способы описания соответствующих адресов хранения операндов, которые можно применять в командах. Основные способы описания операндов: операнды-регистры, непосредственные операнды, операнды в памяти.

Входящие в состав микропроцессора компоненты указывают на то, что он является процессором с программным управлением. Некоторые компоненты - программный счетчик (счетчик команд СК), стек, регистр команд (РК) служат для обработки команд. Арифметико-логическое устройство, триггер переноса, регистры общего назначения (РОН) и регистр адреса данных (РА) служат для обработки данных. Все остальные компоненты, а именно: дешифратор команд (дешифратор кода операции ДКОП) и блок управления и синхронизации (БУ) управляют работой других компонентов. Взаимодействие компонентов осуществляется по внутренней шине данных. Связь МП с другими блоками (ЗУ и устройствами ввода-вывода) происходит по адресной щине, шине данных (внешней) и управляющей шине.

При выполнении каждой команды ЭВМ проделывает определенные стандартные действия.

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

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

После выборки команды останова ЭВМ прекращает обработку программы. Для выхода из этого состояния требуется либо запрос от внешних устройств, либо перезапуск машины.

Пр и мер 3.2. Описать процесс выборки и исполнения команды, по которой содержимое регистра РОН суммируется с содержимым аккумулятора Л и результат операции фиксируется в аккумуляторе.

Команда однобайтовая с прямой регистровой адресацией. В коде команды (10000001) 2 = (81) 16 первые пять старших разрядов определяют код операции; три последних - код адреса регистра С. Команда записана в ячейку ОЗУ с адресом (номером) (0176), 6 . Число (2Б) |6 записано в регистр С РОН. В аккумулятор Л записано число (ЗА) 16 .

Процесс выборки и исполнения команды можно условно разбить на несколько этапов.

  • 1. Адрес команды (0176) 16 записывается в регистр адреса данных (РА).
  • 2. Адрес команды из РА по шине адреса поступает в ОЗУ.
  • 3. ОЗУ находит ячейку с указанным адресом и считывает команду в буферный регистр ОЗУ.
  • 4. Команда из буферного регистра ОЗУ по внешней шине данных, буфер данных (БД), внутренней шине данных поступает в РК.
  • 5. Дешифратор кода операции (ДКОП) распознает, что выборка команды закончена и содержимое аккумулятора и регистра С РОН необходимо подвергнуть суммированию.
  • 6. Содержимое РА увеличивается на единицу, и формируется адрес следующей ячейки ОЗУ (0177) 16 .
  • 7. Блок управления и синхронизации (БУ) вырабатывает последовательность сигналов, под воздействием которых числа (ЗА) 16 из аккумулятора и (2Б) 16 из регистра С РОН поступают в АЛУ, где производится операция суммирования: (ЗА) 16 + (2Б) 16 = = (69) 16 = (01 101001) 2 .
  • 8. Результат операции записывается в аккумулятор, замещая в нем прежнее число (ЗА) 16 .
  • 9. Выполнение команды закончено. Начинается выборка следующей команды с адресом (0177) 16 .

Микропроцессор имеет все режимы адресации, однако они обладают определенными особенностями, присущими данному процессору. Непосредственная адресация предполагает, что операнд занимает одно из полей команды, а следовательно, выбирается из оперативной памяти одновременно с ней. В зависимости от форматов обрабатываемых процессором данных непосредственный операнд может иметь длину 8 или 16 бит, что обозначается соответственно data8 и data 16.

Механизмы адресации операндов, находящихся в регистровой и оперативной памяти, существенно различаются. К регистровой памяти допускается лишь прямая регистровая адресация. При этом в команде указывается номер регистра, содержащего операнд. 16-разрядный операнд может находиться в регистрах АХ, ВХ, СХ, DX, DI, SI, SP, ВР, а 8-разрядный - в регистрах AL, АН, BL, ВН, CL, СН, DL и DH.

Регистры общего назначения (РОН) - основные рабочие регистры программ: АХ, ВХ, СХ и DX. К ним можно адресоваться как отдельным, так и однобайтным словом.

Например, АХ - старший байт АН, младший байт AL.

Регистр АХ - аккумулятор, который используется во всех операциях ввода-вывода и в операциях со строками и в арифметических операциях.

Регистр ВХ - базовый регистр, единственный из РОН, используемый в индексной адресации. Он также применяется в вычислениях.

Регистр DX - регистр данных, используемый в операциях ввода-вывода, а также в операциях умножения и деления больших чисел (совместно с АХ).

Любой из РОН может применяться для сложения или вычитания 8- или 16-разрядных величин.

Регистры указателя SP и ВР применяются для обращения к данным в стеке.

Регистр SP (Stack Pointer) - указатель стека, используется для временного хранения адресов и иногда данных, т. е. адресует стек.

Регистр ВР (Base Pointer) - указатель базы, обеспечивает ссылки на параметры (адрес, данные), передаваемые через стек.

Стек - это линейный список, записи в котором выбираются, вставляются и удаляются с одного конца, называемого вершиной стека. Это обеспечивает доступ к записям по «принципу магазина»: последний вошел, первый вышел (Last In First Out - UFO).

Индексные регистры SI и DI используются для адресации (а также для выполнения операций сложения и вычитания). Регистр SI (Source Index) - индекс источника и регистр DI (Destination Index) - индекс приемника применяются в некоторых операциях со строками или символами.

Адресация оперативной памяти имеет особенности, связанные с ее разбиением на сегменты и использованием сегментной группы регистров для указания начального адреса сегмента. 16-разрядный адрес, получаемый в блоке формирования адреса операнда на основе указанного режима адресации, называется эффективным адресом (ЭА). Иногда эффективный адрес обозначается как ЕА (Effective Address). 20-разрядный адрес, который получается в результате сложения эффективного адреса и увеличенного в 16 раз значения соответствующего сегментного регистра, называется физическим адресом (ФА).

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

Прямая адресация предполагает, что эффективный адрес - часть команды, так как ЭА состоит из 16 разрядов и соответствующее поле команды имеет такую же длину.

При регистровой косвенной адресации эффективный адрес операнда находится в базовом регистре ВХ или в одном из ин-

Обозначение имени регистра в квадратных скобках указывает на содержимое соответствующего регистра. Фигурные скобки - символ выбора одного из трех возможных вариантов.

При регистровой относительной адресации эффективный адрес равен сумме содержимого базового или индексного регистра и смещения:

j disp8 I j disp 16 j

Обозначения disp8 и disp 16 указывают на 8- или 16-разряд-ное смещение соответственно.

Эффективный адрес при базово-индексной адресации равен сумме содержимого базового и индексного регистров, определяемых командой:

] у

Наиболее сложен механизм относительной базово-индексной адресации. Эффективный адрес в этом случае равен сумме 8- или 16-разрядного смещения и базово-индексного адреса:

эА=Л вх П + Л 01 П+1 айр8 ,1.

1 |ВР]} 1 1 авр1б

Форматы двухоперандных команд представлены на рис. 3.2. Пунктиром показаны поля, которые в зависимости от режима адресации могут отсутствовать в команде.

  • 1 байт
  • 1 байт
  • 1 байт

КОП d w md reg r/m

1 байт disp L

сімр і і і

[ disp Н

бкр Н І

Рис. 3.2. Форматы двухоперандных команд микропроцессора 18086: а - формат команд типа Я Я и /?5; б - формат команды с непосредственным операндом

Поле КОП содержит код выполняемой операции. Признак указывает на длину операндов. При ы= 1 операция проводится над словами, а при н> = 0 - над байтами. Признак (1 указывает положение приемника результата. Признак с1=, если результат записывается на место операнда, закодированного в поле ге%, и с! = 0, если результат записывается по адресу, закодированному полями (т(1, г/т).

Следующий байт команды, называемый постбайтом, определяет операнды, участвующие в операции. Поле ^ указывает регистр регистровой памяти согласно табл. 3.3.

Поля тс! и г/т задают режим адресации операнда (табл. 3.4).

Таблица 3.3. Регистры памяти

Таблица 3.4. Режимы адресации операнда

(ВХ) + (81) (ОБ)

(ВХ) + (Б1) + сПзрБ (ОБ)

(ВХ) + (Б1) + сПвр 16 (ОБ)

(ВХ) + (01) (ОБ)

(ВХ) + (01) + (И8р8 (ОБ)

(ВХ) + (О!) + сИвр 16 (ОБ)

(ВР) + (81) (вв)

(ВР) + (Б1) + сИэрБ (вБ)

(ВР) + (Б1) + (Шр16 (ББ)

(ВР) + (01) (вБ)

(ВР) + (01) + сИэрБ (вБ)

(ВР) + (01) + с1 вр 16 (8Б)

(Б1) + (Нерв (ОБ)

(Б1) + сИ8р16 (ОБ)

(оо + аврв (ОБ)

(01) + сН8р 16 (ОБ)

сИвр 16 (ОБ)

(ВР) + сНврБ (вБ)

(ВР) + сП8р16 (вБ)

(ВХ) + с!вр8 (ОБ)

(ВХ) + сП8р16 (ОБ)

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

В командах, использующих непосредственный операнд, признак 5 вместе с признаком определяет разрядность непосредственного операнда, записываемого в команде, и разрядность выполняемой операции (табл. 3.5).

Таблица 3.5. Разрядности операций

Изменение естественного порядка выполнения команд программы осуществляется с помощью команд передачи управления. К ним относятся команды переходов, циклов, вызова подпрограммы и возврата из нее, а также некоторые другие. Классификация команд переходов в ПЭВМ представлена на рис. 3.3.


Физический адрес выполняемой команды определяется содержимым указателя команд 1Р и сегментного регистра команд

С8. Команды, меняющие значение обоих этих регистров, называются командами межсегментных переходов , а меняющие только значение 1Р, - командами внутрисегментных переходов.

Регистровая адресация. Операнды (источники и приемники) - это внутренние регистры МП: АХ, ВХ, СХ, ОХ, 8Р, ВР, 81, 01, а в операциях пересылки - дополнительные сегментные регистры.

Пример 3.3. МОУ АН, ВН.

Непосредственная адресация. Операнды - это константы, непосредственно задаваемые в команде МП (байты, слова, двойные слова).

Пример 3.4. МОУ АН, -2.

Адресация ячеек памяти. При вычислении адреса в памяти используются две составляющие - сегмент и смещение относительно его начала.

Пример 3.5. МОУ У1, 31Ь.

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

При косвенной адресации смещение соответствующего операнда в сегменте содержится в одном из регистров МП, например МОУ [ВХ], АЬ. Косвенная адресация позволяет легко организовывать доступ к сложным элементам данных, например к массиву данных. Для обозначения косвенной адресации название регистра заключают в квадратные скобки (ВХ - регистровая адресация, а [ВХ] - косвенная). Обычно в качестве регистра косвенной адресации используются: [ВХ], , и [ВР]. Для [ВХ], , неявно подразумевается сегмент 08, а для [ВР] - сегмент 88.

Косвенная адресация по базе означает, что исполнительный адрес вычисляется как сумма содержимого соответствующего регистра и некоторой константы. Этот способ адресации используется для доступа к полям структуры, начальный адрес которой задается в регистре, а смещение соответствующего поля - константой, записанной непосредственно в команде (применяются базовые регистры [ ВХ], [ВР] с соответствующими сегментами 08, 88).

Прямая индексная адресация эквивалентна косвенной по базе. При этом используются регистры 81, 01 и соответствующий 08-сегмент.

Пример 3.6.

МОУ Х3, О (аналогично МОУ [ХЗ + 01], 0);

МОУ ХЗ[ВХ][ОХ + 2], АН (ХЗ - адрес массива).

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

Пример 3.7.

База - ВХ, ВР. Индексы - 81, 01.

[ВХ + 81], [ВХ + 01] - с сегментом Э8.

[ВР + 81], [ВР + 01] - с сегментом 88.

В общем случае при использовании косвенной адресации исполнительный адрес можно представить следующим образом:

ЕА= [Регистр базы] + [Индексный регистр] + Константа.

Любая из этих компонент может отсутствовать.

Команды пересылки данных имеют общий формат с двумя операндами - источником и приемником,

например МОУ, .

Пр и мер 3.8. Команды пересылок данных:

МОУ АН, ВН

МОУ АН, ВХ

МОУ ОБ, В1, где В1 - адрес ячейки.

Команда ХСНО, - обмен операндов используется для любых РОН и переменных в памяти, кроме двух ячеек памяти.

Ниже приведены примеры команд.

Примеры арифметических команд:

  • ADD , ;
  • ADC , ;
  • INC ;
  • SUB , ;
  • SBB , ;
  • DEC ;
  • MUL ;
  • IMUL ;
  • DIV ;
  • IDIV .

Примеры команд сдвига:

  • SAL , ;
  • SAR , ;
  • SHL , ;
  • SHR , .

Примеры логических команд:

AND, OR, XOR, NOT.

Примеры команд передачи управления:

  • перехода JMP, JZ, JNZ, JCXZ;
  • цикла LOOP;
  • вызова подпрограммы и возврата из нее: CALL, RET;
  • вызова прерывания и возврата из него: INT, IRET.

Примеры дополнительных команд:

  • работы со стеком: PUSH, POP;
  • установки и ояистки флагов: STC, CLC;
  • холостого хода NOP.

Примеры команд ввода/вывода:

  • IN .., ;
  • ОиТ.., .

Примеры команд работы со строками:

MOVS, CMPS, OUTS.

Команды безусловных переходов производят модификацию регистра IP или регистров IP и CS без предварительного анализа каких-либо условий. Существует пять команд безусловных переходов. Все они имеют одинаковую мнемонику JMP и содержат один операнд. Конкретный формат команды определяется соответствующим префиксом и приведен в табл. 3.6.

Таблица 3.6. Машинные коды некоторых команд

Байт кода команды

Схема операции

md reg r/m

г(г/т) - г + г/т

md 000 r/m

г/т = г/т +

(data H)

ас - ас +

md reg r/m

г{г/т) - г{г/т) - (г/т)г

md 101 r/m

г/т = г/т -

(data H)

ас = ас -

001000dw

md reg r/m

г(г/т) = г & г/т

md 100 r/m

г/т = г/т &

(data H)

ас = ас &

000010dw

md reg r/m

г{г/т) = г V г/т

md 001 r/m

г/т = г/т V

(data H)

ас = ас V

Примечание. В столбце «Схема операции» сокращение «ас» означает регистр-аккумулятор, в качестве которого используются регистр АХ при = 1 и регистр АЬ при = 0.

При прямом безусловном внутрисегментном переходе новое значение указателя команд 1Р равно сумме смещения, закодированного в соответствующем поле команды, и текущего значения 1Р, в качестве которого используется адрес команды, записанной вслед за командой перехода. Команды прямых межсегментных переходов содержат помимо нового значения 1Р и новое значение сегментного регистра С5.

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

Команды условных переходов - только внутрисегментные. По формату и способу формирования нового значения 1Р они аналогичны команде прямого внутрисегментного перехода с 8-разрядным смещением. Отличие их заключается в том, что в командах условного перехода механизм формирования нового значения 1Р включается лишь при выполнении определенных условий, а именно при определенном состоянии регистра флагов.

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

Ниже приведены примеры команд переходов различных типов.

Команды условного перехода:

IP- IP+ 2, если условие не выполнено;

IP= IP+2 + disp L, если условие выполнено.

Пример 3.9.

JZ MARK; переход на метку MARK, если ZF = 1.

Команды прямого внутрисегментного перехода:

IP= IP+ А + disp, где А - длина команды перехода (А = 2 или А = 3 в зависимости от длины смещения).

Пример 3.10.

JMP short ptr MARK; переход на метку MARK с использованием 8-разрядного смещения;

JMP near ptr MARK; переход на метку MARK с использованием 16-разрядного смещения.

Команды прямого межсегментного перехода:

IP=JP_H, IP_L CS= CS_H, CS L.

Пример 3.11.

JMP far ptr MARK; переход на метку MARK к команде, находящейся в другом сегменте.

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

В общем случае команда состоит из:

    операционной части (содержит код операции);

    адресной части (содержит адресную информацию о местонахождении обрабатываемых данных и месте хранения результатов).

В свою очередь, эти части, что особенно характерно для адресной части, могут состоять из нескольких полей.

Структура команды определяется составом, назначением и расположением полей в коде.

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

Пример формата команды процессора i486.

mod r/m - спецификатор режима адресации;

r/m - регистр памяти;

SS - масштабный множитель для режима масштабирования индексной адресации;

КОП - код операции;

index - определяет индексный регистр;

base - определяет базовый регистр.

Важной и сложной проблемой при проектировании ЭВМ является выбор структуры и форматов команды, т.е. ее длины, назначения и размерности отдельных ее полей. Естественно стремление разместить в команде в возможно более полной форме информацию о предписываемой командой операции. Однако в условиях, когда в современных ЭВМ значительно возросло число выполняемых различных операций и соответственно команд (в компьютерах с CISC-архитектурой более 200 команд) и значительно увеличилась емкость адресуемой основной памяти (32, 64 Мб), это приводит к недопустимо большой длине формата команды.

Вместе с тем, для упрощения аппаратуры и повышения быстродействия ЭВМ длина формата команды должна быть по возможности короче, укладываться в машинное слово или полуслово. Решение проблемы выбора формата команды значительно усложняется в микропроцессорах, работающих с коротким словом.

Проследим изменения классических структур команд.

Чтобы команда содержала в явном виде всю необходимую информацию о задаваемой операции, она должна, как это показано на рис. 3.1 (б), содержать следующую информацию: А1, А2 - адреса операндов, А3 - адрес результата, А4 - адрес следующей команды (принудительная адресация команд).

Рис. 3.1. Структуры команд: а) обобщенная, б) четырехадресная, в) трехадресная, г) двухадресная, д) одноадресная, е)безадресная

Такая структура приводит к большей длине команды и неприемлема для прямой адресации операндов основной памяти. В компьютерах с RISC-архитектурой четырехадресные команды используются для адресации операндов, хранящихся в регистровой памяти процессора.

Можно установить, как это принято для большинства машин, что после выполнения данной команды, расположенной по адресу К (и занимающей L ячеек), выполняется команда из (K+L)-ой ячейки. Такой порядок выборки команды называется естественным. Он нарушается только специальными командами (передачи управления). В таком случае отпадает необходимость указывать в команде в явном виде адрес следующей команды.

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

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

В одноадресной команде (рис. 3.1, д) подразумеваемые адреса имеют уже и результат операции и один из операндов. Один из операндов указывается адресом в команде, в качестве второго используется содержимое регистра процессора, называемого в этом случае регистром результата или аккумулятором. Результат операции записывается в тот же регистр.

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

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