Signed-off-by: John Heffner <[EMAIL PROTECTED]> --- tracepath.c | 10 ++++++++-- tracepath6.c | 10 ++++++++-- 2 files changed, 16 insertions(+), 4 deletions(-)
diff --git a/tracepath.c b/tracepath.c index 1f901ba..a562d88 100644 --- a/tracepath.c +++ b/tracepath.c @@ -24,6 +24,10 @@ #include <sys/uio.h> #include <arpa/inet.h> +#ifndef IP_PMTUDISC_PROBE +#define IP_PMTUDISC_PROBE 3 +#endif + struct hhistory { int hops; @@ -322,8 +326,10 @@ main(int argc, char **argv) } memcpy(&target.sin_addr, he->h_addr, 4); - on = IP_PMTUDISC_DO; - if (setsockopt(fd, SOL_IP, IP_MTU_DISCOVER, &on, sizeof(on))) { + on = IP_PMTUDISC_PROBE; + if (setsockopt(fd, SOL_IP, IP_MTU_DISCOVER, &on, sizeof(on)) && + (on = IP_PMTUDISC_DO, + setsockopt(fd, SOL_IP, IP_MTU_DISCOVER, &on, sizeof(on)))) { perror("IP_MTU_DISCOVER"); exit(1); } diff --git a/tracepath6.c b/tracepath6.c index d65230d..6f13a51 100644 --- a/tracepath6.c +++ b/tracepath6.c @@ -30,6 +30,10 @@ #define SOL_IPV6 IPPROTO_IPV6 #endif +#ifndef IPV6_PMTUDISC_PROBE +#define IPV6_PMTUDISC_PROBE 3 +#endif + int overhead = 48; int mtu = 128000; int hops_to = -1; @@ -369,8 +373,10 @@ int main(int argc, char **argv) mapped = 1; } - on = IPV6_PMTUDISC_DO; - if (setsockopt(fd, SOL_IPV6, IPV6_MTU_DISCOVER, &on, sizeof(on))) { + on = IPV6_PMTUDISC_PROBE; + if (setsockopt(fd, SOL_IPV6, IPV6_MTU_DISCOVER, &on, sizeof(on)) && + (on = IPV6_PMTUDISC_DO, + setsockopt(fd, SOL_IPV6, IPV6_MTU_DISCOVER, &on, sizeof(on)))) { perror("IPV6_MTU_DISCOVER"); exit(1); } -- 1.5.0.2.gc260-dirty - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html