From cb6fa44cb5411ed574f14109ee862ff663ab0a36 Mon Sep 17 00:00:00 2001 From: Tom Gundersen Date: Fri, 28 Feb 2014 02:07:29 +0100 Subject: [PATCH] sd-network: turn states 'unknown' and 'unmanaged' into errnos --- src/network/networkd-wait-online.c | 15 +++++---------- src/network/sd-network.c | 23 ++++++++++------------- 2 files changed, 15 insertions(+), 23 deletions(-) diff --git a/src/network/networkd-wait-online.c b/src/network/networkd-wait-online.c index 900dc0512..51c6bbd49 100644 --- a/src/network/networkd-wait-online.c +++ b/src/network/networkd-wait-online.c @@ -38,20 +38,15 @@ static bool all_configured(void) { _cleanup_free_ char *state = NULL; r = sd_network_get_link_state(indices[i], &state); - if (r < 0) + if (r == -EUNATCH) + continue; + if (r < 0 || !streq(state, "configured")) return false; - if (streq(state, "configured")) - one_ready = true; - - if (!streq(state, "configured") && !streq(state, "unmanaged")) - return false; + one_ready = true; } - if (one_ready) - return true; - - return false; + return one_ready; } static int event_handler(sd_event_source *s, int fd, uint32_t revents, diff --git a/src/network/sd-network.c b/src/network/sd-network.c index 746987366..23af94090 100644 --- a/src/network/sd-network.c +++ b/src/network/sd-network.c @@ -34,7 +34,7 @@ #include "dhcp-lease-internal.h" _public_ int sd_network_get_link_state(unsigned index, char **state) { - char *p, *s = NULL; + _cleanup_free_ char *s = NULL, *p = NULL; int r; assert_return(index, -EINVAL); @@ -44,23 +44,20 @@ _public_ int sd_network_get_link_state(unsigned index, char **state) { return -ENOMEM; r = parse_env_file(p, NEWLINE, "STATE", &s, NULL); - free(p); - - if (r == -ENOENT) { - free(s); - s = strdup("unknown"); - if (!s) - return -ENOMEM; - *state = s; - return 0; - } else if (r < 0) { - free(s); + if (r == -ENOENT) + return -ENODATA; + else if (r < 0) return r; - } else if (!s) + else if (!s) return -EIO; + if (streq(s, "unmanaged")) + return -EUNATCH; + *state = s; + s = NULL; + return 0; } -- 2.30.2