Commit df135415 authored by lrn@chromium.org's avatar lrn@chromium.org

X64: Fix bad value in stack layout constants.

Remove references to Array:kHeaderSize.

Review URL: http://codereview.chromium.org/150098


git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@2303 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 118a2ccc
...@@ -1141,7 +1141,7 @@ static void SweepSpace(NewSpace* space) { ...@@ -1141,7 +1141,7 @@ static void SweepSpace(NewSpace* space) {
// We give non-live objects a map that will correctly give their size, // We give non-live objects a map that will correctly give their size,
// since their existing map might not be live after the collection. // since their existing map might not be live after the collection.
int size = object->Size(); int size = object->Size();
if (size >= Array::kHeaderSize) { if (size >= ByteArray::kHeaderSize) {
object->set_map(Heap::byte_array_map()); object->set_map(Heap::byte_array_map());
ByteArray::cast(object)->set_length(ByteArray::LengthFor(size)); ByteArray::cast(object)->set_length(ByteArray::LengthFor(size));
} else { } else {
......
...@@ -1265,7 +1265,7 @@ void FreeListNode::set_size(int size_in_bytes) { ...@@ -1265,7 +1265,7 @@ void FreeListNode::set_size(int size_in_bytes) {
// If the block is too small (eg, one or two words), to hold both a size // If the block is too small (eg, one or two words), to hold both a size
// field and a next pointer, we give it a filler map that gives it the // field and a next pointer, we give it a filler map that gives it the
// correct size. // correct size.
if (size_in_bytes > Array::kHeaderSize) { if (size_in_bytes > ByteArray::kHeaderSize) {
set_map(Heap::byte_array_map()); set_map(Heap::byte_array_map());
ByteArray::cast(this)->set_length(ByteArray::LengthFor(size_in_bytes)); ByteArray::cast(this)->set_length(ByteArray::LengthFor(size_in_bytes));
} else if (size_in_bytes == kPointerSize) { } else if (size_in_bytes == kPointerSize) {
......
...@@ -1270,7 +1270,7 @@ class FreeListNode: public HeapObject { ...@@ -1270,7 +1270,7 @@ class FreeListNode: public HeapObject {
inline void set_next(Address next); inline void set_next(Address next);
private: private:
static const int kNextOffset = Array::kHeaderSize; static const int kNextOffset = POINTER_SIZE_ALIGN(ByteArray::kHeaderSize);
DISALLOW_IMPLICIT_CONSTRUCTORS(FreeListNode); DISALLOW_IMPLICIT_CONSTRUCTORS(FreeListNode);
}; };
...@@ -1304,7 +1304,8 @@ class OldSpaceFreeList BASE_EMBEDDED { ...@@ -1304,7 +1304,8 @@ class OldSpaceFreeList BASE_EMBEDDED {
private: private:
// The size range of blocks, in bytes. (Smaller allocations are allowed, but // The size range of blocks, in bytes. (Smaller allocations are allowed, but
// will always result in waste.) // will always result in waste.)
static const int kMinBlockSize = Array::kHeaderSize + kPointerSize; static const int kMinBlockSize =
POINTER_SIZE_ALIGN(ByteArray::kHeaderSize) + kPointerSize;
static const int kMaxBlockSize = Page::kMaxHeapObjectSize; static const int kMaxBlockSize = Page::kMaxHeapObjectSize;
// The identity of the owning space, for building allocation Failure // The identity of the owning space, for building allocation Failure
......
...@@ -59,12 +59,7 @@ class StackHandlerConstants : public AllStatic { ...@@ -59,12 +59,7 @@ class StackHandlerConstants : public AllStatic {
class EntryFrameConstants : public AllStatic { class EntryFrameConstants : public AllStatic {
public: public:
static const int kCallerFPOffset = -6 * kPointerSize; static const int kCallerFPOffset = -10 * kPointerSize;
static const int kFunctionArgOffset = +3 * kPointerSize;
static const int kReceiverArgOffset = +4 * kPointerSize;
static const int kArgcOffset = +5 * kPointerSize;
static const int kArgvOffset = +6 * kPointerSize;
}; };
......
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