Режим адресации - Addressing mode

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

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

Предостережения

Обратите внимание, что не существует общепринятого способа наименования различных режимов адресации. В частности, разные авторы и производители компьютеров могут давать разные имена одному и тому же режиму адресации или одни и те же имена разным режимам адресации. Кроме того, режим адресации, который в одной данной архитектуре рассматривается как единственный режим адресации, может представлять функциональные возможности, которые в другой архитектуре охватываются двумя или более режимами адресации. Например, некоторые компьютер со сложной системой команд (CISC) архитектуры, такие как Корпорация цифрового оборудования (DEC) VAX, относиться к регистрам и буквальные или непосредственные константы как просто еще один режим адресации. Другие, такие как IBM System / 360 и его преемники, и большинство компьютер с сокращенным набором команд (RISC), кодируйте эту информацию в инструкции. Таким образом, последние машины имеют три различных кода команд для копирования одного регистра в другой, копирования буквальной константы в регистр и копирования содержимого ячейки памяти в регистр, в то время как VAX имеет только одну команду «MOV».

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

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

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

Количество режимов адресации

Различные компьютерные архитектуры сильно различаются по количеству режимов адресации, которые они предоставляют в оборудовании. Есть некоторые преимущества в устранении сложных режимов адресации и использовании только одного или нескольких более простых режимов адресации, даже если для этого требуется несколько дополнительных инструкций и, возможно, дополнительный регистр.[1][2] Это доказало[3][4][5] намного проще проектировать конвейерный ЦП, если доступны только режимы адресации, простые.

Большинство архитектур RISC имеют всего около пяти простых режимов адресации, в то время как архитектуры CISC, такие как DEC VAX, имеют более десятка режимов адресации, некоторые из которых довольно сложны. IBM Система / 360 в архитектуре было всего три режима адресации; еще несколько добавлено для Система / 390.

Когда имеется только несколько режимов адресации, конкретный требуемый режим адресации обычно кодируется в коде инструкции (например, IBM System / 360 и его последователи, большинство RISC). Но когда существует много режимов адресации, в инструкции часто выделяется определенное поле для определения режима адресации. DEC VAX позволял использовать несколько операндов памяти почти для всех инструкций, поэтому зарезервировал первые несколько. биты каждого спецификатора операнда, чтобы указать режим адресации для этого конкретного операнда. Хранение битов спецификатора режима адресации отдельно от битов операции кода операции дает ортогональный набор команд.

Даже на компьютере с множеством режимов адресации измерения реальных программ[6] указывают, что на перечисленные ниже простые режимы адресации приходится около 90% или более всех используемых режимов адресации. Поскольку большинство таких измерений основано на коде, сгенерированном компиляторами из языков высокого уровня, это в некоторой степени отражает ограничения используемых компиляторов.[7][6][8]

Полезный побочный эффект

Некоторые архитектуры наборов инструкций, такие как Intel x86 и IBM / 360 и его преемники имеют загрузить эффективный адрес инструкция.[9][10] Он выполняет вычисление эффективного адреса операнда, но вместо того, чтобы воздействовать на эту ячейку памяти, он загружает адрес, к которому был бы доступ, в регистр. Это может быть полезно при передаче адреса элемента массива в подпрограмму. Это также может быть несколько хитрый способ выполнить больше вычислений, чем обычно, за одну инструкцию; например, использование такой инструкции с режимом адресации «основание + индекс + смещение» (подробно описанным ниже) позволяет складывать два регистра и константу вместе в одной инструкции.

Простые режимы адресации для кода

Абсолютный или прямой

   + ---- + ------------------------------ + | прыжок | адрес | + ---- + ------------------------------ + (Действующий адрес ПК = адрес)

Эффективный адрес для абсолютного адреса инструкции - это сам параметр адреса без изменений.

ПК-родственник

   + ---- + ------------------------------ + | прыжок | смещение | относительный переход + ---- + ------------------------------ + (Действующий адрес ПК = адрес следующей инструкции + смещение, смещение может быть отрицательным)

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

