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

 
 
 
Reply to this topicStart new topic
> 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
Dron_Gus
сообщение Apr 9 2010, 20:32
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 202
Регистрация: 9-01-05
Из: Санкт-Петербург
Пользователь №: 1 861



У STR912 "хитрые" таймеры. Уже не помню, но считали они с какого-то неочивидного начального значения. Плюс где-то тут была тема, где обсуждалось, что таймеры выдают немного нерасчетную частоту. Тоже не помню чем закончилось. Поищите.


--------------------
Если сверху смотреть, то сбоку кажется, что снизу ничего не видно.
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Apr 9 2010, 20:42
Сообщение #3


Гуру
******

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



А с FCS что? Совпадает?
Go to the top of the page
 
+Quote Post
Pechka
сообщение Apr 9 2010, 21:26
Сообщение #4


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

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



CRC ещё не смотрел. Частоту я осциллографом смотрел - вполне нормальные 25МГц. Правда там есть требования по стабильности и точности - в этом вопрос, но осциллограф 200МГц полосой не показывает проблем.
FCS - контрольная сумма? ещё не считал smile.gif В настройках mac прочитал, что естьфункция фильтрации в том числе по несовпадению CRC. включил её, поэтому наивно полагал, что пакеты с заведомо правильной CRC. :/ Завтра проверю.
Go to the top of the page
 
+Quote Post
scifi
сообщение Apr 10 2010, 07:08
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(Pechka @ Apr 9 2010, 23:42) *
Поскольку нужно только ARP, DHCP, IP, UDP решил писать самостоятельно.

Может не по теме, но самому писать эти протоколы - неблагодарная задача. Почему бы не взять Lwip? Там всё это есть, а лишнее можно отключить.
Go to the top of the page
 
+Quote Post
Pechka
сообщение Apr 10 2010, 07:17
Сообщение #6


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

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



Цитата(scifi @ Apr 10 2010, 10:23) *
Может не по теме, но самому писать эти протоколы - неблагодарная задача. Почему бы не взять Lwip? Там всё это есть, а лишнее можно отключить.

Думаю от ошибок приёма это не избавит sad.gif Я взял OpenTCP и вытягиваю оттуда нужные мне куски. А протоколы вобщем-то примтивны эти, поэтому и самому реализовать не сложно в применении к Ethernet.
Go to the top of the page
 
+Quote Post
artur_off
сообщение Apr 10 2010, 08:59
Сообщение #7


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

Группа: Свой
Сообщений: 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
iosifk
сообщение Apr 12 2010, 05:20
Сообщение #8


Гуру
******

Группа: Модераторы
Сообщений: 4 011
Регистрация: 8-09-05
Из: спб
Пользователь №: 8 369



Цитата(Pechka @ Apr 10 2010, 01:41) *
CRC ещё не смотрел. Частоту я осциллографом смотрел - вполне нормальные 25МГц. Правда там есть требования по стабильности и точности - в этом вопрос, но осциллограф 200МГц полосой не показывает проблем.

А по глазковой диаграмме? Должно быть +/- 50 ppm


--------------------
www.iosifk.narod.ru
Go to the top of the page
 
+Quote Post
Pechka
сообщение Apr 13 2010, 08:24
Сообщение #9


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

Группа: Свой
Сообщений: 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
Pechka
сообщение Apr 13 2010, 09:58
Сообщение #10


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

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



Переконфигурировал штатный пример easyweb из кейла - работает нормально. Значит проблема не аппаратная и не с таймером. Отличие моего драйвера от штатного - использование прерываний. Может быть он не успевает закончить прием фрэйма, а я уже пытаюсь из него что-то вытащить и поэтому натыкаюсь на некую абстрактную информацию? прерывание RX_CURR_DONE обрабатываю...
Какие-нибудь ещё варианты есть?

Сообщение отредактировал Pechka - Apr 13 2010, 09:59
Go to the top of the page
 
+Quote Post
Pechka
сообщение Apr 14 2010, 08:26
Сообщение #11


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

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



Более менее разобрался... Сделал правки в программе и всё стало на свои места, кроме одного: в поле protocol type заголовка ARP получаю каждый раз разную ерунду, вместо желаемых 0x800. WireShark всё показывает нормально. однако до и после этого слова инфомрация верная принимается. Ума не приложу, как процессор может портить конкретное слово :/
Go to the top of the page
 
+Quote Post
Log_in
сообщение Dec 20 2013, 10:34
Сообщение #12


Участник
*

Группа: Участник
Сообщений: 21
Регистрация: 9-06-12
Пользователь №: 72 244



Скорей всего уже не актуально, но вполне вероятно это связанно с разным порядком байт для значений в несколько байтов.
Go to the top of the page
 
+Quote Post

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

 


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


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