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

 
 
 
Reply to this topicStart new topic
> SAM3U DMAC, как сбросить
dimka76
сообщение Jul 12 2011, 11:56
Сообщение #1


developer
****

Группа: Свой
Сообщений: 902
Регистрация: 12-04-06
Из: Казань
Пользователь №: 16 032



Прочитал манул, пытался по нему сбросить DMA ничего не получается. (раздел 40.3.6 Disabling a Channel Prior to Transfer Completion)
Подсажите как корректно сбросить DMA ?

Объясню зачем.

SPI slave. В режиме DMA принимает данные (определенное количество). Если мастер по каким-либо причинам не передаст требуемое колдичество байт, то сработает timeout. Но для следующей транзакции необходимо сбросить DMA в исходное состояние.
Пробовал бит RES в регистре Channel Handler Disable Register. Но при следующей транзакции данные получаются какими-то смещенными, как будто адрес приемника DMA не начале буфера.
Собственно и вопрос, как?


--------------------
Все может быть и быть все может, и лишь того не может быть-чего уж точно быть не может, хотя..и это может быть.
Go to the top of the page
 
+Quote Post
DmitryM
сообщение Jul 12 2011, 15:41
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 583
Регистрация: 7-06-06
Из: Таганрог
Пользователь №: 17 840



Цитата(dimka76 @ Jul 12 2011, 15:56) *
Прочитал манул, пытался по нему сбросить DMA ничего не получается. (раздел 40.3.6 Disabling a Channel Prior to Transfer Completion)
Подсажите как корректно сбросить DMA ?

Объясню зачем.

SPI slave. В режиме DMA принимает данные (определенное количество). Если мастер по каким-либо причинам не передаст требуемое колдичество байт, то сработает timeout. Но для следующей транзакции необходимо сбросить DMA в исходное состояние.
Пробовал бит RES в регистре Channel Handler Disable Register. Но при следующей транзакции данные получаются какими-то смещенными, как будто адрес приемника DMA не начале буфера.
Собственно и вопрос, как?


Я бы еще прочитал SPI_RDR. На SAM7S частенько при аварийном завершении в RDR оставались данные и при следующей передаче с PDC смещение на одно значение.
Go to the top of the page
 
+Quote Post
dimka76
сообщение Jul 13 2011, 04:32
Сообщение #3


developer
****

Группа: Свой
Сообщений: 902
Регистрация: 12-04-06
Из: Казань
Пользователь №: 16 032



Цитата(DmitryM @ Jul 12 2011, 19:41) *
Я бы еще прочитал SPI_RDR. На SAM7S частенько при аварийном завершении в RDR оставались данные и при следующей передаче с PDC смещение на одно значение.


Спасибо, надо проверить.


--------------------
Все может быть и быть все может, и лишь того не может быть-чего уж точно быть не может, хотя..и это может быть.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 19th July 2025 - 16:49
Рейтинг@Mail.ru


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