Шрифт:
? IF MV SAT MR;
? MR = MR — AR * MY1(SS);
? MR = MR + MX1 * MY0(RND);
? IF LT MR = МХ0 * MX0(UU);
Рис. 7.10
Устройство сдвига производит операции логического и арифметического сдвига, нормализации и денормализации, а также вычисления блочной экспоненты. Устройство может быть использовано для эффективного управления численными форматами, включая представление чисел в формате с плавающей точкой с повышенной точностью.
ОСОБЕННОСТИ РЕГИСТРА СДВИГА
• Нормализация (преобразование из формата с фиксированной точкой в формат с плавающей точкой)
• Денормализация (преобразование из формата с плавающей точкой в формат с фиксированной точкой)
• Арифметические и логические сдвиги
• Поддержка блочной плавающей точки
• Получение экспоненты
• Вспомогательные регистры для быстрого переключения контекста
• Примеры команд регистра сдвига
? SR = ASHIFT SI BY — 6(LO); {Арифметический сдвиг}
? SR = SR OR LSHIFT SI BY 3(HI); {Логический сдвиг}
? SR = NORM MRl(LO); {Нормализация}
Рис. 7.11
Вычислительные блоки располагаются параллельно, а не последовательно, так что результат работы любого блока может использоваться как исходное данное для другого блока в следующем машинном цикле. Для обеспечения такой возможности используется шина промежуточных результатов (R).
АДРЕСНЫЕ ГЕНЕРАТОРЫ И УСТРОЙСТВО УПРАВЛЕНИЯ ПОСЛЕДОВАТЕЛЬНОСТЬЮ ВЫПОЛНЕНИЯ КОМАНД (СЕКВЕНСЕР)
Два специализированных адресных генератора и мощный секвенсер делают использование вычислительных блоков еще более эффективным. Адресные генераторы (DAG) вычисляют адреса при перемещении данных из памяти в регистры и обратно. Каждый генератор DAG обладает четырьмя регистрами-указателями. Всякий раз, когда указатель используется для адресации данных (косвенная адресация), он модифицируется значением, содержащимся в специализированном регистре-модификаторе. Для реализации автоматической циклической буферизации каждому регистру-указателю приписывается регистр, хранящий длину циклического буфера. При использовании двух независимых адресных генераторов DAG процессор может генерировать одновременно два адреса для обеспечения одновременной выборки двух операндов.
DAG1 может осуществлять адресацию только в памяти данных. DAG2 может осуществлять адресацию и в памяти данных, и в памяти программ. Когда в конфигурационном регистре (MSTAT) установлен соответствующий управляющий бит, адресный генератор DAG1 осуществляет бит-реверсивную адресацию. Бит-реверсивная адресация существенно упрощает реализацию алгоритма БПФ по основанию 2.
Программный секвенсер осуществляет вычисление адреса инструкции, выборка которой должна осуществляться по мере исполнения программы. Ключевым компонентом устройства является регистр команд, который хранит информацию о выполняемой в текущее время команде. Регистр команд образует одноуровневый конвейер в потоке обрабатываемых команд. Команды выбираются и загружаются в регистр команд в одном цикле шины процессора и выполняются в следующем цикле, в то время как осуществляется выборка следующей команды. Чтобы уменьшить количество дополнительных циклов, устройство поддерживает выполнение переходов по условию, вызовов подпрограмм и возвращений к выполнению главной программы за один машинный цикл. Используя внутренний счетчик цикла и стек цикла процессор может выполнять программу цикла с автоматической проверкой условия завершения, без дополнительных затрат процессорного времени на организацию цикла. Таким образом, чтобы организовать цикл, команды явного перехода не требуются. Устройство также способно с минимальной задержкой реагировать на прерывания, поступающие от контроллера прерываний. Появление прерывания вызывает переход к определенной ячейке памяти, где хранится подпрограмма обработки прерывания. Короткая подпрограмма обработки прерывания может располагаться непосредственно в таблице векторов прерываний, где для этих целей зарезервировано четыре ячейки памяти. Для выполнения более сложной подпрограммы обработки прерывания приходится осуществлять переход с помощью команды JUMP в область памяти программ, где может быть размещена более длинная программа.
ОСОБЕННОСТИ УСТРОЙСТВА УПРАВЛЕНИЯ ПОСЛЕДОВАТЕЛЬНОСТЬЮ ВЫПОЛНЕНИЯ КОМАНД (СЕКВЕНСЕРА)
• Генерация адреса следующей команды
• Обработка прерываний с минимальной задержкой
• Поддержка аппаратного стека
• Условный переход осуществляется за один машинный цикл
• Поддерживает автоматическую проверку условия завершения цикла
Пример программы для ADSP21xx:
CNTR = 10;
DO endloop UNTIL CE;
IO(DACCONTROL) = AX0;
MR = MR + MX0 * MY0(SS), MX(0) = DM(I0,M1), MY0 = PM(I4,M5);
endloop:
IF MV SET FL1;
IF EQ CALL mysubroutine;
Рис. 7.13
Встроенные периферийные устройства процессоров семейства ADSP-21XX
В предыдущих разделах мы обсуждали архитектуру ядра процессоров семейства ADSP-21хх с фиксированной точкой, которая является одинаковой для всех представителей семейства. Следующий раздел посвящен встроенным периферийным устройствам, которые имеют различную конфигурацию и разные возможности в зависимости от конкретного исполнения представителя семейства. Архитектура процессора семейства ADSP-218x показана на рис. 7.14.
ВСТРОЕННЫЕ СРЕДСТВА ПЕРИФЕРИИ ПРОЦЕССОРА ADSP-21xx: ИНТЕРФЕЙС ПАМЯТИ
• Все представители семейства используют модифицированную гарвардскую архитектуру
? Раздельные память программ и память данных
? Имеется доступ к данным, хранящимся в памяти программ
• Различные представители семейства имеют различную конфигурацию памяти
• Интерфейс внешней памяти поддерживает как быструю, так и медленную память с возможностью программирования времени ожидания