Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: STM32F - прерывание от DMA раньше, чем ожидалось.
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
KnightIgor
Добрый день мужики, а также немногочисленные дамы!

Имеем STM32F103RB.
Передаю периодически блок данных из памяти через USART (250kbps, 8 бит, 2 стоповых) посредством DMA в нормальном (не циклическом) режиме. Чтобы определить завершение передачи предыдущего пакета и начать следующий организовал прерывание по флагу DMA "Transfer Complete". Что я далее в прерывании делаю, пока не суть важно. Интересно то, что прерывание возникает не в момент, когда DMA засунул в USART последний байт, а раньше - когда предпоследний! Это я определил осциллографом, дергая в указаном прерывании отладочными ногами и наблюдая за передачей от USART: фронт возникает незадолго до того, как из USART начинает уходить предпоследний байт.

Конечно, раздел "Single byte communication", стр. 766 мануала RM0008, я читал. Там очевидно объяснено, что если USART было пустой, первые две следующие друг за другом быстрые записи в регистр данных USART возможны, т.к. флаг TXE возникает тут же и после первой записи. Однако в моем случае DMA передает довольно шибко пол-кило байтов, и к моменту прерывания USART еще возится в поте лица с предыдущими.

Это баг? Или я что проглядел?

Спасибо.
ViKo
Я думаю, как только DMA записал последний байт в TDR USART, он и докладывает, что все сделал. При этом данные еще будут выдвигаться из TSR, сначала предыдущий байт, бит за битом, затем последний перепишется в TSR и тоже будет выдвигаться.
см. Figure 278
KnightIgor
Цитата(ViKo @ Feb 22 2011, 14:00) *
Я думаю, как только DMA записал последний байт в TDR USART, он и докладывает, что все сделал. При этом данные еще будут выдвигаться из TSR, сначала предыдущий байт, бит за битом, затем последний перепишется в TSR и тоже будет выдвигаться.
см. Figure 278


Спасибо! На схеме №295, стр. 787, RM0008 Doc ID 13902 Rev 12 так и нарисовано!

ViKo
Цитата(KnightIgor @ Feb 22 2011, 15:34) *
Спасибо! На схеме №295, стр. 787, RM0008 Doc ID 13902 Rev 12 так и нарисовано!

у меня Rev 11, не совпадают страницы и картинки, чем искать по компу, пойду с сайта скачаю sm.gif
Посмотрел. Да, правильно. Там еще сказано, что нужно флаг TC USART мониторить программно, чтобы удостовериться, что передача завершена.
KnightIgor
Цитата(ViKo @ Feb 22 2011, 14:53) *
Там еще сказано, что нужно флаг TC USART мониторить программно, чтобы удостовериться, что передача завершена.


Верно, что и делаю перед тем как снова толкнуть передачу. Чтобы не крутиться в прерывании от DMA TC в ожидании USART TC в нем лишь разрешается прерывание по этому флагу, где, как щелкнет, уже и выполняются дальшейшие действия.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.