Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 6 Feb 2004 15:40:58 +0200
From:      Alexey Zelkin <phantom@freebsd.org>
To:        Nick Barnes <nb@ravenbrook.com>
Cc:        freebsd-java@freebsd.org
Subject:   Re: JDK garbage collector: thread context scanning
Message-ID:  <20040206134058.GA29887@phantom.cris.net>
In-Reply-To: <67371.1076068441@thrush.ravenbrook.com>
References:  <20040205233233.GA23899@phantom.cris.net> <67371.1076068441@thrush.ravenbrook.com>

next in thread | previous in thread | raw e-mail | index | archive | help
hi,

On Fri, Feb 06, 2004 at 11:54:01AM +0000, Nick Barnes wrote:
> At 2004-02-05 23:32:33+0000, Alexey Zelkin writes:
> 
> > Since JDK 1.4.1 we got correctly working fallbacks, so I was not
> > required to do a black magic anymore.
> 
> Can you enlarge on this?  What are "correctly working fallbacks"?

It means that if callback (used in pthread_kill()/sighandler()) schema
does not return meaningful value (i.e. NULL) then JVM tries to detect
this value with own way.  It is slower solution, but works for us in all
cases (both -STABLE and -CURRENT with any thread libraries)

> > Lately I have implemented pthread_attr_get_np() function which
> > exported all required information on application level and we stoped
> > to use private libc_r structures in JDK 1.4.x
> 
> Which information delivered by pthread_attr_get_np() do you use?
> pthread_attr_getstack()?

Kind of.  But with one small, but important exception.  pthread_attr_getstack()
returns stackaddr and stacksize values from pthread_attr structure associated
with thread.  But in case if you call pthread_create() with default
attribute then stackaddr will be NULL.  In this case libc_r will allocate
stack for this thread internally and will not export this stack pointer
address into application.  Usually there's no need to do it -- if application
want to know location of thread stack it simply mallocs it and provide
its address via pthread_attr structure to pthread_create().  Initially I
did it in way just described, but lately I found that JVM does not
provide way to deallocate stack after thread finishes.  I had to implement
own deallocating schema via separate thread almost line-by-line similar
to libc_r's gc thread.  Another issue with this way -- JVM provides some
restriction of amount of memory to be used (via command line switches) and
in case if this value was too small -- thread stack were able to eat all
available memory for application itself.  Of course it was possible to
implement it in another way and don't eat applications' memory, but it
was even more hackish than described in first item.

So, implementation of pthread_attr_get_np() with current behavior allowed
me to avoid implementing these hack "solutions".

> > Sorry for not saying anything helpful for you :(
> 
> Not at all, this is very helpful.
> 
> Nick Barnes
> Ravenbrook Limited

-- 
/* Alexey Zelkin             && Independent Contractor      */
/* phantom(at)FreeBSD.org    && http://www.FreeBSD.org/java */
/* phantom(at)cris.net       && http://www.FreeBSD.org.ua/  */



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