}
static int decode_link(sd_netlink_message *m, LinkInfo *info, char **patterns) {
+ _cleanup_strv_free_ char **altnames = NULL;
const char *name;
int ifindex, r;
uint16_t type;
if (r < 0)
return r;
+ r = sd_netlink_message_read_strv(m, IFLA_PROP_LIST, IFLA_ALT_IFNAME, &altnames);
+ if (r < 0 && !IN_SET(r, -EOPNOTSUPP, -ENODATA))
+ return r;
+
if (patterns) {
char str[DECIMAL_STR_MAX(int)];
xsprintf(str, "%i", ifindex);
-
- if (!strv_fnmatch(patterns, str, 0) && !strv_fnmatch(patterns, name, 0))
- return 0;
+ if (!strv_fnmatch(patterns, str, 0) && !strv_fnmatch(patterns, name, 0)) {
+ bool match = false;
+ char **p;
+
+ STRV_FOREACH(p, altnames)
+ if (strv_fnmatch(patterns, *p, 0)) {
+ match = true;
+ break;
+ }
+ if (!match)
+ return 0;
+ }
}
r = sd_rtnl_message_link_get_type(m, &info->iftype);
strscpy(info->name, sizeof info->name, name);
info->ifindex = ifindex;
+ info->alternative_names = TAKE_PTR(altnames);
info->has_mac_address =
sd_netlink_message_read_ether_addr(m, IFLA_ADDRESS, &info->mac_address) >= 0 &&
(void) sd_netlink_message_read_u32(m, IFLA_MTU, &info->mtu);
(void) sd_netlink_message_read_u32(m, IFLA_MIN_MTU, &info->min_mtu);
(void) sd_netlink_message_read_u32(m, IFLA_MAX_MTU, &info->max_mtu);
- (void) sd_netlink_message_read_strv(m, IFLA_PROP_LIST, IFLA_ALT_IFNAME, &info->alternative_names);
info->has_rx_queues =
sd_netlink_message_read_u32(m, IFLA_NUM_RX_QUEUES, &info->rx_queues) >= 0 &&
for (i = 1; i < argc; i++) {
r = parse_ifindex_or_ifname(argv[i], &index);
- if (r < 0)
- return log_error_errno(r, "Failed to resolve interface %s", argv[i]);
+ if (r < 0) {
+ r = rtnl_resolve_link_alternative_name(&rtnl, argv[i], &index);
+ if (r < 0)
+ return log_error_errno(r, "Failed to resolve interface %s", argv[i]);
+ }
r = set_put(indexes, INT_TO_PTR(index));
if (r < 0)
static int link_renew(int argc, char *argv[], void *userdata) {
_cleanup_(sd_bus_flush_close_unrefp) sd_bus *bus = NULL;
+ _cleanup_(sd_netlink_unrefp) sd_netlink *rtnl = NULL;
int index, i, k = 0, r;
r = sd_bus_open_system(&bus);
for (i = 1; i < argc; i++) {
r = parse_ifindex_or_ifname(argv[i], &index);
- if (r < 0)
- return log_error_errno(r, "Failed to resolve interface %s", argv[i]);
+ if (r < 0) {
+ r = rtnl_resolve_link_alternative_name(&rtnl, argv[i], &index);
+ if (r < 0)
+ return log_error_errno(r, "Failed to resolve interface %s", argv[i]);
+ }
r = link_renew_one(bus, index, argv[i]);
if (r < 0 && k >= 0)
static int verb_reconfigure(int argc, char *argv[], void *userdata) {
_cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
_cleanup_(sd_bus_flush_close_unrefp) sd_bus *bus = NULL;
+ _cleanup_(sd_netlink_unrefp) sd_netlink *rtnl = NULL;
_cleanup_set_free_ Set *indexes = NULL;
int index, i, r;
Iterator j;
for (i = 1; i < argc; i++) {
r = parse_ifindex_or_ifname(argv[i], &index);
- if (r < 0)
- return log_error_errno(r, "Failed to resolve interface %s", argv[i]);
+ if (r < 0) {
+ r = rtnl_resolve_link_alternative_name(&rtnl, argv[i], &index);
+ if (r < 0)
+ return log_error_errno(r, "Failed to resolve interface %s", argv[i]);
+ }
r = set_put(indexes, INT_TO_PTR(index));
if (r < 0)