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

 
 
> SPI & DMA на UC3, либо twi
altlogic
сообщение Jun 9 2009, 09:58
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 222
Регистрация: 2-12-06
Из: г. Хабаровск
Пользователь №: 23 035



Здравствуйте!

Собственно делал ли кто-нибудь связку интерфейса SPI (TWI) с PDCA? Моя реализация работала, но через ... До поры до времени. Теперь нужно сделать всё правильноsmile.gif Проблема с чтением dummy- байтов по SPI.


--------------------
С уважением, Вячеслав
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
altlogic
сообщение Jun 13 2009, 09:06
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 222
Регистрация: 2-12-06
Из: г. Хабаровск
Пользователь №: 23 035



Цитата(aaarrr @ Jun 13 2009, 18:16) *
Туман надо разогнать:
- передача заканчивается не тогда, когда у PDC TX кончатся данные, а когда эти данные кончатся и в сдвиговом регистре SPI

Поставил проверку на наличие данных в сдвиговом регистре вслед за проверкой данных у PDC TX, и всё равно приём идёт некорректно...
Цитата(aaarrr @ Jun 13 2009, 18:16) *
- если RHR на момент начала передачи полон (например, использовалась только передача без приема), то его нужно предварительно очистить чтением

У SPI нет такого регистра. Аналогичный ему регистр Receive Data Register не очищается чтением.


--------------------
С уважением, Вячеслав
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Jun 13 2009, 09:11
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(altlogic @ Jun 13 2009, 13:06) *
Поставил проверку на наличие данных в сдвиговом регистре вслед за проверкой данных у PDC TX, и всё равно приём идёт некорректно...

Код приведите.

Цитата(altlogic @ Jun 13 2009, 13:06) *
У SPI нет такого регистра. Аналогичный ему регистр Receive Data Register не очищается чтением.

Что значит не очищается? RDRF в SR не сбрасывается? Не верю.
Go to the top of the page
 
+Quote Post
altlogic
сообщение Jun 14 2009, 23:21
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 222
Регистрация: 2-12-06
Из: г. Хабаровск
Пользователь №: 23 035



Решение я нашёл, это радует. НО нашёл его практически методом тыкаsmile.gif Хотелось бы разобраться в сути. Кода очищения буфера spi не осталось. После предварительного dma- чтения без передачи всё нормализовалось.


--------------------
С уважением, Вячеслав
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Jun 15 2009, 07:25
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(altlogic @ Jun 15 2009, 03:21) *
Кода очищения буфера spi не осталось. После предварительного dma- чтения без передачи всё нормализовалось.

Чем "предварительное DMA-чтение без передачи" отличается от "очищения буфера SPI"?
Никаких "хитростей", кроме уже упомянутых, в работе с SPI по DMA нет - так что осталось не понятным?
Go to the top of the page
 
+Quote Post
altlogic
сообщение Jun 15 2009, 09:20
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 222
Регистрация: 2-12-06
Из: г. Хабаровск
Пользователь №: 23 035



Вот отрывок кода предварительного чтения dma-канала:
Код
pdca_channel->mar = (unsigned long)addr;          //загрузка указателя данных
pdca_channel->tcr = size;                                  // длина передачи
pdca_channel->cr = AVR32_PDCA_TEN_MASK;    // задействовать канал приёма
pdca_channel->cr = AVR32_PDCA_TDIS_MASK;  // отключить канал приёма

Как-то не очень похоже на очищение буфера spi, видимо таким образом очищается буфер dma (какой ещё буфер???) Пока не прочитаю в даташите, что это так, не поверю... В описании регистра PDCA Control Register биты TransferEnable и TransferDisable (AVR32_PDCA_TEN_MASK и AVR32_PDCA_TDIS_MASK в коде) соответственно включают и выключают передачу по DMA. Про очитску буферов ничего нет.
Цитата
• TEN: Transfer Enable
0 = No Effect.
1 = Enable transfer for DMA channel.
• TDIS: Transfer Disable
0 = No Effect.
1 = Disable transfer for DMA channel.

Хотя, с другой стороны включение dma-передачи разрешает каналу считать данные из регистра данных приёмника SPI. Но тогда и впрямь простое чтение регистра данных должно быть равносильно активации/декативации канала dma! Попробую всё же ещё раз проверить завтра этот вариант на свежую голову.


--------------------
С уважением, Вячеслав
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 25th June 2025 - 15:55
Рейтинг@Mail.ru


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