Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/ifwatchd Add some consistency for dispatching .... ...
details: https://anonhg.NetBSD.org/src/rev/aaa4fc6b25de
branches: trunk
changeset: 818041:aaa4fc6b25de
user: roy <roy%NetBSD.org@localhost>
date: Wed Sep 21 18:18:10 2016 +0000
description:
Add some consistency for dispatching .... always send the whole message.
diffstat:
usr.sbin/ifwatchd/ifwatchd.c | 55 ++++++++++++++++++++------------------------
1 files changed, 25 insertions(+), 30 deletions(-)
diffs (145 lines):
diff -r a5325d46cd70 -r aaa4fc6b25de usr.sbin/ifwatchd/ifwatchd.c
--- a/usr.sbin/ifwatchd/ifwatchd.c Wed Sep 21 18:00:26 2016 +0000
+++ b/usr.sbin/ifwatchd/ifwatchd.c Wed Sep 21 18:18:10 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ifwatchd.c,v 1.30 2016/09/21 16:47:35 roy Exp $ */
+/* $NetBSD: ifwatchd.c,v 1.31 2016/09/21 18:18:10 roy Exp $ */
/*-
* Copyright (c) 2002, 2003 The NetBSD Foundation, Inc.
@@ -65,12 +65,12 @@
/* local functions */
__dead static void usage(void);
static void dispatch(const void *, size_t);
-static void check_addrs(const char *cp, int addrs, enum event ev);
+static void check_addrs(const struct ifa_msghdr *ifam);
static void invoke_script(const struct sockaddr *sa, const struct sockaddr *dst,
enum event ev, int ifindex, const char *ifname_hint);
static void list_interfaces(const char *ifnames);
static void check_announce(const struct if_announcemsghdr *ifan);
-static void check_carrier(int if_index, int carrier);
+static void check_carrier(const struct if_msghdr *ifm);
static void rescan_interfaces(void);
static void free_interfaces(void);
static int find_interface(int index);
@@ -259,28 +259,22 @@
dispatch(const void *msg, size_t len)
{
const struct rt_msghdr *hd = msg;
- const struct if_msghdr *ifmp;
- const struct ifa_msghdr *ifam;
- enum event ev;
if (hd->rtm_version != RTM_VERSION)
return;
switch (hd->rtm_type) {
case RTM_NEWADDR:
- ev = UP;
- goto work;
case RTM_DELADDR:
- ev = DOWN;
- goto work;
+ check_addrs(msg);
+ break;
case RTM_IFANNOUNCE:
rescan_interfaces();
check_announce(msg);
- return;
+ break;
case RTM_IFINFO:
- ifmp = (const struct if_msghdr*)msg;
- check_carrier(ifmp->ifm_index, ifmp->ifm_data.ifi_link_state);
- return;
+ check_carrier(msg);
+ break;
case RTM_ADD:
case RTM_DELETE:
case RTM_CHANGE:
@@ -291,30 +285,29 @@
case RTM_ONEWADDR:
case RTM_ODELADDR:
case RTM_OCHGADDR:
- return;
+ break;
+ default:
+ if (verbose)
+ printf("unknown message ignored (%d)\n", hd->rtm_type);
+ break;
}
- if (verbose)
- printf("unknown message ignored (%d)\n", hd->rtm_type);
- return;
-
-work:
- ifam = (const struct ifa_msghdr *)msg;
- check_addrs((const char *)(ifam + 1), ifam->ifam_addrs, ev);
}
static void
-check_addrs(const char *cp, int addrs, enum event ev)
+check_addrs(const struct ifa_msghdr *ifam)
{
+ const char *cp = (const char *)(ifam + 1);
const struct sockaddr *sa, *ifa = NULL, *brd = NULL;
char ifname_buf[IFNAMSIZ];
const char *ifname;
int ifndx = 0;
unsigned i;
+ enum event ev;
- if (addrs == 0)
+ if (ifam->ifam_addrs == 0)
return;
for (i = 1; i; i <<= 1) {
- if ((i & addrs) == 0)
+ if ((i & ifam->ifam_addrs) == 0)
continue;
sa = (const struct sockaddr *)cp;
if (i == RTA_IFP) {
@@ -334,8 +327,9 @@
RT_ADVANCE(cp, sa);
}
if (ifa != NULL) {
+ ev = ifam->ifam_type == RTM_DELADDR ? DOWN : UP;
ifname = if_indextoname(ifndx, ifname_buf);
- if (ifname == NULL || ev < UP)
+ if (ifname == NULL)
invoke_script(ifa, brd, ev, ifndx, ifname);
else if (ev == UP) {
if (if_is_connected(ifname))
@@ -444,13 +438,14 @@
}
static void
-check_carrier(int if_index, int carrier_status)
+check_carrier(const struct if_msghdr *ifm)
{
struct interface_data * p;
+ int carrier_status;
enum event ev;
SLIST_FOREACH(p, &ifs, next)
- if (p->index == if_index)
+ if (p->index == ifm->ifm_index)
break;
if (p == NULL)
@@ -462,7 +457,7 @@
* - this is the first time we've been called, and
* inhibit_initial is not set
*/
-
+ carrier_status = ifm->ifm_data.ifi_link_state;
if ((carrier_status != p->last_carrier_status) ||
((p->last_carrier_status == -1) && !inhibit_initial)) {
switch (carrier_status) {
@@ -477,7 +472,7 @@
printf("unknown link status ignored\n");
return;
}
- invoke_script(NULL, NULL, ev, if_index, p->ifname);
+ invoke_script(NULL, NULL, ev, ifm->ifm_index, p->ifname);
p->last_carrier_status = carrier_status;
}
}
Home |
Main Index |
Thread Index |
Old Index