Index: src/objects-inl.h |
diff --git a/src/objects-inl.h b/src/objects-inl.h |
index 371bc2af73927d64f717eb49e68a9dd94e5b0cdf..0a785e613daa604b61106d28791913190e78dfba 100644 |
--- a/src/objects-inl.h |
+++ b/src/objects-inl.h |
@@ -174,7 +174,6 @@ TYPE_CHECKER(MutableHeapNumber, MUTABLE_HEAP_NUMBER_TYPE) |
TYPE_CHECKER(Oddball, ODDBALL_TYPE) |
TYPE_CHECKER(PropertyCell, PROPERTY_CELL_TYPE) |
TYPE_CHECKER(SharedFunctionInfo, SHARED_FUNCTION_INFO_TYPE) |
-TYPE_CHECKER(Simd128Value, SIMD128_VALUE_TYPE) |
TYPE_CHECKER(Symbol, SYMBOL_TYPE) |
TYPE_CHECKER(TransitionArray, TRANSITION_ARRAY_TYPE) |
TYPE_CHECKER(WeakCell, WEAK_CELL_TYPE) |
@@ -204,11 +203,6 @@ bool HeapObject::IsExternal() const { |
return map() == GetHeap()->external_map(); |
} |
-#define SIMD128_TYPE_CHECKER(TYPE, Type, type, lane_count, lane_type) \ |
- bool HeapObject::Is##Type() const { return map() == GetHeap()->type##_map(); } |
-SIMD128_TYPES(SIMD128_TYPE_CHECKER) |
-#undef SIMD128_TYPE_CHECKER |
- |
#define IS_TYPE_FUNCTION_DEF(type_) \ |
bool Object::Is##type_() const { \ |
return IsHeapObject() && HeapObject::cast(this)->Is##type_(); \ |
@@ -617,9 +611,6 @@ bool Object::IsMinusZero() const { |
CAST_ACCESSOR(AbstractCode) |
CAST_ACCESSOR(ArrayList) |
CAST_ACCESSOR(BoilerplateDescription) |
-CAST_ACCESSOR(Bool16x8) |
-CAST_ACCESSOR(Bool32x4) |
-CAST_ACCESSOR(Bool8x16) |
CAST_ACCESSOR(ByteArray) |
CAST_ACCESSOR(BytecodeArray) |
CAST_ACCESSOR(Cell) |
@@ -638,15 +629,11 @@ CAST_ACCESSOR(FixedArray) |
CAST_ACCESSOR(FixedArrayBase) |
CAST_ACCESSOR(FixedDoubleArray) |
CAST_ACCESSOR(FixedTypedArrayBase) |
-CAST_ACCESSOR(Float32x4) |
CAST_ACCESSOR(Foreign) |
CAST_ACCESSOR(FrameArray) |
CAST_ACCESSOR(GlobalDictionary) |
CAST_ACCESSOR(HandlerTable) |
CAST_ACCESSOR(HeapObject) |
-CAST_ACCESSOR(Int16x8) |
-CAST_ACCESSOR(Int32x4) |
-CAST_ACCESSOR(Int8x16) |
CAST_ACCESSOR(JSArray) |
CAST_ACCESSOR(JSArrayBuffer) |
CAST_ACCESSOR(JSArrayBufferView) |
@@ -697,7 +684,6 @@ CAST_ACCESSOR(SeqOneByteString) |
CAST_ACCESSOR(SeqString) |
CAST_ACCESSOR(SeqTwoByteString) |
CAST_ACCESSOR(SharedFunctionInfo) |
-CAST_ACCESSOR(Simd128Value) |
CAST_ACCESSOR(SlicedString) |
CAST_ACCESSOR(Smi) |
CAST_ACCESSOR(String) |
@@ -707,9 +693,6 @@ CAST_ACCESSOR(Struct) |
CAST_ACCESSOR(Symbol) |
CAST_ACCESSOR(TemplateInfo) |
CAST_ACCESSOR(ThinString) |
-CAST_ACCESSOR(Uint16x8) |
-CAST_ACCESSOR(Uint32x4) |
-CAST_ACCESSOR(Uint8x16) |
CAST_ACCESSOR(UnseededNumberDictionary) |
CAST_ACCESSOR(WeakCell) |
CAST_ACCESSOR(WeakFixedArray) |
@@ -1575,110 +1558,6 @@ int HeapNumber::get_sign() { |
return READ_INT_FIELD(this, kExponentOffset) & kSignMask; |
} |
- |
-bool Simd128Value::Equals(Simd128Value* that) { |
- // TODO(bmeurer): This doesn't match the SIMD.js specification, but it seems |
- // to be consistent with what the CompareICStub does, and what is tested in |
- // the current SIMD.js testsuite. |
- if (this == that) return true; |
-#define SIMD128_VALUE(TYPE, Type, type, lane_count, lane_type) \ |
- if (this->Is##Type()) { \ |
- if (!that->Is##Type()) return false; \ |
- return Type::cast(this)->Equals(Type::cast(that)); \ |
- } |
- SIMD128_TYPES(SIMD128_VALUE) |
-#undef SIMD128_VALUE |
- return false; |
-} |
- |
- |
-// static |
-bool Simd128Value::Equals(Handle<Simd128Value> one, Handle<Simd128Value> two) { |
- return one->Equals(*two); |
-} |
- |
- |
-#define SIMD128_VALUE_EQUALS(TYPE, Type, type, lane_count, lane_type) \ |
- bool Type::Equals(Type* that) { \ |
- for (int lane = 0; lane < lane_count; ++lane) { \ |
- if (this->get_lane(lane) != that->get_lane(lane)) return false; \ |
- } \ |
- return true; \ |
- } |
-SIMD128_TYPES(SIMD128_VALUE_EQUALS) |
-#undef SIMD128_VALUE_EQUALS |
- |
- |
-#if defined(V8_TARGET_LITTLE_ENDIAN) |
-#define SIMD128_READ_LANE(lane_type, lane_count, field_type, field_size) \ |
- lane_type value = \ |
- READ_##field_type##_FIELD(this, kValueOffset + lane * field_size); |
-#elif defined(V8_TARGET_BIG_ENDIAN) |
-#define SIMD128_READ_LANE(lane_type, lane_count, field_type, field_size) \ |
- lane_type value = READ_##field_type##_FIELD( \ |
- this, kValueOffset + (lane_count - lane - 1) * field_size); |
-#else |
-#error Unknown byte ordering |
-#endif |
- |
-#if defined(V8_TARGET_LITTLE_ENDIAN) |
-#define SIMD128_WRITE_LANE(lane_count, field_type, field_size, value) \ |
- WRITE_##field_type##_FIELD(this, kValueOffset + lane * field_size, value); |
-#elif defined(V8_TARGET_BIG_ENDIAN) |
-#define SIMD128_WRITE_LANE(lane_count, field_type, field_size, value) \ |
- WRITE_##field_type##_FIELD( \ |
- this, kValueOffset + (lane_count - lane - 1) * field_size, value); |
-#else |
-#error Unknown byte ordering |
-#endif |
- |
-#define SIMD128_NUMERIC_LANE_FNS(type, lane_type, lane_count, field_type, \ |
- field_size) \ |
- lane_type type::get_lane(int lane) const { \ |
- DCHECK(lane < lane_count && lane >= 0); \ |
- SIMD128_READ_LANE(lane_type, lane_count, field_type, field_size) \ |
- return value; \ |
- } \ |
- \ |
- void type::set_lane(int lane, lane_type value) { \ |
- DCHECK(lane < lane_count && lane >= 0); \ |
- SIMD128_WRITE_LANE(lane_count, field_type, field_size, value) \ |
- } |
- |
-SIMD128_NUMERIC_LANE_FNS(Float32x4, float, 4, FLOAT, kFloatSize) |
-SIMD128_NUMERIC_LANE_FNS(Int32x4, int32_t, 4, INT32, kInt32Size) |
-SIMD128_NUMERIC_LANE_FNS(Uint32x4, uint32_t, 4, UINT32, kInt32Size) |
-SIMD128_NUMERIC_LANE_FNS(Int16x8, int16_t, 8, INT16, kShortSize) |
-SIMD128_NUMERIC_LANE_FNS(Uint16x8, uint16_t, 8, UINT16, kShortSize) |
-SIMD128_NUMERIC_LANE_FNS(Int8x16, int8_t, 16, INT8, kCharSize) |
-SIMD128_NUMERIC_LANE_FNS(Uint8x16, uint8_t, 16, UINT8, kCharSize) |
-#undef SIMD128_NUMERIC_LANE_FNS |
- |
- |
-#define SIMD128_BOOLEAN_LANE_FNS(type, lane_type, lane_count, field_type, \ |
- field_size) \ |
- bool type::get_lane(int lane) const { \ |
- DCHECK(lane < lane_count && lane >= 0); \ |
- SIMD128_READ_LANE(lane_type, lane_count, field_type, field_size) \ |
- DCHECK(value == 0 || value == -1); \ |
- return value != 0; \ |
- } \ |
- \ |
- void type::set_lane(int lane, bool value) { \ |
- DCHECK(lane < lane_count && lane >= 0); \ |
- int32_t int_val = value ? -1 : 0; \ |
- SIMD128_WRITE_LANE(lane_count, field_type, field_size, int_val) \ |
- } |
- |
-SIMD128_BOOLEAN_LANE_FNS(Bool32x4, int32_t, 4, INT32, kInt32Size) |
-SIMD128_BOOLEAN_LANE_FNS(Bool16x8, int16_t, 8, INT16, kShortSize) |
-SIMD128_BOOLEAN_LANE_FNS(Bool8x16, int8_t, 16, INT8, kCharSize) |
-#undef SIMD128_BOOLEAN_LANE_FNS |
- |
-#undef SIMD128_READ_LANE |
-#undef SIMD128_WRITE_LANE |
- |
- |
ACCESSORS(JSReceiver, properties, FixedArray, kPropertiesOffset) |
@@ -2458,8 +2337,8 @@ void Object::VerifyApiCallResultType() { |
DCHECK(IsHeapObject()); |
Isolate* isolate = HeapObject::cast(this)->GetIsolate(); |
if (!(IsString() || IsSymbol() || IsJSReceiver() || IsHeapNumber() || |
- IsSimd128Value() || IsUndefined(isolate) || IsTrue(isolate) || |
- IsFalse(isolate) || IsNull(isolate))) { |
+ IsUndefined(isolate) || IsTrue(isolate) || IsFalse(isolate) || |
+ IsNull(isolate))) { |
FATAL("API call returned invalid object"); |
} |
#endif // DEBUG |
@@ -2722,7 +2601,6 @@ AllocationAlignment HeapObject::RequiredAlignment() { |
return kDoubleAligned; |
} |
if (IsHeapNumber()) return kDoubleUnaligned; |
- if (IsSimd128Value()) return kSimd128Unaligned; |
#endif // V8_HOST_ARCH_32_BIT |
return kWordAligned; |
} |