summaryrefslogtreecommitdiff
path: root/compiler/optimizing/graph_visualizer.cc
diff options
context:
space:
mode:
authorAlex Light <allight@google.com>2019-10-23 14:14:25 -0700
committerTreehugger Robot <treehugger-gerrit@google.com>2019-10-28 23:46:26 +0000
commitc2d0c9627b969ba988c8817d1b765b1cb61a61f3 (patch)
treebe3d4547d2a0a42d4085355383c509b0cb55f587 /compiler/optimizing/graph_visualizer.cc
parent0c262edd22824f4465e0cb08879b7eea89d3fac0 (diff)
Perform reverify with shared mutator-lock.
Despite comments that seemed to indicate otherwise the verifier is not capable of running with a strong mutator-lock in all circumstances. Specifically it relies on being able to allocate exceptions in a number of situations (for example when a field could not be found but the class could). This could lead to problems when trying to reverify a class. To fix this we changed the reverify step to happen outside of the strong mutator-lock and instead temporarily mark the redefined methods with every verifier fail flag. The new verification will then be performed and the flags reset (after suspending everything). This also fixes a related issue where performing the verification with an exclusive mutator lock changed how elements in the dex-cache were populated, causing the dex-cache to break invariants about methods always having their classes be present. This could cause crashes in some circumstances (for example test 1990). Test: ./test.py --host Test: go/lem Bug: 142876078 This partially reverts commit b1eebde9469914ad634a6dc3746ddfb222595609 This partially reverts commit db55a1121b2437765e732c8bbedf914f8a52f624 Change-Id: I0f1e8c47118cc84c8f23c4068944069ac74f5ea3
Diffstat (limited to 'compiler/optimizing/graph_visualizer.cc')
0 files changed, 0 insertions, 0 deletions