On Tue, 11 Apr 2000, Arun Sharma wrote:

> In muc.lists.freebsd.hackers, you wrote:
> > 
> > Is there a MT-safe implementation of gethostbyname() in FreeBSD (3.4/4.0)?
> > 
> > On Solaris there is gethostbyname_r().  Calling gethostbyname() with in
> > two threads cause both threads to block.
> 
> You seem to be talking about two different things:
> 
> 1. A reentrant function - two different threads can be in the same function
>    simultaneously
> 
> 2. A non blocking function.
> 

Hi, thanks for the reply.  I'm talking about (1). Reentrant functions
are MT-safe, but a non blocking function may not be.

> Reading the code in /usr/src/lib/libc{,_r}, it appears to me that, the
> FreeBSD implementation is not reentrant, and blocking. However,
> gethostbyname calls poll(2), which causes a reschedule to another runnable
> pthread, if any.
> 

Sure, and there is no "reimplementation" for gethostbyname() in libc_r as
far as I could tell.

> In your case, both the threads are waiting for a DNS server response,
> so the thread scheduler doesn't have a thread to schedule.

If I only create one thread, then the gethostbyname() returns immediately. 
By using truss -p, it seems that gethostbyname() uses a static socket var
for the DNS I/O rather than a local one, and that I think is what caused
the threads to hang.  Or, we're talking about the same thing?

Thanks again for the input.

Ming

> 
> I think it'd be very useful to have a non-blocking DNS lookup API (one
> which exposes the underlying file descriptor) . Winsock has this. UNIX
> netscape 4.x would freeze half as often if this was done right.
> 
>       -Arun
> 



To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-hackers" in the body of the message

Reply via email to