diff --git a/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.hpp b/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.hpp index d26b82e1e9e..18377a64dc6 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.hpp @@ -226,7 +226,10 @@ public: template static void oop_store_in_heap(T* addr, oop value) { - ShenandoahBarrierSet::barrier_set()->write_ref_field_pre_work(addr, value); + const bool keep_alive = (decorators & AS_NO_KEEPALIVE) == 0; + if (keep_alive) { + ShenandoahBarrierSet::barrier_set()->write_ref_field_pre_work(addr, value); + } Raw::oop_store(addr, value); } diff --git a/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.inline.hpp b/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.inline.hpp index 284b2bc937e..65d4d021230 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.inline.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.inline.hpp @@ -58,7 +58,8 @@ inline oop ShenandoahBarrierSet::AccessBarrier::oop_ato expected = res; } while ((! oopDesc::equals_raw(compare_value, expected)) && oopDesc::equals_raw(resolve_forwarded(compare_value), resolve_forwarded(expected))); if (oopDesc::equals_raw(expected, compare_value)) { - if (ShenandoahSATBBarrier && !CompressedOops::is_null(compare_value)) { + const bool keep_alive = (decorators & AS_NO_KEEPALIVE) == 0; + if (keep_alive && ShenandoahSATBBarrier && !CompressedOops::is_null(compare_value)) { ShenandoahBarrierSet::barrier_set()->enqueue(compare_value); } } @@ -70,7 +71,8 @@ template inline oop ShenandoahBarrierSet::AccessBarrier::oop_atomic_xchg_in_heap(oop new_value, T* addr) { oop previous = Raw::oop_atomic_xchg(new_value, addr); if (ShenandoahSATBBarrier) { - if (!CompressedOops::is_null(previous)) { + const bool keep_alive = (decorators & AS_NO_KEEPALIVE) == 0; + if (keep_alive && !CompressedOops::is_null(previous)) { ShenandoahBarrierSet::barrier_set()->enqueue(previous); } }