Date: Wed, 22 Sep 2004 09:05:48 +0100 From: Chris Stenton <jacs@gnome.co.uk> To: freebsd-current@freebsd.org Cc: threads@freebsd.org Subject: daemon threads bug with libpthread Message-ID: <1095840348.23443.14.camel@hawk.gnome.co.uk>
index | next in thread | raw e-mail
If you create a thread before calling daemon then the next thread you
create after the daemon call will cause the following error from the
libpthread library.
Fatal error 'mutex is on list' at line 516 in file
/usr/src/lib/libpthread/thread/thr_mutex.c (errno = 0)
This error does not occur if you link with -lc_r, linking with -lthr
causes a core dump. -lthr does not look very stable.
Here is some test code. I am running FreeBSD 5.3-beta
Please reply directly as I am not on the mailing list
Thanks
Chris
#include <pthread.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
void *slave (void *args);
void *slave2 (void *args);
typedef struct {
int data;
pthread_mutex_t *mut;
} simple;
simple status;
int main ()
{
pthread_t sla, sla2;
pthread_create (&sla, NULL, slave, &status);
pthread_join(sla, NULL);
daemon(0,1);
pthread_create (&sla2, NULL, slave2, &status);
for(;;){
}
return 0;
}
void *slave (void *arg)
{
simple *status;
status = (simple *)arg;
pthread_mutex_lock (status->mut);
status->data++;
usleep(500000);
printf("******slave me me me %d *********** \n",status->data );
pthread_mutex_unlock (status->mut);
return (NULL);
}
void *slave2 (void *arg)
{
simple *status;
status = (simple *)arg;
for(; /* ever */ ;) {
pthread_mutex_lock (status->mut);
status->data++;
usleep(500000);
printf("******slave2 me me me %d \n",status->data );
pthread_mutex_unlock (status->mut);
}
return (NULL);
}
help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1095840348.23443.14.camel>
