Команда "загрузить указатель данных 16-битовой констрантой" загружает указатель данных DPTR 16-битовой константой, указанной во втором и третьем байтах команды. Второй байт команды загружается в старший байт указателя данных (DPH), а третий байт - в младший байт указателя данных (DPL). Эта команда на флаги не влияет и является единственной командой, которая одновременно загружает 16 бит данных.
Ассемблер:
MOV DPTR, #<data16>
Код:
1 0 0 1 0 0 0 0
#data[15-8]
#data[7-0]
Время:
2 циклa
Алгоритм:
(DPTR) :=#[15-0], причем DPH:=#data[15-8] , DPL:=#data[7-0]
Команда "переслать байт из памяти программ" загружает аккумулятор байтом кода или константой из памяти программы. Адрес считываемого байта вычисляется как сумма 8-битового исходного содержимого аккумулятора без знака и содержимого 16-битового регистра. В качестве 16-битового регистра может быть:
указатель данных DPTR
счетчик команд РС
В случае, когда используется РС, он увеличивается до адреса следующей команды перед тем, как его содержимое складывается с содержимым аккумулятора. 16-битовое сложение выполняется так, что перенос из младших восьми бит может распространяться через старшие биты. Эта команда на флаги не влияет.
;(A)=FAH, (PC)=0289
;(ПЗУ[0384])=9BH
MOVC A, @A+PC ;(A)=9BH, (PC)=028AH
Команда MOVX <байт приемника>, <байт источника>
Команда "переслать во внешнюю память (из внешней памяти) данных" пересылает данные между аккумулятором и батом внешней памяти данных. Имеется два типа команд, которые отличаются тем, что обеспечивают 8-битовый или 16-битовый косвенный адрес к внешнему ОЗУ данных.
В первом случае содержимое R0 или R1 в текущем банке регистров обеспечивает 8-битовый адрес, который мультеплексируется с данными порта Р0. Для расширения дешифрации ввода-вывода или адресации небольшого массива ОЗУ достаточно восьми бит адресации. Если применяются ОЗУ, немного больше чем 256 байт, то для фиксации старших битов адреса можно использовать любые другие выходы портов, которые переключаются командой, стоящей перед командой MOVX.
Во втором случае, при выполнении команды MOVX указатель данных DPTR генерирует 16-битовый адрес. Порт Р2 выводит старшие 8 бит адреса (DPH), а порт Р0 мультеплексирует младшие 8 бит адреса (DPL) с данными. Эта форма является эффективной при доступе к большим массивам данных (до 64К байт), так как для установки портов вывода не требуется дополнительных команд.
Ассемблер:
MOVX A@Ri; где i=0,1
Код:
1 1 1 0 0 0 1 i
Время:
2 циклa
Алгоритм:
(A) : = ((Ri))
Пример:
;(A)=32H, (R0)=83H, ячейка
;внешнего ОЗУ по адресу 83H
;содержит B6H
MOVX A,@R0 ;(A)=B6H, (R0)=83H
Ассемблер:
MOVX A, @DPTR
Код:
1 1 1 0 0 0 0 0
Время:
2 циклa
Алгоритм:
(A) : =((DPTR))
Пример:
;(A)=5CH, (DPTR)=1ABEH,
;ячейка внешнего ОЗУ по адресу
;1ABEH содержит 72H
MOVX A, @DPTR ;(A)=72H, (DPTR)=2ABEH
Ассемблер:
MOVX Ri@A; где i=0,1
Код:
1 1 1 1 0 0 1 i
Время:
2 циклa
Алгоритм:
((Ri)) : = (A)
Пример:
;(A)=95H, (R1)=FDH,
;ячейка внешнего ОЗУ с адресом
;FDH содержит 00
MOVX R1,@A ;(A)=95H, (R1)=FDH,
;ячейка внешнего ОЗУ с адресом
;FDH содержит 95H
Ассемблер:
MOVX @DPTR,A
Код:
1 1 1 1
0 0 0 0
Время:
2 циклa
Алгоритм:
((DPTR)) : =(A)
Пример:
;(A)=97H, (DPTR)=1FFFH,
;ячейка внешнего ОЗУ с адресом
;1FFFH содержит 00
MOVX @DPTR, A ;(A)=97H,
;ячейка внешнего ОЗУ с адресом
;1FFFH содержит 97H