Commit 67d72eab authored by vegorov@chromium.org's avatar vegorov@chromium.org

When preparing heap for breakpoints make sure not to flush away non-optimized...

When preparing heap for breakpoints make sure not to flush away non-optimized code for inlined functions.

Debug::PrepareForBreakPoints was not fully populating active_functions list.

R=erik.corry@gmail.com
TEST=test/mjsunit/regress/regress-debug-code-recompilation.js

Review URL: https://chromiumcodereview.appspot.com/9290013

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@10503 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent a49c8a19
This diff is collapsed.
...@@ -3340,7 +3340,7 @@ MaybeObject* Heap::CreateCode(const CodeDesc& desc, ...@@ -3340,7 +3340,7 @@ MaybeObject* Heap::CreateCode(const CodeDesc& desc,
} }
code->set_deoptimization_data(empty_fixed_array(), SKIP_WRITE_BARRIER); code->set_deoptimization_data(empty_fixed_array(), SKIP_WRITE_BARRIER);
code->set_handler_table(empty_fixed_array(), SKIP_WRITE_BARRIER); code->set_handler_table(empty_fixed_array(), SKIP_WRITE_BARRIER);
code->set_next_code_flushing_candidate(undefined_value()); code->set_gc_metadata(Smi::FromInt(0));
// Allow self references to created code object by patching the handle to // Allow self references to created code object by patching the handle to
// point to the newly allocated Code object. // point to the newly allocated Code object.
if (!self_reference.is_null()) { if (!self_reference.is_null()) {
......
...@@ -710,16 +710,17 @@ class CodeFlusher { ...@@ -710,16 +710,17 @@ class CodeFlusher {
SharedFunctionInfo* candidate) { SharedFunctionInfo* candidate) {
Code* code = candidate->code(); Code* code = candidate->code();
return reinterpret_cast<SharedFunctionInfo**>( return reinterpret_cast<SharedFunctionInfo**>(
code->address() + Code::kNextCodeFlushingCandidateOffset); code->address() + Code::kGCMetadataOffset);
} }
static SharedFunctionInfo* GetNextCandidate(SharedFunctionInfo* candidate) { static SharedFunctionInfo* GetNextCandidate(SharedFunctionInfo* candidate) {
return *GetNextCandidateField(candidate); return reinterpret_cast<SharedFunctionInfo*>(
candidate->code()->gc_metadata());
} }
static void SetNextCandidate(SharedFunctionInfo* candidate, static void SetNextCandidate(SharedFunctionInfo* candidate,
SharedFunctionInfo* next_candidate) { SharedFunctionInfo* next_candidate) {
*GetNextCandidateField(candidate) = next_candidate; candidate->code()->set_gc_metadata(next_candidate);
} }
Isolate* isolate_; Isolate* isolate_;
......
...@@ -4042,8 +4042,7 @@ INT_ACCESSORS(Code, instruction_size, kInstructionSizeOffset) ...@@ -4042,8 +4042,7 @@ INT_ACCESSORS(Code, instruction_size, kInstructionSizeOffset)
ACCESSORS(Code, relocation_info, ByteArray, kRelocationInfoOffset) ACCESSORS(Code, relocation_info, ByteArray, kRelocationInfoOffset)
ACCESSORS(Code, handler_table, FixedArray, kHandlerTableOffset) ACCESSORS(Code, handler_table, FixedArray, kHandlerTableOffset)
ACCESSORS(Code, deoptimization_data, FixedArray, kDeoptimizationDataOffset) ACCESSORS(Code, deoptimization_data, FixedArray, kDeoptimizationDataOffset)
ACCESSORS(Code, next_code_flushing_candidate, ACCESSORS(Code, gc_metadata, Object, kGCMetadataOffset)
Object, kNextCodeFlushingCandidateOffset)
byte* Code::instruction_start() { byte* Code::instruction_start() {
......
...@@ -4050,11 +4050,10 @@ class Code: public HeapObject { ...@@ -4050,11 +4050,10 @@ class Code: public HeapObject {
// [deoptimization_data]: Array containing data for deopt. // [deoptimization_data]: Array containing data for deopt.
DECL_ACCESSORS(deoptimization_data, FixedArray) DECL_ACCESSORS(deoptimization_data, FixedArray)
// [code_flushing_candidate]: Field only used during garbage // [gc_metadata]: Field used to hold GC related metadata. The contents of this
// collection to hold code flushing candidates. The contents of this
// field does not have to be traced during garbage collection since // field does not have to be traced during garbage collection since
// it is only used by the garbage collector itself. // it is only used by the garbage collector itself.
DECL_ACCESSORS(next_code_flushing_candidate, Object) DECL_ACCESSORS(gc_metadata, Object)
// Unchecked accessors to be used during GC. // Unchecked accessors to be used during GC.
inline ByteArray* unchecked_relocation_info(); inline ByteArray* unchecked_relocation_info();
...@@ -4278,10 +4277,8 @@ class Code: public HeapObject { ...@@ -4278,10 +4277,8 @@ class Code: public HeapObject {
static const int kHandlerTableOffset = kRelocationInfoOffset + kPointerSize; static const int kHandlerTableOffset = kRelocationInfoOffset + kPointerSize;
static const int kDeoptimizationDataOffset = static const int kDeoptimizationDataOffset =
kHandlerTableOffset + kPointerSize; kHandlerTableOffset + kPointerSize;
static const int kNextCodeFlushingCandidateOffset = static const int kGCMetadataOffset = kDeoptimizationDataOffset + kPointerSize;
kDeoptimizationDataOffset + kPointerSize; static const int kFlagsOffset = kGCMetadataOffset + kPointerSize;
static const int kFlagsOffset =
kNextCodeFlushingCandidateOffset + kPointerSize;
static const int kKindSpecificFlagsOffset = kFlagsOffset + kIntSize; static const int kKindSpecificFlagsOffset = kFlagsOffset + kIntSize;
static const int kKindSpecificFlagsSize = 2 * kIntSize; static const int kKindSpecificFlagsSize = 2 * kIntSize;
......
// Copyright 2012 the V8 project authors. All rights reserved.
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following
// disclaimer in the documentation and/or other materials provided
// with the distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived
// from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --allow-natives-syntax --hydrogen-filter=Debug.setBreakPoint --expose-debug-as debug
Debug = debug.Debug
function f() {a=1;b=2};
function g() {
a=1;
b=2;
}
bp = Debug.setBreakPoint(f, 0, 0);
Debug.clearBreakPoint(bp);
%OptimizeFunctionOnNextCall(Debug.setBreakPoint);
bp = Debug.setBreakPoint(f, 0, 0);
Debug.clearBreakPoint(bp);
bp = Debug.setBreakPoint(f, 0, 0);
Debug.clearBreakPoint(bp);
%OptimizeFunctionOnNextCall(Debug.setBreakPoint);
bp = Debug.setBreakPoint(f, 0, 0);
Debug.clearBreakPoint(bp);
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