Это особенно полезно в связи с переходами, поскольку типичные переходы относятся к ближайшим инструкциям (на языке высокого уровня большинство если или же пока заявления достаточно короткие). Измерения реальных программ показывают, что смещение в 8 или 10 бит достаточно велико для примерно 90% условных переходов (примерно ± 128 или ± 512 байт).[11]

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

Некоторые версии этого режима адресации могут быть условными, ссылаясь на два регистра («переход, если reg1 = reg2»), один регистр («переход, если reg1 = 0») или отсутствие регистров, неявно ссылаясь на некоторый ранее установленный бит в регистр статуса. Смотрите также условное исполнение ниже.

Зарегистрировать косвенный

   + ------- + ----- + | jumpVia | рег | + ------- + ----- + (Действующий адрес ПК = содержимое регистра 'reg')

Действующий адрес для косвенной инструкции Register - это адрес в указанном регистре. Например, (A7) для доступа к содержимому адресного регистра A7.

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

Многие машины RISC, а также CISC IBM System / 360 и последующие, имеют инструкции вызова подпрограммы, которые помещают обратный адрес в адресном регистре - для возврата из вызова подпрограммы используется режим косвенной адресации.

Последовательные режимы адресации

Последовательное исполнение

   + ------ + | nop | выполнить следующую инструкцию + ------ + (Действующий адрес ПК = адрес следующей инструкции)

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

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

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

Условные переходы нагружают ПК одним из двух возможных результатов, в зависимости от условия - большинство архитектур ЦП используют какой-либо другой режим адресации для «взятой» ветви и последовательное выполнение для «невыполненной» ветви.

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

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

ЦП, которые не используют последовательное выполнение

Процессоры, которые не используют последовательное выполнение с программным счетчиком, встречаются крайне редко. В некоторых процессорах каждая инструкция всегда указывает адрес следующей инструкции. Такие процессоры имеют указатель инструкции, который содержит указанный адрес; это не счетчик программы, потому что нет никаких условий для его увеличения. К таким процессорам относятся некоторые барабанная память компьютеры, такие как IBM 650, то Машина SECD, и RTX 32P.[12]

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

Условное исполнение

В некоторых компьютерных архитектурах есть условные инструкции (например, РУКА, но больше не для всех инструкций в 64-битном режиме) или инструкций условной загрузки (например, x86), которые в некоторых случаях могут сделать условные переходы ненужными и избежать сброса конвейер команд. Такая инструкция, как «сравнение», используется для установки код состояния, а последующие инструкции включают проверку этого кода условия, чтобы увидеть, соблюдаются они или игнорируются.

Пропускать

   + ------ + ----- + ----- + | skipEQ | reg1 | reg2 | пропустить следующую инструкцию, если reg1 = reg2 + ------ + ----- + ----- + (Действующий адрес ПК = адрес следующей инструкции + 1)

Пропускную адресацию можно рассматривать как особый вид режима адресации относительно ПК с фиксированным смещением «+1». Как и относительная адресация ПК, у некоторых ЦП есть версии этого режима адресации, которые относятся только к одному регистру («пропустить, если reg1 = 0») или ни к одному регистру, неявно ссылаясь на некоторый ранее установленный бит в регистр статуса. У других ЦП есть версия, которая выбирает определенный бит в определенном байте для тестирования («пропустить, если бит 7 в reg12 равен 0»).

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

Простые режимы адресации для данных

Зарегистрируйтесь (или Зарегистрируйтесь напрямую)

   + ------ + ----- + ----- + ----- + | муль | reg1 | reg2 | reg3 | рег1: = рег2 * рег3; + ------ + ----- + ----- + ----- +

Этот «режим адресации» не имеет действующего адреса и не считается режимом адресации на некоторых компьютерах.

В этом примере все операнды находятся в регистрах, а результат помещается в регистр.

База плюс смещение и варианты

Иногда это называют «основание плюс смещение».

   + ------ + ----- + ----- + ---------------- + | загрузка | рег | база | смещение | reg: = RAM [база + смещение] + ------ + ----- + ----- + ---------------- + (Действующий адрес = смещение + содержимое указанного базового регистра)

