2000-02-09 01:28:47 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
1999-10-21 03:38:37 +05:30
|
|
|
/*
|
2000-04-05 06:30:52 +05:30
|
|
|
* Mini kill/killall implementation for busybox
|
1999-10-21 03:38:37 +05:30
|
|
|
*
|
|
|
|
* Copyright (C) 1995, 1996 by Bruce Perens <bruce@pixar.com>.
|
2004-03-15 13:59:22 +05:30
|
|
|
* Copyright (C) 1999-2004 by Erik Andersen <andersen@codepoet.org>
|
1999-10-21 03:38:37 +05:30
|
|
|
*
|
2006-06-03 02:26:16 +05:30
|
|
|
* Licensed under the GPL v2 or later, see the file LICENSE in this tarball.
|
1999-10-21 03:38:37 +05:30
|
|
|
*/
|
|
|
|
|
2006-06-03 02:26:16 +05:30
|
|
|
#include "busybox.h"
|
1999-10-05 21:54:54 +05:30
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2000-03-07 13:11:42 +05:30
|
|
|
#include <errno.h>
|
1999-10-05 21:54:54 +05:30
|
|
|
#include <unistd.h>
|
|
|
|
#include <signal.h>
|
1999-10-23 11:12:08 +05:30
|
|
|
#include <ctype.h>
|
2001-01-27 13:54:39 +05:30
|
|
|
#include <string.h>
|
1999-12-09 04:49:36 +05:30
|
|
|
#include <unistd.h>
|
|
|
|
|
2006-03-07 02:17:33 +05:30
|
|
|
int kill_main(int argc, char **argv)
|
1999-10-05 21:54:54 +05:30
|
|
|
{
|
2006-07-13 00:47:55 +05:30
|
|
|
int killall, signo = SIGTERM, errors = 0, quiet=0;
|
|
|
|
|
|
|
|
killall = (ENABLE_KILLALL && bb_applet_name[4]=='a') ? 1 : 0;
|
2000-02-09 01:28:47 +05:30
|
|
|
|
|
|
|
/* Parse any options */
|
2003-07-26 13:11:56 +05:30
|
|
|
if (argc < 2)
|
2003-03-19 14:43:01 +05:30
|
|
|
bb_show_usage();
|
2000-02-09 01:28:47 +05:30
|
|
|
|
2003-07-26 13:11:56 +05:30
|
|
|
if(argv[1][0] != '-'){
|
|
|
|
argv++;
|
|
|
|
argc--;
|
|
|
|
goto do_it_now;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* The -l option, which prints out signal names. */
|
|
|
|
if(argv[1][1]=='l' && argv[1][2]=='\0'){
|
|
|
|
if(argc==2) {
|
|
|
|
/* Print the whole signal list */
|
|
|
|
int col = 0;
|
2006-07-13 00:47:55 +05:30
|
|
|
|
|
|
|
for(signo = 0;;) {
|
|
|
|
char *name = get_signame(++signo);
|
|
|
|
if (isdigit(*name)) break;
|
|
|
|
|
2003-07-26 13:11:56 +05:30
|
|
|
if (col > 60) {
|
|
|
|
printf("\n");
|
|
|
|
col = 0;
|
|
|
|
}
|
2006-07-13 00:47:55 +05:30
|
|
|
col += printf("%2d) %-16s", signo, name);
|
2003-07-26 13:11:56 +05:30
|
|
|
}
|
|
|
|
printf("\n");
|
|
|
|
} else {
|
|
|
|
for(argv++; *argv; argv++) {
|
2006-07-13 00:47:55 +05:30
|
|
|
char *name;
|
|
|
|
|
|
|
|
if (isdigit(**argv)) name = get_signame(atoi(*argv));
|
|
|
|
else {
|
|
|
|
int temp = get_signum(*argv);
|
|
|
|
if (temp<0)
|
|
|
|
bb_error_msg_and_die("unknown signal %s", *argv);
|
|
|
|
name = get_signame(temp);
|
|
|
|
}
|
|
|
|
puts(name);
|
2002-07-24 05:15:11 +05:30
|
|
|
}
|
1999-10-05 21:54:54 +05:30
|
|
|
}
|
2003-07-26 13:11:56 +05:30
|
|
|
/* If they specified -l, were all done */
|
|
|
|
return EXIT_SUCCESS;
|
1999-10-05 21:54:54 +05:30
|
|
|
}
|
1999-12-09 04:49:36 +05:30
|
|
|
|
2003-07-26 13:11:56 +05:30
|
|
|
/* The -q quiet option */
|
2006-07-13 00:47:55 +05:30
|
|
|
if(killall && argv[1][1]=='q' && argv[1][2]=='\0'){
|
2003-07-26 13:11:56 +05:30
|
|
|
quiet++;
|
|
|
|
argv++;
|
|
|
|
argc--;
|
2003-08-06 13:13:58 +05:30
|
|
|
if(argc<2 || argv[1][0] != '-'){
|
2003-07-26 13:11:56 +05:30
|
|
|
goto do_it_now;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-07-13 00:47:55 +05:30
|
|
|
if(0>(signo = get_signum(argv[1]+1)))
|
2003-07-26 13:11:56 +05:30
|
|
|
bb_error_msg_and_die( "bad signal name '%s'", argv[1]+1);
|
|
|
|
argv+=2;
|
|
|
|
argc-=2;
|
|
|
|
|
2002-07-24 05:15:11 +05:30
|
|
|
do_it_now:
|
1999-10-23 11:12:08 +05:30
|
|
|
|
2006-01-25 18:51:08 +05:30
|
|
|
/* Pid or name required */
|
|
|
|
if (argc <= 0)
|
|
|
|
bb_show_usage();
|
|
|
|
|
2006-07-13 00:47:55 +05:30
|
|
|
if (!killall) {
|
2000-03-07 13:11:42 +05:30
|
|
|
/* Looks like they want to do a kill. Do that */
|
|
|
|
while (--argc >= 0) {
|
|
|
|
int pid;
|
2000-02-09 01:28:47 +05:30
|
|
|
|
2006-01-04 05:43:22 +05:30
|
|
|
if (!isdigit(**argv) && **argv != '-')
|
2003-07-26 13:11:56 +05:30
|
|
|
bb_error_msg_and_die( "Bad PID '%s'", *argv);
|
2000-03-07 13:11:42 +05:30
|
|
|
pid = strtol(*argv, NULL, 0);
|
2003-07-26 13:11:56 +05:30
|
|
|
if (kill(pid, signo) != 0) {
|
2003-03-19 14:43:01 +05:30
|
|
|
bb_perror_msg( "Could not kill pid '%d'", pid);
|
2002-09-16 11:52:25 +05:30
|
|
|
errors++;
|
2002-07-24 05:15:11 +05:30
|
|
|
}
|
2000-03-07 13:11:42 +05:30
|
|
|
argv++;
|
2000-02-09 01:28:47 +05:30
|
|
|
}
|
2002-09-16 11:52:25 +05:30
|
|
|
|
2006-07-13 00:47:55 +05:30
|
|
|
} else {
|
2000-04-19 01:30:03 +05:30
|
|
|
pid_t myPid=getpid();
|
2006-07-13 00:47:55 +05:30
|
|
|
|
2000-03-07 13:11:42 +05:30
|
|
|
/* Looks like they want to do a killall. Do that */
|
|
|
|
while (--argc >= 0) {
|
2001-12-06 20:22:32 +05:30
|
|
|
long* pidList;
|
2000-04-07 11:30:07 +05:30
|
|
|
|
2002-09-16 11:52:25 +05:30
|
|
|
pidList = find_pid_by_name(*argv);
|
2003-07-26 13:11:56 +05:30
|
|
|
if (!pidList || *pidList<=0) {
|
2002-09-16 11:52:25 +05:30
|
|
|
errors++;
|
|
|
|
if (quiet==0)
|
2003-03-19 14:43:01 +05:30
|
|
|
bb_error_msg( "%s: no process killed", *argv);
|
2003-07-26 13:11:56 +05:30
|
|
|
} else {
|
|
|
|
long *pl;
|
|
|
|
|
|
|
|
for(pl = pidList; *pl !=0 ; pl++) {
|
|
|
|
if (*pl==myPid)
|
|
|
|
continue;
|
|
|
|
if (kill(*pl, signo) != 0) {
|
|
|
|
errors++;
|
|
|
|
if (quiet==0)
|
|
|
|
bb_perror_msg( "Could not kill pid '%ld'", *pl);
|
2002-07-24 05:15:11 +05:30
|
|
|
}
|
2003-07-26 13:11:56 +05:30
|
|
|
}
|
2000-03-07 13:11:42 +05:30
|
|
|
}
|
2002-10-22 17:51:15 +05:30
|
|
|
free(pidList);
|
2000-03-07 13:11:42 +05:30
|
|
|
argv++;
|
2000-02-09 01:28:47 +05:30
|
|
|
}
|
|
|
|
}
|
2006-07-13 00:47:55 +05:30
|
|
|
|
2002-09-16 11:52:25 +05:30
|
|
|
return errors;
|
2000-02-09 01:28:47 +05:30
|
|
|
}
|