summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorats <ats@FreeBSD.org>1994-08-28 15:49:55 +0000
committerats <ats@FreeBSD.org>1994-08-28 15:49:55 +0000
commit6f4fdb72c187027894b619aa628053bb2557eccf (patch)
tree456aa2bdc130a99f87055430cbc1dda42c8f3b4a
parent0be9e2c6549cada3a129b621a02ae734501a4361 (diff)
downloadFreeBSD-src-6f4fdb72c187027894b619aa628053bb2557eccf.zip
FreeBSD-src-6f4fdb72c187027894b619aa628053bb2557eccf.tar.gz
Reviewed by:
Submitted by: Put in a signal handler to catch the SIGSYS signal that indicates that ktrace was not built into the kernel and prevent ktrace to core dump somewhere.
-rw-r--r--usr.bin/ktrace/ktrace.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/usr.bin/ktrace/ktrace.c b/usr.bin/ktrace/ktrace.c
index 26606d7..a57c4f4 100644
--- a/usr.bin/ktrace/ktrace.c
+++ b/usr.bin/ktrace/ktrace.c
@@ -49,8 +49,15 @@ static char sccsid[] = "@(#)ktrace.c 8.1 (Berkeley) 6/6/93";
#include <sys/uio.h>
#include <sys/ktrace.h>
#include <stdio.h>
+#include <signal.h>
#include "ktrace.h"
+void noktrace() {
+ (void)fprintf(stderr, "ktrace: ktrace not enabled in kernel,to use ktrace\n");
+ (void)fprintf(stderr, "you need to add a line \"options KTRACE\" to your kernel\n");
+ exit(1);
+}
+
main(argc, argv)
int argc;
char **argv;
@@ -65,6 +72,9 @@ main(argc, argv)
append = ops = pidset = inherit = 0;
trpoints = DEF_POINTS;
tracefile = DEF_TRACEFILE;
+ /* set up a signal handler for SIGSYS, this indicates that ktrace
+ is not enabled in the kernel */
+ signal(SIGSYS, noktrace);
while ((ch = getopt(argc,argv,"aCcdf:g:ip:t:")) != EOF)
switch((char)ch) {
case 'a':
OpenPOWER on IntegriCloud