| Index: runtime/vm/debugger_x64.cc
|
| diff --git a/runtime/vm/debugger_x64.cc b/runtime/vm/debugger_x64.cc
|
| index 653e3ec8cbd74e71daf027db852bf2ae2ba974ea..6d90fe68bf0c1f7c5f72232e2d48720a5eb40c46 100644
|
| --- a/runtime/vm/debugger_x64.cc
|
| +++ b/runtime/vm/debugger_x64.cc
|
| @@ -50,41 +50,47 @@ uword CodeBreakpoint::OrigStubAddress() const {
|
|
|
| void CodeBreakpoint::PatchCode() {
|
| ASSERT(!is_enabled_);
|
| - switch (breakpoint_kind_) {
|
| - case PcDescriptors::kIcCall: {
|
| - int32_t offset = CodePatcher::GetPoolOffsetAt(pc_);
|
| - ASSERT((offset > 0) && ((offset % 8) == 7));
|
| - saved_value_ = static_cast<uword>(offset);
|
| - const int32_t stub_offset =
|
| - InstructionPattern::OffsetFromPPIndex(
|
| - Assembler::kBreakpointDynamicCPIndex);
|
| - CodePatcher::SetPoolOffsetAt(pc_, stub_offset);
|
| - break;
|
| - }
|
| - case PcDescriptors::kUnoptStaticCall: {
|
| - int32_t offset = CodePatcher::GetPoolOffsetAt(pc_);
|
| - ASSERT((offset > 0) && ((offset % 8) == 7));
|
| - saved_value_ = static_cast<uword>(offset);
|
| - const uint32_t stub_offset =
|
| - InstructionPattern::OffsetFromPPIndex(
|
| - Assembler::kBreakpointStaticCPIndex);
|
| - CodePatcher::SetPoolOffsetAt(pc_, stub_offset);
|
| - break;
|
| - }
|
| - case PcDescriptors::kRuntimeCall:
|
| - case PcDescriptors::kClosureCall:
|
| - case PcDescriptors::kReturn: {
|
| - int32_t offset = CodePatcher::GetPoolOffsetAt(pc_);
|
| - ASSERT((offset > 0) && ((offset % 8) == 7));
|
| - saved_value_ = static_cast<uword>(offset);
|
| - const uint32_t stub_offset =
|
| - InstructionPattern::OffsetFromPPIndex(
|
| - Assembler::kBreakpointRuntimeCPIndex);
|
| - CodePatcher::SetPoolOffsetAt(pc_, stub_offset);
|
| - break;
|
| + const Code& code =
|
| + Code::Handle(Function::Handle(function_).unoptimized_code());
|
| + const Instructions& instrs = Instructions::Handle(code.instructions());
|
| + {
|
| + WritableInstructionsScope writable(instrs.EntryPoint(), instrs.size());
|
| + switch (breakpoint_kind_) {
|
| + case PcDescriptors::kIcCall: {
|
| + int32_t offset = CodePatcher::GetPoolOffsetAt(pc_);
|
| + ASSERT((offset > 0) && ((offset % 8) == 7));
|
| + saved_value_ = static_cast<uword>(offset);
|
| + const int32_t stub_offset =
|
| + InstructionPattern::OffsetFromPPIndex(
|
| + Assembler::kBreakpointDynamicCPIndex);
|
| + CodePatcher::SetPoolOffsetAt(pc_, stub_offset);
|
| + break;
|
| + }
|
| + case PcDescriptors::kUnoptStaticCall: {
|
| + int32_t offset = CodePatcher::GetPoolOffsetAt(pc_);
|
| + ASSERT((offset > 0) && ((offset % 8) == 7));
|
| + saved_value_ = static_cast<uword>(offset);
|
| + const uint32_t stub_offset =
|
| + InstructionPattern::OffsetFromPPIndex(
|
| + Assembler::kBreakpointStaticCPIndex);
|
| + CodePatcher::SetPoolOffsetAt(pc_, stub_offset);
|
| + break;
|
| + }
|
| + case PcDescriptors::kRuntimeCall:
|
| + case PcDescriptors::kClosureCall:
|
| + case PcDescriptors::kReturn: {
|
| + int32_t offset = CodePatcher::GetPoolOffsetAt(pc_);
|
| + ASSERT((offset > 0) && ((offset % 8) == 7));
|
| + saved_value_ = static_cast<uword>(offset);
|
| + const uint32_t stub_offset =
|
| + InstructionPattern::OffsetFromPPIndex(
|
| + Assembler::kBreakpointRuntimeCPIndex);
|
| + CodePatcher::SetPoolOffsetAt(pc_, stub_offset);
|
| + break;
|
| + }
|
| + default:
|
| + UNREACHABLE();
|
| }
|
| - default:
|
| - UNREACHABLE();
|
| }
|
| is_enabled_ = true;
|
| }
|
| @@ -92,17 +98,23 @@ void CodeBreakpoint::PatchCode() {
|
|
|
| void CodeBreakpoint::RestoreCode() {
|
| ASSERT(is_enabled_);
|
| - switch (breakpoint_kind_) {
|
| - case PcDescriptors::kIcCall:
|
| - case PcDescriptors::kUnoptStaticCall:
|
| - case PcDescriptors::kClosureCall:
|
| - case PcDescriptors::kRuntimeCall:
|
| - case PcDescriptors::kReturn: {
|
| - CodePatcher::SetPoolOffsetAt(pc_, static_cast<int32_t>(saved_value_));
|
| - break;
|
| + const Code& code =
|
| + Code::Handle(Function::Handle(function_).unoptimized_code());
|
| + const Instructions& instrs = Instructions::Handle(code.instructions());
|
| + {
|
| + WritableInstructionsScope writable(instrs.EntryPoint(), instrs.size());
|
| + switch (breakpoint_kind_) {
|
| + case PcDescriptors::kIcCall:
|
| + case PcDescriptors::kUnoptStaticCall:
|
| + case PcDescriptors::kClosureCall:
|
| + case PcDescriptors::kRuntimeCall:
|
| + case PcDescriptors::kReturn: {
|
| + CodePatcher::SetPoolOffsetAt(pc_, static_cast<int32_t>(saved_value_));
|
| + break;
|
| + }
|
| + default:
|
| + UNREACHABLE();
|
| }
|
| - default:
|
| - UNREACHABLE();
|
| }
|
| is_enabled_ = false;
|
| }
|
|
|