Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(606)

Side by Side Diff: src/ppc/builtins-ppc.cc

Issue 2068603002: [debugger] simplify debug stepping. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: remove declaration Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 the V8 project authors. All rights reserved. 1 // Copyright 2014 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #if V8_TARGET_ARCH_PPC 5 #if V8_TARGET_ARCH_PPC
6 6
7 #include "src/codegen.h" 7 #include "src/codegen.h"
8 #include "src/debug/debug.h" 8 #include "src/debug/debug.h"
9 #include "src/deoptimizer.h" 9 #include "src/deoptimizer.h"
10 #include "src/full-codegen/full-codegen.h" 10 #include "src/full-codegen/full-codegen.h"
(...skipping 704 matching lines...) Expand 10 before | Expand all | Expand 10 after
715 // Store resume mode into generator object. 715 // Store resume mode into generator object.
716 __ StoreP(r5, FieldMemOperand(r4, JSGeneratorObject::kResumeModeOffset), r0); 716 __ StoreP(r5, FieldMemOperand(r4, JSGeneratorObject::kResumeModeOffset), r0);
717 717
718 // Load suspended function and context. 718 // Load suspended function and context.
719 __ LoadP(cp, FieldMemOperand(r4, JSGeneratorObject::kContextOffset)); 719 __ LoadP(cp, FieldMemOperand(r4, JSGeneratorObject::kContextOffset));
720 __ LoadP(r7, FieldMemOperand(r4, JSGeneratorObject::kFunctionOffset)); 720 __ LoadP(r7, FieldMemOperand(r4, JSGeneratorObject::kFunctionOffset));
721 721
722 // Flood function if we are stepping. 722 // Flood function if we are stepping.
723 Label prepare_step_in_if_stepping, prepare_step_in_suspended_generator; 723 Label prepare_step_in_if_stepping, prepare_step_in_suspended_generator;
724 Label stepping_prepared; 724 Label stepping_prepared;
725 ExternalReference step_in_enabled = 725 ExternalReference last_step_action =
726 ExternalReference::debug_step_in_enabled_address(masm->isolate()); 726 ExternalReference::debug_last_step_action_address(masm->isolate());
727 __ mov(ip, Operand(step_in_enabled)); 727 STATIC_ASSERT(StepFrame > StepIn);
728 __ mov(ip, Operand(last_step_action));
728 __ lbz(ip, MemOperand(ip)); 729 __ lbz(ip, MemOperand(ip));
729 __ cmpi(ip, Operand::Zero()); 730 __ cmpi(ip, Operand::Zero());
730 __ bne(&prepare_step_in_if_stepping); 731 __ bge(&prepare_step_in_if_stepping);
731 732
732 // Flood function if we need to continue stepping in the suspended generator. 733 // Flood function if we need to continue stepping in the suspended generator.
733 734
734 ExternalReference debug_suspended_generator = 735 ExternalReference debug_suspended_generator =
735 ExternalReference::debug_suspended_generator_address(masm->isolate()); 736 ExternalReference::debug_suspended_generator_address(masm->isolate());
736 737
737 __ mov(ip, Operand(debug_suspended_generator)); 738 __ mov(ip, Operand(debug_suspended_generator));
738 __ LoadP(ip, MemOperand(ip)); 739 __ LoadP(ip, MemOperand(ip));
739 __ cmp(ip, r4); 740 __ cmp(ip, r4);
740 __ beq(&prepare_step_in_suspended_generator); 741 __ beq(&prepare_step_in_suspended_generator);
(...skipping 2194 matching lines...) Expand 10 before | Expand all | Expand 10 after
2935 __ bkpt(0); 2936 __ bkpt(0);
2936 } 2937 }
2937 } 2938 }
2938 2939
2939 2940
2940 #undef __ 2941 #undef __
2941 } // namespace internal 2942 } // namespace internal
2942 } // namespace v8 2943 } // namespace v8
2943 2944
2944 #endif // V8_TARGET_ARCH_PPC 2945 #endif // V8_TARGET_ARCH_PPC
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698