Replace our home-grown BitCast with bit_cast from Chrome/Google3.

R=svenpanne@chromium.org

Review URL: https://codereview.chromium.org/553843002

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@23767 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
bmeurer@chromium.org 2014-09-08 09:11:11 +00:00
parent b0b67762fd
commit dab61bc310
52 changed files with 312 additions and 230 deletions

View File

@ -500,8 +500,8 @@ void MacroAssembler::RecordWriteField(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Operand(BitCast<int32_t>(kZapValue + 4))); mov(value, Operand(bit_cast<int32_t>(kZapValue + 4)));
mov(dst, Operand(BitCast<int32_t>(kZapValue + 8))); mov(dst, Operand(bit_cast<int32_t>(kZapValue + 8)));
} }
} }
@ -570,8 +570,8 @@ void MacroAssembler::RecordWriteForMap(Register object,
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(dst, Operand(BitCast<int32_t>(kZapValue + 12))); mov(dst, Operand(bit_cast<int32_t>(kZapValue + 12)));
mov(map, Operand(BitCast<int32_t>(kZapValue + 16))); mov(map, Operand(bit_cast<int32_t>(kZapValue + 16)));
} }
} }
@ -642,8 +642,8 @@ void MacroAssembler::RecordWrite(
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(address, Operand(BitCast<int32_t>(kZapValue + 12))); mov(address, Operand(bit_cast<int32_t>(kZapValue + 12)));
mov(value, Operand(BitCast<int32_t>(kZapValue + 16))); mov(value, Operand(bit_cast<int32_t>(kZapValue + 16)));
} }
} }

View File

@ -311,7 +311,7 @@ void ArmDebugger::Debug() {
} }
for (int i = 0; i < DwVfpRegister::NumRegisters(); i++) { for (int i = 0; i < DwVfpRegister::NumRegisters(); i++) {
dvalue = GetVFPDoubleRegisterValue(i); dvalue = GetVFPDoubleRegisterValue(i);
uint64_t as_words = BitCast<uint64_t>(dvalue); uint64_t as_words = bit_cast<uint64_t>(dvalue);
PrintF("%3s: %f 0x%08x %08x\n", PrintF("%3s: %f 0x%08x %08x\n",
VFPRegisters::Name(i, true), VFPRegisters::Name(i, true),
dvalue, dvalue,
@ -322,10 +322,10 @@ void ArmDebugger::Debug() {
if (GetValue(arg1, &value)) { if (GetValue(arg1, &value)) {
PrintF("%s: 0x%08x %d \n", arg1, value, value); PrintF("%s: 0x%08x %d \n", arg1, value, value);
} else if (GetVFPSingleValue(arg1, &svalue)) { } else if (GetVFPSingleValue(arg1, &svalue)) {
uint32_t as_word = BitCast<uint32_t>(svalue); uint32_t as_word = bit_cast<uint32_t>(svalue);
PrintF("%s: %f 0x%08x\n", arg1, svalue, as_word); PrintF("%s: %f 0x%08x\n", arg1, svalue, as_word);
} else if (GetVFPDoubleValue(arg1, &dvalue)) { } else if (GetVFPDoubleValue(arg1, &dvalue)) {
uint64_t as_words = BitCast<uint64_t>(dvalue); uint64_t as_words = bit_cast<uint64_t>(dvalue);
PrintF("%s: %f 0x%08x %08x\n", PrintF("%s: %f 0x%08x %08x\n",
arg1, arg1,
dvalue, dvalue,

View File

@ -4442,8 +4442,8 @@ void MacroAssembler::RecordWriteField(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
Mov(value, Operand(BitCast<int64_t>(kZapValue + 4))); Mov(value, Operand(bit_cast<int64_t>(kZapValue + 4)));
Mov(scratch, Operand(BitCast<int64_t>(kZapValue + 8))); Mov(scratch, Operand(bit_cast<int64_t>(kZapValue + 8)));
} }
} }
@ -4514,8 +4514,8 @@ void MacroAssembler::RecordWriteForMap(Register object,
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
Mov(dst, Operand(BitCast<int64_t>(kZapValue + 12))); Mov(dst, Operand(bit_cast<int64_t>(kZapValue + 12)));
Mov(map, Operand(BitCast<int64_t>(kZapValue + 16))); Mov(map, Operand(bit_cast<int64_t>(kZapValue + 16)));
} }
} }
@ -4587,8 +4587,8 @@ void MacroAssembler::RecordWrite(
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
Mov(address, Operand(BitCast<int64_t>(kZapValue + 12))); Mov(address, Operand(bit_cast<int64_t>(kZapValue + 12)));
Mov(value, Operand(BitCast<int64_t>(kZapValue + 16))); Mov(value, Operand(bit_cast<int64_t>(kZapValue + 16)));
} }
} }

View File

