Машинные коды команд № 34 и 35 имеют формат «2слова», машинные
коды остальных команд – формат «слово». Команды выполняются за два такта, а
при обращении к ячейкам в ERAM – за 3 такта. В случае необходимости в цикл
выполнения команды при обращении к ERAM может быть введен
дополнительный такт ожидания.
Для интерпретации команд используются обозначения:
ЯчА – регистр общего назначения, регистр ввода-вывода, ячейка памяти
в SRAM, ячейка памяти в ERAM, к которым производится обращение с
использованием адреса А из адресного пространства SRAM;
(ЯчА) – байт в ЯчА;
X, Y, Я – пара регистров общего назначения X (R26, R27), Y (R28, R29),
Z (R30, R31) соответственно;
(X), (Y), (Z) – слово в паре регистров X, Y, Z соответственно;
СТЕК – ЯчА, к которой производится обращение с использованием
адреса, хранящегося в регистре-указателе стека SP;
(СТЕК) – байт в СТЕКе;
(SP) – код числа в регистре SP.
В командах № 34 и 35 реализуется прямая адресация. Адрес байта (А=k)
указывается в коде команды.
В командах № 36 – 57 реализуется косвенная адресация. Адрес байта
находится в паре регистров X, Y или Z. При выполнении команд №42 -47 после
выполнения пересылки адрес в паре регистров аппаратно увеличивается на
единицу. При выполнении команд № 48 – 53 до выполнения пересылки адрес в
паре регистров аппаратно уменьшается на единицу. При выполнении команд
№54 – 57 адрес, по которому производится обращение, равен адресу в паре
регистров Y или Z, увеличенному на число q, которое указано в коде команды.
Адрес в паре регистров остается без изменения.
В командах № 58 и 59 в качестве кода адреса используется код
находящийся в регистре-указателе стека. При запуске МК в регистр – указатель
стека заносится код числа 0. Для нормальной работы стека в регистр-указатель
стека в начале программы необходимо занести код другого числа. Обычно в
качестве такого числа используют старший адрес в SRAM. Например, для МК
типа 8515 таким адресом является число $025F.
Команды с обращением к регистрам ввода-вывода.
По командам с обращением к регистрам ввода-вывода выполняются
операции пересылки (копирования) байта между регистром общего назначения и
регистром ввода-вывода с использованием для выбора регистра ввода-вывода
его номера ($00 - $3F). Машинные коды команд имеют формат «слово».
Команды выполняются за один такт.
Используются обозначения:
PrP – регистр ввода-вывода с номером Р;
(PrP) – байт в регистре PrP.