RFR: 8256830: misc tests failed with "assert(env->is_enabled(JVMTI_EVENT_OBJECT_FREE)) failed: checking"
Kim Barrett
kbarrett at openjdk.java.net
Wed Nov 25 23:34:01 UTC 2020
On Wed, 25 Nov 2020 18:40:49 GMT, Coleen Phillimore <coleenp at openjdk.org> wrote:
> The ServiceThread cleaning used a stale ObjectFree state when calling remove_dead_entries, because another thread had concurrently set is_enabled to false. Add a lock around setting/resetting the lock event state and retest the state under a lock. Ran the test 100s of time without failure, where otherwise it fails very quickly.
> Tested with tier2,3 and running tiers 4,5,6 in progress.
> Thanks to Kim for his previous feedback.
Marked as reviewed by kbarrett (Reviewer).
src/hotspot/share/prims/jvmtiEventController.cpp line 463:
> 461: ((now_enabled & OBJECT_FREE_BIT)) != 0) {
> 462: // Set/reset the event enabled under the tagmap lock.
> 463: set_enabled_events_with_lock(env, now_enabled);
You could tighten up the test to only handle specially when the state of the ObjectFree event is changing, i.e.
(((was_enabled ^ now_enabled) & OBJECT_FREE_BIT) != 0)```
Or you could not bother with the conditionalization at all, and just always call set_enabled_events_with_lock; I bet nobody would notice any performance difference. That would eliminate "benign" races between unlocked bit setting here and bit testing in remove_dead_entries_locked. Of course, the current implementation has such races on these bits all over the place; what's one race more or less among friends...
Or you could just leave it as you have it. Your call.
-------------
PR: https://git.openjdk.java.net/jdk/pull/1439
More information about the hotspot-dev
mailing list