summaryrefslogtreecommitdiff
path: root/compiler/optimizing/code_sinking.h
diff options
context:
space:
mode:
author Vladimir Marko <vmarko@google.com> 2018-04-19 11:54:00 +0100
committer Vladimir Marko <vmarko@google.com> 2018-04-24 17:13:47 +0100
commitdcd117e04b0831e4539544c38c524799114f3e66 (patch)
treec5564d659c74ac9ef5207434ced91f4f7415dc77 /compiler/optimizing/code_sinking.h
parent63fe8dc454298852ae31cfc2692108488a58c650 (diff)
ARM: Use rMR for Baker RB introspection marking.
The marking register (r8 on ARM) is known to be 1 when entering the introspection marking entrypoint, so we can clobber it, use it as a temporaray register (instead or r4) in the runtime entrypoint, and reload the 1 before returning. The immediate benefits are minor, see below, but this shall allow further improvements, for example we could try to change rMR to r4 which would reduce code size of every marking register check by 2 bytes. ARM boot image (boot*.oat) size in aosp_taimen-userdebug: - before: 17861724 - after: 17858088 (-3636) Test: Pixel 2 XL boots. Test: m test-art-host-gtest Test: testrunner.py --target --optimizing --32 Test: Repeat the above tests with heap poisoning enabled. Bug: 36141117 Change-Id: I0f625dec3a6b3ee1786f7e5f4377be42b9bc37d3
Diffstat (limited to 'compiler/optimizing/code_sinking.h')
0 files changed, 0 insertions, 0 deletions