@ -883,7 +883,7 @@ void ExternalReference::SetUp() {
double_constants.one_half = 0.5; double_constants.one_half = 0.5;
double_constants.minus_one_half = -0.5; double_constants.minus_one_half = -0.5;
double_constants.canonical_non_hole_nan = base::OS::nan_value(); double_constants.canonical_non_hole_nan = base::OS::nan_value();
double_constants.the_hole_nan = BitCast<double>(kHoleNanInt64); double_constants.the_hole_nan = bit_cast<double>(kHoleNanInt64);
double_constants.negative_infinity = -V8_INFINITY; double_constants.negative_infinity = -V8_INFINITY;
double_constants.uint32_bias = double_constants.uint32_bias =
static_cast<double>(static_cast<uint32_t>(0xFFFFFFFF)) + 1; static_cast<double>(static_cast<uint32_t>(0xFFFFFFFF)) + 1;
@ -924,9 +924,9 @@ void ExternalReference::InitializeMathExpData() {
math_exp_log_table_array = new double[kTableSize]; math_exp_log_table_array = new double[kTableSize];
for (int i = 0; i < kTableSize; i++) { for (int i = 0; i < kTableSize; i++) {
double value = std::pow(2, i / kTableSizeDouble); double value = std::pow(2, i / kTableSizeDouble);
uint64_t bits = BitCast<uint64_t, double>(value); uint64_t bits = bit_cast<uint64_t, double>(value);
bits &= (static_cast<uint64_t>(1) << 52) - 1; bits &= (static_cast<uint64_t>(1) << 52) - 1;
double mantissa = BitCast<double, uint64_t>(bits); double mantissa = bit_cast<double, uint64_t>(bits);
math_exp_log_table_array[i] = mantissa; math_exp_log_table_array[i] = mantissa;
} }

View File

@ -459,9 +459,7 @@ class RelocInfo {
Mode rmode() const { return rmode_; } Mode rmode() const { return rmode_; }
intptr_t data() const { return data_; } intptr_t data() const { return data_; }
double data64() const { return data64_; } double data64() const { return data64_; }
uint64_t raw_data64() { uint64_t raw_data64() { return bit_cast<uint64_t>(data64_); }
return BitCast<uint64_t>(data64_);
}
Code* host() const { return host_; } Code* host() const { return host_; }
void set_host(Code* host) { host_ = host; } void set_host(Code* host) { host_ = host; }

View File

@ -5,6 +5,8 @@
#ifndef V8_BASE_MACROS_H_ #ifndef V8_BASE_MACROS_H_
#define V8_BASE_MACROS_H_ #define V8_BASE_MACROS_H_
#include <cstring>
#include "include/v8stdint.h" #include "include/v8stdint.h"
#include "src/base/build_config.h" #include "src/base/build_config.h"
#include "src/base/compiler-specific.h" #include "src/base/compiler-specific.h"
@ -102,6 +104,141 @@ char (&ArraySizeHelper(const T (&array)[N]))[N];
#endif // V8_OS_NACL #endif // V8_OS_NACL
// The COMPILE_ASSERT macro can be used to verify that a compile time
// expression is true. For example, you could use it to verify the
// size of a static array:
//
// COMPILE_ASSERT(ARRAYSIZE_UNSAFE(content_type_names) == CONTENT_NUM_TYPES,
// content_type_names_incorrect_size);
//
// or to make sure a struct is smaller than a certain size:
//
// COMPILE_ASSERT(sizeof(foo) < 128, foo_too_large);
//
// The second argument to the macro is the name of the variable. If
// the expression is false, most compilers will issue a warning/error
// containing the name of the variable.
#if V8_HAS_CXX11_STATIC_ASSERT
// Under C++11, just use static_assert.
#define COMPILE_ASSERT(expr, msg) static_assert(expr, #msg)
#else
template <bool>
struct CompileAssert {};
#define COMPILE_ASSERT(expr, msg) \
typedef CompileAssert<static_cast<bool>(expr)> \
msg[static_cast<bool>(expr) ? 1 : -1] ALLOW_UNUSED
// Implementation details of COMPILE_ASSERT:
//
// - COMPILE_ASSERT works by defining an array type that has -1
// elements (and thus is invalid) when the expression is false.
//
// - The simpler definition
//
// #define COMPILE_ASSERT(expr, msg) typedef char msg[(expr) ? 1 : -1]
//
// does not work, as gcc supports variable-length arrays whose sizes
// are determined at run-time (this is gcc's extension and not part
// of the C++ standard). As a result, gcc fails to reject the
// following code with the simple definition:
//
// int foo;
// COMPILE_ASSERT(foo, msg); // not supposed to compile as foo is
// // not a compile-time constant.
//
// - By using the type CompileAssert<(bool(expr))>, we ensures that
// expr is a compile-time constant. (Template arguments must be
// determined at compile-time.)
//
// - The outer parentheses in CompileAssert<(bool(expr))> are necessary
// to work around a bug in gcc 3.4.4 and 4.0.1. If we had written
//
// CompileAssert<bool(expr)>
//
// instead, these compilers will refuse to compile
//
// COMPILE_ASSERT(5 > 0, some_message);
//
// (They seem to think the ">" in "5 > 0" marks the end of the
// template argument list.)
//
// - The array size is (bool(expr) ? 1 : -1), instead of simply
//
// ((expr) ? 1 : -1).
//
// This is to avoid running into a bug in MS VC 7.1, which
// causes ((0.0) ? 1 : -1) to incorrectly evaluate to 1.
#endif
// bit_cast<Dest,Source> is a template function that implements the
// equivalent of "*reinterpret_cast<Dest*>(&source)". We need this in
// very low-level functions like the protobuf library and fast math
// support.
//
// float f = 3.14159265358979;
// int i = bit_cast<int32>(f);
// // i = 0x40490fdb
//
// The classical address-casting method is:
//
// // WRONG
// float f = 3.14159265358979; // WRONG
// int i = * reinterpret_cast<int*>(&f); // WRONG
//
// The address-casting method actually produces undefined behavior
// according to ISO C++ specification section 3.10 -15 -. Roughly, this
// section says: if an object in memory has one type, and a program
// accesses it with a different type, then the result is undefined
// behavior for most values of "different type".
//
// This is true for any cast syntax, either *(int*)&f or
// *reinterpret_cast<int*>(&f). And it is particularly true for
// conversions between integral lvalues and floating-point lvalues.
//
// The purpose of 3.10 -15- is to allow optimizing compilers to assume
// that expressions with different types refer to different memory. gcc
// 4.0.1 has an optimizer that takes advantage of this. So a
// non-conforming program quietly produces wildly incorrect output.
//
// The problem is not the use of reinterpret_cast. The problem is type
// punning: holding an object in memory of one type and reading its bits
// back using a different type.
//
// The C++ standard is more subtle and complex than this, but that
// is the basic idea.
//
// Anyways ...
//
// bit_cast<> calls memcpy() which is blessed by the standard,
// especially by the example in section 3.9 . Also, of course,
// bit_cast<> wraps up the nasty logic in one place.
//
// Fortunately memcpy() is very fast. In optimized mode, with a
// constant size, gcc 2.95.3, gcc 4.0.1, and msvc 7.1 produce inline
// code with the minimal amount of data movement. On a 32-bit system,
// memcpy(d,s,4) compiles to one load and one store, and memcpy(d,s,8)
// compiles to two loads and two stores.
//
// I tested this code with gcc 2.95.3, gcc 4.0.1, icc 8.1, and msvc 7.1.
//
// WARNING: if Dest or Source is a non-POD type, the result of the memcpy
// is likely to surprise you.
template <class Dest, class Source>
inline Dest bit_cast(const Source& source) {
COMPILE_ASSERT(sizeof(Dest) == sizeof(Source), VerifySizesAreEqual);
Dest dest;
memcpy(&dest, &source, sizeof(dest));
return dest;
}
// A macro to disallow the evil copy constructor and operator= functions // A macro to disallow the evil copy constructor and operator= functions
// This should be used in the private: declarations for a class // This should be used in the private: declarations for a class
#define DISALLOW_COPY_AND_ASSIGN(TypeName) \ #define DISALLOW_COPY_AND_ASSIGN(TypeName) \

View File

@ -24,7 +24,7 @@ class SourceCodeCache FINAL BASE_EMBEDDED {
} }
void Iterate(ObjectVisitor* v) { void Iterate(ObjectVisitor* v) {
v->VisitPointer(BitCast<Object**, FixedArray**>(&cache_)); v->VisitPointer(bit_cast<Object**, FixedArray**>(&cache_));
} }
bool Lookup(Vector<const char> name, Handle<SharedFunctionInfo>* handle) { bool Lookup(Vector<const char> name, Handle<SharedFunctionInfo>* handle) {

View File

@ -23,7 +23,7 @@ class CommonNodeCache FINAL : public ZoneObject {
Node** FindFloat64Constant(double value) { Node** FindFloat64Constant(double value) {
// We canonicalize double constants at the bit representation level. // We canonicalize double constants at the bit representation level.
return float64_constants_.Find(zone_, BitCast<int64_t>(value)); return float64_constants_.Find(zone_, bit_cast<int64_t>(value));
} }
Node** FindExternalConstant(ExternalReference reference) { Node** FindExternalConstant(ExternalReference reference) {
@ -32,7 +32,7 @@ class CommonNodeCache FINAL : public ZoneObject {
Node** FindNumberConstant(double value) { Node** FindNumberConstant(double value) {
// We canonicalize double constants at the bit representation level. // We canonicalize double constants at the bit representation level.
return number_constants_.Find(zone_, BitCast<int64_t>(value)); return number_constants_.Find(zone_, bit_cast<int64_t>(value));
} }
Zone* zone() const { return zone_; } Zone* zone() const { return zone_; }

View File

@ -847,7 +847,7 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
__ mov(dst, g.ToImmediate(source)); __ mov(dst, g.ToImmediate(source));
} else { } else {
double v = g.ToDouble(source); double v = g.ToDouble(source);
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
int32_t lower = static_cast<int32_t>(int_val); int32_t lower = static_cast<int32_t>(int_val);
int32_t upper = static_cast<int32_t>(int_val >> kBitsPerInt); int32_t upper = static_cast<int32_t>(int_val >> kBitsPerInt);
if (destination->IsDoubleRegister()) { if (destination->IsDoubleRegister()) {

View File

@ -658,11 +658,11 @@ class Constant FINAL {
explicit Constant(int32_t v) : type_(kInt32), value_(v) {} explicit Constant(int32_t v) : type_(kInt32), value_(v) {}
explicit Constant(int64_t v) : type_(kInt64), value_(v) {} explicit Constant(int64_t v) : type_(kInt64), value_(v) {}
explicit Constant(double v) : type_(kFloat64), value_(BitCast<int64_t>(v)) {} explicit Constant(double v) : type_(kFloat64), value_(bit_cast<int64_t>(v)) {}
explicit Constant(ExternalReference ref) explicit Constant(ExternalReference ref)
: type_(kExternalReference), value_(BitCast<intptr_t>(ref)) {} : type_(kExternalReference), value_(bit_cast<intptr_t>(ref)) {}
explicit Constant(Handle<HeapObject> obj) explicit Constant(Handle<HeapObject> obj)
: type_(kHeapObject), value_(BitCast<intptr_t>(obj)) {} : type_(kHeapObject), value_(bit_cast<intptr_t>(obj)) {}
Type type() const { return type_; } Type type() const { return type_; }
@ -680,17 +680,17 @@ class Constant FINAL {
double ToFloat64() const { double ToFloat64() const {
if (type() == kInt32) return ToInt32(); if (type() == kInt32) return ToInt32();
DCHECK_EQ(kFloat64, type()); DCHECK_EQ(kFloat64, type());
return BitCast<double>(value_); return bit_cast<double>(value_);
} }
ExternalReference ToExternalReference() const { ExternalReference ToExternalReference() const {
DCHECK_EQ(kExternalReference, type()); DCHECK_EQ(kExternalReference, type());
return BitCast<ExternalReference>(static_cast<intptr_t>(value_)); return bit_cast<ExternalReference>(static_cast<intptr_t>(value_));
} }
Handle<HeapObject> ToHeapObject() const { Handle<HeapObject> ToHeapObject() const {
DCHECK_EQ(kHeapObject, type()); DCHECK_EQ(kHeapObject, type());
return BitCast<Handle<HeapObject> >(static_cast<intptr_t>(value_)); return bit_cast<Handle<HeapObject> >(static_cast<intptr_t>(value_));
} }
private: private:

View File

@ -134,8 +134,8 @@ Node* JSGraph::Constant(Handle<Object> value) {
Node* JSGraph::Constant(double value) { Node* JSGraph::Constant(double value) {
if (BitCast<int64_t>(value) == BitCast<int64_t>(0.0)) return ZeroConstant(); if (bit_cast<int64_t>(value) == bit_cast<int64_t>(0.0)) return ZeroConstant();
if (BitCast<int64_t>(value) == BitCast<int64_t>(1.0)) return OneConstant(); if (bit_cast<int64_t>(value) == bit_cast<int64_t>(1.0)) return OneConstant();
return NumberConstant(value); return NumberConstant(value);
} }

View File

@ -249,7 +249,7 @@ TEST_F(MachineOperatorReducerTest, ChangeFloat64ToUint32WithConstant) {
Reduction reduction = Reduce(graph()->NewNode( Reduction reduction = Reduce(graph()->NewNode(
machine()->ChangeFloat64ToUint32(), Float64Constant(FastUI2D(x)))); machine()->ChangeFloat64ToUint32(), Float64Constant(FastUI2D(x))));
ASSERT_TRUE(reduction.Changed()); ASSERT_TRUE(reduction.Changed());
EXPECT_THAT(reduction.replacement(), IsInt32Constant(BitCast<int32_t>(x))); EXPECT_THAT(reduction.replacement(), IsInt32Constant(bit_cast<int32_t>(x)));
} }
} }
@ -290,7 +290,7 @@ TEST_F(MachineOperatorReducerTest, ChangeUint32ToFloat64WithConstant) {
TRACED_FOREACH(uint32_t, x, kUint32Values) { TRACED_FOREACH(uint32_t, x, kUint32Values) {
Reduction reduction = Reduction reduction =
Reduce(graph()->NewNode(machine()->ChangeUint32ToFloat64(), Reduce(graph()->NewNode(machine()->ChangeUint32ToFloat64(),
Int32Constant(BitCast<int32_t>(x)))); Int32Constant(bit_cast<int32_t>(x))));
ASSERT_TRUE(reduction.Changed()); ASSERT_TRUE(reduction.Changed());
EXPECT_THAT(reduction.replacement(), IsFloat64Constant(FastUI2D(x))); EXPECT_THAT(reduction.replacement(), IsFloat64Constant(FastUI2D(x)));
} }
@ -303,11 +303,12 @@ TEST_F(MachineOperatorReducerTest, ChangeUint32ToFloat64WithConstant) {
TEST_F(MachineOperatorReducerTest, ChangeUint32ToUint64WithConstant) { TEST_F(MachineOperatorReducerTest, ChangeUint32ToUint64WithConstant) {
TRACED_FOREACH(uint32_t, x, kUint32Values) { TRACED_FOREACH(uint32_t, x, kUint32Values) {
Reduction reduction = Reduce(graph()->NewNode( Reduction reduction =
machine()->ChangeUint32ToUint64(), Int32Constant(BitCast<int32_t>(x)))); Reduce(graph()->NewNode(machine()->ChangeUint32ToUint64(),
Int32Constant(bit_cast<int32_t>(x))));
ASSERT_TRUE(reduction.Changed()); ASSERT_TRUE(reduction.Changed());
EXPECT_THAT(reduction.replacement(), EXPECT_THAT(reduction.replacement(),
IsInt64Constant(BitCast<int64_t>(static_cast<uint64_t>(x)))); IsInt64Constant(bit_cast<int64_t>(static_cast<uint64_t>(x))));
} }
} }
@ -357,8 +358,8 @@ TEST_F(MachineOperatorReducerTest, TruncateInt64ToInt32WithConstant) {
graph()->NewNode(machine()->TruncateInt64ToInt32(), Int64Constant(x))); graph()->NewNode(machine()->TruncateInt64ToInt32(), Int64Constant(x)));
ASSERT_TRUE(reduction.Changed()); ASSERT_TRUE(reduction.Changed());
EXPECT_THAT(reduction.replacement(), EXPECT_THAT(reduction.replacement(),
IsInt32Constant(BitCast<int32_t>( IsInt32Constant(bit_cast<int32_t>(
static_cast<uint32_t>(BitCast<uint64_t>(x))))); static_cast<uint32_t>(bit_cast<uint64_t>(x)))));
} }
} }

View File

@ -31,7 +31,7 @@ inline int32_t NodeCacheHash(int64_t key) {
template <> template <>
inline int32_t NodeCacheHash(double key) { inline int32_t NodeCacheHash(double key) {
return ComputeLongHash(BitCast<int64_t>(key)); return ComputeLongHash(bit_cast<int64_t>(key));
} }

View File

@ -171,10 +171,10 @@ struct StaticParameterTraits<double> {
return os << val; return os << val;
} }
static int HashCode(double a) { static int HashCode(double a) {
return static_cast<int>(BitCast<int64_t>(a)); return static_cast<int>(bit_cast<int64_t>(a));
} }
static bool Equals(double a, double b) { static bool Equals(double a, double b) {
return BitCast<int64_t>(a) == BitCast<int64_t>(b); return bit_cast<int64_t>(a) == bit_cast<int64_t>(b);
} }
}; };

View File

@ -439,7 +439,7 @@ TEST_F(SimplifiedOperatorReducerTest, ChangeTaggedToUint32WithConstant) {
simplified()->ChangeTaggedToUint32(), NumberConstant(n))); simplified()->ChangeTaggedToUint32(), NumberConstant(n)));
ASSERT_TRUE(reduction.Changed()); ASSERT_TRUE(reduction.Changed());
EXPECT_THAT(reduction.replacement(), EXPECT_THAT(reduction.replacement(),
IsInt32Constant(BitCast<int32_t>(DoubleToUint32(n)))); IsInt32Constant(bit_cast<int32_t>(DoubleToUint32(n))));
} }
} }
@ -470,7 +470,7 @@ TEST_F(SimplifiedOperatorReducerTest, ChangeUint32ToTagged) {
TRACED_FOREACH(uint32_t, n, kUint32Values) { TRACED_FOREACH(uint32_t, n, kUint32Values) {
Reduction reduction = Reduction reduction =
Reduce(graph()->NewNode(simplified()->ChangeUint32ToTagged(), Reduce(graph()->NewNode(simplified()->ChangeUint32ToTagged(),
Int32Constant(BitCast<int32_t>(n)))); Int32Constant(bit_cast<int32_t>(n))));
ASSERT_TRUE(reduction.Changed()); ASSERT_TRUE(reduction.Changed());
EXPECT_THAT(reduction.replacement(), IsNumberConstant(FastUI2D(n))); EXPECT_THAT(reduction.replacement(), IsNumberConstant(FastUI2D(n)));
} }

View File

@ -918,7 +918,7 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
} }
} else { } else {
__ movq(kScratchRegister, __ movq(kScratchRegister,
BitCast<uint64_t, double>(g.ToDouble(constant_source))); bit_cast<uint64_t, double>(g.ToDouble(constant_source)));
if (destination->IsDoubleRegister()) { if (destination->IsDoubleRegister()) {
__ movq(g.ToDoubleRegister(destination), kScratchRegister); __ movq(g.ToDoubleRegister(destination), kScratchRegister);
} else { } else {

View File

@ -25,7 +25,7 @@ namespace v8 {
namespace internal { namespace internal {
inline double JunkStringValue() { inline double JunkStringValue() {
return BitCast<double, uint64_t>(kQuietNaNMask); return bit_cast<double, uint64_t>(kQuietNaNMask);
} }

View File

@ -3675,7 +3675,7 @@ DeoptimizedFrameInfo::~DeoptimizedFrameInfo() {
void DeoptimizedFrameInfo::Iterate(ObjectVisitor* v) { void DeoptimizedFrameInfo::Iterate(ObjectVisitor* v) {
v->VisitPointer(BitCast<Object**>(&function_)); v->VisitPointer(bit_cast<Object**>(&function_));
v->VisitPointer(&context_); v->VisitPointer(&context_);
v->VisitPointers(parameters_, parameters_ + parameters_count_); v->VisitPointers(parameters_, parameters_ + parameters_count_);
v->VisitPointers(expression_stack_, expression_stack_ + expression_count_); v->VisitPointers(expression_stack_, expression_stack_ + expression_count_);

View File

@ -11,8 +11,8 @@ namespace v8 {
namespace internal { namespace internal {
// We assume that doubles and uint64_t have the same endianness. // We assume that doubles and uint64_t have the same endianness.
inline uint64_t double_to_uint64(double d) { return BitCast<uint64_t>(d); } inline uint64_t double_to_uint64(double d) { return bit_cast<uint64_t>(d); }
inline double uint64_to_double(uint64_t d64) { return BitCast<double>(d64); } inline double uint64_to_double(uint64_t d64) { return bit_cast<double>(d64); }
// Helper functions for doubles. // Helper functions for doubles.
class Double { class Double {

View File

@ -570,7 +570,7 @@ class Factory FINAL {
#define ROOT_ACCESSOR(type, name, camel_name) \ #define ROOT_ACCESSOR(type, name, camel_name) \
inline Handle<type> name() { \ inline Handle<type> name() { \
return Handle<type>(BitCast<type**>( \ return Handle<type>(bit_cast<type**>( \
&isolate()->heap()->roots_[Heap::k##camel_name##RootIndex])); \ &isolate()->heap()->roots_[Heap::k##camel_name##RootIndex])); \
} }
ROOT_LIST(ROOT_ACCESSOR) ROOT_LIST(ROOT_ACCESSOR)
@ -578,7 +578,7 @@ class Factory FINAL {
#define STRUCT_MAP_ACCESSOR(NAME, Name, name) \ #define STRUCT_MAP_ACCESSOR(NAME, Name, name) \
inline Handle<Map> name##_map() { \ inline Handle<Map> name##_map() { \
return Handle<Map>(BitCast<Map**>( \ return Handle<Map>(bit_cast<Map**>( \
&isolate()->heap()->roots_[Heap::k##Name##MapRootIndex])); \ &isolate()->heap()->roots_[Heap::k##Name##MapRootIndex])); \
} }
STRUCT_LIST(STRUCT_MAP_ACCESSOR) STRUCT_LIST(STRUCT_MAP_ACCESSOR)
@ -586,7 +586,7 @@ class Factory FINAL {
#define STRING_ACCESSOR(name, str) \ #define STRING_ACCESSOR(name, str) \
inline Handle<String> name() { \ inline Handle<String> name() { \
return Handle<String>(BitCast<String**>( \ return Handle<String>(bit_cast<String**>( \
&isolate()->heap()->roots_[Heap::k##name##RootIndex])); \ &isolate()->heap()->roots_[Heap::k##name##RootIndex])); \
} }
INTERNALIZED_STRING_LIST(STRING_ACCESSOR) INTERNALIZED_STRING_LIST(STRING_ACCESSOR)

View File

@ -41,7 +41,7 @@ inline bool Handle<T>::is_identical_to(const Handle<T> o) const {
template <typename T> template <typename T>
inline T* Handle<T>::operator*() const { inline T* Handle<T>::operator*() const {
SLOW_DCHECK(IsDereferenceAllowed(INCLUDE_DEFERRED_CHECK)); SLOW_DCHECK(IsDereferenceAllowed(INCLUDE_DEFERRED_CHECK));
return *BitCast<T**>(location_); return *bit_cast<T**>(location_);
} }
template <typename T> template <typename T>
@ -55,7 +55,7 @@ inline T** Handle<T>::location() const {
template <typename T> template <typename T>
bool Handle<T>::IsDereferenceAllowed(DereferenceCheckMode mode) const { bool Handle<T>::IsDereferenceAllowed(DereferenceCheckMode mode) const {
DCHECK(location_ != NULL); DCHECK(location_ != NULL);
Object* object = *BitCast<T**>(location_); Object* object = *bit_cast<T**>(location_);
if (object->IsSmi()) return true; if (object->IsSmi()) return true;
HeapObject* heap_object = HeapObject::cast(object); HeapObject* heap_object = HeapObject::cast(object);
Heap* heap = heap_object->GetHeap(); Heap* heap = heap_object->GetHeap();

View File

@ -4724,7 +4724,7 @@ void Heap::IterateStrongRoots(ObjectVisitor* v, VisitMode mode) {
v->VisitPointers(&roots_[0], &roots_[kStrongRootListLength]); v->VisitPointers(&roots_[0], &roots_[kStrongRootListLength]);
v->Synchronize(VisitorSynchronization::kStrongRootList); v->Synchronize(VisitorSynchronization::kStrongRootList);
v->VisitPointer(BitCast<Object**>(&hidden_string_)); v->VisitPointer(bit_cast<Object**>(&hidden_string_));
v->Synchronize(VisitorSynchronization::kInternalizedString); v->Synchronize(VisitorSynchronization::kInternalizedString);
isolate_->bootstrapper()->Iterate(v); isolate_->bootstrapper()->Iterate(v);

View File

@ -2644,7 +2644,7 @@ OStream& HEnterInlined::PrintDataTo(OStream& os) const { // NOLINT
static bool IsInteger32(double value) { static bool IsInteger32(double value) {
double roundtrip_value = static_cast<double>(static_cast<int32_t>(value)); double roundtrip_value = static_cast<double>(static_cast<int32_t>(value));
return BitCast<int64_t>(roundtrip_value) == BitCast<int64_t>(value); return bit_cast<int64_t>(roundtrip_value) == bit_cast<int64_t>(value);
} }

View File

@ -3542,7 +3542,7 @@ class HConstant FINAL : public HTemplateInstruction<0> {
bool IsSpecialDouble() const { bool IsSpecialDouble() const {
return has_double_value_ && return has_double_value_ &&
(BitCast<int64_t>(double_value_) == BitCast<int64_t>(-0.0) || (bit_cast<int64_t>(double_value_) == bit_cast<int64_t>(-0.0) ||
FixedDoubleArray::is_the_hole_nan(double_value_) || FixedDoubleArray::is_the_hole_nan(double_value_) ||
std::isnan(double_value_)); std::isnan(double_value_));
} }
@ -3648,7 +3648,7 @@ class HConstant FINAL : public HTemplateInstruction<0> {
if (has_int32_value_) { if (has_int32_value_) {
return static_cast<intptr_t>(int32_value_); return static_cast<intptr_t>(int32_value_);
} else if (has_double_value_) { } else if (has_double_value_) {
return static_cast<intptr_t>(BitCast<int64_t>(double_value_)); return static_cast<intptr_t>(bit_cast<int64_t>(double_value_));
} else if (has_external_reference_value_) { } else if (has_external_reference_value_) {
return reinterpret_cast<intptr_t>(external_reference_value_.address()); return reinterpret_cast<intptr_t>(external_reference_value_.address());
} else { } else {
@ -3679,8 +3679,8 @@ class HConstant FINAL : public HTemplateInstruction<0> {
int32_value_ == other_constant->int32_value_; int32_value_ == other_constant->int32_value_;
} else if (has_double_value_) { } else if (has_double_value_) {
return other_constant->has_double_value_ && return other_constant->has_double_value_ &&
BitCast<int64_t>(double_value_) == bit_cast<int64_t>(double_value_) ==
BitCast<int64_t>(other_constant->double_value_); bit_cast<int64_t>(other_constant->double_value_);
} else if (has_external_reference_value_) { } else if (has_external_reference_value_) {
return other_constant->has_external_reference_value_ && return other_constant->has_external_reference_value_ &&
external_reference_value_ == external_reference_value_ ==

View File

@ -2530,9 +2530,9 @@ void InstanceofStub::Generate(MacroAssembler* masm) {
static const int kDeltaToCmpImmediate = 2; static const int kDeltaToCmpImmediate = 2;
static const int kDeltaToMov = 8; static const int kDeltaToMov = 8;
static const int kDeltaToMovImmediate = 9; static const int kDeltaToMovImmediate = 9;
static const int8_t kCmpEdiOperandByte1 = BitCast<int8_t, uint8_t>(0x3b); static const int8_t kCmpEdiOperandByte1 = bit_cast<int8_t, uint8_t>(0x3b);
static const int8_t kCmpEdiOperandByte2 = BitCast<int8_t, uint8_t>(0x3d); static const int8_t kCmpEdiOperandByte2 = bit_cast<int8_t, uint8_t>(0x3d);
static const int8_t kMovEaxImmediateByte = BitCast<int8_t, uint8_t>(0xb8); static const int8_t kMovEaxImmediateByte = bit_cast<int8_t, uint8_t>(0xb8);
DCHECK_EQ(object.code(), InstanceofStub::left().code()); DCHECK_EQ(object.code(), InstanceofStub::left().code());
DCHECK_EQ(function.code(), InstanceofStub::right().code()); DCHECK_EQ(function.code(), InstanceofStub::right().code());

View File

@ -1715,7 +1715,7 @@ void LCodeGen::DoConstantS(LConstantS* instr) {
void LCodeGen::DoConstantD(LConstantD* instr) { void LCodeGen::DoConstantD(LConstantD* instr) {
double v = instr->value(); double v = instr->value();
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
int32_t lower = static_cast<int32_t>(int_val); int32_t lower = static_cast<int32_t>(int_val);
int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt)); int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt));
DCHECK(instr->result()->IsDoubleRegister()); DCHECK(instr->result()->IsDoubleRegister());

View File

@ -292,7 +292,7 @@ void LGapResolver::EmitMove(int index) {
} }
} else if (destination->IsDoubleRegister()) { } else if (destination->IsDoubleRegister()) {
double v = cgen_->ToDouble(constant_source); double v = cgen_->ToDouble(constant_source);
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
int32_t lower = static_cast<int32_t>(int_val); int32_t lower = static_cast<int32_t>(int_val);
int32_t upper = static_cast<int32_t>(int_val >> kBitsPerInt); int32_t upper = static_cast<int32_t>(int_val >> kBitsPerInt);
XMMRegister dst = cgen_->ToDoubleRegister(destination); XMMRegister dst = cgen_->ToDoubleRegister(destination);

View File

@ -2082,7 +2082,7 @@ LInstruction* LChunkBuilder::DoConstant(HConstant* instr) {
return DefineAsRegister(new(zone()) LConstantI); return DefineAsRegister(new(zone()) LConstantI);
} else if (r.IsDouble()) { } else if (r.IsDouble()) {
double value = instr->DoubleValue(); double value = instr->DoubleValue();
bool value_is_zero = BitCast<uint64_t, double>(value) == 0; bool value_is_zero = bit_cast<uint64_t, double>(value) == 0;
LOperand* temp = value_is_zero ? NULL : TempRegister(); LOperand* temp = value_is_zero ? NULL : TempRegister();
return DefineAsRegister(new(zone()) LConstantD(temp)); return DefineAsRegister(new(zone()) LConstantD(temp));
} else if (r.IsExternal()) { } else if (r.IsExternal()) {

View File

@ -427,8 +427,8 @@ void MacroAssembler::RecordWriteArray(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
mov(index, Immediate(BitCast<int32_t>(kZapValue))); mov(index, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -472,8 +472,8 @@ void MacroAssembler::RecordWriteField(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
mov(dst, Immediate(BitCast<int32_t>(kZapValue))); mov(dst, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -533,9 +533,9 @@ void MacroAssembler::RecordWriteForMap(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
mov(scratch1, Immediate(BitCast<int32_t>(kZapValue))); mov(scratch1, Immediate(bit_cast<int32_t>(kZapValue)));
mov(scratch2, Immediate(BitCast<int32_t>(kZapValue))); mov(scratch2, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -603,8 +603,8 @@ void MacroAssembler::RecordWrite(
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(address, Immediate(BitCast<int32_t>(kZapValue))); mov(address, Immediate(bit_cast<int32_t>(kZapValue)));
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -2124,7 +2124,7 @@ Operand ApiParameterOperand(int index) {
void MacroAssembler::PrepareCallApiFunction(int argc) { void MacroAssembler::PrepareCallApiFunction(int argc) {
EnterApiExitFrame(argc); EnterApiExitFrame(argc);
if (emit_debug_code()) { if (emit_debug_code()) {
mov(esi, Immediate(BitCast<int32_t>(kZapValue))); mov(esi, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -2659,7 +2659,7 @@ void MacroAssembler::Move(const Operand& dst, const Immediate& x) {
void MacroAssembler::Move(XMMRegister dst, double val) { void MacroAssembler::Move(XMMRegister dst, double val) {
// TODO(titzer): recognize double constants with ExternalReferences. // TODO(titzer): recognize double constants with ExternalReferences.
uint64_t int_val = BitCast<uint64_t, double>(val); uint64_t int_val = bit_cast<uint64_t, double>(val);
if (int_val == 0) { if (int_val == 0) {
xorps(dst, dst); xorps(dst, dst);
} else { } else {

View File

@ -730,9 +730,9 @@ void NamedLoadHandlerCompiler::GenerateLoadInterceptorWithFollowup(
// Clobber registers when generating debug-code to provoke errors. // Clobber registers when generating debug-code to provoke errors.
__ bind(&interceptor_failed); __ bind(&interceptor_failed);
if (FLAG_debug_code) { if (FLAG_debug_code) {
__ mov(receiver(), Immediate(BitCast<int32_t>(kZapValue))); __ mov(receiver(), Immediate(bit_cast<int32_t>(kZapValue)));
__ mov(holder_reg, Immediate(BitCast<int32_t>(kZapValue))); __ mov(holder_reg, Immediate(bit_cast<int32_t>(kZapValue)));
__ mov(this->name(), Immediate(BitCast<int32_t>(kZapValue))); __ mov(this->name(), Immediate(bit_cast<int32_t>(kZapValue)));
} }
__ pop(this->name()); __ pop(this->name());

View File

@ -732,9 +732,9 @@ void NamedLoadHandlerCompiler::GenerateLoadInterceptorWithFollowup(
// Clobber registers when generating debug-code to provoke errors. // Clobber registers when generating debug-code to provoke errors.
__ bind(&interceptor_failed); __ bind(&interceptor_failed);
if (FLAG_debug_code) { if (FLAG_debug_code) {
__ mov(receiver(), Immediate(BitCast<int32_t>(kZapValue))); __ mov(receiver(), Immediate(bit_cast<int32_t>(kZapValue)));
__ mov(holder_reg, Immediate(BitCast<int32_t>(kZapValue))); __ mov(holder_reg, Immediate(bit_cast<int32_t>(kZapValue)));
__ mov(this->name(), Immediate(BitCast<int32_t>(kZapValue))); __ mov(this->name(), Immediate(bit_cast<int32_t>(kZapValue)));
} }
__ pop(this->name()); __ pop(this->name());

View File

@ -191,16 +191,16 @@ void Isolate::Iterate(ObjectVisitor* v, ThreadLocalTop* thread) {
// Visit the roots from the top for a given thread. // Visit the roots from the top for a given thread.
v->VisitPointer(&thread->pending_exception_); v->VisitPointer(&thread->pending_exception_);
v->VisitPointer(&(thread->pending_message_obj_)); v->VisitPointer(&(thread->pending_message_obj_));
v->VisitPointer(BitCast<Object**>(&(thread->pending_message_script_))); v->VisitPointer(bit_cast<Object**>(&(thread->pending_message_script_)));
v->VisitPointer(BitCast<Object**>(&(thread->context_))); v->VisitPointer(bit_cast<Object**>(&(thread->context_)));
v->VisitPointer(&thread->scheduled_exception_); v->VisitPointer(&thread->scheduled_exception_);
for (v8::TryCatch* block = thread->try_catch_handler(); for (v8::TryCatch* block = thread->try_catch_handler();
block != NULL; block != NULL;
block = block->next_) { block = block->next_) {
v->VisitPointer(BitCast<Object**>(&(block->exception_))); v->VisitPointer(bit_cast<Object**>(&(block->exception_)));
v->VisitPointer(BitCast<Object**>(&(block->message_obj_))); v->VisitPointer(bit_cast<Object**>(&(block->message_obj_)));
v->VisitPointer(BitCast<Object**>(&(block->message_script_))); v->VisitPointer(bit_cast<Object**>(&(block->message_script_)));
} }
// Iterate over pointers on native execution stack. // Iterate over pointers on native execution stack.

View File

@ -209,8 +209,8 @@ void MacroAssembler::RecordWriteField(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
li(value, Operand(BitCast<int32_t>(kZapValue + 4))); li(value, Operand(bit_cast<int32_t>(kZapValue + 4)));
li(dst, Operand(BitCast<int32_t>(kZapValue + 8))); li(dst, Operand(bit_cast<int32_t>(kZapValue + 8)));
} }
} }
@ -284,8 +284,8 @@ void MacroAssembler::RecordWriteForMap(Register object,
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
li(dst, Operand(BitCast<int32_t>(kZapValue + 12))); li(dst, Operand(bit_cast<int32_t>(kZapValue + 12)));
li(map, Operand(BitCast<int32_t>(kZapValue + 16))); li(map, Operand(bit_cast<int32_t>(kZapValue + 16)));
} }
} }
@ -359,8 +359,8 @@ void MacroAssembler::RecordWrite(
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
li(address, Operand(BitCast<int32_t>(kZapValue + 12))); li(address, Operand(bit_cast<int32_t>(kZapValue + 12)));
li(value, Operand(BitCast<int32_t>(kZapValue + 16))); li(value, Operand(bit_cast<int32_t>(kZapValue + 16)));
} }
} }

View File

@ -14,7 +14,6 @@
#include "src/assembler.h" #include "src/assembler.h"
#include "src/base/bits.h" #include "src/base/bits.h"
#include "src/disasm.h" #include "src/disasm.h"
#include "src/globals.h" // Need the BitCast.
#include "src/mips/constants-mips.h" #include "src/mips/constants-mips.h"
#include "src/mips/simulator-mips.h" #include "src/mips/simulator-mips.h"
#include "src/ostreams.h" #include "src/ostreams.h"
@ -1126,17 +1125,17 @@ void Simulator::set_fpu_register_hi_word(int fpureg, int32_t value) {
void Simulator::set_fpu_register_float(int fpureg, float value) { void Simulator::set_fpu_register_float(int fpureg, float value) {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
*BitCast<float*>(&FPUregisters_[fpureg]) = value; *bit_cast<float*>(&FPUregisters_[fpureg]) = value;
} }
void Simulator::set_fpu_register_double(int fpureg, double value) { void Simulator::set_fpu_register_double(int fpureg, double value) {
if (IsFp64Mode()) { if (IsFp64Mode()) {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
*BitCast<double*>(&FPUregisters_[fpureg]) = value; *bit_cast<double*>(&FPUregisters_[fpureg]) = value;
} else { } else {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters) && ((fpureg % 2) == 0)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters) && ((fpureg % 2) == 0));
int64_t i64 = BitCast<int64_t>(value); int64_t i64 = bit_cast<int64_t>(value);
set_fpu_register_word(fpureg, i64 & 0xffffffff); set_fpu_register_word(fpureg, i64 & 0xffffffff);
set_fpu_register_word(fpureg + 1, i64 >> 32); set_fpu_register_word(fpureg + 1, i64 >> 32);
} }
@ -1195,21 +1194,20 @@ int32_t Simulator::get_fpu_register_hi_word(int fpureg) const {
float Simulator::get_fpu_register_float(int fpureg) const { float Simulator::get_fpu_register_float(int fpureg) const {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
return *BitCast<float*>( return *bit_cast<float*>(const_cast<int64_t*>(&FPUregisters_[fpureg]));
const_cast<int64_t*>(&FPUregisters_[fpureg]));
} }
double Simulator::get_fpu_register_double(int fpureg) const { double Simulator::get_fpu_register_double(int fpureg) const {
if (IsFp64Mode()) { if (IsFp64Mode()) {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
return *BitCast<double*>(&FPUregisters_[fpureg]); return *bit_cast<double*>(&FPUregisters_[fpureg]);
} else { } else {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters) && ((fpureg % 2) == 0)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters) && ((fpureg % 2) == 0));
int64_t i64; int64_t i64;
i64 = static_cast<uint32_t>(get_fpu_register_word(fpureg)); i64 = static_cast<uint32_t>(get_fpu_register_word(fpureg));
i64 |= static_cast<uint64_t>(get_fpu_register_word(fpureg + 1)) << 32; i64 |= static_cast<uint64_t>(get_fpu_register_word(fpureg + 1)) << 32;
return BitCast<double>(i64); return bit_cast<double>(i64);
} }
} }

View File

@ -212,8 +212,8 @@ void MacroAssembler::RecordWriteField(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
li(value, Operand(BitCast<int64_t>(kZapValue + 4))); li(value, Operand(bit_cast<int64_t>(kZapValue + 4)));
li(dst, Operand(BitCast<int64_t>(kZapValue + 8))); li(dst, Operand(bit_cast<int64_t>(kZapValue + 8)));
} }
} }
@ -287,8 +287,8 @@ void MacroAssembler::RecordWriteForMap(Register object,
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
li(dst, Operand(BitCast<int64_t>(kZapValue + 12))); li(dst, Operand(bit_cast<int64_t>(kZapValue + 12)));
li(map, Operand(BitCast<int64_t>(kZapValue + 16))); li(map, Operand(bit_cast<int64_t>(kZapValue + 16)));
} }
} }
@ -362,8 +362,8 @@ void MacroAssembler::RecordWrite(
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
li(address, Operand(BitCast<int64_t>(kZapValue + 12))); li(address, Operand(bit_cast<int64_t>(kZapValue + 12)));
li(value, Operand(BitCast<int64_t>(kZapValue + 16))); li(value, Operand(bit_cast<int64_t>(kZapValue + 16)));
} }
} }

View File

@ -14,7 +14,6 @@
#include "src/assembler.h" #include "src/assembler.h"
#include "src/base/bits.h" #include "src/base/bits.h"
#include "src/disasm.h" #include "src/disasm.h"
#include "src/globals.h" // Need the BitCast.
#include "src/mips64/constants-mips64.h" #include "src/mips64/constants-mips64.h"
#include "src/mips64/simulator-mips64.h" #include "src/mips64/simulator-mips64.h"
#include "src/ostreams.h" #include "src/ostreams.h"
@ -1057,13 +1056,13 @@ void Simulator::set_fpu_register_hi_word(int fpureg, int32_t value) {
void Simulator::set_fpu_register_float(int fpureg, float value) { void Simulator::set_fpu_register_float(int fpureg, float value) {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
*BitCast<float*>(&FPUregisters_[fpureg]) = value; *bit_cast<float*>(&FPUregisters_[fpureg]) = value;
} }
void Simulator::set_fpu_register_double(int fpureg, double value) { void Simulator::set_fpu_register_double(int fpureg, double value) {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
*BitCast<double*>(&FPUregisters_[fpureg]) = value; *bit_cast<double*>(&FPUregisters_[fpureg]) = value;
} }
@ -1118,14 +1117,13 @@ uint32_t Simulator::get_fpu_register_hi_word(int fpureg) const {
float Simulator::get_fpu_register_float(int fpureg) const { float Simulator::get_fpu_register_float(int fpureg) const {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
return *BitCast<float*>( return *bit_cast<float*>(const_cast<int64_t*>(&FPUregisters_[fpureg]));
const_cast<int64_t*>(&FPUregisters_[fpureg]));
} }
double Simulator::get_fpu_register_double(int fpureg) const { double Simulator::get_fpu_register_double(int fpureg) const {
DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters)); DCHECK((fpureg >= 0) && (fpureg < kNumFPURegisters));
return *BitCast<double*>(&FPUregisters_[fpureg]); return *bit_cast<double*>(&FPUregisters_[fpureg]);
} }

View File

@ -371,9 +371,9 @@ void FixedDoubleArray::FixedDoubleArrayVerify() {
if (!is_the_hole(i)) { if (!is_the_hole(i)) {
double value = get_scalar(i); double value = get_scalar(i);
CHECK(!std::isnan(value) || CHECK(!std::isnan(value) ||
(BitCast<uint64_t>(value) == (bit_cast<uint64_t>(value) ==
BitCast<uint64_t>(canonical_not_the_hole_nan_as_double())) || bit_cast<uint64_t>(canonical_not_the_hole_nan_as_double())) ||
((BitCast<uint64_t>(value) & Double::kSignMask) != 0)); ((bit_cast<uint64_t>(value) & Double::kSignMask) != 0));
} }
} }
} }

View File

@ -2193,18 +2193,18 @@ void FixedArray::set(int index, Object* value) {
inline bool FixedDoubleArray::is_the_hole_nan(double value) { inline bool FixedDoubleArray::is_the_hole_nan(double value) {
return BitCast<uint64_t, double>(value) == kHoleNanInt64; return bit_cast<uint64_t, double>(value) == kHoleNanInt64;
} }
inline double FixedDoubleArray::hole_nan_as_double() { inline double FixedDoubleArray::hole_nan_as_double() {
return BitCast<double, uint64_t>(kHoleNanInt64); return bit_cast<double, uint64_t>(kHoleNanInt64);
} }
inline double FixedDoubleArray::canonical_not_the_hole_nan_as_double() { inline double FixedDoubleArray::canonical_not_the_hole_nan_as_double() {
DCHECK(BitCast<uint64_t>(base::OS::nan_value()) != kHoleNanInt64); DCHECK(bit_cast<uint64_t>(base::OS::nan_value()) != kHoleNanInt64);
DCHECK((BitCast<uint64_t>(base::OS::nan_value()) >> 32) != kHoleNanUpper32); DCHECK((bit_cast<uint64_t>(base::OS::nan_value()) >> 32) != kHoleNanUpper32);
return base::OS::nan_value(); return base::OS::nan_value();
} }

View File

@ -13,8 +13,8 @@ namespace internal {
void LookupResult::Iterate(ObjectVisitor* visitor) { void LookupResult::Iterate(ObjectVisitor* visitor) {
LookupResult* current = this; // Could be NULL. LookupResult* current = this; // Could be NULL.
while (current != NULL) { while (current != NULL) {
visitor->VisitPointer(BitCast<Object**>(&current->holder_)); visitor->VisitPointer(bit_cast<Object**>(&current->holder_));
visitor->VisitPointer(BitCast<Object**>(&current->transition_)); visitor->VisitPointer(bit_cast<Object**>(&current->transition_));
current = current->next_; current = current->next_;
} }
} }

View File

@ -741,62 +741,6 @@ inline int TenToThe(int exponent) {
} }
// The type-based aliasing rule allows the compiler to assume that pointers of
// different types (for some definition of different) never alias each other.
// Thus the following code does not work:
//
// float f = foo();
// int fbits = *(int*)(&f);
//
// The compiler 'knows' that the int pointer can't refer to f since the types
// don't match, so the compiler may cache f in a register, leaving random data
// in fbits. Using C++ style casts makes no difference, however a pointer to
// char data is assumed to alias any other pointer. This is the 'memcpy
// exception'.
//
// Bit_cast uses the memcpy exception to move the bits from a variable of one
// type of a variable of another type. Of course the end result is likely to
// be implementation dependent. Most compilers (gcc-4.2 and MSVC 2005)
// will completely optimize BitCast away.
//
// There is an additional use for BitCast.
// Recent gccs will warn when they see casts that may result in breakage due to
// the type-based aliasing rule. If you have checked that there is no breakage
// you can use BitCast to cast one pointer type to another. This confuses gcc
// enough that it can no longer see that you have cast one pointer type to
// another thus avoiding the warning.
// We need different implementations of BitCast for pointer and non-pointer
// values. We use partial specialization of auxiliary struct to work around
// issues with template functions overloading.
template <class Dest, class Source>
struct BitCastHelper {
STATIC_ASSERT(sizeof(Dest) == sizeof(Source));
INLINE(static Dest cast(const Source& source)) {
Dest dest;
memcpy(&dest, &source, sizeof(dest));
return dest;
}
};
template <class Dest, class Source>
struct BitCastHelper<Dest, Source*> {
INLINE(static Dest cast(Source* source)) {
return BitCastHelper<Dest, uintptr_t>::
cast(reinterpret_cast<uintptr_t>(source));
}
};
template <class Dest, class Source>
INLINE(Dest BitCast(const Source& source));
template <class Dest, class Source>
inline Dest BitCast(const Source& source) {
return BitCastHelper<Dest, Source>::cast(source);
}
template<typename ElementType, int NumElements> template<typename ElementType, int NumElements>
class EmbeddedContainer { class EmbeddedContainer {
public: public:

View File

@ -162,7 +162,7 @@ Operand::Operand(const Operand& operand, int32_t offset) {
int32_t disp_value = 0; int32_t disp_value = 0;
if (mode == 0x80 || is_baseless) { if (mode == 0x80 || is_baseless) {
// Mode 2 or mode 0 with rbp/r13 as base: Word displacement. // Mode 2 or mode 0 with rbp/r13 as base: Word displacement.
disp_value = *BitCast<const int32_t*>(&operand.buf_[disp_offset]); disp_value = *bit_cast<const int32_t*>(&operand.buf_[disp_offset]);
} else if (mode == 0x40) { } else if (mode == 0x40) {
// Mode 1: Byte displacement. // Mode 1: Byte displacement.
disp_value = static_cast<signed char>(operand.buf_[disp_offset]); disp_value = static_cast<signed char>(operand.buf_[disp_offset]);

View File

@ -286,7 +286,7 @@ void ElementsTransitionGenerator::GenerateSmiToDouble(
STATIC_ASSERT(FixedDoubleArray::kHeaderSize == FixedArray::kHeaderSize); STATIC_ASSERT(FixedDoubleArray::kHeaderSize == FixedArray::kHeaderSize);
Label loop, entry, convert_hole; Label loop, entry, convert_hole;
__ movq(r15, BitCast<int64_t, uint64_t>(kHoleNanInt64)); __ movq(r15, bit_cast<int64_t, uint64_t>(kHoleNanInt64));
// r15: the-hole NaN // r15: the-hole NaN
__ jmp(&entry); __ jmp(&entry);
@ -393,7 +393,7 @@ void ElementsTransitionGenerator::GenerateDoubleToObject(
__ movp(FieldOperand(r11, FixedArray::kLengthOffset), r14); __ movp(FieldOperand(r11, FixedArray::kLengthOffset), r14);
// Prepare for conversion loop. // Prepare for conversion loop.
__ movq(rsi, BitCast<int64_t, uint64_t>(kHoleNanInt64)); __ movq(rsi, bit_cast<int64_t, uint64_t>(kHoleNanInt64));
__ LoadRoot(rdi, Heap::kTheHoleValueRootIndex); __ LoadRoot(rdi, Heap::kTheHoleValueRootIndex);
// rsi: the-hole NaN // rsi: the-hole NaN
// rdi: pointer to the-hole // rdi: pointer to the-hole

View File

@ -1721,7 +1721,7 @@ void LCodeGen::DoConstantD(LConstantD* instr) {
DCHECK(instr->result()->IsDoubleRegister()); DCHECK(instr->result()->IsDoubleRegister());
XMMRegister res = ToDoubleRegister(instr->result()); XMMRegister res = ToDoubleRegister(instr->result());
double v = instr->value(); double v = instr->value();
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
// Use xor to produce +0.0 in a fast and compact way, but avoid to // Use xor to produce +0.0 in a fast and compact way, but avoid to
// do so if the constant is -0.0. // do so if the constant is -0.0.
if (int_val == 0) { if (int_val == 0) {
@ -4347,7 +4347,8 @@ void LCodeGen::DoStoreKeyedFixedDoubleArray(LStoreKeyed* instr) {
__ ucomisd(value, value); __ ucomisd(value, value);
__ j(parity_odd, &have_value, Label::kNear); // NaN. __ j(parity_odd, &have_value, Label::kNear); // NaN.
__ Set(kScratchRegister, BitCast<uint64_t>( __ Set(kScratchRegister,
bit_cast<uint64_t>(
FixedDoubleArray::canonical_not_the_hole_nan_as_double())); FixedDoubleArray::canonical_not_the_hole_nan_as_double()));
__ movq(value, kScratchRegister); __ movq(value, kScratchRegister);

View File

@ -188,7 +188,7 @@ void LGapResolver::EmitMove(int index) {
} }
} else if (destination->IsDoubleRegister()) { } else if (destination->IsDoubleRegister()) {
double v = cgen_->ToDouble(constant_source); double v = cgen_->ToDouble(constant_source);
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
XMMRegister dst = cgen_->ToDoubleRegister(destination); XMMRegister dst = cgen_->ToDoubleRegister(destination);
if (int_val == 0) { if (int_val == 0) {
__ xorps(dst, dst); __ xorps(dst, dst);

View File

@ -3395,7 +3395,8 @@ void MacroAssembler::StoreNumberToDoubleElements(
bind(&is_nan); bind(&is_nan);
// Convert all NaNs to the same canonical NaN value when they are stored in // Convert all NaNs to the same canonical NaN value when they are stored in
// the double array. // the double array.
Set(kScratchRegister, BitCast<uint64_t>( Set(kScratchRegister,
bit_cast<uint64_t>(
FixedDoubleArray::canonical_not_the_hole_nan_as_double())); FixedDoubleArray::canonical_not_the_hole_nan_as_double()));
movq(xmm_scratch, kScratchRegister); movq(xmm_scratch, kScratchRegister);
jmp(&have_double_value, Label::kNear); jmp(&have_double_value, Label::kNear);

View File

@ -2205,9 +2205,9 @@ void InstanceofStub::Generate(MacroAssembler* masm) {
static const int kDeltaToCmpImmediate = 2; static const int kDeltaToCmpImmediate = 2;
static const int kDeltaToMov = 8; static const int kDeltaToMov = 8;
static const int kDeltaToMovImmediate = 9; static const int kDeltaToMovImmediate = 9;
static const int8_t kCmpEdiOperandByte1 = BitCast<int8_t, uint8_t>(0x3b); static const int8_t kCmpEdiOperandByte1 = bit_cast<int8_t, uint8_t>(0x3b);
static const int8_t kCmpEdiOperandByte2 = BitCast<int8_t, uint8_t>(0x3d); static const int8_t kCmpEdiOperandByte2 = bit_cast<int8_t, uint8_t>(0x3d);
static const int8_t kMovEaxImmediateByte = BitCast<int8_t, uint8_t>(0xb8); static const int8_t kMovEaxImmediateByte = bit_cast<int8_t, uint8_t>(0xb8);
DCHECK_EQ(object.code(), InstanceofStub::left().code()); DCHECK_EQ(object.code(), InstanceofStub::left().code());
DCHECK_EQ(function.code(), InstanceofStub::right().code()); DCHECK_EQ(function.code(), InstanceofStub::right().code());

View File

@ -1908,7 +1908,7 @@ void LCodeGen::DoConstantS(LConstantS* instr) {
void LCodeGen::DoConstantD(LConstantD* instr) { void LCodeGen::DoConstantD(LConstantD* instr) {
double v = instr->value(); double v = instr->value();
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
int32_t lower = static_cast<int32_t>(int_val); int32_t lower = static_cast<int32_t>(int_val);
int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt)); int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt));
DCHECK(instr->result()->IsDoubleRegister()); DCHECK(instr->result()->IsDoubleRegister());
@ -4088,7 +4088,7 @@ void LCodeGen::DoStoreKeyedFixedDoubleArray(LStoreKeyed* instr) {
// This means we should store the (double) hole. No floating point // This means we should store the (double) hole. No floating point
// registers required. // registers required.
double nan_double = FixedDoubleArray::hole_nan_as_double(); double nan_double = FixedDoubleArray::hole_nan_as_double();
uint64_t int_val = BitCast<uint64_t, double>(nan_double); uint64_t int_val = bit_cast<uint64_t, double>(nan_double);
int32_t lower = static_cast<int32_t>(int_val); int32_t lower = static_cast<int32_t>(int_val);
int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt)); int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt));

View File

@ -292,7 +292,7 @@ void LGapResolver::EmitMove(int index) {
} }
} else if (destination->IsDoubleRegister()) { } else if (destination->IsDoubleRegister()) {
double v = cgen_->ToDouble(constant_source); double v = cgen_->ToDouble(constant_source);
uint64_t int_val = BitCast<uint64_t, double>(v); uint64_t int_val = bit_cast<uint64_t, double>(v);
int32_t lower = static_cast<int32_t>(int_val); int32_t lower = static_cast<int32_t>(int_val);
int32_t upper = static_cast<int32_t>(int_val >> kBitsPerInt); int32_t upper = static_cast<int32_t>(int_val >> kBitsPerInt);
__ push(Immediate(upper)); __ push(Immediate(upper));

View File

@ -349,8 +349,8 @@ void MacroAssembler::RecordWriteArray(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
mov(index, Immediate(BitCast<int32_t>(kZapValue))); mov(index, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -393,8 +393,8 @@ void MacroAssembler::RecordWriteField(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
mov(dst, Immediate(BitCast<int32_t>(kZapValue))); mov(dst, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -452,9 +452,9 @@ void MacroAssembler::RecordWriteForMap(
// Clobber clobbered input registers when running with the debug-code flag // Clobber clobbered input registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
mov(scratch1, Immediate(BitCast<int32_t>(kZapValue))); mov(scratch1, Immediate(bit_cast<int32_t>(kZapValue)));
mov(scratch2, Immediate(BitCast<int32_t>(kZapValue))); mov(scratch2, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -521,8 +521,8 @@ void MacroAssembler::RecordWrite(
// Clobber clobbered registers when running with the debug-code flag // Clobber clobbered registers when running with the debug-code flag
// turned on to provoke errors. // turned on to provoke errors.
if (emit_debug_code()) { if (emit_debug_code()) {
mov(address, Immediate(BitCast<int32_t>(kZapValue))); mov(address, Immediate(bit_cast<int32_t>(kZapValue)));
mov(value, Immediate(BitCast<int32_t>(kZapValue))); mov(value, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }
@ -2016,7 +2016,7 @@ Operand ApiParameterOperand(int index) {
void MacroAssembler::PrepareCallApiFunction(int argc) { void MacroAssembler::PrepareCallApiFunction(int argc) {
EnterApiExitFrame(argc); EnterApiExitFrame(argc);
if (emit_debug_code()) { if (emit_debug_code()) {
mov(esi, Immediate(BitCast<int32_t>(kZapValue))); mov(esi, Immediate(bit_cast<int32_t>(kZapValue)));
} }
} }

View File

@ -1182,7 +1182,7 @@ TEST(14) {
code->Print(os); code->Print(os);
#endif #endif
F3 f = FUNCTION_CAST<F3>(code->entry()); F3 f = FUNCTION_CAST<F3>(code->entry());
t.left = BitCast<double>(kHoleNanInt64); t.left = bit_cast<double>(kHoleNanInt64);
t.right = 1; t.right = 1;
t.add_result = 0; t.add_result = 0;
t.sub_result = 0; t.sub_result = 0;
@ -1199,14 +1199,18 @@ TEST(14) {
#endif #endif
// With VFP2 the sign of the canonicalized Nan is undefined. So // With VFP2 the sign of the canonicalized Nan is undefined. So
// we remove the sign bit for the upper tests. // we remove the sign bit for the upper tests.
CHECK_EQ(kArmNanUpper32, (BitCast<int64_t>(t.add_result) >> 32) & 0x7fffffff); CHECK_EQ(kArmNanUpper32,
CHECK_EQ(kArmNanLower32, BitCast<int64_t>(t.add_result) & 0xffffffffu); (bit_cast<int64_t>(t.add_result) >> 32) & 0x7fffffff);
CHECK_EQ(kArmNanUpper32, (BitCast<int64_t>(t.sub_result) >> 32) & 0x7fffffff); CHECK_EQ(kArmNanLower32, bit_cast<int64_t>(t.add_result) & 0xffffffffu);
CHECK_EQ(kArmNanLower32, BitCast<int64_t>(t.sub_result) & 0xffffffffu); CHECK_EQ(kArmNanUpper32,
CHECK_EQ(kArmNanUpper32, (BitCast<int64_t>(t.mul_result) >> 32) & 0x7fffffff); (bit_cast<int64_t>(t.sub_result) >> 32) & 0x7fffffff);
CHECK_EQ(kArmNanLower32, BitCast<int64_t>(t.mul_result) & 0xffffffffu); CHECK_EQ(kArmNanLower32, bit_cast<int64_t>(t.sub_result) & 0xffffffffu);
CHECK_EQ(kArmNanUpper32, (BitCast<int64_t>(t.div_result) >> 32) & 0x7fffffff); CHECK_EQ(kArmNanUpper32,
CHECK_EQ(kArmNanLower32, BitCast<int64_t>(t.div_result) & 0xffffffffu); (bit_cast<int64_t>(t.mul_result) >> 32) & 0x7fffffff);
CHECK_EQ(kArmNanLower32, bit_cast<int64_t>(t.mul_result) & 0xffffffffu);
CHECK_EQ(kArmNanUpper32,
(bit_cast<int64_t>(t.div_result) >> 32) & 0x7fffffff);
CHECK_EQ(kArmNanLower32, bit_cast<int64_t>(t.div_result) & 0xffffffffu);
} }

View File

@ -62,7 +62,7 @@ int STDCALL ConvertDToICVersion(double d) {
} }
} else { } else {
uint64_t big_result = uint64_t big_result =
(BitCast<uint64_t>(d) & Double::kSignificandMask) | Double::kHiddenBit; (bit_cast<uint64_t>(d) & Double::kSignificandMask) | Double::kHiddenBit;
big_result = big_result >> (Double::kPhysicalSignificandSize - exponent); big_result = big_result >> (Double::kPhysicalSignificandSize - exponent);
result = static_cast<uint32_t>(big_result); result = static_cast<uint32_t>(big_result);
} }

View File

@ -149,8 +149,8 @@ static void TestNaN(const char *code) {
i::FixedDoubleArray* a = i::FixedDoubleArray::cast(array1->elements()); i::FixedDoubleArray* a = i::FixedDoubleArray::cast(array1->elements());
double value = a->get_scalar(0); double value = a->get_scalar(0);
CHECK(std::isnan(value) && CHECK(std::isnan(value) &&
i::BitCast<uint64_t>(value) == i::bit_cast<uint64_t>(value) ==
i::BitCast<uint64_t>( i::bit_cast<uint64_t>(
i::FixedDoubleArray::canonical_not_the_hole_nan_as_double())); i::FixedDoubleArray::canonical_not_the_hole_nan_as_double()));
} }