diff options
| author | Vladimir Marko <vmarko@google.com> | 2017-10-31 11:38:30 +0000 | 
|---|---|---|
| committer | Vladimir Marko <vmarko@google.com> | 2017-11-15 14:29:52 +0000 | 
| commit | 92f7f3ce3b01f7c7df1c15b81c900e087248093f (patch) | |
| tree | 37647ac824e450f80d752539cabbe631ba795c75 /test/ProfileTestMultiDex/Second.java | |
| parent | 5dcb0d2cabe9d67987a6a7477fb124cef92abefb (diff) | |
Use intrinsic codegen for compiling intrinsic methods.
When compiling an intrinsic method, generate a graph that
invokes the same method and try to compile it. If the call
is actually intrinsified (or simplified to other HIR) and
yields a leaf method, use the result of this compilation
attempt, otherwise compile the actual code or JNI stub.
Note that CodeGenerator::CreateThrowingSlowPathLocations()
actually marks the locations as kNoCall if the throw is not
in a catch block, thus considering some throwing methods
(for example, String.charAt()) as leaf methods.
We would ideally want to use the intrinsic codegen for all
intrinsics that do not generate a slow-path call to the
default implementation. Relying on the leaf method is
suboptimal as we're missing out on methods that do other
types of calls, for example runtime calls. This shall be
fixed in a subsequent CL.
Test: m test-art-host-gtest
Test: testrunner.py --host --optimizing
Bug: 67717501
Change-Id: I640fda7c22d4ff494b5ff77ebec3b7f5f75af652
Diffstat (limited to 'test/ProfileTestMultiDex/Second.java')
0 files changed, 0 insertions, 0 deletions
