Разработка устройств на основе цифровых сигнальных процессоров фирмы Analog Devices с использованием Visual DSP++
Шрифт:
Таблица 11.2 Размещение трех буферов в памяти процессора
Имя буфера | Элемент буфера | Двоичный адрес |
---|---|---|
… | ||
abuf | abuf[0] | XXXXXXXXXX0000 |
abuf[1] | XXXXXXXXXX0001 | |
abuf[2] | XXXXXXXXXX0010 | |
abuf[3] | XXXXXXXXXX0011 | |
abuf[4] | XXXXXXXXXX0100 | |
abuf[5] | XXXXXXXXXX0101 | |
bbuf | bbuf[0] | XXXXXXXXXX0110 |
bbuf[1] | XXXXXXXXXX0111 | |
bbuf[2] | XXXXXXXXXX1000 | |
cbuf | cbuf[0] | XXXXXXXXXX1001 |
cbuf[1] | XXXXXXXXXX1010 | |
cbuf[2] | XXXXXXXXXX1011 | |
cbuf[3] | XXXXXXXXXX1100 | |
XXXXXXXXXX1101 | ||
… |
Следующий
Поскольку буферы объявлены отдельно, все они будут кольцевыми и не будут объединены. Правила размещения для каждого из этих буферов такие же, как в рассмотренном выше примере для одиночного буфера abuf. Размещение этих буферов в памяти процессора показано в табл. 11.3.
Таблица 11.3 Размещение трех кольцевых буферов в памяти процессора
Имя буфера | Элемент буфера | Двоичный адрес |
---|---|---|
… | ||
abuf | abuf[0] | XXXXXXXXX00000 |
abuf[1] | XXXXXXXXX00001 | |
abuf[2] | XXXXXXXXX00010 | |
abuf[3] | XXXXXXXXX00011 | |
abuf[4] | XXXXXXXXX00100 | |
abuf[5] | XXXXXXXXX00101 | |
… | ||
bbuf | bbuf[0] | XXXXXXXXX01000 |
bbuf[1] | XXXXXXXXX01001 | |
bbuf[2] | XXXXXXXXX01010 | |
… | ||
cbuf | cbuf[0] | XXXXXXXXX10000 |
cbuf[1] | XXXXXXXXX10001 | |
cbuf[2] | XXXXXXXXX10010 | |
cbuf[3] | XXXXXXXXX10011 | |
… |
Чтобы получить доступ к буферу abuf из программы, необходимо инициализировать индексные регистры DAG и регистры длины буфера следующими инструкциями:
Далее в программе можно читать данные из буфера с помощью инструкции AR=DM(I0, L0)
Данные директивы предназначены для размещения программ и данных в сегментах памяти. Директива PMSEG указывает редактору связей на необходимость разместить все программы и данные модуля в определенном сегменте памяти программ. Директива DMSEG указывает редактору связей на необходимость разместить все структуры данных модуля в определенном сегменте памяти данных. Сегменты должны быть предварительно определены в файле описания архитектуры системного конфигуратора. Директивы PMSEG и DMSEG подобно параметру SEG директив MODULE и VAR имеют следующий формат:
Обычно, чтобы расположить все программы и данные исходного модуля в определенном системным конфигуратором сегменте памяти, необходимо повторить параметр SEG в директиве MODULE и всех директивах VAR внутри модуля. Директивы PMSEG и DMSEG используются для исключения многократного повторения параметров SEG. Директивы PMSEG и DMSEG должны быть размещены в исходном файле программного модуля перед директивой MODULE. Ниже приводится пример, в котором модуль prog1, некоторые буферы и переменную var1 располагают в памяти данных в сегменте с именем seg1:
Директива INIT используется для инициализации переменных и буферов в ПЗУ. Редактор связей помещает данные инициализации в файл образа памяти, который затем используется разделителем программ (splitter) при подготовке данных для записи в ПЗУ. Разделитель трансформирует части этого файла в формат, совместимый с промышленным стандартом программатора ПЗУ.
Инициализирующие значения могут быть перечислены в директиве или указаны во внешнем файле. Директива INIT может иметь одну из следующих форм:
Операторы ^ и % используются для инициализации буфера или переменной базовым адресом, или длиной, или даже другими буферами. Любые комбинации констант, указателей адресов буфера и величин длины буфера могут быть заданы через запятую. Примеры:
Данный пример инициализирует переменную x шестнадцатеричной константой 0x3FFF.
Эта директива инициализирует буфер buf списком констант.
Здесь переменная ab инициализируется указателем стартового адреса буфера buf.
Допускается инициализировать только часть данных буфера, задавая смещение его базового адреса (индекса):
Так, инициализирующие величины будут размещены, начиная с элемента buf[2]. Здесь инициализируются второй, третий и четвертый элементы буфера buf величинами 3, 5 и 7 соответственно.
Третья форма директивы INIT указывает имя файла, который содержит инициализирующие величины. Ассемблер устанавливает указатель на этот файл, и данные присоединяются при запуске редактора связей. Следующий пример заставляет редактор связей инициализировать буфер sin содержимым файла sinus.dat: