(L) Prelim RFR: 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables

David Holmes david.holmes at oracle.com
Wed Nov 4 09:26:16 UTC 2015


On 4/11/2015 6:17 PM, Thomas Stüfe wrote:
> Hi David,
>
> On Wed, Nov 4, 2015 at 5:08 AM, David Holmes <david.holmes at oracle.com
> <mailto:david.holmes at oracle.com>> wrote:
>
>     Hi Thomas,
>
>
>         One question about your changes:
>
>         Before, Thread::current() would assert instead of returning NULL if
>         called before Thread::initialize_thread_current() or after
>         Thead::clear_thread_current() . Now, we just return NULL. Is
>         this intended?
>
>
>     Ah great question ... so before we have a mix of calls to:
>
>     - Thread::current()  (asserts on NULL as does JavaThread::current)
>     - ThreadLocalStorage::thread() (can return NULL)
>     - ThreadLocalStorage::get_thread_slow() (can return NULL)
>
>     and now we only have Thread::current() which means we have to allow
>     returning NULL because it can be intentionally called when a thread
>     is not attached. That means we won't directly catch calls to
>     Thread::current() from code that doesn't realize it is calling it
>     "too soon" - though there do exist numerous assertions in the
>     callers of Thread::current() that check the result is not NULL.
>
>     I could add the assert to Thread::current() and also add
>     Thread::current_or_null() to be used by code that needs to use it to
>     check for attachment (ie JNI code). I'd also have to examine all the
>     changed ThreadLocalStorage::thread/get_thread_slow call-sites to see
>     if any of those legitimately expect the thread may not be attached.
>
>     What do you think?
>
>
> I would prefer having Thread::current() to assert and to have a
> Thread::current_or_null() for cases where NULL could occurr. I tend to
> hit that assert a lot in development, it is useful. And the
> non-asserting version gets already used in a number of places, also in
> our (not OpenJDK) coding.

Yes I agree. Most of the TLS::thread() and TLS::get_thread_slow() should 
actually call Thread::current_or_null(). I also found a couple of 
existing Thread::current()'s that should be current_or_null(). :)

>     I also need to look at the location of Thread::current in the .hpp
>     file rather than .inline.hpp and reconcile that with comments
>     regarding the noinline version (which is only used in
>     g1HotCardCache.hpp).
>
>
> Could we leave just the inline version in thread.hpp and remove the
> noinline version altogether? Now that Thread::current() is very simple,
> we may just as well keep it in the class body like the other accessors.

I'll see if the g1 code can tolerate that.

I'll update a prepare a new webrev tomorrow.

Thanks,
David

> Thanks, Thomas
>
>


More information about the porters-dev mailing list