6833576: G1: assert illegal index, growableArray.hpp:186
The code that calculates the heap region index for an object address incorrectly used signed arithmetic. Reviewed-by: jcoomes, ysr
This commit is contained in:
parent
55750920b4
commit
92afe130d1
@ -37,8 +37,9 @@ G1CollectedHeap::heap_region_containing(const void* addr) const {
|
|||||||
inline HeapRegion*
|
inline HeapRegion*
|
||||||
G1CollectedHeap::heap_region_containing_raw(const void* addr) const {
|
G1CollectedHeap::heap_region_containing_raw(const void* addr) const {
|
||||||
assert(_g1_reserved.contains(addr), "invariant");
|
assert(_g1_reserved.contains(addr), "invariant");
|
||||||
size_t index = ((intptr_t) addr - (intptr_t) _g1_reserved.start())
|
size_t index = pointer_delta(addr, _g1_reserved.start(), 1)
|
||||||
>> HeapRegion::LogOfHRGrainBytes;
|
>> HeapRegion::LogOfHRGrainBytes;
|
||||||
|
|
||||||
HeapRegion* res = _hrs->at(index);
|
HeapRegion* res = _hrs->at(index);
|
||||||
assert(res == _hrs->addr_to_region(addr), "sanity");
|
assert(res == _hrs->addr_to_region(addr), "sanity");
|
||||||
return res;
|
return res;
|
||||||
|
Loading…
Reference in New Issue
Block a user