Commit 72b510df authored by yangguo's avatar yangguo Committed by Commit bot

[liveedit] support restarting interpreted frame and replacing bytecode.

R=mstarzinger@chromium.org
BUG=v8:4765

Review-Url: https://codereview.chromium.org/1968423002
Cr-Commit-Position: refs/heads/master@{#36237}
parent 40c78728
...@@ -623,6 +623,8 @@ void FunctionInfoWrapper::SetInitialProperties(Handle<String> name, ...@@ -623,6 +623,8 @@ void FunctionInfoWrapper::SetInitialProperties(Handle<String> name,
void FunctionInfoWrapper::SetFunctionCode(Handle<Code> function_code, void FunctionInfoWrapper::SetFunctionCode(Handle<Code> function_code,
Handle<HeapObject> code_scope_info) { Handle<HeapObject> code_scope_info) {
// CompileForLiveEdit must deliver full-codegen code.
DCHECK(function_code->kind() == Code::FUNCTION);
Handle<JSValue> code_wrapper = WrapInJSValue(function_code); Handle<JSValue> code_wrapper = WrapInJSValue(function_code);
this->SetField(kCodeOffset_, code_wrapper); this->SetField(kCodeOffset_, code_wrapper);
...@@ -1106,9 +1108,18 @@ void LiveEdit::ReplaceFunctionCode( ...@@ -1106,9 +1108,18 @@ void LiveEdit::ReplaceFunctionCode(
Handle<SharedFunctionInfo> shared_info = shared_info_wrapper.GetInfo(); Handle<SharedFunctionInfo> shared_info = shared_info_wrapper.GetInfo();
if (shared_info->code()->kind() == Code::FUNCTION) { if (shared_info->is_compiled()) {
Handle<Code> code = compile_info_wrapper.GetFunctionCode(); Handle<Code> new_code = compile_info_wrapper.GetFunctionCode();
ReplaceCodeObject(Handle<Code>(shared_info->code()), code); Handle<Code> old_code(shared_info->code());
if (shared_info->HasBytecodeArray()) {
// The old code is interpreted. If we clear the bytecode array, the
// interpreter entry trampoline will self-heal and go to compiled code.
shared_info->ClearBytecodeArray();
shared_info->ReplaceCode(*new_code);
} else {
DCHECK(old_code->kind() == Code::FUNCTION);
ReplaceCodeObject(old_code, new_code);
}
Handle<Object> code_scope_info = compile_info_wrapper.GetCodeScopeInfo(); Handle<Object> code_scope_info = compile_info_wrapper.GetCodeScopeInfo();
if (code_scope_info->IsFixedArray()) { if (code_scope_info->IsFixedArray()) {
shared_info->set_scope_info(ScopeInfo::cast(*code_scope_info)); shared_info->set_scope_info(ScopeInfo::cast(*code_scope_info));
...@@ -1544,6 +1555,13 @@ static const char* DropFrames(Vector<StackFrame*> frames, int top_frame_index, ...@@ -1544,6 +1555,13 @@ static const char* DropFrames(Vector<StackFrame*> frames, int top_frame_index,
top_frame = frames[top_frame_index - 2]; top_frame = frames[top_frame_index - 2];
*mode = LiveEdit::CURRENTLY_SET_MODE; *mode = LiveEdit::CURRENTLY_SET_MODE;
frame_has_padding = false; frame_has_padding = false;
} else if (pre_top_frame_code->kind() == Code::BYTECODE_HANDLER) {
// Interpreted bytecode takes up two stack frames, one for the bytecode
// handler and one for the interpreter entry trampoline. Therefore we shift
// up by one frame.
*mode = LiveEdit::FRAME_DROPPED_IN_DIRECT_CALL;
pre_top_frame = frames[top_frame_index - 2];
top_frame = frames[top_frame_index - 1];
} else { } else {
return "Unknown structure of stack above changing function"; return "Unknown structure of stack above changing function";
} }
......
...@@ -288,21 +288,9 @@ ...@@ -288,21 +288,9 @@
# Ignition # Ignition
# TODO(rmcilroy,4765): assertion failures in LiveEdit tests. # TODO(rmcilroy,4765): assertion failures in LiveEdit tests.
'debug-liveedit-restart-frame': [PASS, NO_IGNITION],
'debug-liveedit-literals': [PASS, NO_IGNITION],
'debug-liveedit-3': [PASS, NO_IGNITION],
'debug-liveedit-1': [PASS, NO_IGNITION],
'debug-liveedit-2': [PASS, NO_IGNITION],
'debug-liveedit-patch-positions-replace': [PASS, NO_IGNITION],
'debug-liveedit-patch-positions': [PASS, NO_IGNITION],
'debug-liveedit-stepin': [PASS, NO_IGNITION], 'debug-liveedit-stepin': [PASS, NO_IGNITION],
'debug-liveedit-newsource': [PASS, NO_IGNITION],
'debug-liveedit-stack-padding': [PASS, NO_IGNITION], 'debug-liveedit-stack-padding': [PASS, NO_IGNITION],
'debug-liveedit-breakpoints': [PASS, NO_IGNITION], 'debug-liveedit-breakpoints': [PASS, NO_IGNITION],
'es6/debug-liveedit-new-target-1': [PASS, NO_IGNITION],
'es6/debug-liveedit-new-target-2': [PASS, NO_IGNITION],
'es6/debug-liveedit-new-target-3': [PASS, NO_IGNITION],
'es6/generators-debug-liveedit': [PASS, NO_IGNITION],
# TODO(mythria, 4780): Related to type feedback for calls in interpreter. # TODO(mythria, 4780): Related to type feedback for calls in interpreter.
'array-literal-feedback': [PASS, NO_IGNITION], 'array-literal-feedback': [PASS, NO_IGNITION],
...@@ -855,21 +843,9 @@ ...@@ -855,21 +843,9 @@
############################################################################## ##############################################################################
['ignition or ignition_turbofan', { ['ignition or ignition_turbofan', {
# TODO(rmcilroy,4765): assertion failures in LiveEdit tests. # TODO(rmcilroy,4765): assertion failures in LiveEdit tests.
'debug-liveedit-restart-frame': [FAIL],
'debug-liveedit-literals': [FAIL],
'debug-liveedit-3': [FAIL],
'debug-liveedit-1': [FAIL],
'debug-liveedit-2': [FAIL],
'debug-liveedit-patch-positions-replace': [FAIL],
'debug-liveedit-patch-positions': [FAIL],
'debug-liveedit-stepin': [FAIL], 'debug-liveedit-stepin': [FAIL],
'debug-liveedit-newsource': [FAIL], 'debug-liveedit-stack-padding': [SKIP],
'debug-liveedit-stack-padding': [FAIL],
'debug-liveedit-breakpoints': [FAIL], 'debug-liveedit-breakpoints': [FAIL],
'es6/debug-liveedit-new-target-1': [FAIL],
'es6/debug-liveedit-new-target-2': [FAIL],
'es6/debug-liveedit-new-target-3': [FAIL],
'es6/generators-debug-liveedit': [FAIL],
# TODO(mythria, 4780): Related to type feedback for calls in interpreter. # TODO(mythria, 4780): Related to type feedback for calls in interpreter.
'array-literal-feedback': [FAIL], 'array-literal-feedback': [FAIL],
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment