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

 
 
 
Reply to this topicStart new topic
> Контроллер с самыми быстрыми портами, Задача сканирования, а не дрыганья
fiim
сообщение Nov 10 2009, 17:01
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 53
Регистрация: 29-10-09
Пользователь №: 53 291



Привет всем умельцам!
Есть плата от относительно старого станка(~10лет)без документации.
Две микрухи на ней с затертыми надписями обмениваются данными.
По осциллограмме понятно, что скорее всего используется нечто похожее на SPI, но не он.
Для анализа нужно отсканировать сотни 3 байт.
Т.е. надо ловить единицу на CLK и в эти моменты записывать в память уровень на выводе DATA.
Проблема в том, что CLK строб сигнал длится очень мало, примерно один такт от 12Мгц, и мой контроллер не успевает его отследить.
Код очень простой:
for(i=0; i<300; i++){
while(pin_CLK==0){};
buffer[i]=pin_DATA;
}
Так вот, написанный на С такой простой код оказался очень большим(даже с оптимизацией)
так что на каждую проверку CLK уходило минимум 12 циклов. smile3046.gif
Пришлось вставить несколько ассемблерных команд, но все равно это 7 циклов процессора:
LDR Rx, [Ry; #] //3 cycles
TST Rx, #.. //1 cycle
BNE XXX //3 cycles
А поскольку собственно загрузка значения ноги в регистр занимает всего один цикл, то в остальные 6 циклов процессор получается не видит ногу, и если на ней в этот период была единица, то он ее пропускает.
Я пробовал несколько контроллеров, соответственно немного менялся код и количество циклов:
Сперва я пробовал на AVR(16МГц) Там благодаря их командам немного другой код и он выполняется за 4 цикла,
но из за малой скорости проца(макс 16 Мгц)из 50 стробов CLK я вижу всего 15!
Тогда я взял LPC2148 - 60Mhz, используя быстрыйпорт получаю 35 стробов CLK из 50!
Тогда я взял STM32F103 -72MHz, получаю 40видимых стробов из 50.
Можно взять 100-мегагерцовый Cortex от NXP или AtXmegaAVR(32MHz) и тогда есть ВЕРОЯТНОСТЬ,
что я не пропущу ни одного строба, но т.к. от одного пропущеного зависит вся цепочка, то здесь нужна не вероятность,
а полная уверенность с запасом!
Итак есть два пути: найти контроллер с супер быстрым портом либо оптимизировать мой ассемблерный код(может я не знаю какой хитрой команды)
Кто что может предложить для решения этой задачки? cranky.gif
Go to the top of the page
 
+Quote Post
_dem
сообщение Nov 10 2009, 17:07
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 263
Регистрация: 2-02-07
Из: CN, Ukraine
Пользователь №: 24 970



А почему вы не можете использовать для этих целей аппаратный SPI ?
Go to the top of the page
 
+Quote Post
skripach
сообщение Nov 10 2009, 17:30
Сообщение #3


■ ■ ■ ■
*****

Группа: Свой
Сообщений: 1 100
Регистрация: 9-08-06
Пользователь №: 19 443



Для анализа нужно отсканировать сотни 3 байт.
Может проще воспользоваться цифровым анализатором?


--------------------
Делай что должен и будь что будет.
Go to the top of the page
 
+Quote Post
fiim
сообщение Nov 10 2009, 17:44
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 53
Регистрация: 29-10-09
Пользователь №: 53 291



Аппаратный SPI, насколько я знаю использует старт-стоп биты, а если эти микрухи юзают другую(не SPI) старт-стоповую систему, то я получу на выходе полную белиберду..
А цифровой анализатор я никогда не использовал, только слышал. Он что способен решать подобные задачи? Как он выглядит, где его берут и как им пользуются?
Go to the top of the page
 
+Quote Post
zltigo
сообщение Nov 10 2009, 17:48
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(fiim @ Nov 10 2009, 20:44) *
Аппаратный SPI, насколько я знаю....

Начните с изучения матчасти - ну нету в SPI ни стартов ни стопов - синхронный он по жизни.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Rst7
сообщение Nov 10 2009, 17:53
Сообщение #6


Йа моск ;)
******

Группа: Модераторы
Сообщений: 4 345
Регистрация: 7-07-05
Из: Kharkiv-city
Пользователь №: 6 610



Кстати, необходимо обратить внимание на максимально допустимую частоту тактового сигнала для модуля SPI выбранного контроллера в режиме slave. В LPC он далеко не быстрый.


--------------------
"Практика выше (теоретического) познания, ибо она имеет не только достоинство всеобщности, но и непосредственной действительности." - В.И. Ленин
Go to the top of the page
 
+Quote Post
fiim
сообщение Nov 10 2009, 18:29
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 53
Регистрация: 29-10-09
Пользователь №: 53 291



Действительно нет старт-стопов за исключением сброса битового счетчика, который применяется для определения момента окончания приема байта. Но он не обязателен! -Ведь его не используют в 3-х проводном SPI, а только в 4-х проводном, и то на всякий случай!
Я был введен в заблуждение некоторыми СИНХРОННЫМИ басами, которые ИМЕЮТ старт-стопы (SWD, C2, I2C )
zltiqo и _dem, спасибо, это действительно может быть выход!!! Кажется в STM32 max SPI=18MHz, должно заработатьsmile.gif
Go to the top of the page
 
+Quote Post

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

 


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


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