1 /* 2 * Copyright 1997 Sean Eric Fagan 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions 6 * are met: 7 * 1. Redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer. 9 * 2. Redistributions in binary form must reproduce the above copyright 10 * notice, this list of conditions and the following disclaimer in the 11 * documentation and/or other materials provided with the distribution. 12 * 3. All advertising materials mentioning features or use of this software 13 * must display the following acknowledgement: 14 * This product includes software developed by Sean Eric Fagan 15 * 4. Neither the name of the author may be used to endorse or promote 16 * products derived from this software without specific prior written 17 * permission. 18 * 19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 * SUCH DAMAGE. 30 * 31 * $FreeBSD: src/usr.sbin/procctl/procctl.c,v 1.6 2000/02/21 10:22:39 ru Exp $ 32 * $DragonFly: src/usr.sbin/procctl/procctl.c,v 1.2 2003/06/17 04:30:01 dillon Exp $ 33 */ 34 35 /* 36 * procctl -- clear the event mask, and continue, any specified processes. 37 * This is largely an example of how to use the procfs interface; however, 38 * for now, it is also sometimes necessary, as a stopped process will not 39 * otherwise continue. (This will be fixed in a later version of the 40 * procfs code, almost certainly; however, this program will still be useful 41 * for some annoying circumstances.) 42 */ 43 44 #include <err.h> 45 #include <errno.h> 46 #include <fcntl.h> 47 #include <signal.h> 48 #include <stdio.h> 49 #include <stdlib.h> 50 #include <string.h> 51 #include <unistd.h> 52 #include <sys/ioctl.h> 53 #include <sys/pioctl.h> 54 55 int 56 main(int ac, char **av) { 57 int fd; 58 int i; 59 60 for (i = 1; i < ac; i++) { 61 char buf[32]; 62 63 snprintf(buf, sizeof(buf), "/proc/%s/mem", av[i]); 64 fd = open(buf, O_RDWR); 65 if (fd == -1) { 66 if (errno == ENOENT) 67 continue; 68 warn("cannot open pid %s", av[i]); 69 continue; 70 } 71 if (ioctl(fd, PIOCBIC, ~0) == -1) 72 warn("cannot clear process %s's event mask", av[i]); 73 if (ioctl(fd, PIOCCONT, 0) == -1 && errno != EINVAL) 74 warn("cannot continue process %s", av[i]); 75 close(fd); 76 } 77 return 0; 78 } 79