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.0-beta3 with the ...



details:   https://anonhg.NetBSD.org/src/rev/1e405590b78f
branches:  trunk
changeset: 352914:1e405590b78f
user:      roy <roy%NetBSD.org@localhost>
date:      Fri Apr 14 09:53:06 2017 +0000

description:
Import dhcpcd-7.0.0-beta3 with the following changes:
  *  restored --logfile support as a few people complained it vanished
     The new logging code even makes the overall binary size smaller
     on most platforms.
  *  BPF filter now trims garbage trailing the payload
     OK, it's not garbage, but userland doesn't know some drivers append
     FCS to it.
  *  support NetBSD's RO_MSGFILTER socket option to reduce avoid context
     switching for route(4) messages that don't interest us.
  *  Don't open sockets if just sending signals.
  *  HMAC-MD5 test's now check expectations in code rather than relying
     on visual confirmation.
  *  added eloop-bench to test performance of eloop with available
     polling mechanisms.

diffstat:

 external/bsd/dhcpcd/dist/BUILDING.md                     |    2 +-
 external/bsd/dhcpcd/dist/Makefile                        |   10 +-
 external/bsd/dhcpcd/dist/compat/dprintf.c                |    5 +-
 external/bsd/dhcpcd/dist/compat/dprintf.h                |    2 +-
 external/bsd/dhcpcd/dist/src/Makefile                    |    7 +-
 external/bsd/dhcpcd/dist/src/arp.c                       |   46 +-
 external/bsd/dhcpcd/dist/src/bpf.h                       |    2 +-
 external/bsd/dhcpcd/dist/src/common.c                    |    7 +-
 external/bsd/dhcpcd/dist/src/control.c                   |    6 +-
 external/bsd/dhcpcd/dist/src/defs.h                      |    2 +-
 external/bsd/dhcpcd/dist/src/dev.c                       |   21 +-
 external/bsd/dhcpcd/dist/src/dhcp-common.c               |   17 +-
 external/bsd/dhcpcd/dist/src/dhcp.c                      |  290 +++++------
 external/bsd/dhcpcd/dist/src/dhcp6.c                     |  290 +++++------
 external/bsd/dhcpcd/dist/src/dhcpcd.8.in                 |   17 +-
 external/bsd/dhcpcd/dist/src/dhcpcd.conf.5.in            |   16 +-
 external/bsd/dhcpcd/dist/src/dhcpcd.h                    |    2 +-
 external/bsd/dhcpcd/dist/src/duid.c                      |   22 +-
 external/bsd/dhcpcd/dist/src/eloop.c                     |   26 +-
 external/bsd/dhcpcd/dist/src/if-bsd.c                    |   75 ++-
 external/bsd/dhcpcd/dist/src/if-linux.c                  |   24 +-
 external/bsd/dhcpcd/dist/src/if-options.h                |    2 +-
 external/bsd/dhcpcd/dist/src/if.c                        |   27 +-
 external/bsd/dhcpcd/dist/src/ipv4.c                      |   39 +-
 external/bsd/dhcpcd/dist/src/ipv4ll.c                    |   27 +-
 external/bsd/dhcpcd/dist/src/ipv6.c                      |   80 +-
 external/bsd/dhcpcd/dist/src/ipv6nd.c                    |  161 ++---
 external/bsd/dhcpcd/dist/src/logerr.c                    |  368 +++++++++++++++
 external/bsd/dhcpcd/dist/src/logerr.h                    |   77 +++
 external/bsd/dhcpcd/dist/src/route.c                     |   26 +-
 external/bsd/dhcpcd/dist/src/script.c                    |   27 +-
 external/bsd/dhcpcd/dist/tests/Makefile                  |   16 +
 external/bsd/dhcpcd/dist/tests/crypt/.gitignore          |    1 +
 external/bsd/dhcpcd/dist/tests/crypt/GNUmakefile         |    7 +
 external/bsd/dhcpcd/dist/tests/crypt/Makefile            |   38 +
 external/bsd/dhcpcd/dist/tests/crypt/README.md           |    8 +
 external/bsd/dhcpcd/dist/tests/crypt/run-test.c          |   38 +
 external/bsd/dhcpcd/dist/tests/crypt/test.h              |   32 +
 external/bsd/dhcpcd/dist/tests/crypt/test_hmac_md5.c     |  207 ++++++++
 external/bsd/dhcpcd/dist/tests/eloop-bench/.gitignore    |    1 +
 external/bsd/dhcpcd/dist/tests/eloop-bench/Makefile      |   42 +
 external/bsd/dhcpcd/dist/tests/eloop-bench/README.md     |   53 ++
 external/bsd/dhcpcd/dist/tests/eloop-bench/eloop-bench.c |  166 ++++++
 43 files changed, 1688 insertions(+), 644 deletions(-)

