Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: STR912: Чтение данные из EMI с использованием DMA.
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
SimpleSoft
День добрый.
Нужно читать из порта 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.

Чихните в нужную сторону: В чём может быть проблема?
SimpleSoft
Провёл эксперимент.
Написал чтение в "лоб".

Код
  asm("mov r10, #0");
  asm("ldr r9,  =0x2C000000");
  asm("ldr r6, =0x7FF");
  asm("mov r5, #0");
  asm("mov r8, #0");


  // Основной цикл (ядро)
  while(1)
  {
    asm("and  r8, r6, r10");
    asm("ldrb r7, [r9, r8]");
    asm("add  r10, r10, #1");

  }


Результат тотже что и при DMA чтении. Валимся в 0x00000022... Хотя если читать всё время из одного и тогоже адреса - всё работает нормально.
Vladimir_T
Временные диаграммы чтения/записи проверьте. Сбоит. Может тайм-аут увеличить?
А что в CPSR?
Aprox
Кристалл STR912F или STR912FA? Говорят в FA пофиксено много глюков, в том числе и по DMA.
SimpleSoft
Цитата(Aprox @ Jan 9 2008, 14:06) *
Кристалл STR912F или STR912FA? Говорят в FA пофиксено много глюков, в том числе и по DMA.


Спасибо, кто откликнулся.

CPSR:0x200000fb

От таймингов не зависит. Пробовал менять до максимальных.

Временные диаграммы вроде в порядке.
А что не так с ними может быть? На что конкретно мне стоит обратить внимание?

ОФФ: Вчера залез в отчаянии на ST.COM... Лежит там аппнот "Using the STR91xFA external memory interface (EMI)"... Скачал, буду повторять 1 к 1.

Плата Olimex STR-E912 (Процессор STR912F, Rev.D)
SimpleSoft
Заметил одну особенность. Если программу запуситить из SRAM на произвол судьбы (в CW 1.7 - нажать на Stop Debugging Shift+F5) то программа работает без проблем. wacko.gif
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.