< prev index next >
src/hotspot/share/asm/assembler.cpp
Print this page
rev 53052 : [mq]: asm.patch
@@ -307,38 +307,7 @@
}
return NULL;
}
bool MacroAssembler::needs_explicit_null_check(intptr_t offset) {
- // Exception handler checks the nmethod's implicit null checks table
- // only when this method returns false.
-#ifdef AARCH64
- // 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;
-#else
- const uintptr_t address_bits = ~(uintptr_t)0;
-#endif
-#ifdef _LP64
- 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 = MIN2(0, UseShenandoahGC ? BrooksPointer::byte_offset() : 0);
- if ((uintptr_t)((offset - adj) & address_bits) >= base) {
- // Normalize offset for the next check.
- offset = (intptr_t)(pointer_delta((void*)offset, (void*)base, 1));
- }
- }
-#endif
-
- if (UseShenandoahGC) {
- if ((offset & address_bits) == (BrooksPointer::byte_offset() & address_bits)) {
- return false;
- }
- }
-
- return offset < 0 || os::vm_page_size() <= offset;
+ return BarrierSet::barrier_set()->barrier_set_assembler()->needs_explicit_null_check(offset);
}
< prev index next >