Change a few runtime functions that took and returned a dummy argument

to instead take no arguments and return the undefined value.


git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@584 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
kmillikin@chromium.org 2008-10-24 10:13:22 +00:00
parent 5ffd290217
commit 681ae19bd4
4 changed files with 29 additions and 28 deletions

View File

@ -226,9 +226,7 @@ void CodeGenerator::GenCode(FunctionLiteral* fun) {
if (FLAG_trace) { if (FLAG_trace) {
// Push a valid value as the parameter. The runtime call only uses // Push a valid value as the parameter. The runtime call only uses
// it as the return value to indicate non-failure. // it as the return value to indicate non-failure.
__ mov(r0, Operand(Smi::FromInt(0))); __ CallRuntime(Runtime::kTraceEnter, 0);
__ push(r0);
__ CallRuntime(Runtime::kTraceEnter, 1);
} }
CheckStack(); CheckStack();
@ -242,11 +240,7 @@ void CodeGenerator::GenCode(FunctionLiteral* fun) {
bool should_trace = bool should_trace =
is_builtin ? FLAG_trace_builtin_calls : FLAG_trace_calls; is_builtin ? FLAG_trace_builtin_calls : FLAG_trace_calls;
if (should_trace) { if (should_trace) {
// Push a valid value as the parameter. The runtime call only uses __ CallRuntime(Runtime::kDebugTrace, 0);
// it as the return value to indicate non-failure.
__ mov(r0, Operand(Smi::FromInt(0)));
__ push(r0);
__ CallRuntime(Runtime::kDebugTrace, 1);
} }
#endif #endif
VisitStatements(body); VisitStatements(body);
@ -1846,8 +1840,8 @@ void CodeGenerator::VisitTryFinally(TryFinally* node) {
void CodeGenerator::VisitDebuggerStatement(DebuggerStatement* node) { void CodeGenerator::VisitDebuggerStatement(DebuggerStatement* node) {
Comment cmnt(masm_, "[ DebuggerStatament"); Comment cmnt(masm_, "[ DebuggerStatament");
if (FLAG_debug_info) RecordStatementPosition(node); if (FLAG_debug_info) RecordStatementPosition(node);
__ CallRuntime(Runtime::kDebugBreak, 1); __ CallRuntime(Runtime::kDebugBreak, 0);
__ push(r0); // Ignore the return value.
} }

View File

@ -356,8 +356,8 @@ void CodeGenerator::GenCode(FunctionLiteral* fun) {
} }
if (FLAG_trace) { if (FLAG_trace) {
__ CallRuntime(Runtime::kTraceEnter, 1); __ CallRuntime(Runtime::kTraceEnter, 0);
frame_->Push(eax); // Ignore the return value.
} }
CheckStack(); CheckStack();
@ -371,8 +371,8 @@ void CodeGenerator::GenCode(FunctionLiteral* fun) {
bool should_trace = bool should_trace =
is_builtin ? FLAG_trace_builtin_calls : FLAG_trace_calls; is_builtin ? FLAG_trace_builtin_calls : FLAG_trace_calls;
if (should_trace) { if (should_trace) {
__ CallRuntime(Runtime::kDebugTrace, 1); __ CallRuntime(Runtime::kDebugTrace, 0);
frame_->Push(eax); // Ignore the return value.
} }
#endif #endif
VisitStatements(body); VisitStatements(body);
@ -2218,8 +2218,8 @@ void CodeGenerator::VisitTryFinally(TryFinally* node) {
void CodeGenerator::VisitDebuggerStatement(DebuggerStatement* node) { void CodeGenerator::VisitDebuggerStatement(DebuggerStatement* node) {
Comment cmnt(masm_, "[ DebuggerStatement"); Comment cmnt(masm_, "[ DebuggerStatement");
RecordStatementPosition(node); RecordStatementPosition(node);
__ CallRuntime(Runtime::kDebugBreak, 1); __ CallRuntime(Runtime::kDebugBreak, 0);
frame_->Push(eax); // Ignore the return value.
} }

View File

@ -3581,10 +3581,10 @@ static Object* RuntimePreempt(Arguments args) {
} }
static Object* Runtime_DebugBreak(Arguments args) { static Object* DebugBreakHelper() {
// Just continue if breaks are disabled. // Just continue if breaks are disabled.
if (Debug::disable_break()) { if (Debug::disable_break()) {
return args[0]; return Heap::undefined_value();
} }
// Don't break in system functions. If the current function is // Don't break in system functions. If the current function is
@ -3596,7 +3596,7 @@ static Object* Runtime_DebugBreak(Arguments args) {
if (fun->IsJSFunction()) { if (fun->IsJSFunction()) {
GlobalObject* global = JSFunction::cast(fun)->context()->global(); GlobalObject* global = JSFunction::cast(fun)->context()->global();
if (global->IsJSBuiltinsObject() || Debug::IsDebugGlobal(global)) { if (global->IsJSBuiltinsObject() || Debug::IsDebugGlobal(global)) {
return args[0]; return Heap::undefined_value();
} }
} }
@ -3607,14 +3607,20 @@ static Object* Runtime_DebugBreak(Arguments args) {
// Enter the debugger. Just continue if we fail to enter the debugger. // Enter the debugger. Just continue if we fail to enter the debugger.
EnterDebugger debugger; EnterDebugger debugger;
if (debugger.FailedToEnter()) { if (debugger.FailedToEnter()) {
return args[0]; return Heap::undefined_value();
} }
// Notify the debug event listeners. // Notify the debug event listeners.
Debugger::OnDebugBreak(Factory::undefined_value()); Debugger::OnDebugBreak(Factory::undefined_value());
// Return to continue execution. // Return to continue execution.
return args[0]; return Heap::undefined_value();
}
static Object* Runtime_DebugBreak(Arguments args) {
ASSERT(args.length() == 0);
return DebugBreakHelper();
} }
@ -3626,7 +3632,7 @@ static Object* Runtime_StackGuard(Arguments args) {
// If not real stack overflow the stack guard was used to interrupt // If not real stack overflow the stack guard was used to interrupt
// execution for another purpose. // execution for another purpose.
if (StackGuard::IsDebugBreak()) Runtime_DebugBreak(args); if (StackGuard::IsDebugBreak()) DebugBreakHelper();
if (StackGuard::IsPreempted()) RuntimePreempt(args); if (StackGuard::IsPreempted()) RuntimePreempt(args);
if (StackGuard::IsInterrupted()) { if (StackGuard::IsInterrupted()) {
// interrupt // interrupt
@ -3724,9 +3730,10 @@ static void PrintTransition(Object* result) {
static Object* Runtime_TraceEnter(Arguments args) { static Object* Runtime_TraceEnter(Arguments args) {
ASSERT(args.length() == 0);
NoHandleAllocation ha; NoHandleAllocation ha;
PrintTransition(NULL); PrintTransition(NULL);
return args[0]; // return TOS return Heap::undefined_value();
} }
@ -3765,10 +3772,10 @@ static Object* Runtime_DebugPrint(Arguments args) {
static Object* Runtime_DebugTrace(Arguments args) { static Object* Runtime_DebugTrace(Arguments args) {
ASSERT(args.length() == 1); ASSERT(args.length() == 0);
NoHandleAllocation ha; NoHandleAllocation ha;
Top::PrintStack(); Top::PrintStack();
return args[0]; // return TOS return Heap::undefined_value();
} }

View File

@ -277,10 +277,10 @@ namespace v8 { namespace internal {
\ \
/* Debugging */ \ /* Debugging */ \
F(DebugPrint, 1) \ F(DebugPrint, 1) \
F(DebugTrace, 1) \ F(DebugTrace, 0) \
F(TraceEnter, 1) \ F(TraceEnter, 0) \
F(TraceExit, 1) \ F(TraceExit, 1) \
F(DebugBreak, 1) \ F(DebugBreak, 0) \
F(FunctionGetAssemblerCode, 1) \ F(FunctionGetAssemblerCode, 1) \
F(Abort, 2) \ F(Abort, 2) \
\ \