Разработка, производство и продажа радиоэлектронной аппаратуры
|
Требуется программист в Зеленограде - обработка данных с датчиков; ColdFire; 40 тыс.
e-mail: jobsmp@pochta.ru
|
STR912: Чтение данные из EMI с использованием DMA. Процессор вылетает по ад...{+}(+)
Отправлено
SimpleSoft 06 января 2008 г. 23:29
Текст заголовка сообщения полностью: STR912: Чтение данные из EMI с использованием DMA. Процессор вылетает по адресу 0x00000022
День добрый.
Нужно читать из порта EMI (к которому подключен АЦП снимающий данные с CCD линейки). CLK для АЦП и CCD идут от EMI_RDn. Матрица отдаёт 2078 байт данных.
MCLK = 96MHz
PCLK = RCLK = HCLK = EMICLK = MCLK/2
Работаем из SRAM. Прерывания не использую.
Среда CrossWorks 1.7
Кусок кода инициализации DMA и цикла съёма:
u8 ucCCD_Buffer[3000];
DMA_InitTypeDef DMA_InitStruct;
void CCD_InitDMATransfer(void)
{
// Инициализируем структуру DMA
DMA_StructInit(&DMA_InitStruct);
// Настраиваем DMA
DMA_InitStruct.DMA_Channel_LLstItm=(u32)(0);
DMA_InitStruct.DMA_Channel_SrcAdd=(u32)(0x2C000000);
DMA_InitStruct.DMA_Channel_DesAdd=(u32)(&ucCCD_Buffer[0]);
DMA_InitStruct.DMA_Channel_SrcWidth= DMA_SrcWidth_Byte;
DMA_InitStruct.DMA_Channel_DesWidth= DMA_DesWidth_Byte; //DMA_DesWidth_Byte
DMA_InitStruct.DMA_Channel_FlowCntrl=DMA_FlowCntrlt0_DMA;
DMA_InitStruct.DMA_Channel_DesBstSize=DMA_DesBst_256Data;//DMA_DesBst_4Data
DMA_InitStruct.DMA_Channel_SrcBstSize=DMA_SrcBst_256Data;//DMA_SrcBst_4Data
DMA_InitStruct.DMA_Channel_TrsfSize =2078;
DMA_ChannelSRCIncConfig (DMA_Channel1, ENABLE);
DMA_ChannelDESIncConfig (DMA_Channel1, ENABLE);
DMA_Init(DMA_Channel1,&DMA_InitStruct);
// Включаем нужный канал
DMA_ChannelCmd (DMA_Channel1,ENABLE);
}
void CCD_StartDMATransfer(void)
{
while(DMA_GetChannelActiveStatus(DMA_Channel1));
DMA_ChannelCmd(DMA_Channel1,DISABLE);
CCD_InitDMATransfer();
}
...
в main:
...
CCD_InitDMATransfer();
while(1)
{
CCD_StartDMATransfer();
}
Проблема: Процессор в течении 15 секунд после запуска программы вылетает по адресу 0x00000022. Перелистал STR91x Reference Manual. Особенно секцию DMAC: Enabling & Disabling DMA Channel. Толку 0.
Чихните в нужную сторону: В чём проблема?
Составить ответ | Вернуться на конференцию
Ответы