mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-10 01:17:44 +03:00
nspawn-network: Split off udev checking from parse_interface.
This commit is contained in:
parent
10ad50d38c
commit
b390f17892
@ -395,18 +395,29 @@ int remove_bridge(const char *bridge_name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int parse_interface(const char *name) {
|
static int parse_interface(const char *name) {
|
||||||
_cleanup_(sd_device_unrefp) sd_device *d = NULL;
|
|
||||||
int ifi, r;
|
int ifi, r;
|
||||||
|
|
||||||
r = parse_ifindex_or_ifname(name, &ifi);
|
r = parse_ifindex_or_ifname(name, &ifi);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to resolve interface %s: %m", name);
|
return log_error_errno(r, "Failed to resolve interface %s: %m", name);
|
||||||
|
|
||||||
if (path_is_read_only_fs("/sys") <= 0) {
|
return ifi;
|
||||||
|
}
|
||||||
|
|
||||||
|
int test_network_interface_initialized(const char *name) {
|
||||||
|
_cleanup_(sd_device_unrefp) sd_device *d = NULL;
|
||||||
|
int ifi, r;
|
||||||
char ifi_str[2 + DECIMAL_STR_MAX(int)];
|
char ifi_str[2 + DECIMAL_STR_MAX(int)];
|
||||||
|
|
||||||
|
if (path_is_read_only_fs("/sys"))
|
||||||
|
return 0;
|
||||||
|
|
||||||
/* udev should be around. */
|
/* udev should be around. */
|
||||||
|
|
||||||
|
ifi = parse_interface(name);
|
||||||
|
if (ifi < 0)
|
||||||
|
return ifi;
|
||||||
|
|
||||||
sprintf(ifi_str, "n%i", ifi);
|
sprintf(ifi_str, "n%i", ifi);
|
||||||
r = sd_device_new_from_device_id(&d, ifi_str);
|
r = sd_device_new_from_device_id(&d, ifi_str);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
@ -423,9 +434,8 @@ static int parse_interface(const char *name) {
|
|||||||
return log_error_errno(r, "Failed to determine the interface %s is being renamed: %m", name);
|
return log_error_errno(r, "Failed to determine the interface %s is being renamed: %m", name);
|
||||||
if (r > 0)
|
if (r > 0)
|
||||||
return log_error_errno(SYNTHETIC_ERRNO(EBUSY), "Interface %s is being renamed.", name);
|
return log_error_errno(SYNTHETIC_ERRNO(EBUSY), "Interface %s is being renamed.", name);
|
||||||
}
|
|
||||||
|
|
||||||
return ifi;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int move_network_interfaces(pid_t pid, char **ifaces) {
|
int move_network_interfaces(pid_t pid, char **ifaces) {
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
int test_network_interface_initialized(const char *name);
|
||||||
|
|
||||||
int setup_veth(const char *machine_name, pid_t pid, char iface_name[IFNAMSIZ], bool bridge);
|
int setup_veth(const char *machine_name, pid_t pid, char iface_name[IFNAMSIZ], bool bridge);
|
||||||
int setup_veth_extra(const char *machine_name, pid_t pid, char **pairs);
|
int setup_veth_extra(const char *machine_name, pid_t pid, char **pairs);
|
||||||
|
|
||||||
|
@ -848,6 +848,10 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
||||||
"Network interface name not valid: %s", optarg);
|
"Network interface name not valid: %s", optarg);
|
||||||
|
|
||||||
|
r = test_network_interface_initialized(optarg);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
if (strv_extend(&arg_network_interfaces, optarg) < 0)
|
if (strv_extend(&arg_network_interfaces, optarg) < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
@ -861,6 +865,10 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
||||||
"MACVLAN network interface name not valid: %s", optarg);
|
"MACVLAN network interface name not valid: %s", optarg);
|
||||||
|
|
||||||
|
r = test_network_interface_initialized(optarg);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
if (strv_extend(&arg_network_macvlan, optarg) < 0)
|
if (strv_extend(&arg_network_macvlan, optarg) < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
@ -874,6 +882,10 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
||||||
"IPVLAN network interface name not valid: %s", optarg);
|
"IPVLAN network interface name not valid: %s", optarg);
|
||||||
|
|
||||||
|
r = test_network_interface_initialized(optarg);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
if (strv_extend(&arg_network_ipvlan, optarg) < 0)
|
if (strv_extend(&arg_network_ipvlan, optarg) < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user