В компенсировать обычно представляет собой 16-битное значение со знаком (хотя 80386 расширил его до 32 бит).

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

На многих RISC-машинах регистр 0 имеет нулевое значение. Если регистр 0 используется как базовый регистр, это становится примером абсолютная адресация. Однако доступна только небольшая часть памяти (64 килобайты, если смещение 16 бит).

16-битное смещение может показаться очень маленьким по сравнению с размером текущей памяти компьютера (вот почему 80386 расширил его до 32-битного). Могло быть и хуже: мэйнфреймы IBM System / 360 имеют только 12-битное смещение без знака. Однако принцип местонахождение ссылки применяется: в течение короткого промежутка времени большинство элементов данных, к которым программа хочет получить доступ, довольно близки друг к другу.

Этот режим адресации тесно связан с режимом индексированной абсолютной адресации.

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

Пример 2: Если базовый регистр содержит адрес составной тип (запись или структура), смещение можно использовать для выбора поля из этой записи (большинство записей / структур имеют размер менее 32 КБ).

Немедленное / буквальное

   + ------ + ----- + ----- + ---------------- + | добавить | reg1 | reg2 | постоянная | reg1: = reg2 + константа; + ------ + ----- + ----- + ---------------- +

Этот «режим адресации» не имеет действующего адреса и не считается режимом адресации на некоторых компьютерах.

Константа может быть со знаком или без знака. Например, move.l # $ FEEDABBA, D0 для перемещения непосредственного шестнадцатеричного значения "FEEDABBA" в регистр D0.

Вместо использования операнда из памяти значение операнда хранится в самой инструкции. На машине DEC VAX размеры буквальных операндов могут быть 6, 8, 16 или 32 бита.

Эндрю Таненбаум показали, что 98% всех констант в программе умещаются в 13 битах (см. Философия дизайна RISC ).

Скрытый

   + ----------------- + | бит очистки | + ----------------- + + ------------------- + | очистить аккумулятор | + ------------------- +

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

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

Подразумеваемая адресация была довольно распространена на старых компьютерах (до середины 1970-х годов). Такие компьютеры обычно имели только один регистр, в котором можно было выполнять арифметические операции - аккумулятор. Такой аккумуляторные машины неявно ссылаются на этот аккумулятор почти в каждой инструкции. Например, операция можно выполнить с помощью последовательности - пункт назначения (аккумулятор) подразумевается в каждой инструкции «загрузить» и «добавить»; источник (аккумулятор) подразумевается в каждой инструкции "store".

Более поздние компьютеры обычно имели более одного регистр общего назначения или расположение ОЗУ, которое может быть источником или местом назначения, или обоими способами для арифметики - и поэтому более поздним компьютерам потребуется какой-то другой режим адресации, чтобы указать источник и место назначения арифметики.

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

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

Многие 32-разрядные компьютеры (например, 68000, ARM или PowerPC) имеют более одного регистра, который может использоваться в качестве указателя стека, и поэтому используют режим адресации «косвенный автоинкремент регистров», чтобы указать, какой из этих регистров следует использовать, когда выталкивание или извлечение данных из стека.

Некоторые современные компьютерные архитектуры (например, IBM / 390 и Intel Pentium) содержат некоторые инструкции с неявными операндами, чтобы поддерживать обратную совместимость с более ранними проектами.

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

Было разработано несколько процессоров, в которых каждый операнд всегда неявно указывается в каждой инструкции - нулевой операнд ЦП.

Другие режимы адресации для кода или данных

Абсолютный / прямой

   + ------ + ----- + ------------------------------------ - + | загрузка | рег | адрес | + ------ + ----- + ------------------------------------ - + (Действующий адрес = адрес, указанный в инструкции)

Это требует места в инструкции для довольно большого адреса. Он часто доступен на машинах CISC, которые имеют инструкции переменной длины, такие как x86.

