From 6a93212b54327c77383d88efd581475105f3b72a Mon Sep 17 00:00:00 2001 From: Alexey Fomenko Date: Thu, 22 Dec 2011 11:38:57 +0100 Subject: kill: fix segfault in arguments parsing Signed-off-by: Alexey Fomenko Signed-off-by: Denys Vlasenko --- procps/kill.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'procps/kill.c') diff --git a/procps/kill.c b/procps/kill.c index 224e5ad1a..b267a7aaf 100644 --- a/procps/kill.c +++ b/procps/kill.c @@ -165,13 +165,15 @@ int kill_main(int argc, char **argv) /* Stop all processes */ kill(-1, SIGSTOP); /* Signal all processes except those in our session */ - while ((p = procps_scan(p, PSSCAN_PID|PSSCAN_SID))) { + while ((p = procps_scan(p, PSSCAN_PID|PSSCAN_SID)) != NULL) { int i; if (p->sid == (unsigned)sid || p->pid == (unsigned)pid - || p->pid == 1) + || p->pid == 1 + ) { continue; + } /* All remaining args must be -o PID options. * Check p->pid against them. */ @@ -255,9 +257,10 @@ int kill_main(int argc, char **argv) pid = bb_strtoi(arg, &end, 10); if (errno && (errno != EINVAL || *end != ' ')) { bb_error_msg("invalid number '%s'", arg); - *end = '\0'; errors++; - } else if (kill(pid, signo) != 0) { + break; + } + if (kill(pid, signo) != 0) { bb_perror_msg("can't kill pid %d", (int)pid); errors++; } -- cgit v1.2.3