From ccbf029d2b4d713aead707aada6a736a0999e839 Mon Sep 17 00:00:00 2001 From: Yasumasa Suenaga Date: Wed, 11 Oct 2017 23:29:24 +0900 Subject: [PATCH] 8189069: regression after push of 8187403: "AssertionFailure: addr should be OopHandle" Reviewed-by: sspitsyn, jgeorge --- .../sun/jvm/hotspot/gc/g1/G1HeapRegionTable.java | 10 ++++------ .../classes/sun/jvm/hotspot/gc/g1/HeapRegion.java | 9 ++------- 2 files changed, 6 insertions(+), 13 deletions(-) diff --git a/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/G1HeapRegionTable.java b/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/G1HeapRegionTable.java index 331a8eb1499..596db0d53a4 100644 --- a/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/G1HeapRegionTable.java +++ b/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/G1HeapRegionTable.java @@ -37,7 +37,6 @@ import sun.jvm.hotspot.types.AddressField; import sun.jvm.hotspot.types.CIntegerField; import sun.jvm.hotspot.types.Type; import sun.jvm.hotspot.types.TypeDataBase; -import sun.jvm.hotspot.utilities.Assert; // Mirror class for G1HeapRegionTable. It's essentially an index -> HeapRegion map. @@ -136,11 +135,10 @@ public class G1HeapRegionTable extends VMObject { } public HeapRegion getByAddress(Address addr) { - if (Assert.ASSERTS_ENABLED) { - Assert.that(addr instanceof OopHandle, "addr should be OopHandle"); - } - long biasedIndex = addr.asLongValue() >>> shiftBy(); - return new HeapRegion(addr.addOffsetToAsOopHandle(biasedIndex * HeapRegion.getPointerSize())); + long offset = biasedIndex * HeapRegion.getPointerSize(); + Address result = (addr instanceof OopHandle) ? addr.addOffsetToAsOopHandle(offset) + : addr.addOffsetTo(offset); + return new HeapRegion(result); } } diff --git a/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/HeapRegion.java b/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/HeapRegion.java index 608bab9fb30..e771bb38de1 100644 --- a/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/HeapRegion.java +++ b/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/gc/g1/HeapRegion.java @@ -38,7 +38,6 @@ import sun.jvm.hotspot.types.AddressField; import sun.jvm.hotspot.types.CIntegerField; import sun.jvm.hotspot.types.Type; import sun.jvm.hotspot.types.TypeDataBase; -import sun.jvm.hotspot.utilities.Assert; // Mirror class for HeapRegion. Currently we don't actually include // any of its fields but only iterate over it. @@ -76,12 +75,8 @@ public class HeapRegion extends CompactibleSpace { public HeapRegion(Address addr) { super(addr); - - if (Assert.ASSERTS_ENABLED) { - Assert.that(addr instanceof OopHandle, "addr should be OopHandle"); - } - - Address typeAddr = addr.addOffsetToAsOopHandle(typeFieldOffset); + Address typeAddr = (addr instanceof OopHandle) ? addr.addOffsetToAsOopHandle(typeFieldOffset) + : addr.addOffsetTo(typeFieldOffset); type = (HeapRegionType)VMObjectFactory.newObject(HeapRegionType.class, typeAddr); }