[RESUMED] Re: RFR: 8158946 - btree009 fails with assert(s > 0) failed: Bad size calculated

Thomas Schatzl thomas.schatzl at oracle.com
Tue Jun 21 22:36:30 UTC 2016


Hi,

On Tue, 2016-06-21 at 18:27 -0400, Derek White wrote:
> Here's a more complete solution to the problem.
> 
> As Kim mentioned, the new version sets the object size field of a 
> java.lang.Class object before it sets the object's header, so GC can 
> reliably get the size of any object with it's header set.

  just briefly looking over the code (maybe I am overlooking something
obvious, I am only looking at the webrev) - wouldn't the code need some
compiler and memory barriers that make sure that this required
read/write orderings are observed?

> This fix works by adding a CollectedHeap::class_allocate() method and
> associated helpers. These are implemented in CollectedHeap.inline.hpp
> only because they share so much structure and code with 
> CollectedHeap::obj_allocate() that I thought it best to keep them 
> together (even though there is no performance reason to have the new 
> code inlined).
> 
> Webrev: http://cr.openjdk.java.net/~drwhite/8158946/webrev.02
> jprt in progress...


Thanks,
  Thomas



More information about the hotspot-gc-dev mailing list