|
|
В начало
Адресация
в МП (Лекция)
ПЛАН ЛЕКЦИИ 1. Форматы команд 2. Способы адресации операндов 1. Форматы команд Основная функция любого процессора – это
выполнение команд. Типовая команда, в общем случае, должна указывать: - подлежащую выполнению операцию; - адреса исходных данных (операндов), над которыми
выполняется операция; - адрес, по которому должен быть помещен результат операции. В соответствии с этим команда состоит из двух
частей: операционной и адрес ной (Рисунок 19).
Рис. 1. Структура команды Формат
команды определяет ее структуру, то есть
количество двоичных разрядов, отводимых под всю команду, а также количество и
расположение отдельных полей команды. Полем
называется совокупность двоичных разрядов, кодирующих составную часть команды.
При создании ЭВМ выбор формата команды влияет на многие характеристики будущей
машины. Оценивая возможные форматы, нужно учитывать следующие факторы: общее
число различных команд; общую длину команды; тип полей команды (фиксированной
или переменной длины) и их длина; простоту декодирования; адресуемость и
способы адресации; стоимость оборудования для декодирования и исполнения
команд. Длина
команды. Это важнейшее обстоятельство,
влияющее на организацию и емкость памяти, структуру шин, сложность и
быстродействие ЦП. С одной стороны, удобно иметь в распоряжении мощный набор
команд, то есть как можно больше кодов операций, операндов, способов адресации,
и максимальное адресное пространство. Однако все это требует выделения большего
количества разрядов под каждое поле команды, что приводит к увеличению ее длины.
Вместе с тем, для ускорения выборки из памяти желательно, чтобы команда была
как можно короче, а ее длина была равна или кратна ширине шины данных. Для
упрощения аппаратуры и повышения быстродействия ЭВМ длину команды обычно
выбирают кратной байту, поскольку в большинстве ЭВМ основная память
организована в виде 8-битовых ячеек. В рамках системы команд одной ВМ могут
использоваться разные форматы команд. Обычно это связано с применением различных
способов адресации. В таком случае в состав кода команды вводится поле для
задания способа адресации (СА), и обобщенный формат команды приобретает вид,
показанный на рисунке 20. В большинстве ВМ одновременно уживаются несколько
различных форматов команд.
Рис. 2. Обобщенный формат команды Разрядность
поля кода операции. Количество двоичных
разрядов, отводимых под код операции, выбирается так, чтобы можно было
представить любую из операций. При заданной длине кода команды приходится
искать компромисс между разрядностью поля кода операции и адресного поля. Большее
количество возможных операций предполагает длинное поле кода операции, что
ведет к сокращению адресного поля, то есть к сужению адресного пространства.
Для устранения этого противоречия иногда длину поля кода операции варьируют.
Изначально под код операции отводится некое фиксированное число разрядов,
однако для отдельных команд это поле расширяется за счет нескольких битов,
отнимаемых у адресного поля. Разрядность
адресной части. В адресной части команды
содержится информация о местонахождении исходных данных и месте сохранения
результата операции. Обычно местонахождение каждого из операндов и результата
задается в команде путем указания адреса со
ответствующей ячейки основной памяти или номера регистра процессора. Принципы
использования информации из адресной части команды определяет систем адресации. Система адресации задает число
адресов в команде команды и
приняты способы адресации. Количество
адресов в команде. Для определения
количества адресов, включаемых в адресную часть, используют термин адресность. В «максимальном» варианте необходимо
указать три компонента: адрес первого операнда, адрес второго операнда и адрес
ячейки, куда заносится результат операции. В принципе может быть добавлен еще
один адрес, указывающий место хранения следующей инструкции. В итоге имеет
место четырехадресный формат команды (Рисунок 21).
Рис. 3. Четырехадресный формат команды В Фон-Неймановских
ЭВМ необходимость в четвертом адресе отпадает, поскольку команды располагаются
в памяти в порядке их выполнения, и адрес очередной команды может быть получен
за счет простого увеличения адреса текущей команды в счетчике команд. Это
позволяет перейти к трехадресному
формату команд (Рисунок 22).
Требуется только добавить в систему команд ЭВМ команды, способные изменять
порядок вычислений.
Рис. 4. Трехадресный формат команды К сожалению, и в трехадресном формате длина
команды может оказаться весьма большой. Так, если адрес ячейки основной памяти
имеет длину 32 бита, а длина кода операции - 8 бит, то длина команды составит
104 бита (13 байт). Если по умолчанию взять в
качестве адреса результата адрес одного из операндов (обычно второго), то можно
обойтись без третьего адреса, и в итоге получаем двухадресный формат команды (Рисунок
23). Естественно, что в этом случае соответствующий операнд после выполнения
операции теряется.
Рис. 5. Двухадресный формат команды Команду можно еще более сократить, перейдя к одноадресному формату (Рисунок 24), что возможно при
выделении определенного стандартного места для хранения первого операнда и
результата. Обычно для этой цели используется специальный регистр центрального
процессора (ЦП), известный под названием аккумулятора, поскольку здесь аккумулируется
результат.
Рис. 6. Одноадресный формат команды Применение единственного регистра для хранения
одного из операндов и результата является ограничивающим фактором, поэтому
помимо аккумулятора часто используют и другие регистры ЦП. Так как число
регистров в ЦП невелико, для указания одного из них в команде достаточно иметь
сравнительно короткое адресное поле. Соответствующий формат носит название полутораадресного
или регистрового формата (Рисунок 25).
Рис. 7. Полутораадресный формат команды Наконец, если для обоих операндов указать
четко заданное местоположение, а также в случае команд, не требующих операнда,
можно получить нулъадресный формат команды (Рисунок 26).
Рис. 8. Нульадресный формат команды В таком варианте адресная часть команды вообще
отсутствует или не задействуется. Выбор адресности команд. При
выборе количества адресов в адресной части команды обычно руководствуются
следующими критериями: - емкостью запоминающего устройства, требуемой
для хранения программы; - временем выполнения программы; - эффективностью использования ячеек памяти
при хранении программы. Адресность и емкость запоминающего
устройства Емкость запоминающего устройства для хранения
программы ЕА можно оценить
из соотношения:
где NA -
количество программ в программе; RK -
разрядность команды, А - индекс, указывающий адресность
команд программы. При выборе количества адресов
по критерию «емкость ЗУ» предпочтение следует отдавать одноадресным командам. Адресность и время выполнения программы. Время выполнения одной команды складывается из времени
выполнения операции и времени обращения к памяти. Для трехадресной команды последнее
суммируется из четырех составляющих времени: - выборки команды; - выборки первого операнда; - выборки второго операнда; - записи в память
результата. Одноадресная команда требует двух обращений к
памяти: - выборки команды; - выборки операнда. Как видно, на выполнение одноадресной команды
затрачивается меньше времени, чем на обработку трехадресной команды, однако для
реализации одной трехадресной команды, как правило, нужно три одноадресных.
Этих соображений тем не менее не достаточно, чтобы
однозначно отдать предпочтение тому или иному варианту адресности.
Определяющим при выборе является тип алгоритмов, на преимущественную реализацию
которых ориентирована конкретная ЭВМ. Возможные типы алгоритмов условно разделим на
три группы: - последовательные; - параллельные; - комбинированные. Двухадресные команды в плане времени реализации
алгоритмов занимают промежуточное положение между одноадресными
и трехадресными. Несколько лучшие показатели дают полуторадресные
команды, в которых, с одной стороны, сохраняются преимущества одноадресных
команд для последовательных алгоритмов, а с другой - повышается эффективность
реализации параллельных и комбинированных алгоритмов. 2. Способы адресации операндов
Приступая к рассмотрению способов адресации,
вначале определим понятия «исполнительный» и «адресный код». Исполнительным
адресом операнда (Аисп) называется двоичный код номера ячейки памяти, служащей
источником или приемником операнда. Этот код подается на адресные входы
запоминающего устройства (ЗУ), и по нему происходит фактическое обращение к
указанной ячейке. Если операнд хранится не в основной памяти, а в регистре
процессора, его исполнительным адресом будет номер регистра. Адресный
код команды (Ак) - это двоичный код в адресном поле команды, из которого
необходимо сформировать исполнительный адрес операнда. В современных ЭВМ исполнительный адрес и
адресный код, как правило, не совпадают, и для доступа к данным требуется
соответствующее преобразование. Способ
адресации - это способ формирования исполнительного адреса операнда по
адресному коду команды. Способ адресации существенно влияет на параметры
процесса обработки информации. Чтобы устройство управления вычислительной
машины могло определить, какой именно способ адресации принят в данной команде,
в разных ВМ используются различные приемы. Часто
разным способам адресации соответствуют и разные коды операции. Другой подход -
это добавление в состав команды специального поля способа адресации, содержимое
которого определяет, какой из способов адресации должен быть применен. Иногда в
команде имеется нескольких полей - по одному на каждый адрес. Отметим, что
возможен также вариант, когда в команде вообще отсутствует адресная информация,
то есть имеет место неявная адресация. При неявной адресации адресного поля
либо просто нет, либо оно содержит не все необходимые адреса - отсутствующий адрес
подразумевается кодом операции. Так, при исключении из команды адреса
результата подразумевается, что результат помещается на место второго операнда.
Неявная адресация применяется достаточно широко, поскольку позволяет сократить
длину команды. Выбор способов адресации является одним из
важнейших вопросов разработки системы команд и всей ВМ в целом. Непосредственная
адресация. При непосредственной адресации (НА) в адресном поле команды вместо
адреса содержится непосредственно сам операнд (Рис. 9). Этот способ может
применяться при выполнении арифметических операций, операций сравнения, а также
для загрузки констант в регистры.
Рис. 9. Непосредственная адресация Когда операндом является число, оно обычно
представляется в дополнительном коде. При записи в регистр, имеющий
разрядность, превышающую длину непосредственного операнда, операнд размещается
в младшей части регистра, а оставшиеся свободными позиции заполняются значением
знакового бита операнда. Помимо того, что в адресном поле могут быть
указаны только константы, еще одним недостатком данного способа адресации
является то, что размер непосредственного операнда
ограничен длиной адресного поля команды, которое в большинстве случаев меньше
длины машинного слова. Прямая
адресация. При прямой или абсолютной
адресации (ПА) адресный код прямо указывает номер ячейки памяти, к которой
производится обращение (Рис. 10), то есть адресный код совпадает с
исполнительным адресом. |
|||