diff options
author | Sebastian Benoit <benno@cvs.openbsd.org> | 2015-10-23 12:22:03 +0000 |
---|---|---|
committer | Sebastian Benoit <benno@cvs.openbsd.org> | 2015-10-23 12:22:03 +0000 |
commit | 0e122f4129cacadda4c2e7bf4ca2aef903981bea (patch) | |
tree | 77134bee129cc31e89e5e7e3c65de07a029a8640 | |
parent | e351d7e37d25278b1f85947e20460f0d13431a9c (diff) |
let the icmp check use getsockopt IP_IPDEFTTL to get the default ttl
instead of using sysctl. makes it possible to pledge hce.
-rw-r--r-- | usr.sbin/relayd/check_icmp.c | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/usr.sbin/relayd/check_icmp.c b/usr.sbin/relayd/check_icmp.c index cf2b10f6b57..077e30adde9 100644 --- a/usr.sbin/relayd/check_icmp.c +++ b/usr.sbin/relayd/check_icmp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: check_icmp.c,v 1.41 2015/08/21 08:45:51 yasuoka Exp $ */ +/* $OpenBSD: check_icmp.c,v 1.42 2015/10/23 12:22:02 benno Exp $ */ /* * Copyright (c) 2006 Pierre-Yves Ritschard <pyr@openbsd.org> @@ -166,9 +166,8 @@ send_icmp(int s, short event, void *arg) struct icmp6_hdr *icp6; ssize_t r; u_char packet[ICMP_BUF_SIZE]; - socklen_t slen; - int i = 0, ttl, mib[4]; - size_t len; + socklen_t slen, len; + int i = 0, ttl; u_int32_t id; if (event == EV_TIMEOUT) { @@ -227,14 +226,13 @@ send_icmp(int s, short event, void *arg) &host->conf.ttl, sizeof(int)); else { /* Revert to default TTL */ - mib[0] = CTL_NET; - mib[1] = cie->af; - mib[2] = IPPROTO_IP; - mib[3] = IPCTL_DEFTTL; len = sizeof(ttl); - if (sysctl(mib, 4, &ttl, &len, NULL, 0) == 0) + if (getsockopt(s, IPPROTO_IP, IP_IPDEFTTL, + &ttl, &len) == 0) (void)setsockopt(s, IPPROTO_IP, IP_TTL, - &ttl, sizeof(int)); + &ttl, len); + else + log_warn("%s: getsockopt",__func__); } r = sendto(s, packet, sizeof(packet), 0, to, slen); |