Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: LWIP simple app  (Прочитано 10061 раз)
0 Пользователей и 1 Гость смотрят эту тему.
IgnisFatuus
Постоялец

ru
Offline Offline

« : 25-06-2014 09:15 » 

День добрый!
Проблема в следующем :
Мне нужен сетевой клиент и сервер написанные с использованием либы LWIP, из которой необходимо использовать только RAW интерфейсы - то есть без сокетов.
Сказу скажу для чего - мне необходимо забирать из сети ВСЮ посылку (с заголовками, и пр пр ), а не только "полезные данные".

Итак, я скомпилил либу по дефолту, безо всяких изменений внутри нее.

Создаю сервер:

1) Как я понял из манов к либе необходимо запустить функцию/метод init() и затем уйти в бесконечный цикл.

Код: (C++)
    int main(int argc, char** argv) {
    echo_init();
    std::cout << "endles cycle" << std::endl;
    while(1) {
    }
    return 0;
}

2) Сам init();

Код: (C++)

echo_pcb = tcp_new(); // - create the pcb
err_t err; ip_addr_t ipaddr; //create variables for error checking and IP address I wanna use with my server.

 IP4_ADDR(&ipaddr, 150,18,8,165); //Put in variable adress of MY machine

  /* ifconfig says  
     eth1      Link encap:Ethernet    
    inet addr:150.18.8.165  Bcast:150.18.11.255*  Mask:255.255.251.0   */

err = tcp_bind(echo_pcb, &ipaddr, 667); //than bind IP address and desired port to the pcb

echo_pcb = tcp_listen(echo_pcb); //Than I listen pcb
tcp_accept(echo_pcb, echo_accept); //If there is request - accept in

Верна ли эта логика?

Клиент:

Код: (C++)
int main(int argc, char** argv) {
   err_t err =  hello_connect();
   if (err != ERR_OK)  {
   std::cout << "err =  " << err << std::endl;
   }
    std::cout << "End of Main" << std::endl;
    return 0;
 }



Сам  hello_connect();

Код: (C++)
 lwip_init();
 u8_t *state;
 err_t err;
 struct tcp_pcb *pcb;
 ip_addr_t ipaddr;

  IP4_ADDR(&ipaddr, 150,18,8,165);
  if ((state = mem_malloc(1)) == NULL)  {
     return ERR_MEM;
  }

   *state = 1;
   if ((pcb = tcp_new()) == NULL)  {
   mem_free(state);
   return ERR_MEM;
  }

  tcp_arg(pcb, state);
  tcp_err(pcb, hello_err);
  tcp_recv(pcb, hello_recv);
  tcp_sent(pcb, NULL);
  tcp_poll(pcb, hello_poll_close, 10);

  tcp_bind(pcb,&ipaddr, 55555); //Bind ourselvs to the port 55555 and my own adress  


  err = tcp_connect(pcb, &ipaddr, 667, hello_connected);
  if (err != ERR_OK)  {
     std::cout << "err =  " << err << std::endl;
    mem_free(state);
     tcp_abort(pcb);
}
 


Проблемы

Сервак поднимается, но создает интерфейс tap0

tap0
 Link encap:Ethernet HWaddr ******** inet addr:192.168.1.1
Bcast:192.168.1.255
Mask:255.255.255.0 inet6 addr: fe80::a82b:dcff:fedf:3964/64
Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500
Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
 TX packets:40 errors:0 dropped:0 overruns:0 carrier:0 collisions:0
txqueuelen:500 RX bytes:0 (0.0 B) TX bytes:8136 (7.9 KiB)


Почему?


Хочу просканировать порты на машине


sudo nmap -sT -O 192.168.1.1


Starting Nmap 6.00 () at 2014-06-25 11:58 MSK

Nmap scan report for 192.168.1.1

Host is up (0.000011s latency).

Not shown: 996 closed ports

PORT    STATE SERVICE

22/tcp  open  ssh

111/tcp open  rpcbind

443/tcp open  https

902/tcp open  iss-realsecure

No exact OS matches for host (If you know what OS is running on it, see :** ).
TCP/IP fingerprint:

OS:SCAN(V=6.00%E=4%D=6/25%OT=22%CT=1%CU=40454%PV=Y%DS=0%DC=L%G=Y%TM=53AA812
OS:3%P=x86_64-unknown-linux-gnu)SEQ(SP=108%GCD=1%ISR=10A%TI=Z%CI=I%II=I%TS=
OS:8)OPS(O1=M400CST11NW7%O2=M400CST11NW7%O3=M400CNNT11NW7%O4=M400CST11NW7%O
OS:5=M400CST11NW7%O6=M400CST11)WIN(W1=8000%W2=8000%W3=8000%W4=8000%W5=8000%
OS:W6=8000)ECN(R=Y%DF=Y%T=41%W=8018%O=M400CNNSNW7%CC=Y%Q=)T1(R=Y%DF=Y%T=41%
OS:S=O%A=S+%F=AS%RD=0%Q=)T2(R=N)T3(R=N)T4(R=Y%DF=Y%T=41%W=0%S=A%A=Z%F=R%O=%
OS:RD=0%Q=)T5(R=Y%DF=Y%T=41%W=0%S=Z%A=S+%F=AR%O=%RD=0%Q=)T6(R=Y%DF=Y%T=41%W
OS:=0%S=A%A=Z%F=R%O=%RD=0%Q=)T7(R=Y%DF=Y%T=41%W=0%S=Z%A=S+%F=AR%O=%RD=0%Q=)
OS:U1(R=Y%DF=N%T=41%IPL=164%UN=0%RIPL=G%RID=G%RIPCK=G%RUCK=G%RUD=G)IE(R=Y%D
OS:FI=N%T=41%CD=S)


Network Distance: 0 hops

OS detection performed. Please report any incorrect results at http://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 25.97 seconds

Нету порта 667  ...

И вообще - ГДЕ мой сервак тогда??? )

Запускаю клиент :

tcp_connect to port 667

И повисает.

Но если я делаю клиент вида :


Код: (C++)
u8_t *state;
    err_t err;
    struct tcp_pcb *pcb;
  ip_addr_t ipaddr;
  netif_init();
  IP4_ADDR(&ipaddr, 127,0,0,1);
 if ((state = mem_malloc(1)) == NULL) {
     return ERR_MEM;
 }

  *state = 1;
  if ((pcb = tcp_new()) == NULL)  {
  mem_free(state);
  return ERR_MEM;
  }
  tcp_arg(pcb, state);
  tcp_err(pcb, hello_err);
  tcp_recv(pcb, hello_recv);
  tcp_sent(pcb, NULL);
  tcp_poll(pcb, hello_poll_close, 10);


  err = tcp_connect(pcb, &ipaddr, 667, hello_connected);
  if (err != ERR_OK)  {
     std::cout << "err =  " << err << std::endl;
     std::cout << "err =  " << (int)err << std::endl;
     mem_free(state);
     tcp_abort(pcb);
 }
 

То в консоль валится


LWIP_HAVE_LOOPIF = 1

tcp_connect to port 667
ip_output_if: lo2
IP header:

+-------------------------------+
| 4 | 5 |  0x00 |        44     | (v, hl, tos, len)

+-------------------------------+
|        0      |000|       0   | (id, flags, offset)

+-------------------------------+
|  255  |    6  |    0xbdc9     | (ttl, proto, chksum)

+-------------------------------+
|  127  |    0  |    0  |    1  | (src)

+-------------------------------+
|  127  |    0  |    0  |    1  | (dest)

+-------------------------------+

netif_loop_output()
tcpip_thread: CALLBACK 0x7f1fbe811868
ip_input: packet accepted on interface lo
ip_input:
IP header:

+-------------------------------+
| 4 | 5 |  0x00 |        44     | (v, hl, tos, len)

+-------------------------------+
|        0      |000|       0   | (id, flags, offset)

+-------------------------------+
|  255  |    6  |    0xbdc9     | (ttl, proto, chksum)

+-------------------------------+
|  127  |    0  |    0  |    1  | (src)

+-------------------------------+
|  127  |    0  |    0  |    1  | (dest)

+-------------------------------+

ip_input: p->len 44 p->tot_len 44
ip_output_if: lo2

IP header:

+-------------------------------+
| 4 | 5 |  0x00 |        40     | (v, hl, tos, len)

+-------------------------------+
|        1      |000|       0   | (id, flags, offset)

+-------------------------------+
|  255  |    6  |    0xbdcc     | (ttl, proto, chksum)

+-------------------------------+
|  127  |    0  |    0  |    1  | (src)

+-------------------------------+
|  127  |    0  |    0  |    1  | (dest)

+-------------------------------+

netif_loop_output()ip_input: packet accepted on interface lo
ip_input:

IP header:

+-------------------------------+
| 4 | 5 |  0x00 |        40     | (v, hl, tos, len)

+-------------------------------+
|        1      |000|       0   | (id, flags, offset)

+-------------------------------+
|  255  |    6  |    0xbdcc     | (ttl, proto, chksum)

+-------------------------------+
|  127  |    0  |    0  |    1  | (src)

+-------------------------------+
|  127  |    0  |    0  |    1  | (dest)

+-------------------------------+

ip_input: p->len 40 p->tot_len 40

 hello_err BEGINE  //This is the mark of error handler
 hello_err END        //This is the mark of error handler

tcp_pcb_purge
tcp_pcb_purge: data left on ->unacked
tcpip_thread: CALLBACK 0x7f1fbe811840
tcpip_thread: PACKET 0x7f1fbe8119a8





Куда идут эти пакеты? Кто ему отвечает? Сам себе?

Итак, итог - мне нужны 2 приложения
1)Сервак, который ждет подключения, берет всю посылку, упаковывает и передает другому (кому-то)
2) Клиент, посылающий некую data.

Господа, есть идеи?

Записан
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #1 : 25-06-2014 10:05 » 

Сорри, с LWIP дела не имел, но немного писал сетевые приложения.
А по-конкретнее, в чём состоит задача и чего Вам не хватает от штатного стека TCP/IP (каких заголовков)? Может Вам поможет библиотека pcap? Мне показалось, что Вы строите что-то типа туннеля, может лучше взять готовый? По поводу номеров портов, просто догадка - может там не хватает htons() для преобразования номера порта в сетевой порядок представления?
Записан
IgnisFatuus
Постоялец

ru
Offline Offline

« Ответ #2 : 25-06-2014 10:46 » 

Смысл в том, чтобы не просто посмотреть все сообщение, а именно забрать его и, как вариант, зашифровать, передать через VPN, расшифровать, отправить адресату.
По поводу порта - в либе именно такой метод установки его значения...
Записан
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #3 : 25-06-2014 12:32 » 

А более-менее штатные туннели, типа прикладных stunnel, openvpn и системного tun/tap никак не устраивают?
« Последнее редактирование: 25-06-2014 12:37 от darkelf » Записан
IgnisFatuus
Постоялец

ru
Offline Offline

« Ответ #4 : 29-07-2014 12:03 » new

Госпада, проблема  решена, если у кого-то по LWIP возникнут вопросы - милости прошу - почта в профиле.
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines