8293252: Shenandoah: ThreadMXBean synchronizer tests crash with aggressive heuristics
Reviewed-by: wkemper, rkennke, heidinga, phh
This commit is contained in:
parent
543851db92
commit
3675f4c2af
@ -133,6 +133,10 @@ public:
|
|||||||
class AccessBarrier: public BarrierSet::AccessBarrier<decorators, BarrierSetT> {
|
class AccessBarrier: public BarrierSet::AccessBarrier<decorators, BarrierSetT> {
|
||||||
typedef BarrierSet::AccessBarrier<decorators, BarrierSetT> Raw;
|
typedef BarrierSet::AccessBarrier<decorators, BarrierSetT> Raw;
|
||||||
|
|
||||||
|
private:
|
||||||
|
template <typename T>
|
||||||
|
static void oop_store_common(T* addr, oop value);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Heap oop accesses. These accessors get resolved when
|
// Heap oop accesses. These accessors get resolved when
|
||||||
// IN_HEAP is set (e.g. when using the HeapAccess API), it is
|
// IN_HEAP is set (e.g. when using the HeapAccess API), it is
|
||||||
@ -174,7 +178,6 @@ public:
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
static oop oop_atomic_xchg_not_in_heap(T* addr, oop new_value);
|
static oop oop_atomic_xchg_not_in_heap(T* addr, oop new_value);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -241,7 +241,7 @@ inline oop ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_loa
|
|||||||
|
|
||||||
template <DecoratorSet decorators, typename BarrierSetT>
|
template <DecoratorSet decorators, typename BarrierSetT>
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline void ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_store_not_in_heap(T* addr, oop value) {
|
inline void ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_store_common(T* addr, oop value) {
|
||||||
shenandoah_assert_marked_if(NULL, value, !CompressedOops::is_null(value) && ShenandoahHeap::heap()->is_evacuation_in_progress());
|
shenandoah_assert_marked_if(NULL, value, !CompressedOops::is_null(value) && ShenandoahHeap::heap()->is_evacuation_in_progress());
|
||||||
shenandoah_assert_not_in_cset_if(addr, value, value != NULL && !ShenandoahHeap::heap()->cancelled_gc());
|
shenandoah_assert_not_in_cset_if(addr, value, value != NULL && !ShenandoahHeap::heap()->cancelled_gc());
|
||||||
ShenandoahBarrierSet* const bs = ShenandoahBarrierSet::barrier_set();
|
ShenandoahBarrierSet* const bs = ShenandoahBarrierSet::barrier_set();
|
||||||
@ -250,14 +250,19 @@ inline void ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_st
|
|||||||
Raw::oop_store(addr, value);
|
Raw::oop_store(addr, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <DecoratorSet decorators, typename BarrierSetT>
|
||||||
|
template <typename T>
|
||||||
|
inline void ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_store_not_in_heap(T* addr, oop value) {
|
||||||
|
oop_store_common(addr, value);
|
||||||
|
}
|
||||||
|
|
||||||
template <DecoratorSet decorators, typename BarrierSetT>
|
template <DecoratorSet decorators, typename BarrierSetT>
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline void ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_store_in_heap(T* addr, oop value) {
|
inline void ShenandoahBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_store_in_heap(T* addr, oop value) {
|
||||||
shenandoah_assert_not_in_cset_loc_except(addr, ShenandoahHeap::heap()->cancelled_gc());
|
shenandoah_assert_not_in_cset_loc_except(addr, ShenandoahHeap::heap()->cancelled_gc());
|
||||||
shenandoah_assert_not_forwarded_except (addr, value, value == NULL || ShenandoahHeap::heap()->cancelled_gc() || !ShenandoahHeap::heap()->is_concurrent_mark_in_progress());
|
shenandoah_assert_not_forwarded_except (addr, value, value == NULL || ShenandoahHeap::heap()->cancelled_gc() || !ShenandoahHeap::heap()->is_concurrent_mark_in_progress());
|
||||||
shenandoah_assert_not_in_cset_except (addr, value, value == NULL || ShenandoahHeap::heap()->cancelled_gc() || !ShenandoahHeap::heap()->is_concurrent_mark_in_progress());
|
|
||||||
|
|
||||||
oop_store_not_in_heap(addr, value);
|
oop_store_common(addr, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <DecoratorSet decorators, typename BarrierSetT>
|
template <DecoratorSet decorators, typename BarrierSetT>
|
||||||
|
@ -1238,7 +1238,7 @@ private:
|
|||||||
// There may be dead oops in weak roots in concurrent root phase, do not touch them.
|
// There may be dead oops in weak roots in concurrent root phase, do not touch them.
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
obj = ShenandoahBarrierSet::resolve_forwarded_not_null(obj);
|
obj = ShenandoahBarrierSet::barrier_set()->load_reference_barrier(obj);
|
||||||
|
|
||||||
assert(oopDesc::is_oop(obj), "must be a valid oop");
|
assert(oopDesc::is_oop(obj), "must be a valid oop");
|
||||||
if (!_bitmap->is_marked(obj)) {
|
if (!_bitmap->is_marked(obj)) {
|
||||||
@ -1348,7 +1348,7 @@ private:
|
|||||||
// There may be dead oops in weak roots in concurrent root phase, do not touch them.
|
// There may be dead oops in weak roots in concurrent root phase, do not touch them.
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
obj = ShenandoahBarrierSet::resolve_forwarded_not_null(obj);
|
obj = ShenandoahBarrierSet::barrier_set()->load_reference_barrier(obj);
|
||||||
|
|
||||||
assert(oopDesc::is_oop(obj), "Must be a valid oop");
|
assert(oopDesc::is_oop(obj), "Must be a valid oop");
|
||||||
if (_bitmap->par_mark(obj)) {
|
if (_bitmap->par_mark(obj)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user