Подробное описание системы команд микропроцессора МС68020 и способов адресации, страница 16

¦  (d{8},An,Xn)  ¦110 ¦ном.An  ¦¦  (d{8},PC,Xn)  ¦ -  ¦   -    ¦

+----------------+----+--------++----------------+----+--------+

¦   (bd,An,Xn)   ¦110 ¦ном.An  ¦¦   (bd,PC,Xn)   ¦ -  ¦   -    ¦

+----------------+----+--------++----------------+----+--------+

¦([bd,An,Xn],od) ¦110 ¦ном.An  ¦¦ ([bd,PC,Xn],od)¦ -  ¦   -    ¦

+----------------+----+--------++----------------+----+--------+

¦([bd,An],Xn,od) ¦110 ¦ном.An  ¦¦ ([bd,PC],Xn,od)¦ -  ¦   -    ¦

L----------------+----+---------L----------------+----+--------BFTST        Проверка битового поля               BFTST

------------------------------------------------------Операция:       проверяется <битовое поле> В Приемнике

Синтаксис:      BFTST <иа> {смещение:длина}

Атрибуты:       Размер не задается

Описание:

Устанавливаются коды условия в соответствии со значением битового поля по указанному исполнительному адресу.

Поле определяется смещением и длиной.  Смещение  задает начальный бит поля, а длина - количество бит поля.

Коды условия:

X   N   Z   V   C

----T---T---T---T---¬

¦ - ¦ * ¦ * ¦ 0 ¦ 0 ¦

L---+---+---+---+---N       1, если старший бит поля равен 1; иначе 0

Z       1, если все биты поля равны 0; иначе 0

V       всегда 0

C       всегда 0

X       не изменяется

Формат команды:

15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0

----T---T---T---T---T---T---T---T---T---T----------------------¬

¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦ Исполнительный адрес ¦

¦ 1 ¦ 1 ¦ 1 ¦ 0 ¦ 1 ¦ 0 ¦ 0 ¦ 0 ¦ 1 ¦ 1 ¦  Мода       Регистр  ¦

+---+---+---+---+---+---+---+---+---+---+---T-------+----------+

¦ 0 ¦ 0 ¦ 0 ¦ 0 ¦СМ ¦     Смещение      ¦ДЛ ¦     Длина        ¦

L---+---+---+---+---+-------------------+---+------------------Поля команды:

Поле СМ определяет способ задания смещения:

0 - смещение задается в поле Смещения.

1 - биты [8:6] слова расширения задают регистр данных, содержащий смещение; биты [10:9] равны 0.

Поле  Смещение задает смещение в зависимости от поля СМ

следующим образом:

Если  СМ = 0,  поле Смещения содержит непосредственный операнд в диапазоне  0-31,  задающий  соответствующую величину смещения.

Если СМ = 1,  поле Смещения определяет регистр данных, содержащий смещение в диапазоне [ -(2**31); 2**31-1 ]

Поле ДЛ определяет способ задания длины:

0 - длина битового поля задается непосредственно в команде в поле Длины.

1 - биты [2:0] слова расширения задают регистр данных, содержащий длину; биты [4:3] равны 0.

Поле Длина задает длину в зависимости от поля ДЛ:

Если ДЛ = 0, в поле Длины содержится  непосредственный операнд в диапазоне 0,1,...31, задающий значение  длины, равное соответственно 32,1,...31.

Если ДЛ = 1, поле Длины определяет регистр данных, содержащий  величину, которая будучи взята по модулю 32, принимает значение 0,1,...31 и  задает  соответственно значение длины, равное 32,1,...31.

Поле  Исполнительного  адреса  определяет базовый адрес битового поля. Допустимы только способы прямой регистровой  адресации данных или адресации управляющих операндов:

-----------------T----T--------¬-----------------T----T--------¬

¦Способ адресации¦Мода¦Регист𠦦Способ адресации¦Мода¦Регистр ¦

+----------------+----+--------++----------------+----+--------+

¦       Dn       ¦000 ¦ном.Dn  ¦¦    (xxx).W     ¦111 ¦  000   ¦

+----------------+----+--------++----------------+----+--------+

¦       An       ¦ -  ¦   -    ¦¦    (xxx).L     ¦111 ¦  001   ¦

+----------------+----+--------++----------------+----+--------+

¦      (An)      ¦010 ¦ном.An  ¦¦   #<данные>    ¦ -  ¦   -    ¦

+----------------+----+--------++----------------+----+--------+

¦      (An)+     ¦ -  ¦   -    ¦¦                ¦    ¦        ¦

+----------------+----+--------++----------------+----+--------+

¦     -(An)      ¦ -  ¦   -    ¦¦                ¦    ¦        ¦

+----------------+----+--------++----------------+----+--------+

¦   (d{16},An)   ¦101 ¦ном.An  ¦¦   (d{16},PC)   ¦111 ¦  010   ¦

+----------------+----+--------++----------------+----+--------+

¦  (d{8},An,Xn)  ¦110 ¦ном.An  ¦¦  (d{8},PC,Xn)  ¦111 ¦  011   ¦

+----------------+----+--------++----------------+----+--------+

¦   (bd,An,Xn)   ¦110 ¦ном.An  ¦¦   (bd,PC,Xn)   ¦111 ¦  011   ¦

+----------------+----+--------++----------------+----+--------+

¦([bd,An,Xn],od) ¦110 ¦ном.An  ¦¦ ([bd,PC,Xn],od)¦111 ¦  011   ¦

+----------------+----+--------++----------------+----+--------+

¦([bd,An],Xn,od) ¦110 ¦ном.An  ¦¦ ([bd,PC],Xn,od)¦111 ¦  011   ¦

L----------------+----+---------L----------------+----+--------BKPT                 Точка останова                  BKPT

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

Синтаксис:      BKPT #<данные>

Атрибуты:       Размер не используется

Описание:

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

При  выполнении  команды  процессор  инициирует на шине цикл подтверждения точки останова, выставляя на  адресных  линиях A2,A3 и A4 значения непосредственных данных

(а именно, номера точки останова в диапазоне 0-7), а на линиях A0-A1 - нули. Возможны два  вида  реакции:  нормальная и возбуждение исключения.

При нормальной реакции с поступлением  сигнала  DSACKx*

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

BKPT.

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

Коды условия: не изменяются.

Формат команды: