ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/gvpe/src/protocol.C
(Generate patch)

Comparing gvpe/src/protocol.C (file contents):
Revision 1.4 by pcg, Thu Mar 6 18:43:07 2003 UTC vs.
Revision 1.7 by pcg, Sun Mar 9 12:48:22 2003 UTC

481connection::send_ping (SOCKADDR *dsa, u8 pong) 481connection::send_ping (SOCKADDR *dsa, u8 pong)
482{ 482{
483 ping_packet *pkt = new ping_packet; 483 ping_packet *pkt = new ping_packet;
484 484
485 pkt->setup (conf->id, pong ? ping_packet::PT_PONG : ping_packet::PT_PING); 485 pkt->setup (conf->id, pong ? ping_packet::PT_PONG : ping_packet::PT_PING);
486 vpn->send_vpn_packet (pkt, dsa); 486 vpn->send_vpn_packet (pkt, dsa, IPTOS_LOWDELAY);
487 487
488 delete pkt; 488 delete pkt;
489} 489}
490 490
491void 491void
496 if (limiter.can (dsa)) 496 if (limiter.can (dsa))
497 { 497 {
498 config_packet *pkt = new config_packet; 498 config_packet *pkt = new config_packet;
499 499
500 pkt->setup (vpn_packet::PT_RESET, conf->id); 500 pkt->setup (vpn_packet::PT_RESET, conf->id);
501 vpn->send_vpn_packet (pkt, dsa); 501 vpn->send_vpn_packet (pkt, dsa, IPTOS_MINCOST);
502 502
503 delete pkt; 503 delete pkt;
504 } 504 }
505} 505}
506 506
550 fatal ("RSA_public_encrypt error"); 550 fatal ("RSA_public_encrypt error");
551#endif 551#endif
552 552
553 slog (L_TRACE, ">>%d PT_AUTH(%d) [%s]", conf->id, subtype, (const char *)sockinfo (sa)); 553 slog (L_TRACE, ">>%d PT_AUTH(%d) [%s]", conf->id, subtype, (const char *)sockinfo (sa));
554 554
555 vpn->send_vpn_packet (pkt, sa); 555 vpn->send_vpn_packet (pkt, sa, IPTOS_RELIABILITY);
556 556
557 delete pkt; 557 delete pkt;
558 } 558 }
559} 559}
560 560
561void 561void
562connection::establish_connection () 562connection::establish_connection ()
563{ 563{
564 if (!ictx && conf != THISNODE && conf->connectmode != conf_node::C_NEVER) 564 if (!ictx && conf != THISNODE && connectmode != conf_node::C_NEVER)
565 { 565 {
566 if (now >= next_retry) 566 if (now >= next_retry)
567 { 567 {
568 int retry_int = retry_cnt & 3 ? (retry_cnt & 3) : 1 << (retry_cnt >> 2); 568 int retry_int = retry_cnt & 3 ? (retry_cnt & 3) : 1 << (retry_cnt >> 2);
569 569
570 if (retry_cnt < (17 << 2) | 3) 570 if (retry_cnt < (17 << 2) | 3)
571 retry_cnt++; 571 retry_cnt++;
572 572
573 if (conf->connectmode == conf_node::C_ONDEMAND 573 if (connectmode == conf_node::C_ONDEMAND
574 && retry_int > ::conf.keepalive) 574 && retry_int > ::conf.keepalive)
575 retry_int = ::conf.keepalive; 575 retry_int = ::conf.keepalive;
576 576
577 next_retry = now + retry_int; 577 next_retry = now + retry_int;
578 next_wakeup (next_retry); 578 next_wakeup (next_retry);
635 635
636void 636void
637connection::send_data_packet (tap_packet * pkt, bool broadcast) 637connection::send_data_packet (tap_packet * pkt, bool broadcast)
638{ 638{
639 vpndata_packet *p = new vpndata_packet; 639 vpndata_packet *p = new vpndata_packet;
640 int tos = 0;
641
642 if (conf->inherit_tos
643 && (*pkt)[12] == 0x08 && (*pkt)[13] == 0x00 // IP
644 && ((*pkt)[14] & 0xf0) == 0x40) // IPv4
645 tos = (*pkt)[15] & IPTOS_TOS_MASK;
640 646
641 p->setup (this, broadcast ? 0 : conf->id, &((*pkt)[6 + 6]), pkt->len - 6 - 6, ++oseqno); // skip 2 macs 647 p->setup (this, broadcast ? 0 : conf->id, &((*pkt)[6 + 6]), pkt->len - 6 - 6, ++oseqno); // skip 2 macs
642 vpn->send_vpn_packet (p, &sa); 648 vpn->send_vpn_packet (p, &sa, tos);
643 649
644 delete p; 650 delete p;
645 651
646 if (oseqno > MAX_SEQNO) 652 if (oseqno > MAX_SEQNO)
647 rekey (); 653 rekey ();
692 { 698 {
693 reset_connection (); 699 reset_connection ();
694 700
695 config_packet *p = (config_packet *) pkt; 701 config_packet *p = (config_packet *) pkt;
696 if (p->chk_config ()) 702 if (p->chk_config ())
697 if (conf->connectmode == conf_node::C_ALWAYS) 703 if (connectmode == conf_node::C_ALWAYS)
698 establish_connection (); 704 establish_connection ();
699 705
700 //D slog the protocol mismatch? 706 //D slog the protocol mismatch?
701 } 707 }
702 break; 708 break;
781 while (tap_packet *p = queue.get ()) 787 while (tap_packet *p = queue.get ())
782 { 788 {
783 send_data_packet (p); 789 send_data_packet (p);
784 delete p; 790 delete p;
785 } 791 }
792
793 connectmode = conf->connectmode;
786 794
787 slog (L_INFO, _("connection to %d (%s %s) established"), 795 slog (L_INFO, _("connection to %d (%s %s) established"),
788 conf->id, conf->nodename, (const char *)sockinfo (ssa)); 796 conf->id, conf->nodename, (const char *)sockinfo (ssa));
789 797
790 if (::conf.script_node_up) 798 if (::conf.script_node_up)
949 957
950void connection::timer () 958void connection::timer ()
951{ 959{
952 if (conf != THISNODE) 960 if (conf != THISNODE)
953 { 961 {
954 if (now >= next_retry && conf->connectmode == conf_node::C_ALWAYS) 962 if (now >= next_retry && connectmode == conf_node::C_ALWAYS)
955 establish_connection (); 963 establish_connection ();
956 964
957 if (ictx && octx) 965 if (ictx && octx)
958 { 966 {
959 if (now >= next_rekey) 967 if (now >= next_rekey)
1093 1101
1094 return 0; 1102 return 0;
1095} 1103}
1096 1104
1097void 1105void
1098vpn::send_vpn_packet (vpn_packet *pkt, SOCKADDR *sa) 1106vpn::send_vpn_packet (vpn_packet *pkt, SOCKADDR *sa, int tos)
1099{ 1107{
1108 setsockopt (socket_fd, SOL_IP, IP_TOS, &tos, sizeof tos);
1100 sendto (socket_fd, &((*pkt)[0]), pkt->len, 0, (sockaddr *)sa, sizeof (*sa)); 1109 sendto (socket_fd, &((*pkt)[0]), pkt->len, 0, (sockaddr *)sa, sizeof (*sa));
1101} 1110}
1102 1111
1103void 1112void
1104vpn::shutdown_all () 1113vpn::shutdown_all ()
1121 connection *conn = new connection (this); 1130 connection *conn = new connection (this);
1122 1131
1123 conn->conf = *i; 1132 conn->conf = *i;
1124 conns.push_back (conn); 1133 conns.push_back (conn);
1125 1134
1126 if (conn->conf->connectmode == conf_node::C_ALWAYS)
1127 conn->establish_connection (); 1135 conn->establish_connection ();
1128 } 1136 }
1129} 1137}
1130 1138
1131connection *vpn::find_router () 1139connection *vpn::find_router ()
1132{ 1140{
1136 for (conns_vector::iterator i = conns.begin (); i != conns.end (); ++i) 1144 for (conns_vector::iterator i = conns.begin (); i != conns.end (); ++i)
1137 { 1145 {
1138 connection *c = *i; 1146 connection *c = *i;
1139 1147
1140 if (c->conf->routerprio > prio 1148 if (c->conf->routerprio > prio
1141 && c->conf->connectmode == conf_node::C_ALWAYS 1149 && c->connectmode == conf_node::C_ALWAYS
1142 && c->conf != THISNODE 1150 && c->conf != THISNODE
1143 && c->ictx && c->octx) 1151 && c->ictx && c->octx)
1144 { 1152 {
1145 prio = c->conf->routerprio; 1153 prio = c->conf->routerprio;
1146 router = c; 1154 router = c;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines