Skip to content

Commit a0267b3

Browse files
yuwatakeszybz
authored andcommitted
nspawn: also support ifindex when specifying network interface
1 parent 7895b07 commit a0267b3

File tree

1 file changed

+10
-10
lines changed

1 file changed

+10
-10
lines changed

src/nspawn/nspawn-network.c

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,6 @@
11
/* SPDX-License-Identifier: LGPL-2.1+ */
22

33
#include <linux/veth.h>
4-
#include <net/if.h>
54
#include <sys/file.h>
65

76
#include "sd-device.h"
@@ -14,6 +13,7 @@
1413
#include "missing_network.h"
1514
#include "netlink-util.h"
1615
#include "nspawn-network.h"
16+
#include "parse-util.h"
1717
#include "siphash24.h"
1818
#include "socket-util.h"
1919
#include "stat-util.h"
@@ -202,9 +202,9 @@ int setup_veth(const char *machine_name,
202202
if (r < 0)
203203
return r;
204204

205-
i = (int) if_nametoindex(iface_name);
206-
if (i <= 0)
207-
return log_error_errno(errno, "Failed to resolve interface %s: %m", iface_name);
205+
r = parse_ifindex_or_ifname(iface_name, &i);
206+
if (r < 0)
207+
return log_error_errno(r, "Failed to resolve interface %s: %m", iface_name);
208208

209209
return i;
210210
}
@@ -258,9 +258,9 @@ static int join_bridge(sd_netlink *rtnl, const char *veth_name, const char *brid
258258
assert(veth_name);
259259
assert(bridge_name);
260260

261-
bridge_ifi = (int) if_nametoindex(bridge_name);
262-
if (bridge_ifi <= 0)
263-
return -errno;
261+
r = parse_ifindex_or_ifname(bridge_name, &bridge_ifi);
262+
if (r < 0)
263+
return r;
264264

265265
r = sd_rtnl_message_new_link(rtnl, &m, RTM_SETLINK, 0);
266266
if (r < 0)
@@ -398,9 +398,9 @@ static int parse_interface(const char *name) {
398398
char ifi_str[2 + DECIMAL_STR_MAX(int)];
399399
int ifi, r;
400400

401-
ifi = (int) if_nametoindex(name);
402-
if (ifi <= 0)
403-
return log_error_errno(errno, "Failed to resolve interface %s: %m", name);
401+
r = parse_ifindex_or_ifname(name, &ifi);
402+
if (r < 0)
403+
return log_error_errno(r, "Failed to resolve interface %s: %m", name);
404404

405405
sprintf(ifi_str, "n%i", ifi);
406406
r = sd_device_new_from_device_id(&d, ifi_str);

0 commit comments

Comments
 (0)