RFR: 8203319: JDK-8201487 disabled too much queue balancing
Kim Barrett
kim.barrett at oracle.com
Thu May 31 19:33:53 UTC 2018
> On May 30, 2018, at 7:57 PM, Kim Barrett <kim.barrett at oracle.com> wrote:
>
>> On May 30, 2018, at 1:49 PM, Thomas Schatzl <thomas.schatzl at oracle.com> wrote:
>> On Wed, 2018-05-30 at 13:33 -0400, Kim Barrett wrote:
>>> I tried to write a test directed at the problematic cases, but
>>> couldn't find a way to produce a setup with
>>> 1 < # of processing threads < # of discovery theads
>>>
>>> In particular, a configuration with ParallelGCThreads < ConcGCThreads
>>> is disallowed by option checking, so the VM won't even start with
>>> such a configuration. So it seems the problematic cases described in
>>> the bug report can't currently arise in practice.
>>
>> Due to UseDynamicNumberOfGCThreads the number of active threads for the
>> work queue may be < ConcGCThreads. Just run on a small heap (iirc it
>> selects 1 thread per 32MB of heap) on a large machine.
>
> I was able to produce some pretty stupid configurations, using -XX:+ForceDynamicNumberOfGCThreads.
> But I wasn’t able to get the number of marking (discovery) threads to be lower than the
> number of reference processing threads. If the heap is small the number of marking
> threads will be kept small too.
I patched the VM to allow ConcGCThreads > ParallelGCThreads and verified
balancing was being triggered even with ParallelRefProcBalancingEnabled turned off,
as desired.
More information about the hotspot-gc-dev
mailing list