Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: SAM3U DMAC
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
dimka76
Прочитал манул, пытался по нему сбросить DMA ничего не получается. (раздел 40.3.6 Disabling a Channel Prior to Transfer Completion)
Подсажите как корректно сбросить DMA ?

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

SPI slave. В режиме DMA принимает данные (определенное количество). Если мастер по каким-либо причинам не передаст требуемое колдичество байт, то сработает timeout. Но для следующей транзакции необходимо сбросить DMA в исходное состояние.
Пробовал бит RES в регистре Channel Handler Disable Register. Но при следующей транзакции данные получаются какими-то смещенными, как будто адрес приемника DMA не начале буфера.
Собственно и вопрос, как?
DmitryM
Цитата(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 смещение на одно значение.
dimka76
Цитата(DmitryM @ Jul 12 2011, 19:41) *
Я бы еще прочитал SPI_RDR. На SAM7S частенько при аварийном завершении в RDR оставались данные и при следующей передаче с PDC смещение на одно значение.


Спасибо, надо проверить.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.