From: Mark Wielaard Date: Thu, 2 Jan 2014 20:17:18 +0000 (+0100) Subject: libdwfl: linux-pid-attach.c (dwfl_linux_proc_attach): Use and check strtol X-Git-Tag: elfutils-0.158~10 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=68de442d13f7b3192d0b81634c0f2136002c4552;p=thirdparty%2Felfutils.git libdwfl: linux-pid-attach.c (dwfl_linux_proc_attach): Use and check strtol Signed-off-by: Mark Wielaard --- diff --git a/libdwfl/ChangeLog b/libdwfl/ChangeLog index 2190899ee..766fb18ac 100644 --- a/libdwfl/ChangeLog +++ b/libdwfl/ChangeLog @@ -1,3 +1,7 @@ +2014-01-02 Mark Wielaard + + * linux-pid-attach.c (dwfl_linux_proc_attach): Use strtol, not atoi. + 2013-12-30 Mark Wielaard * argp-std.c (parse_opt): Call dwfl_linux_proc_attach and diff --git a/libdwfl/linux-pid-attach.c b/libdwfl/linux-pid-attach.c index 21ff4b99e..58d6942fe 100644 --- a/libdwfl/linux-pid-attach.c +++ b/libdwfl/linux-pid-attach.c @@ -306,8 +306,15 @@ dwfl_linux_proc_attach (Dwfl *dwfl, pid_t pid, bool assume_ptrace_stopped) while (getline (&line, &linelen, procfile) >= 0) if (strncmp (line, "Tgid:", 5) == 0) { - pid = atoi (&line[5]); - break; + errno = 0; + char *endptr; + long val = strtol (&line[5], &endptr, 10); + if ((errno == ERANGE && val == LONG_MAX) + || *endptr != '\n' || val < 0 || val != (pid_t) val) + pid = 0; + else + pid = (pid_t) val; + break; } free (line); fclose (procfile);