[10?] RFR (XS): 8129440: G1 crash during concurrent root region scan
Thomas Schatzl
thomas.schatzl at oracle.com
Thu Dec 7 12:04:05 UTC 2017
Hi,
On Thu, 2017-12-07 at 10:14 +0100, Erik Helin wrote:
> On 12/06/2017 08:17 PM, Thomas Schatzl wrote:
> > Hi all,
> >
> > can I have reviews for this small change that prevents C++
> > compilers from generating code that reloads oop value from the heap
> > instead of using a local variable in concurrent marking closures.
> > This can cause issues if this reloading occurs after the originally
> > loaded value has been checked for NULL to prevent SIGSEGVs and the
> > mutator changed the value in the meantime.
> >
> > E.g.
> >
> > oop o = load_from_heap(p);
> > if (o == NULL) {
> > return;
> > }
> > // do something with o; potential crash here when reloading from
> > p
> > instead of actually reusing o
> >
> > According to SAP particularly the IBM xlc compiler tends to to such
> > nasty things (which is completely okay from a language POV).
> >
> > The fix is to make the load from the heap a volatile load using the
> > new AccessBarrier API in cases this can happen.
> >
> > CR:
> > https://bugs.openjdk.java.net/browse/JDK-8129440
> > Webrev:
> > http://cr.openjdk.java.net/~tschatzl/8129440/webrev/
>
> Looks good, Reviewed.
>
thanks for your review.
Thomas
More information about the hotspot-gc-dev
mailing list