summaryrefslogtreecommitdiff
path: root/compiler/optimizing/stack_map_stream.cc
diff options
context:
space:
mode:
author David Brazdil <dbrazdil@google.com> 2018-05-15 13:45:08 +0100
committer David Brazdil <dbrazdil@google.com> 2018-05-16 10:11:07 +0000
commit904e75a66edea51adc11f61ad8ccaab557402095 (patch)
treef8f1c1acdaf7575b110c1e2941896517ebfd6f8c /compiler/optimizing/stack_map_stream.cc
parentadff274917f36ce3aad85cd876e76d615734f2be (diff)
Fix stripping of access flags during JVMTI redefine
When JVMTI redefines a method/field, it replaces the guts of an ArtMethod with the implementation in a provided dex file. This process includes overwriting the intrinsics ordinal (stored in ArtMethod's access flags) so that the new implementation is picked up. This overwrite, however, does not check if the ArtMethod is an intrinsic in the first place and will clear the bits regardless. This caused an issue for hidden API as its access flags conflict with those of intrinsics. All redefined framework classes would therefore become completely visible to all callers. This patch fixes the issue by adding a IsIntrisic() check around the function which clears the access flags. Bug: 79698297 Test: art/test.py -b --host -r -t 999-redefine-hiddenapi Test: art/test.py -b --host -r -t 950-redefine-intrinsic Change-Id: I7e607d874cc732ceb118d58e4cd40ff4353215f5
Diffstat (limited to 'compiler/optimizing/stack_map_stream.cc')
0 files changed, 0 insertions, 0 deletions