X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flibsystemd-network%2Fnetwork-internal.c;h=e9146d0e54d46b83984d96cb0056569b1075099a;hb=ecde7065f7b11a7a226d2f7b0e90e998a6347a59;hp=e7ba628fc71e8ef2030d0986c9f5d71a4b0cb5f1;hpb=3a67e927e3be7efb8edf314a31aa4f8f5cba4f53;p=elogind.git diff --git a/src/libsystemd-network/network-internal.c b/src/libsystemd-network/network-internal.c index e7ba628fc..e9146d0e5 100644 --- a/src/libsystemd-network/network-internal.c +++ b/src/libsystemd-network/network-internal.c @@ -327,16 +327,97 @@ int net_parse_inaddr(const char *address, unsigned char *family, void *dst) { return 0; } -bool link_has_carrier(unsigned flags, uint8_t operstate) { - /* see Documentation/networking/operstates.txt in the kernel sources */ +void serialize_in_addrs(FILE *f, const char *key, struct in_addr *addresses, size_t size) { + unsigned i; - if (operstate == IF_OPER_UP) - return true; + assert(f); + assert(key); + assert(addresses); + assert(size); - if (operstate == IF_OPER_UNKNOWN) - /* operstate may not be implemented, so fall back to flags */ - if ((flags & IFF_LOWER_UP) && !(flags & IFF_DORMANT)) - return true; + fprintf(f, "%s=", key); - return false; + 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 ++; + } + + *ret_size = size; + *ret = addresses; + addresses = NULL; + + 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++; + } + + *ret_size = size; + *ret = addresses; + addresses = NULL; + + return 0; }