< prev index next >
src/hotspot/cpu/aarch64/gc/shenandoah/shenandoahBarrierSetAssembler_aarch64.cpp
Print this page
rev 53052 : [mq]: asm.patch
*** 689,693 ****
--- 689,717 ----
StubCodeGenerator cgen(&buf);
_shenandoah_wb = generate_shenandoah_wb(&cgen, false, true);
_shenandoah_wb_C = generate_shenandoah_wb(&cgen, true, !ShenandoahWriteBarrierCsetTestInIR);
}
}
+
+ bool ShenandoahBarrierSetAssembler::needs_explicit_null_check(intptr_t offset) {
+ // AArch64 addresses passed from the signal handler may have
+ // their top 8 bits zeroed. That affects the case where
+ // Shenandoah tries to load a Brooks pointer via a null oop.
+ const uintptr_t address_bits = (uintptr_t)0xfffffffffffful;
+ if (UseCompressedOops && Universe::narrow_oop_base() != NULL) {
+ assert (Universe::heap() != NULL, "java heap should be initialized");
+ // The first page after heap_base is unmapped and
+ // the 'offset' is equal to [heap_base + offset] for
+ // narrow oop implicit null checks.
+ uintptr_t base = (uintptr_t) Universe::narrow_oop_base();
+ int adj = BrooksPointer::byte_offset();
+ if ((uintptr_t) ((offset - adj) & address_bits) >= base) {
+ // Normalize offset for the next check.
+ offset = (intptr_t) (pointer_delta((void *) offset, (void *) base, 1));
+ }
+ }
+
+ if ((offset & address_bits) == (BrooksPointer::byte_offset() & address_bits)) {
+ return false;
+ }
+ return offset < 0 || os::vm_page_size() <= offset;
+ ble}
\ No newline at end of file
< prev index next >