diffs (truncated from 5655 to 300 lines):

diff -r 46f15ace3684 -r 1e405590b78f external/bsd/dhcpcd/dist/BUILDING.md
--- a/external/bsd/dhcpcd/dist/BUILDING.md      Fri Apr 14 09:50:56 2017 +0000
+++ b/external/bsd/dhcpcd/dist/BUILDING.md      Fri Apr 14 09:53:06 2017 +0000
@@ -11,7 +11,7 @@
 size is a concern, you can use the `--small` configure option to enable
 a reduced feature set within dhcpcd.
 Currently this just removes non important options out of
-`dhcpcd-definitions.conf`, the custom logger and
+`dhcpcd-definitions.conf`, the logfile option and
 support for DHCPv6 Prefix Delegation.
 Other features maybe dropped as and when required.
 dhcpcd can also be made smaller by removing the IPv4 or IPv6 stack:
diff -r 46f15ace3684 -r 1e405590b78f external/bsd/dhcpcd/dist/Makefile
--- a/external/bsd/dhcpcd/dist/Makefile Fri Apr 14 09:50:56 2017 +0000
+++ b/external/bsd/dhcpcd/dist/Makefile Fri Apr 14 09:53:06 2017 +0000
@@ -16,7 +16,7 @@
 
 CLEANFILES+=   *.tar.xz
 
-.PHONY:                hooks import import-bsd test
+.PHONY:                hooks import import-bsd tests
 
 .SUFFIXES:     .in
 
@@ -26,8 +26,10 @@
 depend: config.h
        for x in ${SUBDIRS}; do cd $$x; ${MAKE} $@; cd ..; done
 
-test:
-       cd $@; ${MAKE} $@; ./$@
+tests:
+       cd $@; ${MAKE} $@
+
+test: tests
 
 hooks:
        cd $@; ${MAKE}
@@ -43,7 +45,7 @@
 
 clean:
        rm -rf cov-int
-       for x in ${SUBDIRS} test; do cd $$x; ${MAKE} $@; cd ..; done
+       for x in ${SUBDIRS} tests; do cd $$x; ${MAKE} $@; cd ..; done
 
 distclean: clean
        rm -f config.h config.mk config.log \
diff -r 46f15ace3684 -r 1e405590b78f external/bsd/dhcpcd/dist/compat/dprintf.c
--- a/external/bsd/dhcpcd/dist/compat/dprintf.c Fri Apr 14 09:50:56 2017 +0000
+++ b/external/bsd/dhcpcd/dist/compat/dprintf.c Fri Apr 14 09:53:06 2017 +0000
@@ -1,6 +1,6 @@
 /*
  * dhcpcd - DHCP client daemon
- * Copyright (c) 2006-2014 Roy Marples <roy%marples.name@localhost>
+ * Copyright (c) 2006-2017 Roy Marples <roy%marples.name@localhost>
  * All rights reserved
 
  * Redistribution and use in source and binary forms, with or without
@@ -41,7 +41,7 @@
        if ((e = dup(fd)) == -1)
                return -1;
 
-       if ((fp = fdopen(e, "w")) == NULL) {
+       if ((fp = fdopen(e, "a")) == NULL) {
                close(e);
                return -1;
        }
@@ -62,4 +62,3 @@
        va_end(va);
        return e;
 }
-
diff -r 46f15ace3684 -r 1e405590b78f external/bsd/dhcpcd/dist/compat/dprintf.h
--- a/external/bsd/dhcpcd/dist/compat/dprintf.h Fri Apr 14 09:50:56 2017 +0000
+++ b/external/bsd/dhcpcd/dist/compat/dprintf.h Fri Apr 14 09:53:06 2017 +0000
@@ -1,6 +1,6 @@
 /*
  * dhcpcd - DHCP client daemon
- * Copyright (c) 2006-2014 Roy Marples <roy%marples.name@localhost>
+ * Copyright (c) 2006-2017 Roy Marples <roy%marples.name@localhost>
  * All rights reserved
 
  * Redistribution and use in source and binary forms, with or without
diff -r 46f15ace3684 -r 1e405590b78f external/bsd/dhcpcd/dist/src/Makefile
--- a/external/bsd/dhcpcd/dist/src/Makefile     Fri Apr 14 09:50:56 2017 +0000
+++ b/external/bsd/dhcpcd/dist/src/Makefile     Fri Apr 14 09:53:06 2017 +0000
@@ -1,12 +1,12 @@
 # dhcpcd Makefile
 
 PROG=          dhcpcd
-SRCS=          common.c control.c dhcpcd.c duid.c eloop.c
+SRCS=          common.c control.c dhcpcd.c duid.c eloop.c logerr.c
 SRCS+=         if.c if-options.c sa.c route.c
 SRCS+=         dhcp-common.c script.c
 
 CFLAGS?=       -O2
-MKDIRS=
+SUBDIRS+=      ${MKDIRS}
 
 TOP?=          ..
 include ${TOP}/iconfig.mk
@@ -45,6 +45,7 @@
                $< > $@
 
 all: ${TOP}/config.h ${PROG} ${SCRIPTS} ${MAN5} ${MAN8}
+       for x in ${SUBDIRS}; do cd $$x; ${MAKE} $@; cd ..; done
 
 dev:
        cd dev && ${MAKE}
@@ -80,6 +81,7 @@
        ${INSTALL} -d ${DESTDIR}${DBDIR}
 
 proginstall: _proginstall ${EMBEDDEDINSTALL}
+       for x in ${SUBDIRS}; do cd $$x; ${MAKE} $@; cd ..; done
 
 _maninstall: ${MAN5} ${MAN8}
        ${INSTALL} -d ${DESTDIR}${MANDIR}/man5
@@ -125,6 +127,7 @@
 
 clean:
        rm -f ${OBJS} ${PROG} ${PROG}.core ${CLEANFILES}
+       for x in ${SUBDIRS}; do cd $$x; ${MAKE} $@; cd ..; done
 
 distclean: clean
        rm -f .depend
diff -r 46f15ace3684 -r 1e405590b78f external/bsd/dhcpcd/dist/src/arp.c
--- a/external/bsd/dhcpcd/dist/src/arp.c        Fri Apr 14 09:50:56 2017 +0000
+++ b/external/bsd/dhcpcd/dist/src/arp.c        Fri Apr 14 09:53:06 2017 +0000
@@ -38,7 +38,6 @@
 #include <signal.h>
 #include <stdlib.h>
 #include <string.h>
-#include <syslog.h>
 #include <unistd.h>
 
 #define ELOOP_QUEUE 5
@@ -52,6 +51,7 @@
 #include "if.h"
 #include "if-options.h"
 #include "ipv4ll.h"
+#include "logerr.h"
 
 #if defined(ARP) && (!defined(KERNEL_RFC5227) || defined(ARPING))
 #define ARP_LEN                                                                      \
@@ -152,7 +152,7 @@
        }
        if (ifn) {
 #ifdef ARP_DEBUG
-               syslog(LOG_DEBUG, "%s: ignoring ARP from self", ifp->name);
+               logdebugx("%s: ignoring ARP from self", ifp->name);
 #endif
                return;
        }
@@ -180,7 +180,7 @@
 
        if ((state = ARP_STATE(ifp)) != NULL && state->fd != -1) {
                eloop_event_delete(ifp->ctx->eloop, state->fd);
-               bpf_close(state->fd);
+               bpf_close(ifp, state->fd);
                state->fd = -1;
        }
 }
@@ -202,7 +202,7 @@
        while (!(flags & BPF_EOF)) {
                bytes = bpf_read(ifp, state->fd, buf, sizeof(buf), &flags);
                if (bytes == -1) {
-                       syslog(LOG_ERR, "%s: arp bpf_read: %m", ifp->name);
+                       logerr("%s: %s", __func__, ifp->name);
                        arp_close(ifp);
                        return;
                }
@@ -222,7 +222,7 @@
        if (state->fd == -1) {
                state->fd = bpf_open(ifp, bpf_arp);
                if (state->fd == -1) {
-                       syslog(LOG_ERR, "%s: %s: %m", __func__, ifp->name);
+                       logerr("%s: %s", __func__, ifp->name);
                        return -1;
                }
                eloop_event_add(ifp->ctx->eloop, state->fd, arp_read, ifp);
@@ -256,13 +256,12 @@
                tv.tv_nsec = 0;
                eloop_timeout_add_tv(ifp->ctx->eloop, &tv, arp_probed, astate);
        }
-       syslog(LOG_DEBUG,
-           "%s: ARP probing %s (%d of %d), next in %0.1f seconds",
+       logdebugx("%s: ARP probing %s (%d of %d), next in %0.1f seconds",
            ifp->name, inet_ntoa(astate->addr),
            astate->probes ? astate->probes : PROBE_NUM, PROBE_NUM,
            timespec_to_double(&tv));
        if (arp_request(ifp, 0, astate->addr.s_addr) == -1)
-               syslog(LOG_ERR, "send_arp: %m");
+               logerr(__func__);
 }
 
 void
@@ -270,15 +269,16 @@
 {
 
        if (arp_open(astate->iface) == -1) {
-               syslog(LOG_ERR, "%s: %s: %m", __func__, astate->iface->name);
+               logerr(__func__);
                return;
        } else {
                const struct iarp_state *state = ARP_CSTATE(astate->iface);
 
-               bpf_arp(astate->iface, state->fd);
+               if (bpf_arp(astate->iface, state->fd) == -1)
+                       logerr(__func__);
        }
        astate->probes = 0;
-       syslog(LOG_DEBUG, "%s: probing for %s",
+       logdebugx("%s: probing for %s",
            astate->iface->name, inet_ntoa(astate->addr));
        arp_probe1(astate);
 }
@@ -311,18 +311,16 @@
        astate->claims++;
 #else
        if (++astate->claims < ANNOUNCE_NUM)
-               syslog(LOG_DEBUG,
-                   "%s: ARP announcing %s (%d of %d), "
+               logdebugx("%s: ARP announcing %s (%d of %d), "
                    "next in %d.0 seconds",
                    ifp->name, inet_ntoa(astate->addr),
                    astate->claims, ANNOUNCE_NUM, ANNOUNCE_WAIT);
        else
-               syslog(LOG_DEBUG,
-                   "%s: ARP announcing %s (%d of %d)",
+               logdebugx("%s: ARP announcing %s (%d of %d)",
                    ifp->name, inet_ntoa(astate->addr),
                    astate->claims, ANNOUNCE_NUM);
        if (arp_request(ifp, astate->addr.s_addr, astate->addr.s_addr) == -1)
-               syslog(LOG_ERR, "arp_request: %m");
+               logerr(__func__);
 #endif
        eloop_timeout_add_sec(ifp->ctx->eloop, ANNOUNCE_WAIT,
            astate->claims < ANNOUNCE_NUM ? arp_announce1 : arp_announced,
@@ -335,7 +333,7 @@
 
 #ifndef KERNEL_RFC5227
        if (arp_open(astate->iface) == -1) {
-               syslog(LOG_ERR, "%s: %s: %m", __func__, astate->iface->name);
+               logerr(__func__);
                return;
        }
 #endif
@@ -352,13 +350,13 @@
        if (amsg != NULL) {
                char buf[HWADDR_LEN * 3];
 
-               syslog(LOG_ERR, "%s: hardware address %s claims %s",
+               logerrx("%s: hardware address %s claims %s",
                    astate->iface->name,
                    hwaddr_ntoa(amsg->sha, astate->iface->hwlen,
                    buf, sizeof(buf)),
                    inet_ntoa(astate->failed));
        } else
-               syslog(LOG_ERR, "%s: DAD detected %s",
+               logerrx("%s: DAD detected %s",
                    astate->iface->name, inet_ntoa(astate->failed));
 }
 
@@ -389,7 +387,7 @@
                ifp->if_data[IF_DATA_ARP] = malloc(sizeof(*state));
                state = ARP_STATE(ifp);
                if (state == NULL) {
-                       syslog(LOG_ERR, "%s: %m", __func__);
+                       logerr(__func__);
                        return NULL;
                }
                state->fd = -1;
@@ -400,7 +398,7 @@
        }
 
        if ((astate = calloc(1, sizeof(*astate))) == NULL) {
-               syslog(LOG_ERR, "%s: %s: %m", ifp->name, __func__);
+               logerr(__func__);
                return NULL;
        }
        astate->iface = ifp;
@@ -409,7 +407,8 @@
        state = ARP_STATE(ifp);
        TAILQ_INSERT_TAIL(&state->arp_states, astate, next);
 
-       bpf_arp(ifp, state->fd);
+       if (bpf_arp(ifp, state->fd) == -1)
+               logerr(__func__); /* try and continue */
 
        return astate;
 }
@@ -444,7 +443,8 @@
                free(state);
                ifp->if_data[IF_DATA_ARP] = NULL;
        } else
-               bpf_arp(ifp, state->fd);
+               if (bpf_arp(ifp, state->fd) == -1)
+                       logerr(__func__);
 }
 
 static void



Home | Main Index | Thread Index | Old Index