[8u] RFR: nativeInstruction atomicity and correctness of patching

Anton Kozlov akozlov at azul.com
Wed Mar 30 13:00:20 UTC 2016


Hi, All!

Could you review a patch that should fix nativeInst in several aspects?

* macroassembler trampoline_call generates code, which loads call
target from memory just after trampoline. That constant could be
patched atomically and in mt_safe way. NativeTrampolineCall class was
introduced.

* NativeGeneralJump not falls to undefined behavior conditions now,
only imm branches swapped with imm branches. It used only by C1
patching facultiles, so there should be no harm that the implementation
depends on C1 implementation. It is a part of C1 patching that triggers
deoptimisation on aarch64, http://mail.openjdk.java.net/pipermail/aarch
64-port-dev/2013-September/000273.html. Note, that quote about
concurrent modification and execution in discussion applies to aarch32
as well.

* Atomic::store, Atomic::load for jlongs made really atomic.

Sorry for missing testcase.

Thanks,
Anton
-------------- next part --------------
A non-text attachment was scrubbed...
Name: nativeInstrRe.patch
Type: text/x-patch
Size: 13913 bytes
Desc: nativeInstrRe.patch
URL: <http://mail.openjdk.java.net/pipermail/aarch32-port-dev/attachments/20160330/60ebe3c2/nativeInstrRe-0001.patch>


More information about the aarch32-port-dev mailing list