RFR: JDK-8319314: NMT detail report slow or hangs for large number of mappings
Thomas Stuefe
stuefe at openjdk.org
Fri Nov 3 12:35:22 UTC 2023
On Fri, 3 Nov 2023 09:25:27 GMT, Johan Sjölen <jsjolen at openjdk.org> wrote:
>> If a lot of mappings have been registered with NMT, NMT detail report may get so slow as to hang seemingly.
>>
>> 100 k mappings will take > 1 minute
>> 1 million mappings never returns (I canceled the test after 90 minutes)
>>
>> We burn all the time doing a sorted insert into the target array of the MemBaseline object. That sorted insert is pointless since the source array is already sorted by region base address.
>>
>> Omitting the pointless sort drops the runtime for 1 million mappings from > 90 minutes to 48 seconds.
>>
>> Tests: Tested locally. GHAs (Windows error unrelated).
>
> src/hotspot/share/nmt/memBaseline.cpp line 130:
>
>> 128:
>> 129: bool do_allocation_site(const ReservedMemoryRegion* rgn) {
>> 130: assert(rgn->base() >= _last_base, "region unordered?");
>
> It seems like we don't assign to `_last_base`?
Ah, missed that. Thanks.
Wonder why no mails are sent to MLs though.
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/16480#discussion_r1381443268
More information about the hotspot-runtime-dev
mailing list