summaryrefslogtreecommitdiff
path: root/compiler/optimizing/parallel_move_test.cc
diff options
context:
space:
mode:
author Sebastien Hertz <shertz@google.com> 2015-01-13 22:48:34 +0100
committer Sebastien Hertz <shertz@google.com> 2015-01-13 23:11:06 +0100
commit55f6534f260ec82ef2d69a0667b1883f13d11399 (patch)
tree6e00c7f32242baf3a1482db3656816a0b2f134a4 /compiler/optimizing/parallel_move_test.cc
parent8fccea249b1a6f1469eeea42c2b2cca06ce1c70d (diff)
JDWP: fix deadlock with GC
This CL fixes a deadlock where JDWP thread and running GC thread are waiting for each other. Here is the sequence of the deadlock: 1. GC thread disables access to weak global references, then releases mutator lock. 2. JDWP thread takes mutator lock exclusively after suspending all threads. 3. GC thread waits for shared mutator lock which is held by JDWP thread. 4. JDWP thread clears weak global references but need to wait for GC thread to re-enable access to them. To avoid that situation, we ensure the JDWP thread does not attempt to delete weak global references while holding the mutator exclusively so GC thread is not blocked. Bug: 18995321 Change-Id: Ia7e82f463c27ffdcfd730c3117337a6a33d111e7
Diffstat (limited to 'compiler/optimizing/parallel_move_test.cc')
0 files changed, 0 insertions, 0 deletions