aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFilipe Brandenburger <filbranden@google.com>2018-06-25 18:07:48 -0700
committerMike Gilbert <floppym@gentoo.org>2018-06-27 14:18:42 -0400
commit8d43fc51b59ab4cfbc65bc01ca4e42dc09b2b6de (patch)
tree23440e5d216932c34a9968085df1eb8e159db2a7
parentsd-bus: fix implicit downcast of bitfield reported by LGTM (diff)
downloadsystemd-8d43fc51b59ab4cfbc65bc01ca4e42dc09b2b6de.tar.gz
systemd-8d43fc51b59ab4cfbc65bc01ca4e42dc09b2b6de.tar.bz2
systemd-8d43fc51b59ab4cfbc65bc01ca4e42dc09b2b6de.zip
resolvconf: fixes for the compatibility interface
Also use compat_main() when called as `resolvconf`, since the interface is closer to that of `systemd-resolve`. Use a heap allocated string to set arg_ifname, since a stack allocated one would be lost after the function returns. (This last one broke the case where an interface name was suffixed with a dot, such as in `resolvconf -a tap0.dhcp`.) Tested: $ build/resolvconf -a nonexistent.abc </etc/resolv.conf Unknown interface 'nonexistent': No such device Fixes #9423. (cherry picked from commit 5a01b3f35d7b6182c78b6973db8d99bdabd4f9c3)
-rw-r--r--src/resolve/resolvconf-compat.c4
-rw-r--r--src/resolve/resolvectl.c2
2 files changed, 4 insertions, 2 deletions
diff --git a/src/resolve/resolvconf-compat.c b/src/resolve/resolvconf-compat.c
index d7e68003e..072345894 100644
--- a/src/resolve/resolvconf-compat.c
+++ b/src/resolve/resolvconf-compat.c
@@ -53,6 +53,8 @@ static int parse_nameserver(const char *string) {
if (strv_push(&arg_set_dns, word) < 0)
return log_oom();
+
+ word = NULL;
}
return 0;
@@ -202,7 +204,7 @@ int resolvconf_parse_argv(int argc, char *argv[]) {
dot = strchr(argv[optind], '.');
if (dot) {
- iface = strndupa(argv[optind], dot - argv[optind]);
+ iface = strndup(argv[optind], dot - argv[optind]);
log_debug("Ignoring protocol specifier '%s'.", dot + 1);
} else
iface = argv[optind];
diff --git a/src/resolve/resolvectl.c b/src/resolve/resolvectl.c
index e96c13fea..e9e395e3e 100644
--- a/src/resolve/resolvectl.c
+++ b/src/resolve/resolvectl.c
@@ -3092,7 +3092,7 @@ int main(int argc, char **argv) {
goto finish;
}
- if (streq(program_invocation_short_name, "systemd-resolve"))
+ if (STR_IN_SET(program_invocation_short_name, "systemd-resolve", "resolvconf"))
r = compat_main(argc, argv, bus);
else
r = native_main(argc, argv, bus);