From a0130e8d2842a9a82e4fd4e811ee699272eb2e0b Mon Sep 17 00:00:00 2001 From: Andra Danciu Date: Thu, 23 Jul 2020 12:34:56 +0000 Subject: Prepare compiler for adding VarHandle support. This commit prepares the ground for adding VarHandle support in the compiler. The intrinsic locations builder and code generator are now triggered for HInvokePolymorphic nodes. VarHandle and MethodHandle intrinsics are marked as unimplemented rather than unreachable. Since the Varhandle intrinsics are not implemented yet, the functionality is not changed (i.e. the intrinsics are evaluated at runtime and not compiled). I manually tested that the intrinsic Visit* methods are triggered for the VarHandle methods. Bug: b/65872996 Test: art/test.py --host -r -t 713-varhandle-invokers Test: art/test.py --host --all-compiler -r Change-Id: I3333728c5f16d8dc4f92ceae2738ed59b3e31e6a --- runtime/class_linker-inl.h | 1 + 1 file changed, 1 insertion(+) (limited to 'runtime/class_linker-inl.h') diff --git a/runtime/class_linker-inl.h b/runtime/class_linker-inl.h index 30e78e5663..81784fb416 100644 --- a/runtime/class_linker-inl.h +++ b/runtime/class_linker-inl.h @@ -226,6 +226,7 @@ inline bool ClassLinker::CheckInvokeClassMismatch(ObjPtr dex_c switch (type) { case kStatic: case kSuper: + case kPolymorphic: break; case kInterface: { // We have to check whether the method id really belongs to an interface (dex static bytecode -- cgit v1.2.3-59-g8ed1b