From 061ffc47cfc7366939108bc389f9fff2785f77df Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Markus=20Gr=C3=B6nlund?= Date: Mon, 18 Jan 2021 16:14:07 +0000 Subject: [PATCH] 8249245: assert(((((JfrTraceIdBits::load(klass)) & ((JfrTraceIdEpoch::this_epoch_method_and_class_bits()))) != 0))) failed: invariant Reviewed-by: egahlin --- .../checkpoint/types/traceid/jfrTraceIdLoadBarrier.inline.hpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdLoadBarrier.inline.hpp b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdLoadBarrier.inline.hpp index 17bdc7b19d5..d997c99b488 100644 --- a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdLoadBarrier.inline.hpp +++ b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdLoadBarrier.inline.hpp @@ -83,7 +83,7 @@ inline traceid JfrTraceIdLoadBarrier::load(const Method* method) { inline traceid JfrTraceIdLoadBarrier::load(const Klass* klass, const Method* method) { assert(klass != NULL, "invariant"); assert(method != NULL, "invariant"); - if (METHOD_FLAG_NOT_USED_THIS_EPOCH(method)) { + if (should_tag(method)) { SET_METHOD_AND_CLASS_USED_THIS_EPOCH(klass); SET_METHOD_FLAG_USED_THIS_EPOCH(method); assert(METHOD_AND_CLASS_USED_THIS_EPOCH(klass), "invariant"); @@ -112,7 +112,7 @@ inline traceid JfrTraceIdLoadBarrier::load_leakp(const Klass* klass, const Metho assert(METHOD_AND_CLASS_USED_THIS_EPOCH(klass), "invariant"); assert(method != NULL, "invariant"); assert(klass == method->method_holder(), "invariant"); - if (METHOD_FLAG_NOT_USED_THIS_EPOCH(method)) { + if (should_tag(method)) { // the method is already logically tagged, just like the klass, // but because of redefinition, the latest Method* // representation might not have a reified tag.