Разработка устройств на основе цифровых сигнальных процессоров фирмы Analog Devices с использованием Visual DSP++
Шрифт:
Для восьмеричных чисел применяется префикс 0 (ноль):
Двоичные числа записываются с префиксом B#:
Десятичные числа записываются в программе без префиксов. Т.е. по умолчанию формат числа считается десятичным:
Пример записи арифметического выражения:
Пример
Директива VAR объявляет переменные и буферы переменных. Буфер переменных представляет собой набор ячеек памяти, расположенных упорядоченно друг за другом по смежным (соседним) адресам. Буфер может быть многомерным и одномерным, т.е. состоящим из нескольких или из одной переменной. Буфер должен быть объявлен до использования в программе. Буферы удобны для организации приема и передачи блочных данных и часто используются в программах.
Директива VAR имеет следующую форму записи:
С директивой могут использоваться следующие параметры:
PM или DM — тип памяти для размещения буфера;
RAM или ROM — тип памяти процессора;
ABS=адрес — абсолютный адрес (нельзя использовать вместе с директивой STATIC);
SEG=сегмент — размещение буфера в сегменте, объявленном системным конфигуратором;
CIRC — кольцевой буфер;
STATIC — предотвращает перезапись буфера во время загрузки начальной страницы.
Одна директива VAR позволяет объявить в одной строке длиной до 200 символов несколько буферов, разделенных запятыми.
Буферы могут быть линейными и кольцевыми. Буферы могут быть произвольной длины от единицы до размера, не превышающего объем памяти процессора. Линейный буфер размещается в памяти с любого адреса. Кольцевой буфер может быть размещен в памяти с некоторыми ограничениями, связанными с аппаратными особенностями памяти процессоров. Так, кольцевой буфер должен стартовать с базового адреса, который кратен 2 в степени n, где n — количество бит требуемых для представления длины буфера в двоичном виде. Это необходимо учитывать при создании кольцевых буферов с параметром ABS.
При многочисленном объявлении линейных буферов в одной строке редактор связей размещает их в смежных областях памяти. Если при таком объявлении используется параметр CIRC, то создается единственный кольцевой буфер, а остальные объявленные в этой строке буферы будут линейными.
Буферы могут быть размещены как в памяти программ PM, так и в памяти данных DM, по умолчанию. Тип памяти по умолчанию устанавливается в RAM для памяти DM и PM.
Параметр ABS размещает буфер с указанного стартового адреса, делая его неперемещаемым.
Параметр SEG размещает буфер в указанном сегменте памяти, который был объявлен в файле системного конфигуратора.
Параметр CIRC определяет кольцевой буфер. Буфер будет организован как линейный, если не применен атрибут CIRC.
Параметр STATIC предотвращает перезапись буфера, когда загружается страница начальной загрузки.
Пример объявления буфера:
Здесь линейный буфер объявлен в памяти программ RAM, который перемещаем в
Для объявления одномерных буферов, т.е. простых переменных, применяется директива VAR без указания длины буфера. Например:
Данная директива объявляет однословную переменную с именем xdata в памяти данных RAM по шестнадцатеричному адресу 0x000C.
Ниже приведен пример объявления автоматически перемещаемого кольцевого буфера с именем buffer_c, длина которого определяется величиной константы size, объявленной директивой CONST.
Ниже приведены примеры, позволяющие понять, как можно размещать циклические буферы в памяти. Следующий оператор объявляет кольцевой буфер с именем abuf из шести ячеек памяти:
Поскольку ближайшим числом больше шести и кратным двум является число 8, то базовый (стартовый) адрес буфера должен быть кратен 8. Три младших значимых разряда (МЗР) этого адреса будут равны нулю. В табл. 11.1 показано размещение этого буфера в памяти.
Таблица 11.1 Размещение одного циклического буфера в памяти сигнального процессора
Имя буфера | Элемент буфера | Двоичный адрес |
---|---|---|
… | ||
abuf | abuf[0] | XXXXXXXXXX0000 |
abuf[1] | XXXXXXXXXX0001 | |
abuf[2] | XXXXXXXXXX0010 | |
abuf[3] | XXXXXXXXXX0011 | |
abuf[4] | XXXXXXXXXX0100 | |
abuf[5] | XXXXXXXXXX0101 | |
XXXXXXXXXX0110 | ||
… |
Если в одной строке объявлены несколько буферов с параметром CIRC, то будет создан один кольцевой буфер, вмещающий в себя все буферы. Первый из этих буферов будет кольцевым, а отдельные буферы будут простыми линейными буферами. Например, следующая директива создает один кольцевой буфер abuf и два линейных буфера с именами bbuf и cbuf.
Для размещения всех этих буферов в памяти процессора потребуется 6+3+5=14 ячеек памяти. Поскольку первым в директиве объявлен буфер abuf, то он будет кольцевым. Ближайшим числом больше 14 и кратным двум является число 16. Поэтому базовый адрес буфера abuf должен быть кратен 16 (четыре младших значащих разряда будут равны нулю). Базовый адрес буфера bbuf будет следовать сразу за адресом последнего элемента буфера abuf. Аналогично будет размещен и буфер cbuf. Размещение всех этих буферов в памяти процессора показано в табл. 11.2.