реклама на сайте
подробности

 
 
> STR912: Чтение данные из EMI с использованием DMA., Процессор вылетает по адресу 0x00000022
SimpleSoft
сообщение Jan 7 2008, 09:46
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 273
Регистрация: 3-11-05
Пользователь №: 10 442



День добрый.
Нужно читать из порта 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 - Jan 7 2008, 09:50
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 5)
SimpleSoft
сообщение Jan 7 2008, 11:20
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 273
Регистрация: 3-11-05
Пользователь №: 10 442



Провёл эксперимент.
Написал чтение в "лоб".

Код
  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... Хотя если читать всё время из одного и тогоже адреса - всё работает нормально.
Go to the top of the page
 
+Quote Post
Vladimir_T
сообщение Jan 9 2008, 06:52
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



Временные диаграммы чтения/записи проверьте. Сбоит. Может тайм-аут увеличить?
А что в CPSR?
Go to the top of the page
 
+Quote Post
Aprox
сообщение Jan 9 2008, 12:06
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 374
Регистрация: 7-11-07
Из: Moscow
Пользователь №: 32 131



Кристалл STR912F или STR912FA? Говорят в FA пофиксено много глюков, в том числе и по DMA.
Go to the top of the page
 
+Quote Post
SimpleSoft
сообщение Jan 9 2008, 15:32
Сообщение #5


Местный
***

Группа: Участник
Сообщений: 273
Регистрация: 3-11-05
Пользователь №: 10 442



Цитата(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 - Jan 9 2008, 15:33
Go to the top of the page
 
+Quote Post
SimpleSoft
сообщение Jan 9 2008, 17:46
Сообщение #6


Местный
***

Группа: Участник
Сообщений: 273
Регистрация: 3-11-05
Пользователь №: 10 442



Заметил одну особенность. Если программу запуситить из SRAM на произвол судьбы (в CW 1.7 - нажать на Stop Debugging Shift+F5) то программа работает без проблем. wacko.gif
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd June 2025 - 20:19
Рейтинг@Mail.ru


Страница сгенерированна за 0.01412 секунд с 7
ELECTRONIX ©2004-2016