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

 
 
> STR912 Ethernet - ошибки приема, Некоторые байты информации портятся, некоторые нет...
Pechka
сообщение Apr 9 2010, 19:27
Сообщение #1


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

Группа: Свой
Сообщений: 144
Регистрация: 25-03-10
Из: Москва
Пользователь №: 56 210



Здравствуйте! возникла проблема при разработке приложения. Поскольку нужно только ARP, DHCP, IP, UDP решил писать самостоятельно. На уровне ARP запросов заметил проблему: принимаю фрэйм с путаными байтами. WireShark показывает фрэйм с одними данными, а принятая информация отличается. Причём портятся, обычно, одни и те же байты фрэйма. Причём если O - нормальный байт, а X ошибочный, то общийвид фрэйма получается примерно такой:
OOOOOOOOOOOOOOXXOOOOOOOXXXOOOOOXXX (крестики-нолики расставлены схемотично). Первый ошибочный байт возникает в номере протокола в заголовке ARP(вместо 0x0800 получется 0xE5C и иногда разные вариации этого).
Драйвер брал штатный из примера кейла и переделал его под свой phy контроллер.
Кто-нибудь сталкивался с таким? С чем может быть связано такое поведение?

P.S. clock на phy контроллер делаю по-средствам PWM таймера 3. т.е. внетреняя частота 100МГц делю на 4 и получаю требуемые 25. Может проблема в джиттере клока?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
artur_off
сообщение Apr 10 2010, 08:59
Сообщение #2


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

Группа: Свой
Сообщений: 118
Регистрация: 24-05-08
Из: Odessa
Пользователь №: 37 784



Цитата(Pechka @ Apr 9 2010, 22:42) *
P.S. clock на phy контроллер делаю по-средствам PWM таймера 3. т.е. внетреняя частота 100МГц делю на 4 и получаю требуемые 25. Может проблема в джиттере клока?


Зачем с помощью таймера, если для этих целей предусмотрен специальный вывод.


--------------------
 Big time. 
Go to the top of the page
 
+Quote Post
Pechka
сообщение Apr 13 2010, 08:24
Сообщение #3


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

Группа: Свой
Сообщений: 144
Регистрация: 25-03-10
Из: Москва
Пользователь №: 56 210



Цитата(artur_off @ Apr 10 2010, 12:14) *
Зачем с помощью таймера, если для этих целей предусмотрен специальный вывод.

Мне нужно чтобы одновременно работал USB и Ethernet. Если подбираю клок под одно, то не получается сделать другое. Однако, если на USB подать клок на внешний пин, его же поделить на 2 тригером и подать на PLL можно решить проблему наличия единственного клока в системе.
Выход PHY_CLK выдаёт только то, что поступает на вход PLL, поэтому тут вариантов не много. sad.gif

Цитата(iosifk @ Apr 12 2010, 08:35) *
А по глазковой диаграмме? Должно быть +/- 50 ppm

На осциллографе 25.0000, что входит в указанные ворота (проверял этот параметр когда читал datasheet на phy контроллер).
Go to the top of the page
 
+Quote Post



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

 


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


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