|
STM32F - прерывание от DMA раньше, чем ожидалось., Прерывание по завершении DMA передачи. |
|
|
|
Feb 22 2011, 12:53
|
Знающий
   
Группа: Участник
Сообщений: 643
Регистрация: 29-05-09
Из: Германия
Пользователь №: 49 725

|
Добрый день мужики, а также немногочисленные дамы!
Имеем STM32F103RB. Передаю периодически блок данных из памяти через USART (250kbps, 8 бит, 2 стоповых) посредством DMA в нормальном (не циклическом) режиме. Чтобы определить завершение передачи предыдущего пакета и начать следующий организовал прерывание по флагу DMA "Transfer Complete". Что я далее в прерывании делаю, пока не суть важно. Интересно то, что прерывание возникает не в момент, когда DMA засунул в USART последний байт, а раньше - когда предпоследний! Это я определил осциллографом, дергая в указаном прерывании отладочными ногами и наблюдая за передачей от USART: фронт возникает незадолго до того, как из USART начинает уходить предпоследний байт.
Конечно, раздел "Single byte communication", стр. 766 мануала RM0008, я читал. Там очевидно объяснено, что если USART было пустой, первые две следующие друг за другом быстрые записи в регистр данных USART возможны, т.к. флаг TXE возникает тут же и после первой записи. Однако в моем случае DMA передает довольно шибко пол-кило байтов, и к моменту прерывания USART еще возится в поте лица с предыдущими.
Это баг? Или я что проглядел?
Спасибо.
Сообщение отредактировал KnightIgor - Feb 22 2011, 12:54
|
|
|
|
|
 |
Ответов
(1 - 4)
|
Feb 22 2011, 13:34
|
Знающий
   
Группа: Участник
Сообщений: 643
Регистрация: 29-05-09
Из: Германия
Пользователь №: 49 725

|
Цитата(ViKo @ Feb 22 2011, 14:00)  Я думаю, как только DMA записал последний байт в TDR USART, он и докладывает, что все сделал. При этом данные еще будут выдвигаться из TSR, сначала предыдущий байт, бит за битом, затем последний перепишется в TSR и тоже будет выдвигаться. см. Figure 278 Спасибо! На схеме №295, стр. 787, RM0008 Doc ID 13902 Rev 12 так и нарисовано!
|
|
|
|
|
Feb 22 2011, 13:53
|

Универсальный солдатик
     
Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362

|
Цитата(KnightIgor @ Feb 22 2011, 15:34)  Спасибо! На схеме №295, стр. 787, RM0008 Doc ID 13902 Rev 12 так и нарисовано! у меня Rev 11, не совпадают страницы и картинки, чем искать по компу, пойду с сайта скачаю  Посмотрел. Да, правильно. Там еще сказано, что нужно флаг TC USART мониторить программно, чтобы удостовериться, что передача завершена.
|
|
|
|
|
Feb 22 2011, 19:51
|
Знающий
   
Группа: Участник
Сообщений: 643
Регистрация: 29-05-09
Из: Германия
Пользователь №: 49 725

|
Цитата(ViKo @ Feb 22 2011, 14:53)  Там еще сказано, что нужно флаг TC USART мониторить программно, чтобы удостовериться, что передача завершена. Верно, что и делаю перед тем как снова толкнуть передачу. Чтобы не крутиться в прерывании от DMA TC в ожидании USART TC в нем лишь разрешается прерывание по этому флагу, где, как щелкнет, уже и выполняются дальшейшие действия.
Сообщение отредактировал KnightIgor - Feb 22 2011, 19:52
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|