public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* ptrace(), fork(), sleep(), exit(), SIGCHLD
@ 2001-08-13  8:29 Bruce Janson
  2001-08-14  7:28 ` christophe barbé
  0 siblings, 1 reply; 20+ messages in thread
From: Bruce Janson @ 2001-08-13  8:29 UTC (permalink / raw)
  To: linux-kernel

Hi,
    The following program behaves incorrectly when traced:

  $ uname -a
  Linux dependo 2.4.2-2 #1 Sun Apr 8 19:37:14 EDT 2001 i686 unknown
  $ cc -v
  Reading specs from /usr/lib/gcc-lib/i386-redhat-linux/2.96/specs
  gcc version 2.96 20000731 (Red Hat Linux 7.1 2.96-81)
  $ strace -V
  strace -- version 4.2
  $ cat t.c
  main()
  {
  	switch (fork())
  	{
  	case -1:
  		write(2, "fork\n", 5);
  		break;
  
  	case 0:
  		usleep(1000000);
  		break;
  
  	default:
  		if (usleep(5000000) == -1)
  			write(2, "wrong\n", 6);
  		break;
  	}
  
  	exit(0);
  }
  $ cc t.c
  $ time ./a.out
  
  real    0m5.011s
  user    0m0.000s
  sys     0m0.000s
  $ time strace -o /dev/null ./a.out
  wrong
  
  real    0m1.025s
  user    0m0.010s
  sys     0m0.010s
  $ 

The problem appears to be that, when traced, the child process' exit()
interrupts the parent's usleep() with a SIGCHLD, the latter returning EINTR.
It also fails in the same way under Linux 2.2.16 and 2.2.19.

What am I missing?

^ permalink raw reply	[flat|nested] 20+ messages in thread

end of thread, other threads:[~2001-08-23 21:16 UTC | newest]

Thread overview: 20+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2001-08-13  8:29 ptrace(), fork(), sleep(), exit(), SIGCHLD Bruce Janson
2001-08-14  7:28 ` christophe barbé
2001-08-14 15:06   ` Bruce Janson
2001-08-15 15:46     ` george anzinger
2001-08-15 17:53       ` george anzinger
2001-08-15 18:02       ` george anzinger
2001-08-16  0:59         ` How should nano_sleep be fixed (was: ptrace(), fork(), sleep(), exit(), SIGCHLD) george anzinger
2001-08-16 10:17           ` christophe barbé
2001-08-16 10:29             ` Russell King
2001-08-16 14:16               ` george anzinger
2001-08-16 16:00               ` christophe barbé
2001-08-16 16:12                 ` Russell King
2001-08-16 18:17                   ` george anzinger
2001-08-17 18:25                     ` george anzinger
2001-08-17 18:57                       ` Victor Yodaiken
2001-08-17 19:56                         ` george anzinger
2001-08-22 18:40                           ` Russell King
2001-08-23 20:04                             ` george anzinger
2001-08-23 20:11                               ` Russell King
2001-08-23 21:13                                 ` george anzinger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox