public inbox for libc-hacker@sourceware.org
 help / color / mirror / Atom feed
* deadlock in signal handler with NPTL
@ 2004-06-22 21:51 Thorsten Kukuk
  2004-06-22 22:07 ` Jakub Jelinek
  0 siblings, 1 reply; 6+ messages in thread
From: Thorsten Kukuk @ 2004-06-22 21:51 UTC (permalink / raw)
  To: libc-hacker

[-- Attachment #1: Type: text/plain, Size: 612 bytes --]


Hi,

I got the following test program. I know, it is very ugly and there
are a lot of things somebody should not do, but this is something
what programs like sshd are doing.

The problem is: This program deadlocks very fast in a FUTEX_WAIT
call. This does not happen with LinuxThreads.

Any ideas what goes wrong?

  Thorsten

-- 
Thorsten Kukuk       http://www.suse.de/~kukuk/        kukuk@suse.de
SuSE Linux AG        Maxfeldstr. 5                 D-90409 Nuernberg
--------------------------------------------------------------------    
Key fingerprint = A368 676B 5E1B 3E46 CFCE  2D97 F8FD 4E23 56C6 FB4B

[-- Attachment #2: s.c --]
[-- Type: text/plain, Size: 574 bytes --]


#include <sys/types.h>

#include <unistd.h>
#include <stdio.h>
#include <syslog.h>
#include <signal.h>


void
handler(int sig)
{
	syslog(LOG_DEBUG, "sigtest");
	printf("in handler\n");
	fflush(stdout);
}

int
main(int argc, char *argv[])
{
	pid_t pid;

	switch (pid = fork()) {
	case 0:
		break;
	case -1:
		perror("form");
		exit(1);
	default:
		signaller(pid);
		exit(0);
	}
	signal(SIGCHLD, handler);
	while (1) {
		syslog(LOG_DEBUG, "test");
		printf("in loop\n");
		fflush(stdout);
	}
}

int
signaller(pid_t pid)
{
	while (1) {
		usleep(1);
		kill(pid, SIGCHLD);
	}
}

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

end of thread, other threads:[~2004-06-23  8:23 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2004-06-22 21:51 deadlock in signal handler with NPTL Thorsten Kukuk
2004-06-22 22:07 ` Jakub Jelinek
2004-06-23  4:26   ` Thorsten Kukuk
2004-06-23  4:41     ` Steve Munroe
2004-06-23  6:56       ` Thorsten Kukuk
2004-06-23  8:23         ` Jakub Jelinek

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).