Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: DMА неработают нестабильно
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > MSP430
sifadin
Здравствуйте!
У меня есть два SPI A0 и В1 , которые работают в режиме slave
есть массив BYTE str[2048]

C помощью DMA1 и 0 я пытаюсь загонять в массив по 128 байт в режиме одиночной передачи
из SPIA0 в &str[0]

из SPIB1 в &str[1024]

Вот инициализация
void dma_ini(void)
{
DMACTL0 =DMA0TSEL_16+DMA1TSEL_16; - запуск по флагу приема
DMA0CTL = DMADSTINCR_3+DMASBDB+DMALEVEL;//+DMAIE; //инкрементация

__data16_write_addr((unsigned short) &DMA0SA,(unsigned long) &UCA0RXBUF);
__data16_write_addr((unsigned short) &DMA0DA,(unsigned long) &str[1024]);

DMA0SZ = 128; DMA1SZ = 128;
__data16_write_addr((unsigned short) &DMA1SA,(unsigned long) &UCB1RXBUF);
__data16_write_addr((unsigned short) &DMA1DA,(unsigned long) &str[0]);

DMA1CTL = DMADSTINCR_3+DMASBDB+DMALEVEL;//+DMAIE;

}

В тексте main()
{
..............
DMA0CTL |= DMAEN;
DMA1CTL |= DMAEN;

while(wrifl);
}

Останавливаясь на while я вижу что
-либо ничего не прочитано
-либо один канал прочитан правильно, второй с ошибками

Если оставить один канал то все нормально прочитывается


В чем тут может быть дело? Кто-нибудь сталкивался?
rezident
А вы уверены, что это глюки работы DMA, а не отладчика? DMA и вообще периферия работает независимо от ядра МК и поэтому в окне отладчика могут отображаться совсем не то, что реально находится в памяти данных при работающем DMA.
Что такое while(wrifl); Что за флаг/переменная опрашивается? Не корректнее ли будет поставить точку останова в конце трансфера данных, а не бог знает где?
sifadin
Извините. Проблема была с SPI. Так что тема закрывается
Спасибо
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.