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

 
 
 
Reply to this topicStart new topic
> LwIP: Eth + GPRS(PPP)
k000858
сообщение Jul 17 2017, 10:14
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



Есть устройство, на борту Ethernet и GSM модуль.
Протоколы (в том числе и PPP для работы GPRS) обеспечивает стек LwIP. И есть одна странность:

После поднятия PPP стек начинает отправлять данные по TCP соединению, поднятому по интерфейсу Eth, но в PPP протокол. Соответственно исходящие пакеты уходят не в Ethernet интерфейс а в GSM модуль. Как такое вообще возможно? Как пофиксить или хотя бы по-дебажить?
Go to the top of the page
 
+Quote Post
scifi
сообщение Jul 17 2017, 10:22
Сообщение #2


Гуру
******

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



Вроде бы функция ip_route() в файле ip.c этим занимается. Смотрите, почему не в туда отправляет.
Go to the top of the page
 
+Quote Post
k000858
сообщение Jul 17 2017, 11:14
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



кажется, разобрался. с помощью ip_route проверяются оба интерфейса на предмет предчастности к ip адресу доставки. Если адрес не подходит к интерфейсу, выбирается дефолтный интерфейс. Зачем то в LwIP после поднятия PPP он делается дефолтным. До его поднятия пакеты уходят куда надо, а после начинается такая вот фигня
Go to the top of the page
 
+Quote Post
scifi
сообщение Jul 17 2017, 11:46
Сообщение #4


Гуру
******

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



Цитата(k000858 @ Jul 17 2017, 14:14) *
Если адрес не подходит к интерфейсу, выбирается дефолтный интерфейс.

Интересно, как может получиться так, что IP адрес не подходит к интерфейсу во время TCP-сессии? У вас что-то сломалось.
Go to the top of the page
 
+Quote Post
k000858
сообщение Jul 17 2017, 11:50
Сообщение #5


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



Цитата(scifi @ Jul 17 2017, 14:46) *
Интересно, как может получиться так, что IP адрес не подходит к интерфейсу во время TCP-сессии? У вас что-то сломалось.

да вот так: на интерфейсе айпи 192.168.15.20 а сессия поднялась с адреса 123.123.123.123
Go to the top of the page
 
+Quote Post
kolobok0
сообщение Jul 17 2017, 17:26
Сообщение #6


практикующий тех. волшебник
*****

Группа: Участник
Сообщений: 1 084
Регистрация: 9-09-05
Пользователь №: 8 417



Цитата(k000858 @ Jul 17 2017, 14:50) *
...с адреса 123.123.123.123


уж очень смахивает на дурдом в коде...
мусор - не похож, 4 байта подряд...
обнуляют обычно нулями...
края на затирку вроде как не 7Bh...

имхо = ищите ляпы в коде...
(круглый)
Go to the top of the page
 
+Quote Post
k000858
сообщение Jul 18 2017, 03:36
Сообщение #7


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



Цитата(kolobok0 @ Jul 17 2017, 20:26) *
уж очень смахивает на дурдом в коде...
мусор - не похож, 4 байта подряд...
обнуляют обычно нулями...
края на затирку вроде как не 7Bh...

имхо = ищите ляпы в коде...
(круглый)

мда. похоже неудачный пример привел. ок
на Eth интерфейсе 172.31.74.11 (маска 255.255.255.0), а пакет уходит на 172.31.68.231, при этом на GSM интерфейсе 172.16.0.31
Ни тот, ни другой IP не входит в диапазон адреса получателя, соответственно LwIP использует дефолтный интерфейс.

мусор в коде то у кого? у меня или у LwIP?
Go to the top of the page
 
+Quote Post
scifi
сообщение Jul 18 2017, 05:02
Сообщение #8


Гуру
******

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



Цитата(k000858 @ Jul 18 2017, 06:36) *
мусор в коде то у кого? у меня или у LwIP?

Не надо грязи.
Вообще-то обычно вполне разумно устанавливать ppp интерфейсом по умолчанию. Если вам это не подходит, есть функция netif_set_default().
Go to the top of the page
 
+Quote Post
k000858
сообщение Jul 18 2017, 05:22
Сообщение #9


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



Цитата(scifi @ Jul 18 2017, 08:02) *
Не надо грязи.
Вообще-то обычно вполне разумно устанавливать ppp интерфейсом по умолчанию. Если вам это не подходит, есть функция netif_set_default().

В моем случае разумней дефолтным интерфейсом использовать Ethernet (что в коде и делается, однако после поднятия PPP - он переназначается дефолтным), потому как GPRS является резервным каналом.
С помощью netif_set_default можно конечно снова переназначить Ethernet дефолтным. Просто мне не совсем понятно зачем PPP переназначается принудительно, да происходит это не сразу после поднятия PPP (во всяком случае после вызова колбэк-функции по его поднятию, поэтому не ясно когда стоит сново назначить дефолтным Ethernet)
Go to the top of the page
 
+Quote Post
scifi
сообщение Jul 18 2017, 05:42
Сообщение #10


Гуру
******

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



Цитата(k000858 @ Jul 18 2017, 08:22) *
Просто мне не совсем понятно зачем PPP переназначается принудительно, да происходит это не сразу после поднятия PPP (во всяком случае после вызова колбэк-функции по его поднятию, поэтому не ясно когда стоит сново назначить дефолтным Ethernet)

Можно тупо влезть в код lwip и закомментировать соответствующую строку, если это не выведено наружу в виде настройки.
Go to the top of the page
 
+Quote Post
k000858
сообщение Jul 18 2017, 05:51
Сообщение #11


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



Цитата(scifi @ Jul 18 2017, 08:42) *
Можно тупо влезть в код lwip и закомментировать соответствующую строку, если это не выведено наружу в виде настройки.

это то да)
но может есть более изящный способ, в смысле, может есть какая то настроечка) вдруг кто сталкивался с подобныи эффектом
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jul 18 2017, 06:11
Сообщение #12


Гуру
******

Группа: Модераторы
Сообщений: 7 974
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



QUOTE (scifi @ Jul 18 2017, 08:02) *
Вообще-то обычно вполне разумно устанавливать ppp интерфейсом по умолчанию.
Простите, что вмешиваюсь, но в каких случаях и какие это может дать преимущества? Мне, как и k000858, кажется, что логичнее держать интерфейсом по умолчанию eth с бесплатным трафиком, чем ppp с платным.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
k000858
сообщение Jul 18 2017, 07:05
Сообщение #13


Местный
***

Группа: Участник
Сообщений: 272
Регистрация: 31-01-12
Пользователь №: 69 978



И вообще, мне кажется, было бы логичнее отправлять ответы на запросы в тот интерфейс, в по какому они были получены. Иначе это уже какой то маршрутизатор. Может есть какая то настроечка для LwIP ?!
Go to the top of the page
 
+Quote Post
scifi
сообщение Jul 18 2017, 08:05
Сообщение #14


Гуру
******

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



Цитата(k000858 @ Jul 18 2017, 10:05) *
И вообще, мне кажется, было бы логичнее отправлять ответы на запросы в тот интерфейс, в по какому они были получены.

Логичнее, конечно. Но для этого нужно делать привязку пакетов к TCP-сессиям - лишний геморрой. К тому же пакет, открывающий новую TCP-сессию, куда слать? В общем, не надо вот это вот, потому что уже не совсем lightweight будет этот ip.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 27th July 2017 - 00:43
Рейтинг@Mail.ru


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