RFR: 8348960: [leyden] compiler/c1/TestConcurrentPatching.java is stuck [v3]
Vladimir Ivanov
vlivanov at openjdk.org
Tue Feb 4 18:29:34 UTC 2025
On Tue, 4 Feb 2025 13:43:27 GMT, Aleksey Shipilev <shade at openjdk.org> wrote:
>> src/hotspot/share/compiler/compileBroker.cpp line 421:
>>
>>> 419: assert(_lock->owned_by_self(), "must own lock");
>>> 420:
>>> 421: CompileTask* task;
>>
>> I assume these changes aren't strictly needed (`_queue` is always drained under the lock).
>
> While `_queue` is drained under the lock, it is being _added to_ without a lock, which means we are using `empty` under concurrent queue modification, which is, per NBQ docs, not guaranteed to work well. (ABA problems.)
Thanks for the clarification. I missed that `NonblockingQueue::empty()` is not thread-safe.
-------------
PR Review Comment: https://git.openjdk.org/leyden/pull/30#discussion_r1941699216
More information about the leyden-dev
mailing list