2013-01-24 10:41:58 +01:00
|
|
|
From f3910003bce32ebdc1dbb71fd9ca2d4b8352b563 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Michal Schmidt <mschmidt@redhat.com>
|
|
|
|
Date: Tue, 30 Oct 2012 10:29:40 +0100
|
|
|
|
Subject: [PATCH] shared, libsystemd-daemon: check for empty strings in
|
|
|
|
strto*l conversions
|
|
|
|
|
|
|
|
strtol() and friends may set EINVAL if no conversion was performed, but
|
|
|
|
they are not required to do so. In practice they don't. We need to check
|
|
|
|
for it.
|
|
|
|
|
|
|
|
https://bugzilla.redhat.com/show_bug.cgi?id=870577
|
|
|
|
---
|
|
|
|
src/libsystemd-daemon/sd-daemon.c | 4 ++--
|
|
|
|
src/shared/conf-parser.c | 2 +-
|
|
|
|
src/shared/util.c | 8 ++++----
|
|
|
|
3 files changed, 7 insertions(+), 7 deletions(-)
|
|
|
|
|
2013-03-22 12:08:23 +01:00
|
|
|
Index: systemd-195/src/libsystemd-daemon/sd-daemon.c
|
|
|
|
===================================================================
|
|
|
|
--- systemd-195.orig/src/libsystemd-daemon/sd-daemon.c
|
|
|
|
+++ systemd-195/src/libsystemd-daemon/sd-daemon.c
|
|
|
|
@@ -88,7 +88,7 @@ _sd_export_ int sd_listen_fds(int unset_
|
2013-01-24 10:41:58 +01:00
|
|
|
goto finish;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (!p || *p || l <= 0) {
|
|
|
|
+ if (!p || p == e || *p || l <= 0) {
|
|
|
|
r = -EINVAL;
|
|
|
|
goto finish;
|
|
|
|
}
|
2013-03-22 12:08:23 +01:00
|
|
|
@@ -112,7 +112,7 @@ _sd_export_ int sd_listen_fds(int unset_
|
2013-01-24 10:41:58 +01:00
|
|
|
goto finish;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (!p || *p) {
|
|
|
|
+ if (!p || p == e || *p) {
|
|
|
|
r = -EINVAL;
|
|
|
|
goto finish;
|
|
|
|
}
|
2013-03-22 12:08:23 +01:00
|
|
|
Index: systemd-195/src/shared/conf-parser.c
|
|
|
|
===================================================================
|
|
|
|
--- systemd-195.orig/src/shared/conf-parser.c
|
|
|
|
+++ systemd-195/src/shared/conf-parser.c
|
2013-01-24 10:41:58 +01:00
|
|
|
@@ -865,7 +865,7 @@ int config_parse_mode(
|
|
|
|
|
|
|
|
errno = 0;
|
|
|
|
l = strtol(rvalue, &x, 8);
|
|
|
|
- if (!x || *x || errno) {
|
|
|
|
+ if (!x || x == rvalue || *x || errno) {
|
|
|
|
log_error("[%s:%u] Failed to parse mode value, ignoring: %s", filename, line, rvalue);
|
|
|
|
return 0;
|
|
|
|
}
|
2013-03-22 12:08:23 +01:00
|
|
|
Index: systemd-195/src/shared/util.c
|
|
|
|
===================================================================
|
|
|
|
--- systemd-195.orig/src/shared/util.c
|
|
|
|
+++ systemd-195/src/shared/util.c
|
|
|
|
@@ -388,7 +388,7 @@ int safe_atou(const char *s, unsigned *r
|
2013-01-24 10:41:58 +01:00
|
|
|
errno = 0;
|
|
|
|
l = strtoul(s, &x, 0);
|
|
|
|
|
|
|
|
- if (!x || *x || errno)
|
|
|
|
+ if (!x || x == s || *x || errno)
|
|
|
|
return errno ? -errno : -EINVAL;
|
|
|
|
|
|
|
|
if ((unsigned long) (unsigned) l != l)
|
2013-03-22 12:08:23 +01:00
|
|
|
@@ -408,7 +408,7 @@ int safe_atoi(const char *s, int *ret_i)
|
2013-01-24 10:41:58 +01:00
|
|
|
errno = 0;
|
|
|
|
l = strtol(s, &x, 0);
|
|
|
|
|
|
|
|
- if (!x || *x || errno)
|
|
|
|
+ if (!x || x == s || *x || errno)
|
|
|
|
return errno ? -errno : -EINVAL;
|
|
|
|
|
|
|
|
if ((long) (int) l != l)
|
2013-03-22 12:08:23 +01:00
|
|
|
@@ -428,7 +428,7 @@ int safe_atollu(const char *s, long long
|
2013-01-24 10:41:58 +01:00
|
|
|
errno = 0;
|
|
|
|
l = strtoull(s, &x, 0);
|
|
|
|
|
|
|
|
- if (!x || *x || errno)
|
|
|
|
+ if (!x || x == s || *x || errno)
|
|
|
|
return errno ? -errno : -EINVAL;
|
|
|
|
|
|
|
|
*ret_llu = l;
|
2013-03-22 12:08:23 +01:00
|
|
|
@@ -445,7 +445,7 @@ int safe_atolli(const char *s, long long
|
2013-01-24 10:41:58 +01:00
|
|
|
errno = 0;
|
|
|
|
l = strtoll(s, &x, 0);
|
|
|
|
|
|
|
|
- if (!x || *x || errno)
|
|
|
|
+ if (!x || x == s || *x || errno)
|
|
|
|
return errno ? -errno : -EINVAL;
|
|
|
|
|
|
|
|
*ret_lli = l;
|