RFR: 8255131: G1CollectedHeap::is_in() returns wrong result
Stefan Johansson
sjohanss at openjdk.java.net
Thu Oct 22 11:10:12 UTC 2020
On Thu, 22 Oct 2020 11:01:53 GMT, Kim Barrett <kbarrett at openjdk.org> wrote:
>> Hi all,
>>
>> please review this change to exchange the broken G1CollectedHeap::is_in() by G1CollectedHeap::is_in_exact() that has the same performance profile and correct.
>>
>> G1CollectedHeap::is_in() returns true for any region ever committed (and crashes for not yet committed regions), while is_in_exact() (almost) did the right thing. Almost because HeapRegionManager::is_available() would assert if the given pointer is outside the heap and it's not guarded by is_in_reserved.
>>
>> Test: tier1
>>
>> Thanks,
>> Thomas
>
> src/hotspot/share/gc/g1/g1CollectedHeap.cpp line 2264:
>
>> 2262: bool G1CollectedHeap::is_in(const void* p) const {
>> 2263: if (is_in_reserved(p) &&
>> 2264: _hrm->is_available(addr_to_region((HeapWord*)p))) {
>
> This line is misindented. But rather than adjusting the indentation, how about instead changing the function to
> bool G1CollectedHeap::is_in(const void* p) const {
> return is_in_reserved(p) && _hrm->is_available(addr_to_region((HeapWord*)p));
> }
I was thinking something similar, so I would approve going with this proposal.
-------------
PR: https://git.openjdk.java.net/jdk/pull/799
More information about the hotspot-gc-dev
mailing list