Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/bsd/dhcpcd/dist Import dhcpcd-7.0.2 with the follow...



details:   https://anonhg.NetBSD.org/src/rev/7484627f3cc3
branches:  trunk
changeset: 360715:7484627f3cc3
user:      roy <roy%NetBSD.org@localhost>
date:      Tue Mar 27 06:14:39 2018 +0000

description:
Import dhcpcd-7.0.2 with the following changes:

  *  Added support for setproctitle(3)
  *  Kernel RA is no longer disabled when IPv6 is disabled in dhcpcd
  *  DHCPv6 PD is no longer stopped if no Routers are found
  *  If the DHCP leased address is deleted, enter the reboot state
  *  DHCPv6 unicast is no longer performed when not in master mode
  *  dhcpcd will now detect netlink/route socket overflows ad re-sync

diffstat:

 external/bsd/dhcpcd/dist/configure                   |   21 +
 external/bsd/dhcpcd/dist/hooks/dhcpcd-run-hooks.8.in |   15 +-
 external/bsd/dhcpcd/dist/src/arp.c                   |   32 +-
 external/bsd/dhcpcd/dist/src/common.h                |    2 +-
 external/bsd/dhcpcd/dist/src/defs.h                  |    2 +-
 external/bsd/dhcpcd/dist/src/dhcp.h                  |    2 +-
 external/bsd/dhcpcd/dist/src/dhcp6.c                 |   79 +++---
 external/bsd/dhcpcd/dist/src/dhcp6.h                 |    2 +-
 external/bsd/dhcpcd/dist/src/dhcpcd.conf.5.in        |    6 +-
 external/bsd/dhcpcd/dist/src/dhcpcd.h                |    1 +
 external/bsd/dhcpcd/dist/src/if-bsd.c                |  217 ++++++++----------
 external/bsd/dhcpcd/dist/src/if-linux.c              |   52 +--
 external/bsd/dhcpcd/dist/src/if-sun.c                |   10 +-
 external/bsd/dhcpcd/dist/src/if.c                    |   34 ++-
 external/bsd/dhcpcd/dist/src/if.h                    |    4 +-
 external/bsd/dhcpcd/dist/src/ipv4.c                  |   71 +++++-
 external/bsd/dhcpcd/dist/src/ipv4.h                  |    7 +-
 external/bsd/dhcpcd/dist/src/ipv6.c                  |   62 +++-
 external/bsd/dhcpcd/dist/src/ipv6.h                  |    8 +-
 external/bsd/dhcpcd/dist/src/ipv6nd.c                |   72 +++---
 external/bsd/dhcpcd/dist/src/ipv6nd.h                |    2 +-
 21 files changed, 407 insertions(+), 294 deletions(-)

diffs (truncated from 1390 to 300 lines):

diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/configure
--- a/external/bsd/dhcpcd/dist/configure        Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/configure        Tue Mar 27 06:14:39 2018 +0000
@@ -799,6 +799,27 @@
        fi
 fi
 
+if [ -z "$SETPROCTITLE" ]; then
+       printf "Testing for setproctitle ... "
+       cat << EOF >_setproctitle.c
+#include <stdlib.h>
+int main(void) {
+       setproctitle("foo");
+       return 0;
+}
+EOF
+       if $XCC _setproctitle.c -o _setproctitle 2>&3; then
+               SETPROCTITLE=yes
+       else
+               SETPROCTITLE=no
+       fi
+       echo "$SETPROCTITLE"
+       rm -f _setproctitle.c _setproctitle
+fi
+if [ "$SETPROCTITLE" = yes ]; then
+       echo "#define   HAVE_SETPROCTITLE" >>$CONFIG_H
+fi
+
 if [ -z "$STRTOI" ]; then
        printf "Testing for strtoi ... "
        cat <<EOF >_strtoi.c
diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/hooks/dhcpcd-run-hooks.8.in
--- a/external/bsd/dhcpcd/dist/hooks/dhcpcd-run-hooks.8.in      Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/hooks/dhcpcd-run-hooks.8.in      Tue Mar 27 06:14:39 2018 +0000
@@ -22,7 +22,7 @@
 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 .\" SUCH DAMAGE.
 .\"
-.Dd November 3, 2017
+.Dd February 20, 2018
 .Dt DHCPCD-RUN-HOOKS 8
 .Os
 .Sh NAME
@@ -47,6 +47,19 @@
 A test hook is also supplied that simply echos the dhcp variables to the
 console from DISCOVER message.
 .Pp
+The hooks scripts are loaded into the current shell rather than executed
+in their own process.
+This allows each hook script, such as
+.Pa @SYSCONFDIR@/dhcpcd.enter-hook
+to customise environment variables or provide alternative functions to hooks
+further down the chain.
+As such, using the shell builtins
+.Ic exit ,
+.Ic exec
+or similar will cause
+.Nm
+to exit at that point.
+.Pp
 Each time
 .Nm
 is invoked,
diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/src/arp.c
--- a/external/bsd/dhcpcd/dist/src/arp.c        Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/src/arp.c        Tue Mar 27 06:14:39 2018 +0000
@@ -561,28 +561,28 @@
 void
 arp_handleifa(int cmd, struct ipv4_addr *addr)
 {
-#ifdef IN_IFF_DUPLICATED
        struct iarp_state *state;
        struct arp_state *astate, *asn;
 
-       /* If the address is deleted, the ARP state should be freed by the
-        * state owner, such as DHCP or IPv4LL. */
-       if (cmd != RTM_NEWADDR || (state = ARP_STATE(addr->iface)) == NULL)
+       state = ARP_STATE(addr->iface);
+       if (state == NULL)
                return;
 
        TAILQ_FOREACH_SAFE(astate, &state->arp_states, next, asn) {
-               if (astate->addr.s_addr == addr->addr.s_addr) {
-                       if (addr->addr_flags & IN_IFF_DUPLICATED) {
-                               if (astate->conflicted_cb)
-                                       astate->conflicted_cb(astate, NULL);
-                       } else if (!(addr->addr_flags & IN_IFF_NOTUSEABLE)) {
-                               if (astate->probed_cb)
-                                       astate->probed_cb(astate);
-                       }
+               if (astate->addr.s_addr != addr->addr.s_addr)
+                       continue;
+               if (cmd == RTM_DELADDR)
+                       arp_free(astate);
+#ifdef IN_IFF_DUPLICATED
+               if (cmd != RTM_NEWADDR)
+                       continue;
+               if (addr->addr_flags & IN_IFF_DUPLICATED) {
+                       if (astate->conflicted_cb)
+                               astate->conflicted_cb(astate, NULL);
+               } else if (!(addr->addr_flags & IN_IFF_NOTUSEABLE)) {
+                       if (astate->probed_cb)
+                               astate->probed_cb(astate);
                }
+#endif
        }
-#else
-       UNUSED(cmd);
-       UNUSED(addr);
-#endif
 }
diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/src/common.h
--- a/external/bsd/dhcpcd/dist/src/common.h     Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/src/common.h     Tue Mar 27 06:14:39 2018 +0000
@@ -141,7 +141,7 @@
 #  define      __CTASSERT99(x, a, b)   __CTASSERT0(x, __CONCAT(__ctassert,a), \
                                               __CONCAT(_,b))
 # endif
-# define       __CTASSERT0(x, y, z)    __CTASSERT1(x, y, z) 
+# define       __CTASSERT0(x, y, z)    __CTASSERT1(x, y, z)
 # define       __CTASSERT1(x, y, z)    typedef char y ## z[/*CONSTCOND*/(x) ? 1 : -1] __unused
 #endif
 
diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/src/defs.h
--- a/external/bsd/dhcpcd/dist/src/defs.h       Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/src/defs.h       Tue Mar 27 06:14:39 2018 +0000
@@ -28,7 +28,7 @@
 #define CONFIG_H
 
 #define PACKAGE                        "dhcpcd"
-#define VERSION                        "7.0.1"
+#define VERSION                        "7.0.2"
 
 #ifndef CONFIG
 # define CONFIG                        SYSCONFDIR "/" PACKAGE ".conf"
diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/src/dhcp.h
--- a/external/bsd/dhcpcd/dist/src/dhcp.h       Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/src/dhcp.h       Tue Mar 27 06:14:39 2018 +0000
@@ -254,7 +254,7 @@
 ssize_t dhcp_env(char **, const char *, const struct bootp *, size_t,
     const struct interface *);
 
-void dhcp_handleifa(int, struct ipv4_addr *);
+void dhcp_handleifa(int, struct ipv4_addr *, pid_t pid);
 void dhcp_drop(struct interface *, const char *);
 void dhcp_start(struct interface *);
 void dhcp_abort(struct interface *);
diff -r 53e7b2f9f084 -r 7484627f3cc3 external/bsd/dhcpcd/dist/src/dhcp6.c
--- a/external/bsd/dhcpcd/dist/src/dhcp6.c      Mon Mar 26 21:43:30 2018 +0000
+++ b/external/bsd/dhcpcd/dist/src/dhcp6.c      Tue Mar 27 06:14:39 2018 +0000
@@ -777,6 +777,15 @@
                return -1;
        }
 
+       /* In non master mode we listen and send from fixed addresses.
+        * We should try and match an address we have to unicast to,
+        * but for now this is the safest policy. */
+       if (unicast != NULL && !(ifp->ctx->options & DHCPCD_MASTER)) {
+               logdebugx("%s: ignoring unicast option as not master",
+                   ifp->name);
+               unicast = NULL;
+       }
+
 #ifdef AUTH
        auth_len = 0;
        if (ifo->auth.options & DHCPCD_AUTH_SEND) {
@@ -1092,6 +1101,8 @@
        uint8_t neg;
        const char *broad_uni;
        const struct in6_addr alldhcp = IN6ADDR_LINKLOCAL_ALLDHCP_INIT;
+       struct ipv6_addr *lla;
+       int s;
 
        if (!callback && ifp->carrier == LINK_DOWN)
                return 0;
@@ -1104,12 +1115,13 @@
 #endif
 
        state = D6_STATE(ifp);
+       lla = ipv6_linklocal(ifp);
        /* We need to ensure we have sufficient scope to unicast the address */
        /* XXX FIXME: We should check any added addresses we have like from
         * a Router Advertisement */
        if (IN6_IS_ADDR_UNSPECIFIED(&state->unicast) ||
            (state->state == DH6S_REQUEST &&
-           (!IN6_IS_ADDR_LINKLOCAL(&state->unicast) || !ipv6_linklocal(ifp))))
+           (!IN6_IS_ADDR_LINKLOCAL(&state->unicast) || lla == NULL)))
        {
                dst.sin6_addr = alldhcp;
                broad_uni = "broadcasting";
@@ -1251,7 +1263,16 @@
                ctx->sndhdr.msg_controllen = 0;
        }
 
-       if (sendmsg(ctx->dhcp6_fd, &ctx->sndhdr, 0) == -1) {
+       if (ctx->dhcp6_fd != -1)
+               s = ctx->dhcp6_fd;
+       else if (lla != NULL && lla->dhcp6_fd != -1)
+               s = lla->dhcp6_fd;
+       else {
+               logerrx("%s: no socket to send from", ifp->name);
+               return -1;
+       }
+
+       if (sendmsg(s, &ctx->sndhdr, 0) == -1) {
                logerr("%s: %s: sendmsg", __func__, ifp->name);
                /* Allow DHCPv6 to continue .... the errors
                 * would be rate limited by the protocol.
@@ -3551,19 +3572,16 @@
        if (ia != NULL) {
                memcpy(&sa.sin6_addr, &ia->addr, sizeof(sa.sin6_addr));
                sa.sin6_scope_id = ia->iface->index;
-       } else if (!(ctx->options & DHCPCD_MASTER))
-               /* This socket is only used for sending. */
-               return s;
+       }
 
        if (bind(s, (struct sockaddr *)&sa, sizeof(sa)) == -1)
                goto errexit;
 
-       if (ia == NULL) {
-               n = 1;
-               if (setsockopt(s, IPPROTO_IPV6, IPV6_RECVPKTINFO,
-                   &n, sizeof(n)) == -1)
-                       goto errexit;
-       } else {
+       n = 1;
+       if (setsockopt(s, IPPROTO_IPV6, IPV6_RECVPKTINFO, &n, sizeof(n)) == -1)
+               goto errexit;
+
+       if (ia != NULL) {
                ia->dhcp6_fd = s;
                eloop_event_add(ctx->eloop, s, dhcp6_recvaddr, ia);
        }
@@ -3577,18 +3595,6 @@
        return -1;
 }
 
-static int
-dhcp6_open(struct dhcpcd_ctx *ctx)
-{
-
-       /* Open an unbound socket to send from. */
-       ctx->dhcp6_fd = dhcp6_listen(ctx, NULL);
-       if (ctx->dhcp6_fd != -1 && (ctx->options & DHCPCD_MASTER))
-               eloop_event_add(ctx->eloop, ctx->dhcp6_fd, dhcp6_recvctx, ctx);
-
-       return ctx->dhcp6_fd;
-}
-
 #ifndef SMALL
 static void
 dhcp6_activateinterfaces(struct interface *ifp)
@@ -3623,13 +3629,18 @@
 dhcp6_start1(void *arg)
 {
        struct interface *ifp = arg;
+       struct dhcpcd_ctx *ctx = ifp->ctx;
        struct if_options *ifo = ifp->options;
        struct dhcp6_state *state;
        size_t i;
        const struct dhcp_compat *dhc;
 
-       if (ifp->ctx->dhcp6_fd == -1 && dhcp6_open(ifp->ctx) == -1)
-               return;
+       if (ctx->dhcp6_fd == -1 && ctx->options & DHCPCD_MASTER) {
+               ctx->dhcp6_fd = dhcp6_listen(ctx, NULL);
+               if (ctx->dhcp6_fd == -1)
+                       return;
+               eloop_event_add(ctx->eloop, ctx->dhcp6_fd, dhcp6_recvctx, ctx);
+       }
 
        state = D6_STATE(ifp);
        /* If no DHCPv6 options are configured,
@@ -3858,22 +3869,20 @@
 void
 dhcp6_dropnondelegates(struct interface *ifp)
 {
+
 #ifndef SMALL
-       struct dhcp6_state *state;
-       struct ipv6_addr *ia;
-
-       if ((state = D6_STATE(ifp)) == NULL)
+       if (dhcp6_hasprefixdelegation(ifp))
                return;
-       TAILQ_FOREACH(ia, &state->addrs, next) {
-               if (ia->flags & (IPV6_AF_DELEGATED | IPV6_AF_DELEGATEDPFX))
-                       return;
-       }
 #endif
+       if (D6_CSTATE(ifp) == NULL)
+               return;
+
+       loginfox("%s: dropping DHCPv6 due to no valid routers", ifp->name);
        dhcp6_drop(ifp, "EXPIRE6");
 }
 
 void
-dhcp6_handleifa(int cmd, struct ipv6_addr *ia)



Home | Main Index | Thread Index | Old Index