From: Jonathan Rajotte Date: Fri, 24 Jul 2015 21:42:59 +0000 (-0400) Subject: Fix: pids should be numbers only X-Git-Tag: v2.8.0-rc1~534 X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=commitdiff_plain;h=44c1a903e17ad14d5ba1cd07585a7a2415eac78a Fix: pids should be numbers only Ruled out cases: word, number+word, word+number, number+word+number Ex: foo, 123foo, foo123, 123foo123 Signed-off-by: Jonathan Rajotte Signed-off-by: Jérémie Galarneau --- diff --git a/src/bin/lttng/commands/track-untrack.c b/src/bin/lttng/commands/track-untrack.c index 52442cc13..639e18481 100644 --- a/src/bin/lttng/commands/track-untrack.c +++ b/src/bin/lttng/commands/track-untrack.c @@ -96,6 +96,7 @@ int parse_pid_string(const char *_pid_string, int count = 0; int *pid_list = NULL; char *pid_string = NULL; + char *endptr; if (all && _pid_string) { ERR("An empty PID string is expected with --all"); @@ -132,13 +133,16 @@ int parse_pid_string(const char *_pid_string, while (one_pid_str != NULL) { unsigned long v; - v = strtoul(one_pid_str, NULL, 10); + errno = 0; + v = strtoul(one_pid_str, &endptr, 10); if ((v == 0 && errno == EINVAL) - || (v == ULONG_MAX && errno == ERANGE)) { + || (v == ULONG_MAX && errno == ERANGE) + || (*one_pid_str != '\0' && *endptr != '\0')){ ERR("Error parsing PID %s", one_pid_str); retval = CMD_ERROR; goto error; } + if ((long) v > INT_MAX || (int) v < 0) { ERR("Invalid PID value %ld", (long) v); retval = CMD_ERROR;