X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Flibsystemd-network%2Fnetwork-internal.c;h=97217c12e5b626167529bc7d7ac220255fd3e60f;hp=cf577e54a4ee9b72de6ba1408881a6d9396fd70d;hb=836cf0905c4a8fe3358d6b0e005192d5ee51d3e2;hpb=7951dea20911969287878e6897b3eca348721ade diff --git a/src/libsystemd-network/network-internal.c b/src/libsystemd-network/network-internal.c index cf577e54a..97217c12e 100644 --- a/src/libsystemd-network/network-internal.c +++ b/src/libsystemd-network/network-internal.c @@ -34,21 +34,33 @@ #include "conf-parser.h" #include "condition.h" -#define HASH_KEY SD_ID128_MAKE(d3,1e,48,fa,90,fe,4b,4c,9d,af,d5,d7,a1,b1,2e,8a) - -int net_get_unique_predictable_data(struct udev_device *device, uint8_t result[8]) { - size_t l, sz = 0; +const char *net_get_name(struct udev_device *device) { const char *name = NULL, *field = NULL; - int r; - uint8_t *v; + + assert(device); /* fetch some persistent data unique (on this machine) to this device */ - FOREACH_STRING(field, "ID_NET_NAME_ONBOARD", "ID_NET_NAME_SLOT", "ID_NET_NAME_PATH", "ID_NET_NAME_MAC") { + FOREACH_STRING(field, "ID_NET_NAME_ONBOARD", "ID_NET_NAME_SLOT", + "ID_NET_NAME_PATH", "ID_NET_NAME_MAC") { name = udev_device_get_property_value(device, field); if (name) break; } + return name; +} + +#define HASH_KEY SD_ID128_MAKE(d3,1e,48,fa,90,fe,4b,4c,9d,af,d5,d7,a1,b1,2e,8a) + +int net_get_unique_predictable_data(struct udev_device *device, uint8_t result[8]) { + size_t l, sz = 0; + const char *name = NULL; + int r; + uint8_t *v; + + assert(device); + + name = net_get_name(device); if (!name) return -ENOENT; @@ -179,7 +191,7 @@ int config_parse_ifname(const char *unit, void *userdata) { char **s = data; - char *n; + _cleanup_free_ char *n = NULL; assert(filename); assert(lvalue); @@ -198,12 +210,11 @@ int config_parse_ifname(const char *unit, } free(*s); - if (*n) + if (*n) { *s = n; - else { - free(n); + n = NULL; + } else *s = NULL; - } return 0; } @@ -327,35 +338,97 @@ int net_parse_inaddr(const char *address, unsigned char *family, void *dst) { return 0; } -int load_module(struct kmod_ctx *ctx, const char *mod_name) { - struct kmod_list *modlist = NULL, *l; - int r; +void serialize_in_addrs(FILE *f, const char *key, struct in_addr *addresses, size_t size) { + unsigned i; - assert(ctx); - assert(mod_name); + assert(f); + assert(key); + assert(addresses); + assert(size); - r = kmod_module_new_from_lookup(ctx, mod_name, &modlist); - if (r < 0) - return r; + fprintf(f, "%s=", key); - if (!modlist) { - log_error("Failed to find module '%s'", mod_name); - return -ENOENT; + for (i = 0; i < size; i++) + fprintf(f, "%s%s", inet_ntoa(addresses[i]), + (i < (size - 1)) ? " ": ""); + + fputs("\n", f); +} + +int deserialize_in_addrs(struct in_addr **ret, size_t *ret_size, const char *string) { + _cleanup_free_ struct in_addr *addresses = NULL; + size_t size = 0; + char *word, *state; + size_t len; + + assert(ret); + assert(ret_size); + assert(string); + + FOREACH_WORD(word, len, string, state) { + _cleanup_free_ char *addr_str = NULL; + struct in_addr *new_addresses; + int r; + + new_addresses = realloc(addresses, (size + 1) * sizeof(struct in_addr)); + if (!new_addresses) + return -ENOMEM; + else + addresses = new_addresses; + + addr_str = strndup(word, len); + if (!addr_str) + return -ENOMEM; + + r = inet_pton(AF_INET, addr_str, &(addresses[size])); + if (r <= 0) + continue; + + size ++; } - kmod_list_foreach(l, modlist) { - struct kmod_module *mod = kmod_module_get_module(l); + *ret_size = size; + *ret = addresses; + addresses = NULL; - r = kmod_module_probe_insert_module(mod, 0, NULL, NULL, NULL, NULL); - if (r == 0) - log_info("Inserted module '%s'", kmod_module_get_name(mod)); - else { - log_error("Failed to insert '%s': %s", kmod_module_get_name(mod), - strerror(-r)); - } + return 0; +} + +int deserialize_in6_addrs(struct in6_addr **ret, size_t *ret_size, const char *string) { + _cleanup_free_ struct in6_addr *addresses = NULL; + size_t size = 0; + char *word, *state; + size_t len; + + assert(ret); + assert(ret_size); + assert(string); + + FOREACH_WORD(word, len, string, state) { + _cleanup_free_ char *addr_str = NULL; + struct in6_addr *new_addresses; + int r; + + new_addresses = realloc(addresses, (size + 1) * sizeof(struct in6_addr)); + if (!new_addresses) + return -ENOMEM; + else + addresses = new_addresses; + + addr_str = strndup(word, len); + if (!addr_str) + return -ENOMEM; + + r = inet_pton(AF_INET6, addr_str, &(addresses[size])); + if (r <= 0) + continue; + + size++; } - kmod_module_unref_list(modlist); + *ret_size = size; + *ret = addresses; + addresses = NULL; - return r; + return 0; }