RFR(S) 8228618: s390: c1/c2 fail to add metadata relocation in the static call stub
Reingruber, Richard
richard.reingruber at sap.com
Fri Jul 26 09:31:24 UTC 2019
Hi,
could I please get reviews for the following bugfix on s390:
Webrev: http://cr.openjdk.java.net/~rrich/webrevs/2019/8228618/webrev/
Bug: https://bugs.openjdk.java.net/browse/JDK-8228618
On s390 the test vmTestbase/nsk/jvmti/RedefineClasses/StressRedefine crashed the vm
non-deterministically.
Analysis:
- c1/c2 generates static call stub without metadata relocation for the instruction L that loads the target Method* T
into Z_method.
(see LIR_Assembler::emit_static_call_stub(), CompiledStaticCall::emit_to_interp_stub(), MacroAssembler::load_const_from_toc())
- During call resolution the initialization of T in the metadata pool fails silently because no
metadata relocation for L is found.
Note that the load does not load from the metadata pool, but from the toc, which is accurately updated.
(see CompiledDirectStaticCall::set_to_interpreted(), NativeMovConstReg::set_data(), relocInfo::update_oop_pool())
- T is not marked 'on-stack' during class redefinition, because it is not found in the metadata pool of the caller
(see MetadataOnStackMark, nmethod::metadata_do())
- Metadata of T (e.g. constant pool) is reclaimed, because T was redefined.
- static stub referencing T is executed and VM crashes
The actual fix is in MacroAssembler::load_const_from_toc(). There are uses apart from the static
stub, which had the same issue.
I refactored the code a little bit and removed unreachable sections.
NativeMovConstReg::set_data() erases type information of the data. We could check for the existence
of appropriate relocations, if it didn't do that, but that would require changes in shared
code.
Thanks, Richard.
More information about the hotspot-compiler-dev
mailing list