From feaa2ee03c5dc83faf4a90b3352bb31fb9cdba72 Mon Sep 17 00:00:00 2001 From: delphij Date: Mon, 13 Apr 2009 16:23:32 +0000 Subject: Don't exit until all truss children were exit. --- usr.bin/truss/main.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) (limited to 'usr.bin/truss/main.c') diff --git a/usr.bin/truss/main.c b/usr.bin/truss/main.c index 54f7ee8..9c1589b 100644 --- a/usr.bin/truss/main.c +++ b/usr.bin/truss/main.c @@ -1,4 +1,4 @@ -/* +/*- * Copryight 1997 Sean Eric Fagan * * Redistribution and use in source and binary forms, with or without @@ -43,6 +43,7 @@ __FBSDID("$FreeBSD$"); #include #include #include +#include #include #include @@ -164,6 +165,8 @@ main(int ac, char **av) { int c; int i; + pid_t childpid; + int status; char **command; struct ex_types *funcs; int initial_open; @@ -288,8 +291,6 @@ START_TRACE: if (trussinfo->curthread->in_fork && (trussinfo->flags & FOLLOWFORKS)) { - int childpid; - trussinfo->curthread->in_fork = 0; childpid = funcs->exit_syscall(trussinfo, @@ -360,6 +361,11 @@ START_TRACE: } } while (trussinfo->pr_why != S_EXIT); fflush(trussinfo->outfile); - + + if (trussinfo->flags & FOLLOWFORKS) + do { + childpid = wait(&status); + } while (childpid != -1); + return (0); } -- cgit v1.1