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

 
 
> Непонимание работы ядра Ethernet, c opencores, поясните пжл.
alexPec
сообщение Dec 22 2012, 08:43
Сообщение #1


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

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



Сконфигурировал ядро (то, которое с авалон-мм) для работы с одним дескриптором на передачу и одним на прием. Ставлю брейкпоинт на обработку прерывания по приему. Посылаю пинг с компа. Срабатывает брейк, жду. Проходят 4 пинга, при этом программа висит на брейке. Дальше нажимаю run - и тут же выскакивает (после обработки первого пинга) брейк от второго (затем от 3-го и 4-го), а пинги то уже прошли!

Вопросы такие, поясните кто с этим дело имел:

1. Один дескриптор обрабатывает 1 фрейм эзернета или несколько?
2. Почему срабатывают прерывания по приему, когда пинги уже прошли? И именно столько раз, сколько было пингов?
3. Если дескриптор обрабатывает 1 фрейм - непонятно, где копятся остальные пинги пока программа висит в брейке?
4. Если дескриптор обрабатывает скольугодно фреймов (пишет все что приходит с эзернета подряд) - как ограничить железяке место, куда она может писать? Ато ведь кончится отведенное ей место - залезет на область данных или программы и будет ситуация ж..па.

PS даже если 4. верно, непонятно почему срабатывают прерывания после того как пинги прошли.

Буду рад любым пояснениям.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
vadimuzzz
сообщение Jan 16 2013, 12:50
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 291
Регистрация: 21-07-05
Пользователь №: 6 988



внутри корки есть FIFO, фреймы первым делом оказываются там. контроллер dma при наличии в этом буфере данных будет немедленно инициировать транзакции по шине Avalon-ST, поэтому и прерывания после breakpoint пойдут почти мгновенно. как только вы создаете второй дескриптор на чтение, контроллер dma увидит данные в буфере и сольет его за несколько тактов.
Go to the top of the page
 
+Quote Post
alexPec
сообщение Jan 17 2013, 16:09
Сообщение #3


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

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



Еще вопрос, если можно:

Когда стою в брейкпоинте, а на порт приходят пакеты, то после брейка запускаю выполнение, то что было в фифо(видимо) еще вызывает прерывания, а потом прерывания по приему перестают вызываться. Отправка пакетов при этом работает.
То есть видимо когда корковое фифо переполняется (если например тормознуть программу и не обрабатывать пакетов 5-10), то потом прием пакетов (в частности прерывание по приему) не работает.
Подозреваю, что если будет много пакетов в сети, то ситуация повторится - фифо переполнится (проц не успеет например обработать заголовки) и прием заткнется. Как то можно это вылечить? Ну например пусть пакеты пропадут, но когда приходит очередной - прерывание все таки чтобы срабатывало?
Go to the top of the page
 
+Quote Post



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

 


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


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