Некоторые машины RISC имеют специальный Загрузить верхний литерал инструкция, которая помещает 16- или 20-битную константу в верхнюю половину регистра. Затем его можно использовать в качестве базового регистра в режиме адресации "основание плюс смещение", которое предоставляет младшие 16 или 12 бит. Комбинация позволяет получить полный 32-битный адрес.

Индексированный абсолютный

   + ------ + ----- + ----- + ------------------------------ - + | загрузка | рег | индекс | адрес | + ------ + ----- + ----- + ------------------------------ - + (Действующий адрес = адрес + содержимое указанного индексного регистра)

Это также требует места в инструкции для довольно большого адреса. Адрес может быть началом массива или вектора, а индекс может выбирать конкретный требуемый элемент массива. Процессор может масштабировать индексный регистр, чтобы учесть размер каждого элемента массива.

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

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

Пример 2: Программист может определить несколько больших массивов как глобальные или как переменные класса Начало массива сохраняется в буквальном адресе (возможно, измененном во время загрузки программы на перемещение погрузчика ) инструкции, которая ссылается на нее. Смещение - какой элемент из массива использовать на этой итерации цикла - хранится в индексном регистре. Часто инструкции в цикле повторно используют один и тот же регистр для счетчика цикла и смещения нескольких массивов.

Базовый плюс индекс

   + ------ + ----- + ----- + ----- + | загрузка | рег | база | индекс | + ------ + ----- + ----- + ----- + (Действующий адрес = содержимое указанного базового регистра + содержимое указанного индексного регистра)

Базовый регистр может содержать начальный адрес массива или вектора, а индекс может выбирать конкретный требуемый элемент массива. Процессор может масштабировать индексный регистр чтобы позволить размер каждого элемента массива. Это может использоваться для доступа к элементам массива, переданного в качестве параметра.

База плюс индекс плюс смещение

   + ------ + ----- + ----- + ----- + ---------------- + | загрузка | рег | база | индекс | смещение | + ------ + ----- + ----- + ----- + ---------------- + (Действующий адрес = смещение + содержимое указанного базового регистра + содержимое указанного индексного регистра)

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

Масштабированный

   + ------ + ----- + ----- + ----- + | загрузка | рег | база | индекс | + ------ + ----- + ----- + ----- + (Действующий адрес = содержимое указанного базового регистра + масштабированное содержимое указанного индексного регистра)

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

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

Зарегистрировать косвенный

   + ------ + ------ + ----- + | загрузка | reg1 | база | + ------ + ------ + ----- + (Действующий адрес = содержимое базового регистра)

Некоторые компьютеры имеют это как отдельный режим адресации. Многие компьютеры просто используют база плюс смещение со значением смещения 0. Например, (A7)

Зарегистрировать косвенный автоинкремент

   + ------ + ----- + ------- + | загрузка | рег | база | + ------ + ----- + ------- + (Действующий адрес = содержимое базового регистра)

После определения эффективного адреса значение в базовом регистре увеличивается на размер элемента данных, к которому необходимо получить доступ. Например, (A7) + получит доступ к содержимому адресного регистра A7, а затем увеличит адресный указатель A7 на 1 (обычно на 1 слово). Внутри цикла этот режим адресации может использоваться для пошагового перебора всех элементов массива или вектора.

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

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

  • Motorola 68000 (адрес представлен в 24 бита). Может иметь один или два операнда регистра автоинкремента. В 68010 + решил проблему, сохранив внутреннее состояние процессора на автобус или ошибки адреса.
  • DEC VAX. Может иметь до 6 операндов регистра автоинкремента. Доступ к каждому операнду может вызвать два ошибки страницы (если операнды оказались за границей страницы). Конечно, сама инструкция может иметь длину более 50 байт и может выходить за границы страницы!

Зарегистрируйте косвенный автодекремент

   + ------ + ----- + ----- + | загрузка | рег | база | + ------ + ----- + ----- + (Действующий адрес = новое содержимое базового регистра)

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

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

См. Обсуждение побочных эффектов под режим адресации с автоинкрементом.

Непрямая память

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

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

Некоторые ранние миникомпьютеры (например, DEC PDP-8, Данные General Nova ) имел всего несколько регистров и ограниченный диапазон адресации (8 бит). Следовательно, использование косвенной адресации памяти было почти единственным способом обращения к любому значительному объему памяти.

ПК-родственник

   + ------ + ------ + --------- + ---------------- + | загрузка | reg1 | база = ПК | смещение | + ------ + ------ + --------- + ---------------- + reg1: = RAM [ПК + смещение ] (Действующий адрес = ПК + смещение)

Режим адресации относительно ПК может использоваться для загрузки в регистр значения, хранящегося в памяти программ, на небольшом расстоянии от текущей инструкции. Его можно рассматривать как частный случай режима адресации «основание плюс смещение», когда в качестве «базового регистра» выбирается программный счетчик (ПК).

Есть несколько процессоров, которые поддерживают ссылки на данные, относящиеся к ПК. К таким процессорам относятся:

В MOS 6502 и его производные использовали относительную адресацию для всех инструкции по ветке. Только эти инструкции использовали этот режим, прыжки использовали множество других режимов адресации.

В x86-64 архитектура и 64-битная ARMv8-A архитектура[13] имеют режимы адресации относительно ПК, называемые «относительной RIP» в x86-64 и «буквальной» в ARMv8-A. В Motorola 6809 также поддерживает режим адресации относительно ПК.

В PDP-11 архитектура, VAX архитектура, а 32-битная ARM архитектуры поддерживать адресацию относительно ПК, имея ПК в регистровом файле.

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

Этот режим адресации, который всегда извлекает данные из памяти или сохраняет данные в памяти, а затем последовательно переходит к выполнению следующей инструкции (эффективный адрес указывает на данные), не следует путать с «относительной ветвью ПК», которая не извлекает данные. из или сохранить данные в памяти, но вместо этого выполняет переход к какой-либо другой инструкции с заданным смещением (эффективный адрес указывает на исполняемую инструкцию).

Устаревшие режимы адресации

Перечисленные здесь режимы адресации использовались в период 1950–1980 годов, но больше не доступны на большинстве современных компьютеров. Этот список ни в коем случае не является полным; время от времени использовалось много других интересных и своеобразных режимов адресации, например абсолютное-минус-логическое-ИЛИ двух или трех индексных регистров.[14][15]

Многоуровневая косвенная память

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

В IBM 1620, то Данные General Nova, то HP 2100 серии и НАР 2 каждый из них имеет такую ​​многоуровневую косвенную память и может входить в такой бесконечный цикл вычисления адреса. Режим косвенной адресации памяти на Nova повлиял на изобретение косвенный многопоточный код.

ОИК PDP-10 компьютер с 18-битный адреса и 36-битные слова допускали многоуровневую косвенную адресацию с возможностью использования индексного регистра на каждом этапе.

Регистры с отображением в память

На некоторых компьютерах регистры считались занимающими первые 8 или 16 слов памяти (например, ICL 1900, DEC PDP-10). Это означало, что не было необходимости в отдельной инструкции «добавить регистр в регистр» - можно было просто использовать команду «добавить память в регистр».

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

Более поздние модели DEC PDP-11 series отображал регистры на адреса в области ввода / вывода, но это было в первую очередь предназначено для удаленной диагностики. Как ни странно, 16-битные регистры были отображены на последовательные 8-битные байтовые адреса.

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

ОИК PDP-8 У миникомпьютера было восемь специальных мест (по адресам с 8 по 15). При доступе через косвенную адресацию к памяти эти ячейки будут автоматически увеличиваться после использования.[16] Это позволило легко перемещаться по памяти в цикле без необходимости использовать какие-либо регистры для обработки шагов.

В Данные General Nova миникомпьютер имел 16 специальных ячеек памяти с адресами с 16 по 31.[17] При доступе через косвенную адресацию памяти значения с 16 по 23 будут автоматически увеличиваться перед использованием, а с 24 по 31 будут автоматически уменьшаться перед использованием.

Нулевая страница

