К группе команд пересылки данных относятся следующие команды:
mov <операнд назначения>,<операнд-источник>
xchg <операнд!>,<операнд2>
MOV — это основная команда пересылки данных. Она реализует самые разнооб-
разные варианты пересылки. Отметим особенности применения этой команды.
« Командой MOV нельзя осуществить пересылку из одной области памяти в дру-
гую. Если такая необходимость возникает, то нужно использовать в качестве
промежуточного буфера любой доступный в данный момент регистр общего
назначения. К примеру, рассмотрим фрагмент программы для пересылки бай-
та из ячейки fls в ячейку fid:
masm
model
.data
fls db
fid db
.code
start:
mov
mov
small
5
1
al.fls
fld.al
end start
Нельзя- загрузить в сегментный регистр значение непосредственно из памяти.
Для такой загрузки требуется промежуточный объект. Это может быть регистр
общего назначения или стек. Если вы посмотрите на листинг 5.1, то увидите
в начале сегмента кода две команды MOV, выполняющие настройку сегментного
регистра DS. При этом из-за невозможности напрямую загрузить в сегментный
регистр значение адреса сегмента, содержащееся в предопределенной перемен-
ной @data, приходится использовать регистр общего назначения АХ.
II Нельзя переслать содержимое одного сегментного регистра в другой сегмент-
ный регистр. Это объясняется тем, что в системе команд нет соответствующего
кода операции. Но необходимость в таком действии часто возникает. Выпол-
нить такую пересылку можно, используя в качестве промежуточных все те же
регистры общего назначения. Вот пример инициализации регистра ES значени-
ем из регистра DS:
mov ax.ds
mov es.ax
Но есть и другой, более «красивый» способ выполнения данной операции —
использование стека и команд PUSH и POP:
push ds ;поместить значение регистра ds в стек
pop es ;записать в es число из стека
• Нельзя использовать сегментный регистр CS в качестве операнда назначения.
Причина здесь простая. Дело в том, что в архитектуре процессора IA-32 пара
CS:IP содержит адрес команды, которая должна выполняться следующей. Из-
менение командой MOV содержимого регистра CS фактически означало бы опе-
рацию перехода, а не пересылки, что недопустимо.
В связи с командой MOV отметим один тонкий момент. Пусть в регистре ВХ со-
держится адрес некоторого поля (то есть мы используем косвенную базовую адре-
сацию). Его содержимое нужно переслать в регистр АХ. Очевидно, что нужно при-
менить команду MOV в форме
mov a x , [ Ь х ]
Транслятор задает себе вопрос: что адресует регистр ВХ в памяти — слово или
байт? Обычно в этом случае он принимает решение сам, по размеру большего опе-
ранда, но может и выдать предупреждающее сообщение о возможном несовпаде-
нии типов операндов.
Или другой случай — возможно, более показательный. Рассмотрим команды
инкремента INC (увеличения операнда на 1) и декремента DEC (уменьшения опе-
ранда на 1):
inc [Ьх]
dec [bx]
Что адресуется регистром ВХ в памяти — байт, слово или двойное слово?
Допустим также, что требуется инициализировать поле, адресуемое регистром
ВХ, значением 0. Очевидно, что одно из решений — применение команды MOV:
mov [bx] ,0
И опять у транслятора вопрос: какую машинную команду ему конструировать?
Для инициализации байта? Для инициализации слова? Для инициализации двой-
ного слова?
Во всех этих случаях необходимо уточнять тип используемых операндов. Для
этого существует специальный оператор ассемблера PTR (см. приложение). Пра-
вильно записать приведенные ранее команды можно следующим образом:
mov ax,word ptr[bx] ;если [bx] адресует слово в памяти
inc byte ptr[bx] ;если [bx] адресует байт в памяти
dec dword ptr[bx] ;если [Ьх] адресует двойное слово в памяти
mov word ptr[bx],0 ;если [Ьх] адресует слово в памяти
Можно рекомендовать использовать оператор PTR во всех сомнительных отно-
сительно согласования размеров операндов случаях. Также этот оператор нужно
применять, когда требуется принудительно поменять размерность операндов.
К примеру, требуется переслать значение Offh во второй байт поля flp:
masm
model small
.data
tip dw 0
.code
start:
mov byte ptr (flp+l),0ffh
end start
Несмотря на то что поле flp имеет тип WORD, мы сообщаем ассемблеру, что поле
нужно трактовать как байтовое, и заставляем вычислить значение эффективного
адреса второго операнда как смещение flp плюс единица. Тем самым мы получаем
доступ ко второму байту поля flp.
Для двунаправленной пересылки данных применяют команду XCHG. Для этой
операции можно, конечно, применить последовательность из нескольких команд
MOV, но из-за того что операция обмена используется довольно часто, разработчи-
ки системы команд процессора посчитали нужным ввести отдельную команду об-
мена — XCHG. Естественно, что операнды должны иметь один тип. Не допускается
(как и для всех команд ассемблера) напрямую обменивать между собой содержи-
мое двух ячеек памяти. К примеру,
xchg ах,Ьх ;обменять содержимое регистров ах и Ьх
;обменять содержимое регистра ах и слова в памяти по адресу в [si]:
xchg ax,word ptr [si]
Опубликовал Kest
January 03 2009 21:49:04 ·
0 Комментариев ·
16616 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.