diff options
| author | 2015-08-20 12:07:57 +0200 | |
|---|---|---|
| committer | 2015-08-25 15:13:49 +0200 | |
| commit | 54b62480636ae846d705fc180c7bd6cd08ec1e42 (patch) | |
| tree | d46a6c7bebb45ddbbd5b0a6818b3bb2ce49f48ed /compiler/optimizing/stack_map_stream.cc | |
| parent | f0170ded84fbcd3d9152cdbcf9ffbf74c71b03ba (diff) | |
Fix deoptimization with pending exception
When deoptimizing the stack, we set a fake exception in the current
Thread* (see method Thread::GetDeoptimizationException). On the next
exception check, the QuickExceptionHandler will deoptimize the stack.
The issue is when we deoptimize while an exception is already pending
in the current Thread*: setting the fake exception will clobber the
pending exception which is not correct. This happens in the
artQuickToInterpreterBridge when returning from the interpreter and
we want to deoptimize the stack for debugging (like single-stepping).
This CL saves the pending exception before asking for deoptimization.
Then the exception is restored just before executing the deoptimized
frames with the interpreter.
Also cleans up the way we save deoptimization context (return value
and pending exception).
Bug: 23371176
Bug: 19944235
Change-Id: I7f4c8347b328817c452beda3399e210eba3a88a4
Diffstat (limited to 'compiler/optimizing/stack_map_stream.cc')
0 files changed, 0 insertions, 0 deletions