Reviewers: Kevin Millikin,
Description:
Change return type of FrameDescription::GetFrameSize to avoid unneeded type
casts.
Please review this at http://codereview.chromium.org/7282033/
SVN Base: http://v8.googlecode.com/svn/branches/bleeding_edge/
Affected files:
M src/arm/deoptimizer-arm.cc
M src/deoptimizer.h
M src/deoptimizer.cc
M src/ia32/deoptimizer-ia32.cc
M src/x64/deoptimizer-x64.cc
Index: src/arm/deoptimizer-arm.cc
===================================================================
--- src/arm/deoptimizer-arm.cc (revision 8498)
+++ src/arm/deoptimizer-arm.cc (working copy)
@@ -550,7 +550,7 @@
}
// Fill the frame content from the actual data on the frame.
- for (intptr_t i = 0; i < input_->GetFrameSize(); i += kPointerSize) {
+ for (unsigned i = 0; i < input_->GetFrameSize(); i += kPointerSize) {
input_->SetFrameSlot(i, Memory::uint32_at(tos + i));
}
}
Index: src/deoptimizer.cc
===================================================================
--- src/deoptimizer.cc (revision 8498)
+++ src/deoptimizer.cc (working copy)
@@ -161,7 +161,7 @@
// Get the "simulated" top and size for the requested frame.
Address top =
reinterpret_cast<Address>(deoptimizer->output_[frame_index]->GetTop());
- intptr_t size =
+ unsigned size =
deoptimizer->output_[frame_index]->GetFrameSize() / kPointerSize;
// Done with the GC-unsafe frame descriptions. This re-enables
allocation.
@@ -1114,12 +1114,12 @@
if (slot_index >= 0) {
// Local or spill slots. Skip the fixed part of the frame
// including all arguments.
- unsigned base = static_cast<unsigned>(
- GetFrameSize() - deoptimizer->ComputeFixedSize(GetFunction()));
+ unsigned base =
+ GetFrameSize() - deoptimizer->ComputeFixedSize(GetFunction());
return base - ((slot_index + 1) * kPointerSize);
} else {
// Incoming parameter.
- unsigned base = static_cast<unsigned>(GetFrameSize() -
+ unsigned base = GetFrameSize() -
deoptimizer->ComputeIncomingArgumentSize(GetFunction()));
return base - ((slot_index + 1) * kPointerSize);
}
@@ -1128,8 +1128,8 @@
unsigned FrameDescription::GetExpressionCount(Deoptimizer* deoptimizer) {
ASSERT_EQ(Code::FUNCTION, kind_);
- intptr_t size = GetFrameSize() -
deoptimizer->ComputeFixedSize(GetFunction());
- return static_cast<unsigned>(size / kPointerSize);
+ unsigned size = GetFrameSize() -
deoptimizer->ComputeFixedSize(GetFunction());
+ return size / kPointerSize;
}
Index: src/deoptimizer.h
===================================================================
--- src/deoptimizer.h (revision 8498)
+++ src/deoptimizer.h (working copy)
@@ -340,7 +340,10 @@
free(description);
}
- intptr_t GetFrameSize() const { return frame_size_; }
+ uint32_t GetFrameSize() const {
+ ASSERT(static_cast<uint32_t>(frame_size_) == frame_size_);
+ return static_cast<uint32_t>(frame_size_);
+ }
JSFunction* GetFunction() const { return function_; }
@@ -434,6 +437,9 @@
private:
static const uint32_t kZapUint32 = 0xbeeddead;
+ // Frame_size_ must hold a uint32_t value. It is only a uintptr_t to
+ // keep the variable-size array frame_content_ of type intptr_t at
+ // the end of the structure aligned.
uintptr_t frame_size_; // Number of bytes.
JSFunction* function_;
intptr_t registers_[Register::kNumRegisters];
Index: src/ia32/deoptimizer-ia32.cc
===================================================================
--- src/ia32/deoptimizer-ia32.cc (revision 8498)
+++ src/ia32/deoptimizer-ia32.cc (working copy)
@@ -621,7 +621,7 @@
}
// Fill the frame content from the actual data on the frame.
- for (intptr_t i = 0; i < input_->GetFrameSize(); i += kPointerSize) {
+ for (unsigned i = 0; i < input_->GetFrameSize(); i += kPointerSize) {
input_->SetFrameSlot(i, Memory::uint32_at(tos + i));
}
}
Index: src/x64/deoptimizer-x64.cc
===================================================================
--- src/x64/deoptimizer-x64.cc (revision 8498)
+++ src/x64/deoptimizer-x64.cc (working copy)
@@ -316,7 +316,7 @@
USE(height_in_bytes);
unsigned fixed_size = ComputeFixedSize(function_);
- unsigned input_frame_size =
static_cast<unsigned>(input_->GetFrameSize());
+ unsigned input_frame_size = input_->GetFrameSize();
ASSERT(fixed_size + height_in_bytes == input_frame_size);
unsigned stack_slot_size = optimized_code_->stack_slots() * kPointerSize;
@@ -451,7 +451,7 @@
// The 'fixed' part of the frame consists of the incoming parameters and
// the part described by JavaScriptFrameConstants.
unsigned fixed_frame_size = ComputeFixedSize(function);
- unsigned input_frame_size =
static_cast<unsigned>(input_->GetFrameSize());
+ unsigned input_frame_size = input_->GetFrameSize();
unsigned output_frame_size = height_in_bytes + fixed_frame_size;
// Allocate and store the output frame description.
@@ -616,7 +616,7 @@
}
// Fill the frame content from the actual data on the frame.
- for (intptr_t i = 0; i < input_->GetFrameSize(); i += kPointerSize) {
+ for (unsigned i = 0; i < input_->GetFrameSize(); i += kPointerSize) {
input_->SetFrameSlot(i, Memory::uint64_at(tos + i));
}
}
--
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev