summaryrefslogtreecommitdiff
path: root/usr.bin/pmdb/pmdb.c
diff options
context:
space:
mode:
authorTodd T. Fries <todd@cvs.openbsd.org>2002-06-09 02:44:14 +0000
committerTodd T. Fries <todd@cvs.openbsd.org>2002-06-09 02:44:14 +0000
commit644356b24e821469532d008a5aaaae1e59c20c5c (patch)
tree1b7704988ebedfce982e54cf0c0c704567dd9011 /usr.bin/pmdb/pmdb.c
parentc645793bc2c9536cd259f4bf722d057e4a2f423a (diff)
provide '-p <pid>' (process attach); thanks to
Jean-Francois Brousseau <krapht@secureops.com>
Diffstat (limited to 'usr.bin/pmdb/pmdb.c')
-rw-r--r--usr.bin/pmdb/pmdb.c29
1 files changed, 21 insertions, 8 deletions
diff --git a/usr.bin/pmdb/pmdb.c b/usr.bin/pmdb/pmdb.c
index 43a8ae790f2..99701a6e0af 100644
--- a/usr.bin/pmdb/pmdb.c
+++ b/usr.bin/pmdb/pmdb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmdb.c,v 1.7 2002/06/05 18:02:27 fgsch Exp $ */
+/* $OpenBSD: pmdb.c,v 1.8 2002/06/09 02:44:13 todd Exp $ */
/*
* Copyright (c) 2002 Artur Grabowski <art@openbsd.org>
* All rights reserved.
@@ -81,7 +81,7 @@ usage()
{
extern char *__progname;
- fprintf(stderr, "Usage: %s [-c core] <program> args\n", __progname);
+ fprintf(stderr, "Usage: %s [-c core] [-p pid] <program> args\n", __progname);
exit(1);
}
@@ -92,20 +92,27 @@ main(int argc, char **argv)
int i, c;
int status;
void *cm;
- char *pmenv, *core;
+ char *pmenv, *core, *perr;
int level;
+ pid_t pid;
if (argc < 2) {
usage();
}
core = NULL;
+ pid = 0;
- while ((c = getopt(argc, argv, "c:")) != -1) {
+ while((c = getopt(argc, argv, "c:p:")) != -1) {
switch(c) {
case 'c':
core = optarg;
break;
+ case 'p':
+ pid = (pid_t) strtol(optarg, &perr, 10);
+ if(*perr != '\0')
+ errx(1, "invalid PID");
+ break;
case '?':
default:
usage();
@@ -126,7 +133,7 @@ main(int argc, char **argv)
asprintf(&pmenv, "%d", level);
setenv("IN_PMDB", pmenv, 1);
- ps.ps_pid = 0;
+ ps.ps_pid = pid;
ps.ps_state = NONE;
ps.ps_argc = argc;
ps.ps_argv = argv;
@@ -308,10 +315,16 @@ cmd_quit(int argc, char **argv, void *arg)
{
struct pstate *ps = arg;
- ps->ps_flags |= PSF_KILL;
+ if ((ps->ps_flags & PSF_ATCH)) {
+ if ((ps->ps_flags & PSF_ATCH) &&
+ ptrace(PT_DETACH, ps->ps_pid, NULL, 0) < 0)
+ err(1, "ptrace(PT_DETACH)");
+ } else {
+ ps->ps_flags |= PSF_KILL;
- if (process_kill(ps))
- return 1;
+ if (process_kill(ps))
+ return 1;
+ }
ps->ps_state = TERMINATED;
return 1;