В Данные General Nova, Motorola 6800 семья и Технология MOS 6502 Семейство процессоров имело очень мало внутренних регистров. Арифметические и логические инструкции в основном выполнялись со значениями в памяти, а не во внутренних регистрах. В результате многие инструкции требовали двухбайтовой (16-битной) области памяти. Учитывая, что коды операций на этих процессорах имели длину всего один байт (8 бит), адреса памяти могли составлять значительную часть размера кода.

Разработчики этих процессоров включили частичное средство, известное как адресация «нулевой страницы». К начальным 256 байтам памяти ($ 0000 - $ 00FF; также известной как страница "0") можно было получить доступ, используя однобайтовый абсолютный или индексированный адрес памяти. Это сократило время выполнения инструкции на один такт и длину инструкции на один байт. Сохраняя часто используемые данные в этом регионе, программы можно было бы делать меньше и быстрее.

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

Прямая страница

Режим адреса нулевой страницы был улучшен в нескольких поздних моделях 8-битных процессоров, включая WDC 65816, то CSG 65CE02, а Motorola 6809. Новый режим, известный как «прямая страничная» адресация, добавил возможность перемещать 256-байтовое окно памяти нулевой страницы из начала памяти (адрес смещения $ 0000) в новое место в пределах первых 64 КБ памяти.

CSG 65CE02 позволял переместить прямую страницу на любую 256-байтовую границу в пределах первых 64 КБ памяти, сохраняя 8-битное значение смещения в регистре новой базовой страницы (B). Motorola 6809 может сделать то же самое со своим регистром прямой страницы (DP). WDC 65816 пошел дальше и позволил переместить прямую страницу в любое место в пределах первых 64 КБ памяти, сохранив 16-битное значение смещения в новом прямом (D) регистре.

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

Масштабируемый индекс с проверкой границ

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

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

Косвенно в битовое поле в слове

Некоторые компьютеры имели специальные режимы косвенной адресации для подполей внутри слов.

В GE / Honeywell серии 600 символьная адресация косвенного слова, указанного в 6-битном или 9-битном символьном поле в его 36-битный слово.

ОИК PDP-10, также 36-битный, имел специальные инструкции, которые позволяли обрабатывать память как последовательность битовых полей фиксированного размера или байтов любого размера от 1 до 36 бит. Дескриптор последовательности из одного слова в памяти, называемый «байтовым указателем», содержал текущий адрес слова в последовательности, позицию бита в слове и размер каждого байта.

Существовали инструкции для загрузки и сохранения байтов через этот дескриптор и для увеличения дескриптора, чтобы он указывал на следующий байт (байты не разделялись по границам слова). Многие программы DEC использовали пять 7-битных байтов на слово (простые символы ASCII), при этом один бит на слово не использовался. Реализации C приходилось использовать четыре 9-битных байта на слово, поскольку функция 'malloc' в C предполагает, что размер int кратно размеру char;[18] фактическое кратное значение определяется системно-зависимым оператором времени компиляции размер.

Индексировать следующую инструкцию

В Эллиотт 503,[19] то Эллиот 803,[19][20] и Компьютер наведения Apollo использовалась только абсолютная адресация и не было индексных регистров. Таким образом, косвенные переходы или переходы по регистрам не поддерживались в наборе команд. Вместо этого можно было бы дать указание добавить содержимое текущего слова памяти к следующей инструкции. Добавление небольшого значения к следующей инструкции, которая будет выполняться, может, например, изменить Прыгать 0 в Прыжок 20, создавая эффект индексированного перехода. Обратите внимание, что инструкция изменяется на лету и остается неизменной в памяти, т.е. самомодифицирующийся код. Если значение, добавляемое к следующей инструкции, было достаточно большим, она могла изменить код операции этой инструкции, а также адрес или вместо него.

Глоссарий

Косвенный
Данные, указанные в указатель или же адрес.
Немедленный
Данные, встроенные непосредственно в инструкция или список команд.
Индекс
Динамическое смещение, обычно индексный регистр, возможно с масштабированием по размеру объекта.
Компенсировать
Немедленное добавление стоимости к адресу; например, соответствующий доступу к полю структуры в Язык программирования C.
Относительный
Адрес сформирован относительно другого адреса.
Прирост публикации
Пошаговое изменение адреса использованных данных, аналогично * p ++ в Язык программирования C, используется для стек поп операции.
Предварительный декремент
Уменьшение адреса перед использованием, аналогично *--п в Язык программирования C, используется для толкание стека операции.

Смотрите также

Рекомендации

  1. ^ Ф. Чоу; С. Коррелл; М. Гимельштейн; Э. Киллиан; Л. Вебер (1987). "Сколько режимов адресации достаточно?".
  2. ^ Джон Л. Хеннесси; Марк А. Горовиц (1986). «Обзор проекта MIPS-X-MP» (PDF). ... MIPS-X использует единственный режим адресации: базовый регистр плюс смещение. Этот простой режим адресации позволяет очень рано начать вычисление эффективного адреса ...
  3. ^ Доктор Джон Сквайр. «Лекция 19, Конвейерная передача данных». CS411 Избранные лекции.
  4. ^ «Высокопроизводительные вычисления, примечания к классу 11 (15 и 20 сентября 2000 г.) - конвейерная обработка». Архивировано из оригинал на 2013-12-27. Получено 2014-02-08.
  5. ^ Джон Пол Шен, Микко Х. Липасти (2004). Современный дизайн процессора. McGraw-Hill Professional. ISBN  9780070570641.
  6. ^ а б Джон Л. Хеннесси; Дэвид А. Паттерсон (2002-05-29). Компьютерная архитектура: количественный подход. п. 104. ISBN  9780080502526. C54x имеет 17 режимов адресации данных, не считая доступа к регистрам, но четыре из них, найденные в MIPS, составляют 70% режимов. Автоинкремент и автодекремент, встречающиеся в некоторых архитектурах RISC, составляют еще 25% использования. Эти данные были собраны для измерения статических инструкций для вызываемой C библиотеки из 54 подпрограмм DSP, закодированных на языке ассемблера.
  7. ^ Доктор Софьен Тахар. «Принципы набора команд: использование режима адресации (сводка)» (PDF). Архивировано из оригинал (PDF) на 30.09.2011. 3 программы, измеренные на машине со всеми режимами адресации (VAX) ... смещение 75% и немедленное
  8. ^ Али-Реза Адл-Табатабай; Джефф Лэнгдейл; Стивен Лукко; Роберт Вахбе (1995). «Эффективные мобильные программы, не зависящие от языка». 79% всех выполняемых инструкций могут быть заменены инструкциями RISC или синтезированы в инструкции RISC с использованием только базовой комбинации инструкций блока.
  9. ^ Принципы работы IBM System / 360 (PDF). IBM. Сентябрь 1968 г. с. 135. A22-6821-7. Получено 12 июля 2019.
  10. ^ z / Архитектура Принципы работы (PDF). IBM. Сентябрь 2017. С. 7–266. SA22-7832-11. Получено 12 июля 2019.
  11. ^ Конг, Шинг; Паттерсон, Дэвид (1995). «Дизайн набора инструкций». Слайд 27.
  12. ^ Купман, Филипп (1989). «Архитектура RTX 32P». Стек Компьютеры.
  13. ^ «Введение в 64-битную архитектуру ARMv8». Академия МСЖД. quequero.org. 9 апреля 2014 г.
  14. ^ 704 Электронная машина обработки данных. Руководство по эксплуатации. (PDF). IBM. 1955. С. 10–11.
  15. ^ Справочное руководство IBM 7090 Data Processing System (PDF). IBM. 1962. С. 9–10.
  16. ^ Джонс, Дуглас, Справочные инструкции по PDP-8, получено 1 июля 2013
  17. ^ Друг, Карл, Общие данные о наборе команд NOVA, получено 1 июля 2013
  18. ^ "Ссылка на C: функция malloc ()"
  19. ^ а б Дэйв Брукс. "Некоторые старые компьютеры".
  20. ^ Билл Первис. «Некоторые подробности оборудования Elliott 803B»

внешняя ссылка