return 0;
}
-int rtnl_resolve_link_alternative_name(sd_netlink **rtnl, const char *name, int *ret) {
+int rtnl_resolve_link_alternative_name(sd_netlink **rtnl, const char *name) {
_cleanup_(sd_netlink_message_unrefp) sd_netlink_message *message = NULL, *reply = NULL;
- int r;
+ int r, ret;
assert(rtnl);
assert(name);
- assert(ret);
if (!*rtnl) {
r = sd_netlink_open(rtnl);
if (r < 0)
return r;
- return sd_rtnl_message_link_get_ifindex(reply, ret);
+ r = sd_rtnl_message_link_get_ifindex(reply, &ret);
+ if (r < 0)
+ return r;
+ assert(ret > 0);
+ return ret;
}
int rtnl_message_new_synthetic_error(sd_netlink *rtnl, int error, uint32_t serial, sd_netlink_message **ret) {
int rtnl_set_link_properties(sd_netlink **rtnl, int ifindex, const char *alias, const struct ether_addr *mac, uint32_t mtu);
int rtnl_set_link_alternative_names(sd_netlink **rtnl, int ifindex, char * const *alternative_names);
int rtnl_set_link_alternative_names_by_ifname(sd_netlink **rtnl, const char *ifname, char * const *alternative_names);
-int rtnl_resolve_link_alternative_name(sd_netlink **rtnl, const char *name, int *ret);
+int rtnl_resolve_link_alternative_name(sd_netlink **rtnl, const char *name);
int rtnl_log_parse_error(int r);
int rtnl_log_create_error(int r);
static bool arg_full = false;
static unsigned arg_lines = 10;
+static int resolve_ifname(sd_netlink **rtnl, const char *name) {
+ int r;
+
+ r = parse_ifindex_or_ifname(name);
+ if (r > 0)
+ return r;
+ assert(r < 0);
+
+ r = rtnl_resolve_link_alternative_name(rtnl, name);
+ if (r > 0)
+ return r;
+ assert(r < 0);
+ return log_error_errno(r, "Failed to resolve interface \"%s\": %m", name);
+}
+
static char *link_get_type_string(unsigned short iftype, sd_device *d) {
const char *t, *devtype;
char *p;
return log_oom();
for (i = 1; i < argc; i++) {
- index = parse_ifindex_or_ifname(argv[i]);
- if (index < 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]);
- }
+ index = resolve_ifname(&rtnl, argv[i]);
+ if (index < 0)
+ return index;
r = set_put(indexes, INT_TO_PTR(index));
if (r < 0)
return log_error_errno(r, "Failed to connect system bus: %m");
for (i = 1; i < argc; i++) {
- index = parse_ifindex_or_ifname(argv[i]);
- if (index < 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]);
- }
+ index = resolve_ifname(&rtnl, argv[i]);
+ if (index < 0)
+ return index;
r = link_renew_one(bus, index, argv[i]);
if (r < 0 && k >= 0)
return log_oom();
for (i = 1; i < argc; i++) {
- index = parse_ifindex_or_ifname(argv[i]);
- if (index < 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]);
- }
+ index = resolve_ifname(&rtnl, argv[i]);
+ if (index < 0)
+ return index;
r = set_put(indexes, INT_TO_PTR(index));
if (r < 0)