|
MOV AX, SOURCE; переслать данные из SOURCE
MOV DEST,AX; в DEST
Обращаю Ваше внимание, что в большинстве примеров дальнейшего изложения выделенные команды буду заменять многоточием.
- сегментный регистр-сегментный регистр. Нельзя пересылать содержимое одного сегментного регистра в другой сегментный регистр, однако при необходимости такой пересылки поступают также, как и в предыдущих случаях: пересылку осуществляют через регистр общего назначения;
- нельзя использовать сегментный регистр CS в качестве операнда назначения (приемника). Это объясняется тем, что регистр CS и регистр указатель команд IP вместе содержат адрес команды, которая должна выполняться следующей. Изменение содержимого CS равносильно операции перехода, ибо меняет последовательность команд.
Команда Xchg (exchange) меняет между собой значения двух регистров общего назначения или регистра ОН и ячейки памяти. Необходимое требование к операндам – чтобы они имели один тип. Например:
Xchg AX, BX;обменять значения двух регистров (слова
Xchg AL, BH; или байты
Xchg WORD1, DX; обменять значения регистра и
Xchg DL, BYTE1;ячейки памяти.
Смещение, которое вычисляется операционным блоком для доступа к находящемуся в памяти операнду, называется исполнительным адресом операнда. Этот исполнительный адрес показывает, на каком расстоянии (в байтах) от начала сегмента располагается искомый операнд. Напоминаю, что физический или абсолютный адрес в памяти ЭВМ определяется как
абсолютный адрес = адрес начала сегмента + смещение внутри данного сегмента
или как
абсолютный адрес = сегментный адрес + исполнительный адрес.
Причем обе приведенные выше записи содержат одни и те же слагаемые, определенные разными терминами. Отсюда следует, что исполнительный адрес переменной есть не что иное, как смещение относительно начала сегмента данных.
В зависимости от используемого режима адресации получение исполнительного адреса может заключаться только в извлечении его как составной части исполняемой команды, а могут потребоваться дополнительные операции сложения составной части команды с содержимым других регистров.
Различают адресацию операндов:
- непосредственную, которая заключается в указании в команде самого значения операнда, а не его адреса;
- прямую, предполагающую указание в команде непосредственно исполнительного адреса;
- косвенную, при которой в команде указывается адрес регистра или ячейки памяти, в которых хранится адрес операнда или его составляющие;
- ассоциативную (используется в ассоциативных запоминающих устройствах, на ней останавливаться не будем);
- неявную, когда адреса операндов в команде не указываются, а подразумеваются кодом операции.
Непосредственная адресация имеет место, если операнд-источник является константой или переменной, которой присвоено постоянное значение. Например:
MOV AX, 500 загружает значение 500 в РОН AX или
.......
K EQU 1024
.........
MOV CX, K загружает в РОН СХ константу 1024, определенную идентификатором К.
Следует отметить, что непосредственный операнд может быть задан простым выражением, в котором константы или идентификаторы констант связаны арифметическими операциями +, -, * или / (в таких выражениях не должно быть скобок). Например:
MOV AX, 156*10Н/2.
Следует помнить, что диапазон посылаемых чисел (значений непосредственного операнда) определяется вместимостью приемника - если это однобайтовый регистр (AH, AL, BL …), то в него можно посылать беззнаковые числа в диапазоне от 0 до 255, знаковые – от –128 до 127.
Прямая регистровая адресация имеет место в командах, оперирующих с содержимым РОН или сегментных регистров в качестве одного или обеих операндов команды. Например, команда:
MOV DS, AX
копирует содержимое РОН АХ в сегментный регистр DS, при этом содержимое регистра AXне изменяется.
При использовании этого вида адресации в программах необходимо следить, чтобы разрядности обеих регистров были одинаковы.
Прямая адресация ячеек ОП имеет несколько вариантов:
- прямая обычная характеризуется тем, что смещение является составной частью команды и не требует при формировании исполнительного адреса дополнительных регистров, иными словами = . Обычно применяется, если операндом служит помеченная переменная, например:
MOV AX, SOURCE
загружает слово из ячейки памяти в регистр. При этом в памяти старший байт следует за младшим, а не предшествует ему. Это обусловлено тем, что в памяти ЭВМ старшая часть располагается в ячейках памяти со старшими адресами. Поэтому схема приведенной команды будет следующей:
SOURCE | ВВ | |
АА | ||
SOURCE+2 |
После выполнения вышеуказанной команды пересылки регистр АХ будет содержать АХ=ААВВ.
Примеры прямой обычной адресации вы можете видеть в программе, приведенной в приложении 1.А.
Приводимые далее режимы адресации будем рассматривать на примере двумерного массива SOURCE, определенного в сегменте данных как
SOURCE DB 1,2,3,4,5,6,
DB 10,20,30,40,50,60.
- прямая с индексированием: = + , причем находится в индексном регистре, например:
- MOV AX, SOURCE[SI].
Если занести в индексный регистр SI номер элемента массива, например, 6, то в результате выполнения команды в регистр АХ будет занесено значение 4. Чтобы уяснить этот момент, обратитесь к вышеприведенной таблице, из которой видно, что первый элемент массива имеет смещение 0, второй – смещение 2. Продолжив этот ряд, получим, что третий элемент расположен в памяти со смещением 4, а четвертый - со смещением 6 относительно начала массива, имеющего имя SOURCE.
- прямая с базированием: = + , адрес находится в базовом регистре, например:
- MOV AX, SOURCE[ВХ].
Такая адресацияпредназначена для доступа к данным с известным смещением относительно некоторого базового адреса, при этом исполнительный адрес получается путем сложения значения сдвига с содержимым регистров BX или BP. Например, таблица TABLE содержит поля фамилии (FAM 20 байт), имени (NAME 15 байт) и адреса (PLACE 50 байт). Тогда командами
MOV ВХ, 20
MOV AL, TABLE[ВХ]
получим в регистре AL первый байт имени.
- прямая с индексированием и базированием: = + + , например:
MOV AX, SOURCE[ВХ+SI].
Возможна и такая форма записи команды:
MOV AX, SOURCE [BX][SI].
Здесь ВХ может быть связан с номером столбца, а SI– c номером строки, как в языках высокого уровня элементы массива определяются двумя индексами – SOURCE(J,I). Разница в том, что значения в регистрах базы и индекса должны учитывать размеры элементов массива и определять смещения. Так, пятый элемент во втором столбце определяется как
BX = (размер элемента в байтах * количество элементов в строке) *
(J-1)= = 2*6 = 12 (ВХ определяет смещение начала J-того столбца);
SI= размер элемента в байтах (I-1) = 2 4= 8.
(Единица из номеров строки и столбца вычитается потому, что смещения начинают считаться с нуля!)
Косвенная адресация (в некоторых источниках литературы /Абель/ эта адресация называется непрямой) использует способность компьютера адресовать память в форме сегмент:смещение. Для этого используются основные (BX и BP) и индексные регистры (DI и SI), заключенные в квадратные скобки, что определяет обращение к памяти.
Косвенный адрес, например [DI], указывает ассемблеру, что подлежащий использованию адрес памяти при исполнении программы будет храниться в регистре DI. Регистры BX, DI и SI связаны с DS как DS:BX, DS:DI и DS:SI и обрабатывают данные, определенные в сегменте данных, ВР связан с SS как SS:BP и применяется для обработки данных в стеке.
Правило использования косвенной адресации:
- если 1-ый операнд содержит косвенный адрес, то 2-ой операнд ссылается на регистр или непосредственное значение;
Дата добавления: 2015-07-08; просмотров: 105 | Нарушение авторских прав
<== предыдущая страница | | | следующая страница ==> |
Режимы адресации памяти | | | если 2-ой операнд содержит косвенный адрес, то 1-ый операнд ссылается на регистр. |