|
D
|
|
|
P
|
DM
|
|
|
PM
|
001
|
M
|
DMI
|
DMM
|
M
|
DREG
|
PMI
|
PMM
|
DREG
|
|
D
|
|
|
D
|
|
|
|
|
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
0
COMPUTE
Тип обращения (чтение или запись) выбирается DMD и PMD. Ячейка памяти регистрового
файла определяется DMDREG и PMDREG.
DMI и PMI определяют регистр I для памяти данных и памяти программы. DMM
и РММ определяют регистр М, используемый для обновления регистра I. Поле COMPUTE определяет операцию
вычисления, выполняемую параллельно с доступом к данным. Если операция
вычисления не задана в команде, то это операция NO Р.
Операция вычисления, необязательное условие
Синтаксис:
IF условие вычисление;
Функция:
Условная команда вычисления. Команда выполняется, если при
проверке определенное условие верно.
Примеры: IF MS MRF=0; F6= (F2+F3) /2;
Код операции: 47 46 45 44 43 42 41 40 39 38 37 36 35
34 33 32 31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
0
COMPUTE
Если заданное полем COND условие
верно, то определенная в поле COMPUTE операция
выполняется. Если условие в команде не определено, то COND
является условием TRUE, и вычисление выполняется всегда.
Пересылка данных между памятью данных или памятью программы
и универсальным регистром, необязательное условие, необязательная операция
вычисления
Функция:
Обращения между памятью данных или памятью программы и
универсальным регистром. Определенные регистры I используются
для адресации памяти данных и памяти программы. Значение I
либо пред-модифицируется (М, I) либо
пост-модифицируется (I, М) значением определенного
регистра М. При пост-модификации значение регистра I
обновляется модифицированным значением. Если определена операция вычисления, то
она выполняется параллельно с доступом к данным. Если условие определено, то
оно влияет на выполнение всей команды.
Универсальный регистр (ureg) может
находиться не в том же самом DAG (т.е. DAG1 или DAG2), что и la/Mb или Ic/Md.
Примеры:
R6=R3-R11, DM (IO,M1) =ASTAT;
IF NOT SV F8=CLIP F2 BY F14, PX=PM (112,M12);
Код операции:
47 46 45 44 43 42 41 40 39 38 37 36
35 34 33 32 31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
COMPUTE
COND определяет условие для проверки.
Если условие в команде не определено, то COND является
условием TRUE, и команда выполняется всегда.
Тип доступа (чтение или запись) выбирается D.
G выбирает память данных или память программы. UREG определяет универсальный регистр. I
определяет индексный регистр I, М - регистр модификации
М. U выбирает либо пред-модификацию без обновления либо
пост-модификацию с обновлением. Поле COMPUTE определяет
вычислительную операцию, выполняемую параллельно с доступом к данным. Если в
команде не определено никакой операции вычисления, то это поле NOR
Пересылка данных между памятью данных или памятью программы
и регистровым файлом относительно PC, необязательное
условие, необязательная операция вычисления
Синтаксис:
DM (Ia,<data6>) PM (Ic,<data6>)
DM (<data6>, Ia) PM (<data6>, Ic)
dreg = DM (Ia,<data6>) PM (Ic,<data6>)
dreg = DM (<data6>, Ia) PM (<data6>,
Ic)
Функция:
Обращения между памятью данных или памятью программы и
регистровым файлом. Определенные регистры I
используются для адресации памяти данных и памяти программы. Значение I либо пред-модифицируется (data, I), либо поет-модифицируется (I, data) непосредственным значением данных. При пост-модификации
регистр I обновляется модифицированным значением. Если
определена операция вычисления, то она выполняется параллельно с доступом к
данным. Если условие определено, то оно влияет на выполнение всей команды.
Примеры:
IF FLAG0_IN F1=F15*F12, F11=PM (110,40); R12=R3
AND Rl, DM (6, II) =R6;
Код операции:
47 46 45 44 43 42
41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23
011
|
0
|
I
|
G
|
D
|
и
|
COND
|
DATA
|
DREG
|
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
COMPUTE
COND определяет условие для проверки.
Если условие в команде не определено, то COND является
условием TRUE, и команда выполняется всегда.
D выбирает тип обращения (чтение или
запись). G выбирает память данных или память программ. DREG определяет регистр регистрового файла. I
определяет индексный регистр I. DATA
определяет 6-разрядное значение модификации в виде двоичного дополнения. U определяет либо пред-модификацию без обновления, либо
пост-модификацию с обновлением. Поле COMPUTE определяет
вычислительную операцию, выполняемую параллельно с доступом к данным. Если в
команде не определено никакой операции вычисления, то это поле NOR
Пересылка между двумя универсальными регистрами,
необязательное условие, необязательная операция вычисления
Синтаксис:
IF условие вычисление, uregl=ureg2;
Функция:
Передача данных из одного универсального регистра в другой. Если
операция вычисления определена, она выполняется параллельно с доступом к данным.
Если условие определено, то оно влияет на выполнение всей команды.
Примеры:
IF TF MRF=R2*R6 (SSFR), M4=R0; LCNTR=L7;
Код операции:
47 46 45 44 43 42 41 40 39 38 37
36 35 34 33 32 31 30 29 28 27 26 25 24 23
Oil
|
1
|
Source UREG
|
COND
|
Dest UREG
|
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
0
COMPUTE
COND определяет условие для проверки.
Если никакого условия в команде не определено, то COND
является условием TRUE, и команда выполняется всегда.
Source UREG указывает универсальный регистр - источник данных. Dest UREG
указывает универсальный регистр - адресат. Поле COMPUTE
определяет операцию вычисления, выполняемую параллельно с доступом к данным. Если
в команде не определено никакой операции вычисления, то это поле NOP.
Операция непосредственного сдвига, необязательное условие,
необязательная пересылка данных между памятью данных или памятью программы и
регистровым файлом
Синтаксис:
a. IF
условие Непосредственный сдвиг
DM (Ia,Mb) PM (Ic,Md) = dreg;
b. IF
условие Непосредственный сдвиг
dreg = DM
(Ia,Mb) PM (Ic,Md)
Функция:
Если определен доступ из регистрового файла к памяти данных
или памяти программы, то он выполняется параллельно с операцией устройства
сдвига. Регистр I используется для адресации памяти
данных и памяти программы. Значение I
поет-модифицируется значением определенного регистра М и обновляется
модифицированным значением. Если условие определено, то оно влияет на
выполнение всей команды.
Замечание: см. раздел 4.4.1 "Ограничения на передачу
данных с использованием регистров DAG" в главе 4 Передача
данных.
Примеры:
IF GT R2=R6 LSHIFT BY 30, DM (14,M4) =R0; IF
NOT SZ R3=FEXT Rl BY 8: 4;
Код операции: (с доступом к данным)
47 46 45 44 43
42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23
100
|
0
|
I
|
м
|
COND
|
G
|
D
|
DATAEX
|
DREG
|
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7
6 5 4 3 2 1 0
Код операции: (без доступа к данным)
47 46 45 44 43
42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 1211 10 9
8 7 6 5 4 3 2 1 0
COND определяет условие для проверки.
Если в команде не определено никакого условия, то COND
является условием TRUE, и команда выполняется всегда.
SHIFTOP определяет операцию
устройства сдвига. Поле DATA определяет 8-разрядное
непосредственное значение сдвига. Для операции устройства сдвига, требующей
двух 6-разрядных чисел (значение сдвига и значение длины), поле DATAEX добавляет 4 старших разряда к полю DATA,
образуя 12-разрядное непосредственное значение. Шесть младших разрядов являются
значением сдвига, шесть старших - значением длины. Если определен доступ к
памяти, то D выбирает тип доступа (чтение или запись). G выбирает память данных или память программы. DREG определяет регистр регистрового файла. I
определяет индексный регистр I, который
поет-модифицируется и обновляется значением регистра М, определяемым полем М. Поле
COMPUTE определяет вычислительную операцию, выполняемую
параллельно с доступом к данным. Если в команде не определено никакой операции
вычисления, то это поле NOR. Модификация индексного
регистра, необязательное условие, необязательная операция вычисления.
Синтаксис:
IF условие вычисление, MODIFY
(Ia,Mb) (Ic,Md)
Функция:
Обновление определенного регистра I
значением определенного регистра М. Если операция вычисления определена, она
выполняется параллельно с доступом к данным. Если определено условие, то оно
влияет на выполнение всей команды. Замечание: см. раздел 4.4.1 "Ограничения
на передачу данных с использованием регистров DAG"
в главе 4 Передача данных. Примеры: IF NOT FLAG2_IN R4=R6*R12 (SUF), MODIFY (110,M8); IF NOT LCE MODIFY
(13,Ml);
Код операции:
(с доступом к данным)
47 46 45 44 43 42
41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7 6 5 4 3 2 1 0
COMPUTE
COND определяет условие для проверки.
Если в команде не определено никакого условия, то COND
является условием TRUE, и команда выполняется всегда. G выбирает DAG1 или DAG2.1
определяет индексный регистр, М - регистр модификации. Поле COMPUTE
определяет вычислительную операцию, выполняемую параллельно с доступом к данным.
Если в команде не определено никакой операции вычисления, то это поле NOР.
Прямой (или относительно PC) переход/вызов,
необязательное условие
Функция:
Переход или вызов по определенному адресу или по адресу
относительно PC. Адрес относительно PC
- это 24-разрядное число в виде двоичного дополнения. Модификатор команды DB указывает, что переход задержанный; иначе - он не
задержанный. Если модификатор прерывания цикла (LA) определен
для перехода, то данные извлекаются из стеков цикла и стека PC
при выполнении перехода. Модификатор LA должен
использоваться только в случае, если переход выполняется за границу цикла. Если
цикла нет или адрес перехода находится внутри цикла, то модификатор LA не должен использоваться.
Модификатор очистки прерывания (CI) команды
JUMP позволяет повторно использовать прерывание во
время его обработки. Обычно ADSP-2106x
игнорирует и не фиксирует прерывание, которое происходит повторно, когда
программа его обработки уже выполняется. Команда JUMP (CI) должна размещаться внутри программы обработки прерывания.
JUMP (CI) очищает состояние
текущего прерывания без выхода из программы обработки прерывания, сводя
программу обработки прерывания к стандартной подпрограмме - это позволяет
прерыванию произойти снова в результате какого-либо события или задачи в
системе ADSP-2106x. Команда JUMP (CI) сводит программу обработки
прерывания к стандартной подпрограмме, обнуляя соответствующий бит в регистре
фиксирования прерывания (IRPTL) и регистре указателя
маски прерывания (IMASKP). Затем ADSP-2106x позволяет прерыванию произойти снова. При возвращении из
подпрограммы, в которую была сведена программа обработки прерывания командой JUMP (CI), должен использоваться
модификатор (LR) команды RTS (в
случае, если прерывание поступает в течение двух последних команд цикла).
Примеры:
IF AV JUMP (PC, 0X00А4);
CALL init (DB); (init
- это программная метка)
JUMP (PC,2)
(DB,CI); (очистка текущего
прерывания
для повторного использования)
Код операции: (для прямого перехода)
47 46 45 44 43 42 41 40 39 38 37 36 35
34 33 32 31 30 29 28 27 26 25 24
000
|
00110
|
в
|
А
|
COND
|
|
J
|
|
CI
|
22
|
21
|
20
|
19
|
18
|
17
|
16
|
15
|
14 13 12
|
11
|
10
|
9
|
8
|
V
|
6
|
5
|
4
|
3
|
2
|
1
|
0
|
|
|
|
|
|
|
|
|
|
ADDR
|
|
|
|
|
|
|
|
|
|
|
|
|
Код операции: (для перехода относительно PC)
47 46 45 44 43 42 41 40 39 38 37
36 35 34 33 32 31 30 29 28 27 26 25 24
23
|
22
|
21
|
20
|
19
|
18
|
17
|
16
|
15
|
14 13 12
|
11
|
10
|
9
|
8
|
7
|
6
|
5
|
4
|
3
|
2
|
1
|
0
|
|
|
|
|
|
|
|
|
|
RELADDR
|
|
|
|
|
|
|
|
|
|
|
|
|
COND определяет условие для проверки.
Если в команде не определено никакого условия, то COND
является условием TRUE, и команда выполняется всегда. В
выбирает тип перехода - переход или вызов. J
определяет, задержан переход или нет. Поле адреса ADDR
определяет 24-разрядный адрес памяти программы. RELADDR
- это 24-разрядное число в виде двоичного дополнения, которое прибавляется к
текущему значению PC для генерации адреса перехода. Бит
А активизирует прерывание цикла. CI активизирует
очистку прерывания. (Для вызовов CI и А игнорируются)
Косвенный (или относительно PC) переход/вызов,
необязательное условие, необязательная операция вычисления
Функция:
Переход или вызов по адресу, определяемому
пред-модифицированным значением регистра I, или по
адресу относительно PC. Адрес относительно PC - это 6-разрядное число в виде двоичного дополнения. Если
регистр I определен, то он модифицируется определенным
значением регистра М для генерации адреса перехода. На содержимое регистра I операция модификации не влияет.
Переход или вызов выполняется, если заданное условие верно. Если
операция вычисления определена без ELSE, то она
выполняется параллельно с вызовом или переходом. Если операция вычисления
определена с ELSE, то она выполняется, только если
заданное условие ложно. Заметим, что условие должно быть задано, если
определена фраза ELSE вычисление.
Переход или вызов по определенному адресу или адресу
относительно PC. Адрес относительно PC
- это 24-разрядное число в виде двоичного дополнения. Модификатор команды DB указывает, что переход задержанный; иначе - он не
задержанный. Если модификатор прерывания цикла (LA) определен
для перехода, то данные извлекаются из стеков цикла и стека PC
при выполнении перехода. Модификатор LA должен
использоваться только в случае, если переход выполняется за границу цикла. Если
цикла нет или адрес перехода находится внутри цикла, то модификатор LA не должен использоваться.
Модификатор очистки прерывания (CI) команды
JUMP позволяет повторно использовать прерывание во
время его обработки. Обычно ADSP-2106x
игнорирует и не фиксирует прерывание, которое происходит повторно, когда
программа его обработки уже выполняется. Команда JUMP (CI) должна размещаться внутри программы обработки прерывания.
JUMP (CI) очищает состояние
текущего прерывания без выхода из программы обработки прерывания, сводя
программу обработки прерывания к стандартной подпрограмме - это позволяет
прерыванию произойти снова в результате какого-либо события или задачи в
системе ADSP-2106x. Команда JUMP (CI) сводит программу обработки
прерывания к стандартной подпрограмме, обнуляя соответствующий бит в регистре
фиксирования прерывания (IRPTL) и регистре указателя
маски прерывания (IMASKP). Затем ADSP-2106x позволяет прерыванию произойти снова. При возвращении из
подпрограммы, в которую была сведена программа обработки прерывания командой JUMP (CI), должен использоваться
модификатор (LR) команды RTS (в
случае, если прерывание поступает в течение двух последних команд цикла). (См. команду
типа 11, возвращение из подпрограммы)
Примеры:
JUMP (M8,112), R6=R6-1; IF EQ CALL (PC,17),
ELSE R6=R6-1;
Код операции:
(для косвенного перехода)
47 46 45 44 43 42 41
40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23
000
|
01000
|
в
|
А
|
PMI
|
РММ
|
J
|
Е
|
CI
|
|
22 21 20 19 18 17 16 15 14 13 1211 10 9
8 7 6 5 4 3 2 10
COMPUTE
Код операции: (для перехода относительно PC)
47 46 45 44 43 42 41 40 39 38 37
36 35 34 33 32 31 30 29 28 27 26 25 24 23
000
|
01001
|
в
|
А
|
COND
|
RELADDR
|
J
|
Е
|
CI
|
|
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7 6 5 4 3 2 10
COMPUTE
COND определяет условие для проверки.
Если условие в команде не определено, то COND является
условием TRUE, и команда выполняется всегда. Е
определяет, используется или нет фраза ELSE. В выбирает
тип перехода - переход или вызов. J определяет задержан
переход или нет. Бит А активизирует прерывание цикла. CI
активизирует очистку прерывания. (Для вызовов CI и А
игнорируются) RELADDR - это 6-разрядное число в виде
двоичного дополнения, которое прибавляется к текущему значению PC для генерации адреса перехода. PMI
выбирает регистр I для косвенного перехода. Регистр I пред-модифицируется, но не обновляется значением регистра
М, который выбирается полем РММ. Поле COMPUTE
определяет вычислительную операцию, выполняемую параллельно с доступом к данным.
Если в команде не определено никакой операции вычисления, то это поле NOР.
Косвенный (или относительно PC) переход
и необязательная операция вычисления с передачей данных между памятью данных и
регистровым файлом
Функция:
Условный переход по адресу, определяемому пред
модифицированным значением регистра I, или по адресу
относительно PC и необязательная операция вычисления
параллельно с пересылкой данных между памятью данных и регистровым файлом. В
этой команде условие IF и ключевое слово ELSE должны обязательно использоваться. Если заданное условие
верно, то выполняется переход. Если заданное условие ложно, то операция
вычисления и передача из (в) памяти данных выполняются параллельно. В этой команде
необязательна только операция вычисления.
Для перехода адрес относительно PC -
это 6-разрядное число в виде двоичного дополнения. Если регистр I определен (1с), он модифицируется значением определенного
регистра М (Md) для генерации адреса перехода. Операция
модификации не влияет на содержимое регистра I. Заметим,
что модификаторы команды задержанного перехода (DB),
прерывания цикла (LA) и очистки прерывания не разрешены
в этой команде.
Для доступа к памяти данных адрес обеспечивается регистром I (la). Значение регистра I поет-модифицируется значением определенного регистра М и
обновляется модифицированным значением. Адресация с пред-модификацией для
такого доступа к памяти данных запрещена.
Примеры: IF TF JUMP (M8,18), ELSE R6=DM (16,Ml);
IF NE JUMP (PC,0X20), ELSE F12=FLOAT RIO BY
R3, R6=DM (115,MO);
Код операции: (для косвенного перехода)
47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27
26 25 24 23
110
|
D
|
DMI
|
DMM
|
COND
|
PMI
|
РММ
|
DREG
|
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7 6 5 4 3 2 10
Код операции: (с переходом относительно PC)
47 46 45 44 43 42
41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23
111
|
D
|
DMI
|
DMM
|
COND
|
RELADDR
|
DREG
|
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7 6 5 4 3
2 10
COMPUTE
COND определяет условие для проверки.
PMI определяет регистр I для
команды косвенного перехода. Регистр I
пред-модифицируется, но не обновляется значением регистра М, который выбирается
полем РММ. RELADDR - это 6-разрядное число в виде
двоичного дополнения, которое прибавляется к текущему значению PC для генерации адреса перехода. D
выбирает тип доступа к памяти данных (чтение и запись). DREG
определяет регистр регистрового файла. DMI определяет
регистр I, который поет-модифицируется и обновляется
значением регистра М, определямого полем DMM. Поле COMPUTE определяет вычислительную операцию, выполняемую
параллельно с доступом к данным. Если в команде не определено никакой операции
вычисления, то это поле NOR
Возврат из подпрограммы или прерывания, необязательное
условие, необязательная операция вычисления
Функция:
Возврат из подпрограммы (RTS) или
возврат из программы обработки прерывания (RTI). Модификатор
команды DB указывает, что переход задержанный; иначе - он
незадержанный.
Команда возврата из подпрограммы заставляет процессор
выполнить переход по адресу, сохраненному в вершине стека счетчика команд. Различие
между RTS и RTI заключается в
том, что команда RTI не только извлекает адрес возврата
из стека счетчика команд, но также:
1) извлекает содержимое стека состояния, если туда было
помещено содержимое регистров состояния ASTAT и MODE1 (если было прерывание IRQ,_0,
прерывание по таймеру или векторное прерывание VIRPT);
2) обнуляет соответствующий бит в регистрах фиксирования
прерывания (IRPTL) и указателя маски прерывания (IMASKP).
Возврат выполняется, если условие определено и верно. Если
операция вычисления определена без ELSE, она
выполняется параллельно с возвратом. Если операция вычисления определена с ELSE, она выполняется только в том случае, если условие ложно.
Заметьте, что условие должно быть определено, если определена фраза ELSE вычисление.
Если незадержанный вызов используется как одна из трех
последних команд в цикле, то с командой RTS должен
применяться модификатор повторного входа в цикл (LR). Команда
RTS (LR) гарантирует правильный
повторный вход в цикл. Например, в цикле, организованном по счетчику, условия
завершения цикла проверяется посредством уменьшения значения счетчика текущего
цикла (CURLCNTR) в течение выполнения двух последних
команд цикла. Команда RTS (LR) гарантирует
правильный повторный вход в цикл, предотвращая декремент счетчика циклов (дважды
для одной и той же итерации цикла).
При возвращении из подпрограммы, в которую была сведена
программа обработки прерывания командой JUMP (CI), должен использоваться модификатор (LR)
команды RTS (в случае, если прерывание поступает в
течение двух последних команд цикла).
Примеры: RTI, R6=R5 XOR R1; IF NOT GT RTS (DB); IF SZ RTS, ELSE R0=LSHIFT Rl
BY R15.
Код операции: (возврат из подпрограммы)
47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27
26 25 24 23
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7 6 5 4 3 2 10
Код операции: (возврат из программы обработки
прерывания)
47 46 45 44 43 42 41 40 39 38 37 36
35 34 33 32 31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 1211 10 9 8 7 6 5 4 3 2 10
COMPUTE
COND определяет условие для проверки.
Если в команде никакого условия не определено, то COND
является условием TRUE, и возврат выполняется всегда. J определяет, задержан возврат или нет. Е определяет, используется
или нет фраза ELSE. Поле COMPUTE
определяет выполняемую вычислительную операцию. Если в команде не определено
никакой операции вычисления, то это поле NO P. LR
определяет, назначен или нет модификатор повторного входа в цикл.
Загрузка счетчика цикла, команда DO UNTIL LCE
Функция:
Инициализирует организованный по счетчику программный цикл. Счетчик
цикла LCNTR загружается 16-разрядным непосредственным
значением данных или значением из универсального регистра. Начальный адрес
цикла помещается в стек PC. Адрес окончания цикла и
условие окончания LCE помещаются в стек адреса цикла. Конечный
адрес может быть меткой для абсолютного 24-разрядного адреса памяти программы
или 24-разрядным адресом относительно PC в виде
двоичного дополнения. LCNTR помещается в стек счетчика
цикла и становится значением CURLCNTR. Цикл выполняется
до тех пор, пока содержимое CURLCNTR не достигнет нуля.
Примеры:
LCNTR=100, DO fmax UNTIL LCE; (fmax - программная метка) LCNTR=R12, DO (PC,16)
UNTIL LCE;
Код операции: (для загрузки счетчика цикла
непосредственным значением данных)
47 46 45 44 43 42 41 40 39 38 37
36 35 34 33 32 31 30 29 28 27 26 25 24
23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2
1 0
RELADDR
Код операции: (для загрузки счетчика цикла из
универсального регистра)
47 46 45 44 43 42 41 40 39 38 37 36
35 34 33 32 31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
0
RELADDR
RELADDR определяет адрес конца цикла
по отношению к адресу команды DO LOOP. (Абсолютный адрес тоже допускается; он преобразуется в
эквивалентный относительный адрес ассемблером при кодировке) Счетчик цикла (LCNTR) загружается 16-разрядным значением DATA
или содержимым регистра, определенным полем UREG.
<addr24> (PC,<reladdr24>) UNTIL условие
окончания;
Функция:
Инициализирует организованный по счетчику программный цикл. Начальный
адрес цикла помещается в стек PC. Адрес окончания цикла
и условие окончания помещаются в стек цикла. Конечный адрес может быть меткой
для абсолютного 24-разрядного адреса памяти программы или 24-разрядным адресом
относительно PC в виде двоичного дополнения. Цикл
повторяется до тех пор, пока не выполняется заданное условие окончания цикла.
Примеры:
DO end UNTIL FLAG IN; (end - программная
метка) DO (PC, 7) UNTIL AC;
Код операции: (относительная адресация)
47 46 45 44 43 42 41 40 39 38 37
36 35 34 33 32 31 30 29 28 27 26 25 24
23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2
1 0
RELADDR
RELADDR определяет адрес конца цикла
по отношению к адресу команды DO LOOP. (Абсолютный адрес тоже допускается; он преобразуется в
эквивалентный относительный адрес ассемблером при кодировке) TERM
определяет условие окончания цикла.
Пересылка данных между памятью данных или памятью программы
и универсальным регистром, прямая адресация, непосредственное значение адреса
Функция:
Обращения между памятью данных или памятью программы и
универсальным регистром при прямой адресации. Полный адрес памяти данных или
памяти программы определяется в программе. Адреса памяти данных 32-разрядные (от
О до 232-1). Адреса памяти программы 24-разрядные (от 0 до 224-1).
Примеры:
DM (temp) =MODE1; (temp - программная метка) DMWAIT=PM (0x489060);
Код операции:
47 46 45 44 43 42 41 40 39 38 37 36
35 34 33 32
31 30 29 28 27 26 25 24 23 22 21 20
19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
D выбирает тип обращения (запись или
чтение). G выбирает тип памяти (память данных или
память программы). UREG определяет номер универсального
регистра. ADDR содержит непосредственное значение
адреса.
Пересылка данных между памятью данных или памятью программы
и универсальным
Функция:
Обращения между памятью данных или памятью программы и
универсальным регистром при косвенной адресации с использованием регистров I. Регистр I пред-модифицируется
непосредственным значением, заданным в команде. Содержимое регистра I не обновляется. Модификаторы адреса памяти данных
32-разрядные (от 0 до 232-1). Модификаторы адреса памяти программы
24-разрядные (от 0 до 224-1). Замечания:
Универсальный регистр (ureg) может
находиться не в том же самом DAG (т.е.
DAG1 или DAG2),
что и la/Mb или Ic/Md.
См. раздел 4.4.1 "Ограничения на передачу данных с использованием
регистров DAG" в главе 4 Передача данных.
Примеры:
DM (24,15) =TCOUNT; USTATl=PM (offs, 113);
("offs" - определенная
константа)
Код операции:
47 46 45 44 43 42 41 40 39 38 37
36 35 34 33 32
31 30 29 28 27 26 25 24 23
22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
D выбирает
тип доступа (запись или чтение). G выбирает тип памяти
(данные или программа). UREG определяет номер
универсального регистра. Поле I определяет индексный
регистр I. Поле DATA определяет
значение модификации для регистра I.
Прямая запись данных в память данных или память программы
Синтаксис:
DM (Ia,Mb) =<data32>; PM (Ic,Md)
Функция:
Запись 32-разрядных данных в память данных или память
программы при косвенной адресации. Данные размещаются в старших 32 разрядах
40-разрядного слова памяти. Младшие 8 разрядов обнуляются. Регистр I поет-модифицируется и обновляется определенным значением
регистра М. Замечания:
Универсальный регистр (ureg) может
находиться не в том же самом DAG (т.е. DAG1 или DAG2), что и la/Mb или Ic/Md.
Примеры:
DM (I4,M0) =19304;
РМ (114,Mil) =count;
(count-константа, определяемая пользователем)
Код операции:
47 46 45 44 43 42 41 40 39 38 37 36
35 34 33 32
31 30 29 28 27 26 25 24 23 22 21
20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
I выбирает индексный регистр I, М выбирает регистр модификации М. G
выбирает тип памяти (память данных или память программы). DATA
определяет 32-разрядные данные.
Запись данных в универсальный регистр
Синтаксис:
ureg = <data32>;
Функция:
Запись 32-разрядных данных в универсальный регистр. Если
регистр 40-разрядный, данные размещаются в старших 32 разрядах, а в 8 младших
записываются нули.
Примеры:
IMASK=0xFFFC0060;
M15=modl; (modi - константа, определяемая пользователем)
Код операции:
47 46 45 44 43 42 41 40 39 38 37 36
35 34 33 32
31 30 29 28 27 26 25 24 23 22 21 20
19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
DATA
UREG определяет номер универсального
регистра. Поле DATA определяет значение данных.
Набор команд процессоров семейства ADSP-21000 обеспечивает
широкие возможности для их программирования. Многофункциональные команды
позволяют выполнять вычисления параллельно с передачей данных, а также
одновременные операции умножителя и ALU. Практически каждая команда может быть
выполнена за один процессорный цикл. Алгебраический синтаксис, используемый
ассемблером семейства ADSP-2106x, упрощает кодирование и читаемость. Удобный
набор средств разработки облегчает программирование.
1. Остапенко А.Г., Лавлинский С.И., Сушков
А.В. и др. Цифровые процессоры обработки сигналов. Справочник. М.: Радио
и связь, 1994.264 с.