[13] RFR: 8227223: [Graal] Implement basic type consistency checks for Low level MH intrinsics
Jamsheed
jamsheed.c.m at oracle.com
Thu Jul 4 18:12:26 UTC 2019
slight oversight, thought webrev provided Vladimir Kozlov was based on
jdk14 and it cleanly applied on jdk13. it was indeed jdk13 based.
removed duplicates.
On 04/07/19 9:09 PM, Jamsheed wrote:
> Request for review for the backport of JDK-8221577 [1] .
>
> The fix [2] was integrated into JDK 14 as part of JDK-8225497:"Update
> Graal" [1].
>
> jdk13 backport webrev:
> https://cr.openjdk.java.net/~kvn/8221577/webrev.00/ (Thank you,
> Vladimir Kozlov)
>
> bug: https://bugs.openjdk.java.net/browse/JDK-8227223
>
> Description of problem by Vladimir Ivanov:
>
> "Method handle linkers (MethodHandle.linkTo*) are inherently unsafe:
> it's possible to use arbitrary signature to invoke a method and
> behavior is implementation/platform-specific when argument type
> mismatch occurs (e.g., int vs float). Type checking for method handle
> invocation happens earlier: either in
> MethodHandle.invoke/invokeExact() or as part of invokedynamic linkage.
> MH linkers implement low-level semantics of different invocation modes.
>
> Though such type mismatches (int vs float) shouldn't occur at runtime
> (it's guaranteed by how method handles are constructed), JIT-compiler
> can observe it on unreachable branches which can't be proved as such
> at compile-time. (See JDK-8166110 for an example.)
>
> In order to avoid paradoxes in IR, C2 doesn't inline through
> MH.linkTo* methods if there's type mismatch for any argument or return
> type (decision is made in ciMethod::is_consistent_info())."
>
> Best Regards,
>
> Jamsheed
>
> [1] https://bugs.openjdk.java.net/browse/JDK-8221577
>
> [2]
> https://github.com/oracle/graal/commit/d880341edf09d6a14021e2c7f09f70eda56c1c9d
>
More information about the hotspot-compiler-dev
mailing list