X-Git-Url: https://git.librecmc.org/?p=oweals%2Ftinc.git;a=blobdiff_plain;f=src%2Fnet_packet.c;h=626f8b1cdbfb55fe357a0369cfa3ee0591bad386;hp=9b0e4685012491e75f25d3bd06e8e40ee0fd2a95;hb=a8f7fccbc2b5f1c4c39fc2804abaa358b31a5080;hpb=b6543af7626403516b5fc54c24b11d3a242a2992 diff --git a/src/net_packet.c b/src/net_packet.c index 9b0e468..626f8b1 100644 --- a/src/net_packet.c +++ b/src/net_packet.c @@ -135,7 +135,7 @@ void mtu_probe_h(node_t *n, vpn_packet_t *packet, length_t len) { if(!packet->data[0]) { packet->data[0] = 1; - send_packet(n, packet); + send_udppacket(n, packet); } else { if(len > n->maxmtu) len = n->maxmtu; @@ -521,12 +521,16 @@ static node_t *try_harder(const sockaddr_t *from, const vpn_packet_t *pkt) { avl_node_t *node; edge_t *e; node_t *n = NULL; + static time_t last_hard_try = 0; for(node = edge_weight_tree->head; node; node = node->next) { e = node->data; - if(sockaddrcmp_noport(from, &e->address)) - continue; + if(sockaddrcmp_noport(from, &e->address)) { + if(last_hard_try == now) + continue; + last_hard_try = now; + } if(!n) n = e->to;