along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: graph.c,v 1.1.2.31 2003/12/20 19:47:52 guus Exp $
+ $Id: graph.c,v 1.1.2.32 2003/12/20 21:09:33 guus Exp $
*/
/* We need to generate two trees from the graph:
avl_insert_node(node_udp_tree, node);
if(e->to->options & OPTION_DONTFRAGMENT) {
+ e->to->mtu = MTU;
e->to->mtuprobes = 0;
+ e->to->probedmtu = 0;
if(e->to->status.validkey)
send_mtu_probe(e->to);
}
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: net_packet.c,v 1.1.2.45 2003/12/20 19:47:52 guus Exp $
+ $Id: net_packet.c,v 1.1.2.46 2003/12/20 21:09:33 guus Exp $
*/
#include "system.h"
n->mtuprobes++;
+ if(n->mtuprobes >= 10 && !n->probedmtu) {
+ ifdebug(TRAFFIC) logger(LOG_INFO, _("No response to MTU probes from %s (%s)"), n->name, n->hostname);
+ return;
+ }
+
for(i = 0; i < 3; i++) {
- if(n->mtuprobes >= 100 || n->probedmtu >= n->mtu) {
+ if(n->mtuprobes >= 30 || n->probedmtu >= n->mtu) {
n->mtu = n->probedmtu;
ifdebug(TRAFFIC) logger(LOG_INFO, _("Fixing MTU of %s (%s) to %d after %d probes"), n->name, n->hostname, n->mtu, n->mtuprobes);
return;
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: net_setup.c,v 1.1.2.48 2003/12/20 19:47:52 guus Exp $
+ $Id: net_setup.c,v 1.1.2.49 2003/12/20 21:09:33 guus Exp $
*/
#include "system.h"
if(get_config_bool(lookup_config(myself->connection->config_tree, "TCPOnly"), &choice) && choice)
myself->options |= OPTION_TCPONLY;
- if(get_config_bool(lookup_config(myself->connection->config_tree, "DontFragment"), &choice) && choice)
+ if(get_config_bool(lookup_config(myself->connection->config_tree, "PMTUDiscovery"), &choice) && choice)
myself->options |= OPTION_DONTFRAGMENT;
if(myself->options & OPTION_TCPONLY)
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: net_socket.c,v 1.1.2.36 2003/12/20 19:47:52 guus Exp $
+ $Id: net_socket.c,v 1.1.2.37 2003/12/20 21:09:33 guus Exp $
*/
#include "system.h"
{
bool choice;
- if(get_config_bool(lookup_config(myself->connection->config_tree, "DontFragment"), &choice) && choice) {
+ if(sa->sa.sa_family == AF_INET && get_config_bool(lookup_config(myself->connection->config_tree, "PMTUDiscovery"), &choice) && choice) {
option = IP_PMTUDISC_DO;
if(setsockopt(nfd, SOL_IP, IP_MTU_DISCOVER, &option, sizeof(option))) {
closesocket(nfd);
- logger(LOG_ERR, _("Can't set MTU discovery mode: %s"), strerror(errno));
+ logger(LOG_ERR, _("Can't set PMTU discovery mode: %s"), strerror(errno));
+ return -1;
+ }
+ }
+ }
+#endif
+
+#if defined(SOL_IPV6) && defined(IPV6_MTU_DISCOVER) && defined(IPV6_PMTUDISC_DO)
+ {
+ bool choice;
+
+ if(sa->sa.sa_family == AF_INET6 && get_config_bool(lookup_config(myself->connection->config_tree, "PMTUDiscovery"), &choice) && choice) {
+ option = IPV6_PMTUDISC_DO;
+ if(setsockopt(nfd, SOL_IPV6, IPV6_MTU_DISCOVER, &option, sizeof(option))) {
+ closesocket(nfd);
+ logger(LOG_ERR, _("Can't set PMTU discovery mode: %s"), strerror(errno));
return -1;
}
}
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: protocol_auth.c,v 1.1.4.31 2003/12/20 19:47:52 guus Exp $
+ $Id: protocol_auth.c,v 1.1.4.32 2003/12/20 21:09:33 guus Exp $
*/
#include "system.h"
if((get_config_bool(lookup_config(c->config_tree, "TCPOnly"), &choice) && choice) || myself->options & OPTION_TCPONLY)
c->options |= OPTION_TCPONLY | OPTION_INDIRECT;
- if((get_config_bool(lookup_config(c->config_tree, "DontFragment"), &choice) && choice) || myself->options & OPTION_DONTFRAGMENT)
+ if((get_config_bool(lookup_config(c->config_tree, "PMTUDiscovery"), &choice) && choice) || myself->options & OPTION_DONTFRAGMENT)
c->options |= OPTION_DONTFRAGMENT;
return send_request(c, "%d %s %d %lx", ACK, myport, c->estimated_weight, c->options);