Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 29 Sep 2000 10:52:00 +0200 (IST)
From:      Roman Shterenzon <roman@harmonic.co.il>
To:        Alfred Perlstein <bright@wintelcom.net>
Cc:        freebsd-stable@FreeBSD.ORG
Subject:   Re: pthreads bug?
Message-ID:  <970217520.39d4583032fbe@webmail.harmonic.co.il>
In-Reply-To: <20000929013521.C27736@fw.wintelcom.net>
References:  <970215688.39d451088fbef@webmail.harmonic.co.il> <20000929013521.C27736@fw.wintelcom.net>

next in thread | previous in thread | raw e-mail | index | archive | help
Quoting Alfred Perlstein <bright@wintelcom.net>:
> > I attach example program, which, when receives SIGUSR1 should close
> the socket,
> > but, in fact gets blocked in the close() function.
> > Obviously it's waiting to acquire some lock.
> > Does anyone have an idea?
> 
> Yes, I have an idea and an idea how to fix it, I'm wondering what
> the thread in accept() sees after this happens?
> 
> what is the errno from accept?
The point is, that when close() is called, accept doesn't break out.

from close(2)
IMPLEMENTATION NOTES
     In the non-threaded library close() is implemented as the close syscall.

     In the threaded library, the close syscall is assembled to
     _thread_sys_close() and close() is implemented as a function which locks
     d for read and write, then calls _thread_sys_close().  Before returning,
     close() unlocks d.


So from my point of view the close tries to acquire a lock.


--Roman Shterenzon, UNIX System Administrator and Consultant
[ Xpert UNIX Systems Ltd., Herzlia, Israel. Tel: +972-9-9522361 ]


To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-stable" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?970217520.39d4583032fbe>