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/src Import dhcpcd-7.1.1 with the fo...
details: https://anonhg.NetBSD.org/src/rev/39724d910c4b
branches: trunk
changeset: 996746:39724d910c4b
user: roy <roy%NetBSD.org@localhost>
date: Thu Feb 07 21:34:30 2019 +0000
description:
Import dhcpcd-7.1.1 with the following changes:
* IPv4LL: Fixed build with this disabled
* IPv4LL: Remember last address between carrier resets
* BSD: Fixed initial link infos reported as LINK_STATE_UNKNOWN
diffstat:
external/bsd/dhcpcd/dist/src/arp.c | 4 ++--
external/bsd/dhcpcd/dist/src/arp.h | 4 ++--
external/bsd/dhcpcd/dist/src/common.h | 8 ++++++++
external/bsd/dhcpcd/dist/src/defs.h | 2 +-
external/bsd/dhcpcd/dist/src/dhcp.h | 15 +++------------
external/bsd/dhcpcd/dist/src/dhcp6.h | 21 ++++-----------------
external/bsd/dhcpcd/dist/src/dhcpcd.h | 14 +++++++++-----
external/bsd/dhcpcd/dist/src/if.c | 26 ++++++++++++++++++++++----
external/bsd/dhcpcd/dist/src/ipv4.c | 13 +++++++++----
external/bsd/dhcpcd/dist/src/ipv4.h | 9 ++-------
external/bsd/dhcpcd/dist/src/ipv4ll.h | 6 ------
external/bsd/dhcpcd/dist/src/ipv6.c | 18 ++++++++++++++++--
external/bsd/dhcpcd/dist/src/ipv6.h | 16 +++-------------
external/bsd/dhcpcd/dist/src/ipv6nd.h | 13 ++++---------
external/bsd/dhcpcd/dist/src/script.c | 19 +++++++++++++++----
15 files changed, 100 insertions(+), 88 deletions(-)
diffs (truncated from 636 to 300 lines):
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/arp.c
--- a/external/bsd/dhcpcd/dist/src/arp.c Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/arp.c Thu Feb 07 21:34:30 2019 +0000
@@ -400,7 +400,7 @@
}
void
-arp_announceaddr(struct dhcpcd_ctx *ctx, struct in_addr *ia)
+arp_announceaddr(struct dhcpcd_ctx *ctx, const struct in_addr *ia)
{
struct interface *ifp;
struct ipv4_addr *iaf;
@@ -424,7 +424,7 @@
}
void
-arp_ifannounceaddr(struct interface *ifp, struct in_addr *ia)
+arp_ifannounceaddr(struct interface *ifp, const struct in_addr *ia)
{
struct arp_state *astate;
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/arp.h
--- a/external/bsd/dhcpcd/dist/src/arp.h Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/arp.h Thu Feb 07 21:34:30 2019 +0000
@@ -95,8 +95,8 @@
struct arp_state *arp_new(struct interface *, const struct in_addr *);
struct arp_state *arp_find(struct interface *, const struct in_addr *);
void arp_announce(struct arp_state *);
-void arp_announceaddr(struct dhcpcd_ctx *, struct in_addr *);
-void arp_ifannounceaddr(struct interface *, struct in_addr *);
+void arp_announceaddr(struct dhcpcd_ctx *, const struct in_addr *);
+void arp_ifannounceaddr(struct interface *, const struct in_addr *);
void arp_cancel(struct arp_state *);
void arp_free(struct arp_state *);
void arp_free_but(struct arp_state *);
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/common.h
--- a/external/bsd/dhcpcd/dist/src/common.h Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/common.h Thu Feb 07 21:34:30 2019 +0000
@@ -130,6 +130,14 @@
# endif
#endif
+#ifndef __fallthrough
+# if __GNUC__ >= 7
+# define __fallthrough __attribute__((fallthrough))
+# else
+# define __fallthrough
+# endif
+#endif
+
/*
* Compile Time Assertion.
*/
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/defs.h
--- a/external/bsd/dhcpcd/dist/src/defs.h Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/defs.h Thu Feb 07 21:34:30 2019 +0000
@@ -28,7 +28,7 @@
#define CONFIG_H
#define PACKAGE "dhcpcd"
-#define VERSION "7.1.0"
+#define VERSION "7.1.1"
#ifndef CONFIG
# define CONFIG SYSCONFDIR "/" PACKAGE ".conf"
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/dhcp.h
--- a/external/bsd/dhcpcd/dist/src/dhcp.h Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/dhcp.h Thu Feb 07 21:34:30 2019 +0000
@@ -228,6 +228,7 @@
#endif
};
+#ifdef INET
#define D_STATE(ifp) \
((struct dhcp_state *)(ifp)->if_data[IF_DATA_DHCP])
#define D_CSTATE(ifp) \
@@ -243,7 +244,6 @@
#include "dhcpcd.h"
#include "if-options.h"
-#ifdef INET
char *decode_rfc3361(const uint8_t *, size_t);
ssize_t decode_rfc3442(char *, size_t, const uint8_t *p, size_t);
@@ -266,15 +266,6 @@
void dhcp_close(struct interface *);
void dhcp_free(struct interface *);
int dhcp_dump(struct interface *);
-#else
-#define dhcp_start(a) {}
-#define dhcp_abort(a) {}
-#define dhcp_renew(a) {}
-#define dhcp_reboot(a, b) (b = b)
-#define dhcp_reboot_newopts(a, b) (b = b)
-#define dhcp_close(a) {}
-#define dhcp_free(a) {}
-#define dhcp_dump(a) (-1)
-#endif
+#endif /* INET */
-#endif
+#endif /* DHCP_H */
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/dhcp6.h
--- a/external/bsd/dhcpcd/dist/src/dhcp6.h Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/dhcp6.h Thu Feb 07 21:34:30 2019 +0000
@@ -55,6 +55,8 @@
#define DHCP6_RECONFIGURE_REQ 18
#define DHCP6_RECONFIGURE_REPLY 19
+#ifdef DHCP6
+
#define D6_OPTION_CLIENTID 1
#define D6_OPTION_SERVERID 2
#define D6_OPTION_IA_NA 3
@@ -216,7 +218,6 @@
(D6_CSTATE((ifp)) && \
D6_CSTATE((ifp))->reason && dhcp6_dadcompleted((ifp)))
-#ifdef DHCP6
void dhcp6_printoptions(const struct dhcpcd_ctx *,
const struct dhcp_opt *, size_t);
const struct ipv6_addr *dhcp6_iffindaddr(const struct interface *ifp,
@@ -236,20 +237,6 @@
void dhcp6_drop(struct interface *, const char *);
void dhcp6_dropnondelegates(struct interface *ifp);
int dhcp6_dump(struct interface *);
-#else
-#define dhcp6_printoptions(a, b, c) {}
-#define dhcp6_iffindaddr(a, b, c) (NULL)
-#define dhcp6_findaddr(a, b, c) (NULL)
-#define dhcp6_find_delegates(a) {}
-#define dhcp6_start(a, b) (0)
-#define dhcp6_reboot(a) {}
-#define dhcp6_renew(a) {}
-#define dhcp6_env(a, b, c, d, e) (0)
-#define dhcp6_free(a) {}
-#define dhcp6_dadcompleted(a) (0)
-#define dhcp6_drop(a, b) {}
-#define dhcp6_dropnondelegates(a) {}
-#define dhcp6_dump(a) (-1)
-#endif
+#endif /* DHCP6 */
-#endif
+#endif /* DHCP6_H */
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/dhcpcd.h
--- a/external/bsd/dhcpcd/dist/src/dhcpcd.h Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/dhcpcd.h Thu Feb 07 21:34:30 2019 +0000
@@ -49,9 +49,10 @@
#define IF_ACTIVE 1
#define IF_ACTIVE_USER 2
-#define LINK_UP 1
-#define LINK_UNKNOWN 0
-#define LINK_DOWN -1
+#define LINK_UP 1
+#define LINK_UNKNOWN 0
+#define LINK_DOWN -1
+#define LINK_DOWN_IFFUP -2
#define IF_DATA_IPV4 0
#define IF_DATA_ARP 1
@@ -84,8 +85,9 @@
unsigned short vlanid;
unsigned int metric;
int carrier;
- int wireless;
- uint8_t ssid[IF_SSIDLEN + 1]; /* NULL terminated */
+ bool media_valid;
+ bool wireless;
+ uint8_t ssid[IF_SSIDLEN];
unsigned int ssid_len;
char profile[PROFILE_LEN];
@@ -198,8 +200,10 @@
struct dhcp_opt *nd_opts;
size_t nd_opts_len;
+#ifdef DHCP6
struct dhcp_opt *dhcp6_opts;
size_t dhcp6_opts_len;
+#endif
#ifndef __linux__
int ra_global;
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/if.c
--- a/external/bsd/dhcpcd/dist/src/if.c Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/if.c Thu Feb 07 21:34:30 2019 +0000
@@ -78,12 +78,20 @@
if (ifp == NULL)
return;
+#ifdef IPV4LL
ipv4ll_free(ifp);
+#endif
+#ifdef INET
dhcp_free(ifp);
ipv4_free(ifp);
+#endif
+#ifdef DHCP6
dhcp6_free(ifp);
+#endif
+#ifdef INET6
ipv6nd_free(ifp);
ipv6_free(ifp);
+#endif
rt_freeif(ifp);
free_options(ifp->ctx, ifp->options);
free(ifp);
@@ -147,9 +155,13 @@
strlcpy(ifmr.ifm_name, ifp->name, sizeof(ifmr.ifm_name));
if (ioctl(ifp->ctx->pf_inet_fd, SIOCGIFMEDIA, &ifmr) != -1 &&
ifmr.ifm_status & IFM_AVALID)
+ {
+ ifp->media_valid = true;
r = (ifmr.ifm_status & IFM_ACTIVE) ? LINK_UP : LINK_DOWN;
- else
+ } else {
+ ifp->media_valid = false;
r = ifr.ifr_flags & IFF_RUNNING ? LINK_UP : LINK_UNKNOWN;
+ }
#else
r = ifr.ifr_flags & IFF_RUNNING ? LINK_UP : LINK_DOWN;
#endif
@@ -462,7 +474,7 @@
case IFT_PPP: /* FALLTHROUGH */
#endif
#ifdef IFT_PROPVIRTUAL
- case IFT_PROPVIRTUAL: /* FALLTHROUGH */
+ case IFT_PROPVIRTUAL:
#endif
#if defined(IFT_BRIDGE) || defined(IFT_PPP) || defined(IFT_PROPVIRTUAL)
/* Don't allow unless explicit */
@@ -476,6 +488,7 @@
ifp->name);
active = IF_INACTIVE;
}
+ __fallthrough; /* Appease gcc-7 */
/* FALLTHROUGH */
#endif
#ifdef IFT_L2VLAN
@@ -584,7 +597,7 @@
* we can work them out. */
ifp->metric = 200 + ifp->index;
if (if_getssid(ifp) != -1) {
- ifp->wireless = 1;
+ ifp->wireless = true;
ifp->metric += 100;
}
#endif
@@ -726,19 +739,24 @@
return -1;
if (si->carrier < ti->carrier)
return 1;
-
+#ifdef INET
if (D_STATE_RUNNING(si) && !D_STATE_RUNNING(ti))
return -1;
if (!D_STATE_RUNNING(si) && D_STATE_RUNNING(ti))
return 1;
+#endif
+#ifdef INET6
if (RS_STATE_RUNNING(si) && !RS_STATE_RUNNING(ti))
return -1;
if (!RS_STATE_RUNNING(si) && RS_STATE_RUNNING(ti))
return 1;
+#endif
+#ifdef DHCP6
if (D6_STATE_RUNNING(si) && !D6_STATE_RUNNING(ti))
return -1;
if (!D6_STATE_RUNNING(si) && D6_STATE_RUNNING(ti))
return 1;
+#endif
#ifdef INET
/* Special attention needed here due to states and IPv4LL. */
diff -r 38c24642da76 -r 39724d910c4b external/bsd/dhcpcd/dist/src/ipv4.c
--- a/external/bsd/dhcpcd/dist/src/ipv4.c Thu Feb 07 21:16:35 2019 +0000
+++ b/external/bsd/dhcpcd/dist/src/ipv4.c Thu Feb 07 21:34:30 2019 +0000
@@ -200,8 +200,10 @@
{
const struct dhcp_state *dstate;
+#ifdef IPV4LL
if (IPV4LL_STATE_RUNNING(ifp))
return 1;
+#endif
dstate = D_CSTATE(ifp);
return (dstate &&
@@ -425,20 +427,25 @@
inet_getroutes(struct dhcpcd_ctx *ctx, struct rt_head *routes)
{
struct interface *ifp;
+#ifdef IPV4LL
struct rt def;
bool have_default;
+#endif
TAILQ_FOREACH(ifp, ctx->ifaces, next) {
Home |
Main Index |
Thread Index |
Old Index