From: Yu Watanabe Date: Sat, 6 Nov 2021 01:24:09 +0000 (+0900) Subject: netif-util: move several functions from network-util.[ch] to shared/netif-util.[ch] X-Git-Tag: v250-rc1~328^2~3 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=b5cc5591faec4117162099c92bc84d1120e6e234;p=thirdparty%2Fsystemd.git netif-util: move several functions from network-util.[ch] to shared/netif-util.[ch] These functions are not relevant to sd-network, and only used by networkd, networkctl, and udevd. --- diff --git a/src/libsystemd-network/dhcp-identifier.c b/src/libsystemd-network/dhcp-identifier.c index 23021f7bad8..eb313caf816 100644 --- a/src/libsystemd-network/dhcp-identifier.c +++ b/src/libsystemd-network/dhcp-identifier.c @@ -9,7 +9,7 @@ #include "dhcp-identifier.h" #include "dhcp6-protocol.h" -#include "network-util.h" +#include "netif-util.h" #include "siphash24.h" #include "sparse-endian.h" #include "stat-util.h" diff --git a/src/libsystemd/sd-network/network-util.c b/src/libsystemd/sd-network/network-util.c index 5632debdebe..971247714ac 100644 --- a/src/libsystemd/sd-network/network-util.c +++ b/src/libsystemd/sd-network/network-util.c @@ -1,14 +1,9 @@ /* SPDX-License-Identifier: LGPL-2.1-or-later */ -#include "sd-id128.h" +#include "sd-network.h" #include "alloc-util.h" -#include "arphrd-util.h" -#include "device-util.h" -#include "fd-util.h" #include "network-util.h" -#include "siphash24.h" -#include "sparse-endian.h" #include "string-table.h" #include "strv.h" @@ -140,79 +135,3 @@ int parse_operational_state_range(const char *str, LinkOperationalStateRange *ou return 0; } - -int link_get_type_string(sd_device *device, unsigned short iftype, char **ret) { - const char *t; - char *p; - - if (device && - sd_device_get_devtype(device, &t) >= 0 && - !isempty(t)) { - p = strdup(t); - if (!p) - return -ENOMEM; - - *ret = p; - return 0; - } - - t = arphrd_to_name(iftype); - if (!t) - return -ENOENT; - - p = strdup(t); - if (!p) - return -ENOMEM; - - *ret = ascii_strlower(p); - return 0; -} - -const char *net_get_name_persistent(sd_device *device) { - const char *name, *field; - - 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") - if (sd_device_get_property_value(device, field, &name) >= 0) - return name; - - return NULL; -} - -#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(sd_device *device, bool use_sysname, uint64_t *result) { - size_t l, sz = 0; - const char *name; - int r; - uint8_t *v; - - assert(device); - - /* net_get_name_persistent() will return one of the device names based on stable information about - * the device. If this is not available, we fall back to using the actual device name. */ - name = net_get_name_persistent(device); - if (!name && use_sysname) - (void) sd_device_get_sysname(device, &name); - if (!name) - return log_device_debug_errno(device, SYNTHETIC_ERRNO(ENODATA), - "No stable identifying information found"); - - log_device_debug(device, "Using \"%s\" as stable identifying information", name); - l = strlen(name); - sz = sizeof(sd_id128_t) + l; - v = newa(uint8_t, sz); - - /* Fetch some persistent data unique to this machine */ - r = sd_id128_get_machine((sd_id128_t*) v); - if (r < 0) - return r; - memcpy(v + sizeof(sd_id128_t), name, l); - - /* Let's hash the machine ID plus the device name. We use - * a fixed, but originally randomly created hash key here. */ - *result = htole64(siphash24(v, sz, HASH_KEY.bytes)); - return 0; -} diff --git a/src/libsystemd/sd-network/network-util.h b/src/libsystemd/sd-network/network-util.h index 3a2e4a7f6c6..6e2ad284263 100644 --- a/src/libsystemd/sd-network/network-util.h +++ b/src/libsystemd/sd-network/network-util.h @@ -1,12 +1,9 @@ /* SPDX-License-Identifier: LGPL-2.1-or-later */ #pragma once -#include +#include #include -#include "sd-device.h" -#include "sd-network.h" - #include "macro.h" bool network_is_online(void); @@ -86,7 +83,3 @@ typedef struct LinkOperationalStateRange { LINK_OPERSTATE_ROUTABLE } int parse_operational_state_range(const char *str, LinkOperationalStateRange *out); - -int link_get_type_string(sd_device *device, unsigned short iftype, char **ret); -int net_get_unique_predictable_data(sd_device *device, bool use_sysname, uint64_t *result); -const char *net_get_name_persistent(sd_device *device); diff --git a/src/network/networkctl.c b/src/network/networkctl.c index 6dd05145c95..ec86391cd36 100644 --- a/src/network/networkctl.c +++ b/src/network/networkctl.c @@ -42,6 +42,7 @@ #include "macro.h" #include "macvlan-util.h" #include "main-func.h" +#include "netif-util.h" #include "netlink-util.h" #include "network-internal.h" #include "network-util.h" diff --git a/src/network/networkd-ipv4ll.c b/src/network/networkd-ipv4ll.c index a3e5b4ba74c..d05182fde7d 100644 --- a/src/network/networkd-ipv4ll.c +++ b/src/network/networkd-ipv4ll.c @@ -3,7 +3,7 @@ #include #include -#include "network-internal.h" +#include "netif-util.h" #include "networkd-address.h" #include "networkd-ipv4ll.h" #include "networkd-link.h" diff --git a/src/network/networkd-json.c b/src/network/networkd-json.c index 2bae2f2913d..6a40e4f8e67 100644 --- a/src/network/networkd-json.c +++ b/src/network/networkd-json.c @@ -1,6 +1,6 @@ /* SPDX-License-Identifier: LGPL-2.1-or-later */ -#include "network-util.h" +#include "netif-util.h" #include "networkd-json.h" #include "networkd-link.h" #include "networkd-manager.h" diff --git a/src/shared/meson.build b/src/shared/meson.build index 6e09ef84795..a23d43ce09a 100644 --- a/src/shared/meson.build +++ b/src/shared/meson.build @@ -218,6 +218,8 @@ shared_sources = files(''' net-condition.h netif-naming-scheme.c netif-naming-scheme.h + netif-util.c + netif-util.h nscd-flush.h nsflags.c nsflags.h diff --git a/src/shared/net-condition.c b/src/shared/net-condition.c index 1da60810ee0..7cfac18d651 100644 --- a/src/shared/net-condition.c +++ b/src/shared/net-condition.c @@ -6,6 +6,7 @@ #include "env-util.h" #include "log.h" #include "net-condition.h" +#include "netif-util.h" #include "network-util.h" #include "socket-util.h" #include "string-table.h" diff --git a/src/shared/netif-util.c b/src/shared/netif-util.c new file mode 100644 index 00000000000..fb81460c916 --- /dev/null +++ b/src/shared/netif-util.c @@ -0,0 +1,86 @@ +/* SPDX-License-Identifier: LGPL-2.1-or-later */ + +#include "sd-id128.h" + +#include "arphrd-util.h" +#include "device-util.h" +#include "netif-util.h" +#include "siphash24.h" +#include "sparse-endian.h" +#include "strv.h" + +int link_get_type_string(sd_device *device, unsigned short iftype, char **ret) { + const char *t; + char *p; + + if (device && + sd_device_get_devtype(device, &t) >= 0 && + !isempty(t)) { + p = strdup(t); + if (!p) + return -ENOMEM; + + *ret = p; + return 0; + } + + t = arphrd_to_name(iftype); + if (!t) + return -ENOENT; + + p = strdup(t); + if (!p) + return -ENOMEM; + + *ret = ascii_strlower(p); + return 0; +} + +const char *net_get_name_persistent(sd_device *device) { + const char *name, *field; + + 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") + if (sd_device_get_property_value(device, field, &name) >= 0) + return name; + + return NULL; +} + +#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(sd_device *device, bool use_sysname, uint64_t *ret) { + size_t l, sz = 0; + const char *name; + int r; + uint8_t *v; + + assert(device); + + /* net_get_name_persistent() will return one of the device names based on stable information about + * the device. If this is not available, we fall back to using the actual device name. */ + name = net_get_name_persistent(device); + if (!name && use_sysname) + (void) sd_device_get_sysname(device, &name); + if (!name) + return log_device_debug_errno(device, SYNTHETIC_ERRNO(ENODATA), + "No stable identifying information found"); + + log_device_debug(device, "Using \"%s\" as stable identifying information", name); + l = strlen(name); + sz = sizeof(sd_id128_t) + l; + v = newa(uint8_t, sz); + + /* Fetch some persistent data unique to this machine */ + r = sd_id128_get_machine((sd_id128_t*) v); + if (r < 0) + return r; + memcpy(v + sizeof(sd_id128_t), name, l); + + /* Let's hash the machine ID plus the device name. We use + * a fixed, but originally randomly created hash key here. */ + *ret = htole64(siphash24(v, sz, HASH_KEY.bytes)); + return 0; +} diff --git a/src/shared/netif-util.h b/src/shared/netif-util.h new file mode 100644 index 00000000000..7a2cf1be9e2 --- /dev/null +++ b/src/shared/netif-util.h @@ -0,0 +1,11 @@ +/* SPDX-License-Identifier: LGPL-2.1-or-later */ +#pragma once + +#include +#include + +#include "sd-device.h" + +int link_get_type_string(sd_device *device, unsigned short iftype, char **ret); +const char *net_get_name_persistent(sd_device *device); +int net_get_unique_predictable_data(sd_device *device, bool use_sysname, uint64_t *ret); diff --git a/src/udev/net/link-config.c b/src/udev/net/link-config.c index 1ce8e471e76..0fd5f845d2d 100644 --- a/src/udev/net/link-config.c +++ b/src/udev/net/link-config.c @@ -22,8 +22,8 @@ #include "memory-util.h" #include "net-condition.h" #include "netif-naming-scheme.h" +#include "netif-util.h" #include "netlink-util.h" -#include "network-util.h" #include "parse-util.h" #include "path-lookup.h" #include "path-util.h"