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

 
 
> Смещён приём через PDC для SPI
Goofy
сообщение Feb 9 2008, 09:02
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 169
Регистрация: 17-09-07
Из: Красноярск
Пользователь №: 30 600



Последовательность функция для запуска передчи команды по SPI (для dataflash)
Код
    DFChipSelect();

    AT91F_PDC_DisableRx(pPdc);
    AT91F_PDC_SetRx(pPdc, (char *) &(), bCmdSize);
    AT91F_PDC_SetNextRx(pPdc, pData, dDataSize);

    AT91F_PDC_DisableTx(pPdc);    
    AT91F_PDC_SetTx(pPdc, (char *) &(pDataFlash->commandS), bCmdSize);
    AT91F_PDC_SetNextTx(pPdc, pData, dDataSize);

    AT91F_PDC_EnableRx(pPdc);
    AT91F_PDC_EnableTx(pPdc);

В качестве команды засылается запрос на статус регистр (0xD7) размер команды 2 (bCmdSize=2)
Глядя на диаграмму передачи со статус регистра видно, что статус регистр должен передаваться по MISO сразу же после 8го тика SCK. Судя по всему так и происходит. Но сам статус регист оказывается не в ((char*)pDataFlash->command) [1], а в ((char*)pDataFlash->command) [0] !!! Как будто датафлэш передаёт данные во время прохождения запроса. Как будто PDC для приёма курит один байт, перед тем как начать приём.
Что не учёл, где накосячил?
Процессор sam7s256 код из атмеловского апноута для sam7x.

Очевидно, что это проявляется не только с датафлэш, тк для АЦП запросы короткие то там я тупо подстроился под эту систему и заставил всё работать. Но это ведь может плохо кончиться!
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Goofy
сообщение Feb 14 2008, 10:33
Сообщение #2


Частый гость
**

Группа: Свой
Сообщений: 169
Регистрация: 17-09-07
Из: Красноярск
Пользователь №: 30 600



Это баг самого sam7s. Проявляется видимо не у всех, но

http://www.at91.com/phpbb/viewtopic.php?p=...2fa6260ff26533e

Судя по моим наблюдениям сбойно работает shift register SPI, все данные проходящие через него смещенны на байт вправо, очевидны глюки с переключением размера регистра. (я работал с 8битным). Проявляется в том, что при начале новой передачи, в буффер приёма попадает байт от конца предыдущей. От этого, кстати, при работе через PDC, RCR сразу потеряет единичку.

Уже жалею что с этим чипом связался, походу его и с производства сняли. Это первый в моей практике ARM и через такие стенодробительные процедуры... Закаляет однако smile.gif

Сообщение отредактировал Goofy - Feb 14 2008, 10:36
Go to the top of the page
 
+Quote Post
prottoss
сообщение Feb 14 2008, 11:03
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 2 720
Регистрация: 24-03-05
Пользователь №: 3 659



Цитата(Goofy @ Feb 14 2008, 17:33) *
Это баг самого sam7s.


1.Только что сравнил баги SPI SAM7S и SAM7X - все одно и тоже... Похоже баг только в вашем контроллере smile.gif включая "...плата там и правда вся в соплях из проводов..."

2.А как Вы узнали, что его сняли с производства? Вроде как продакшн везде написано 07.gif

http://www.atmel.com/dyn/products/param_ta...p;Direction=ASC

http://www.atmel.com/dyn/products/devices.asp?family_id=605

3. Чип и вправду кривоватый - кстати, тоже мой первенец 05.gif Но работать с ним, зная баги, можно.


--------------------
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Goofy   Смещён приём через PDC для SPI   Feb 9 2008, 09:02
- - prottoss   Цитата(Goofy @ Feb 9 2008, 16:02) КодAT91...   Feb 9 2008, 09:54
|- - Goofy   Цитата(prottoss @ Feb 9 2008, 16:54) Это ...   Feb 9 2008, 10:11
|- - prottoss   Цитата(Goofy @ Feb 9 2008, 17:11) это нак...   Feb 9 2008, 10:22
|- - Goofy   Цитата(prottoss @ Feb 9 2008, 17:22) Да В...   Feb 10 2008, 08:05
|- - prottoss   Цитата(Goofy @ Feb 10 2008, 15:05) это о...   Feb 10 2008, 09:53
|- - Goofy   Структура на которую ссылается pDataFlash имеет ви...   Feb 10 2008, 10:35
|- - prottoss   Цитата(Goofy @ Feb 10 2008, 17:35) Структ...   Feb 10 2008, 11:08
|- - Goofy   А можно попросить код? Именно с sam7s стыковали да...   Feb 10 2008, 13:34
|- - prottoss   Цитата(Goofy @ Feb 10 2008, 20:34) А можн...   Feb 10 2008, 13:55
- - Goofy   За код спасибо большое! Но то что у меня про...   Feb 11 2008, 08:39
|- - prottoss   Цитата(Goofy @ Feb 11 2008, 15:39) За код...   Feb 11 2008, 08:55
|- - Goofy   Цитата(prottoss @ Feb 11 2008, 15:55) не ...   Feb 11 2008, 09:02
|- - defunct   Goofy Сдается мне проблема не с RX DMA. Попробуйте...   Feb 11 2008, 11:40
- - Goofy   Код for (i=0;i<4;i++) Bufr[i]=...   Feb 11 2008, 18:40
|- - Goofy   Цитата(prottoss @ Feb 14 2008, 18:03) 1.Т...   Feb 14 2008, 13:14
- - prottoss   Кстати, а как Вы управляете чипселектом? Через жел...   Feb 14 2008, 13:21
|- - Goofy   Цитата(prottoss @ Feb 14 2008, 20:21) Кст...   Feb 14 2008, 13:46
|- - prottoss   Цитата(Goofy @ Feb 14 2008, 20:46) Через ...   Feb 14 2008, 15:18
|- - Goofy   Цитата(prottoss @ Feb 14 2008, 22:18) Ну ...   Feb 14 2008, 15:54
|- - prottoss   Цитата(Goofy @ Feb 14 2008, 22:54) Работа...   Feb 14 2008, 16:10
|- - Goofy   Цитата(prottoss @ Feb 14 2008, 23:08) Хот...   Feb 14 2008, 16:14
|- - prottoss   Цитата(Goofy @ Feb 14 2008, 23:14) угу П...   Feb 14 2008, 16:37
|- - Goofy   Подправил Кодvoid InitSPI(void) { AT91F_SP...   Feb 14 2008, 18:01
|- - prottoss   Цитата(Goofy @ Feb 15 2008, 01:01) Кодuns...   Feb 14 2008, 18:12
|- - Goofy   Цитата(prottoss @ Feb 15 2008, 01:12) Вот...   Feb 14 2008, 18:14
- - prottoss   Блин Название то теме Вы придумали? Что то вы экс...   Feb 14 2008, 18:27
- - Goofy   Цитата(prottoss @ Feb 15 2008, 01:27) Бли...   Feb 14 2008, 19:19


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

 


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


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