1 // Copyright 2015 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #include "src/v8.h"
6 
7 #include "src/objects.h"
8 #include "src/ostreams.h"
9 #include "test/cctest/cctest.h"
10 
11 using namespace v8::internal;
12 
13 #define FLOAT_TEST(type, lane_count)                     \
14   {                                                      \
15     float nan = std::numeric_limits<float>::quiet_NaN(); \
16     float lanes[lane_count] = {0};                       \
17     Handle<type> a = factory->New##type(lanes);          \
18     Handle<type> b = factory->New##type(lanes);          \
19     CHECK(a->BitwiseEquals(*b));                         \
20     CHECK(a->SameValue(*b));                             \
21     CHECK(a->SameValueZero(*b));                         \
22     CHECK_EQ(a->Hash(), b->Hash());                      \
23     for (int i = 0; i < lane_count; i++) {               \
24       a->set_lane(i, -0.0);                              \
25       CHECK(!a->BitwiseEquals(*b));                      \
26       CHECK_NE(a->Hash(), b->Hash());                    \
27       CHECK(!a->SameValue(*b));                          \
28       CHECK(a->SameValueZero(*b));                       \
29       b->set_lane(i, -0.0);                              \
30       CHECK(a->BitwiseEquals(*b));                       \
31       CHECK_EQ(a->Hash(), b->Hash());                    \
32       CHECK(a->SameValue(*b));                           \
33       CHECK(a->SameValueZero(*b));                       \
34       a->set_lane(i, nan);                               \
35       CHECK(!a->BitwiseEquals(*b));                      \
36       CHECK(!a->SameValue(*b));                          \
37       CHECK(!a->SameValueZero(*b));                      \
38       CHECK_NE(a->Hash(), b->Hash());                    \
39       b->set_lane(i, nan);                               \
40       CHECK(a->BitwiseEquals(*b));                       \
41       CHECK_EQ(a->Hash(), b->Hash());                    \
42       CHECK(a->SameValue(*b));                           \
43       CHECK(a->SameValueZero(*b));                       \
44     }                                                    \
45   }
46 
47 #define INT_TEST(type, lane_count, lane_type)   \
48   {                                             \
49     lane_type lanes[lane_count] = {0};          \
50     Handle<type> a = factory->New##type(lanes); \
51     Handle<type> b = factory->New##type(lanes); \
52     CHECK(a->BitwiseEquals(*b));                \
53     CHECK(a->SameValue(*b));                    \
54     CHECK(a->SameValueZero(*b));                \
55     CHECK_EQ(a->Hash(), b->Hash());             \
56     for (int i = 0; i < lane_count; i++) {      \
57       a->set_lane(i, i + 1);                    \
58       CHECK(!a->BitwiseEquals(*b));             \
59       CHECK_NE(a->Hash(), b->Hash());           \
60       CHECK(!a->SameValue(*b));                 \
61       CHECK(!a->SameValueZero(*b));             \
62       b->set_lane(i, i + 1);                    \
63       CHECK(a->BitwiseEquals(*b));              \
64       CHECK_EQ(a->Hash(), b->Hash());           \
65       CHECK(a->SameValue(*b));                  \
66       CHECK(a->SameValueZero(*b));              \
67       a->set_lane(i, -(i + 1));                 \
68       CHECK(!a->BitwiseEquals(*b));             \
69       CHECK_NE(a->Hash(), b->Hash());           \
70       CHECK(!a->SameValue(*b));                 \
71       CHECK(!a->SameValueZero(*b));             \
72       b->set_lane(i, -(i + 1));                 \
73       CHECK(a->BitwiseEquals(*b));              \
74       CHECK_EQ(a->Hash(), b->Hash());           \
75       CHECK(a->SameValue(*b));                  \
76       CHECK(a->SameValueZero(*b));              \
77     }                                           \
78   }
79 
80 #define BOOL_TEST(type, lane_count)             \
81   {                                             \
82     bool lanes[lane_count] = {false};           \
83     Handle<type> a = factory->New##type(lanes); \
84     Handle<type> b = factory->New##type(lanes); \
85     CHECK(a->BitwiseEquals(*b));                \
86     CHECK(a->SameValue(*b));                    \
87     CHECK(a->SameValueZero(*b));                \
88     CHECK_EQ(a->Hash(), b->Hash());             \
89     for (int i = 0; i < lane_count; i++) {      \
90       a->set_lane(i, true);                     \
91       CHECK(!a->BitwiseEquals(*b));             \
92       CHECK_NE(a->Hash(), b->Hash());           \
93       CHECK(!a->SameValue(*b));                 \
94       CHECK(!a->SameValueZero(*b));             \
95       b->set_lane(i, true);                     \
96       CHECK(a->BitwiseEquals(*b));              \
97       CHECK_EQ(a->Hash(), b->Hash());           \
98       CHECK(a->SameValue(*b));                  \
99       CHECK(a->SameValueZero(*b));              \
100     }                                           \
101   }
102 
TEST(SimdTypes)103 TEST(SimdTypes) {
104   CcTest::InitializeVM();
105   Isolate* isolate = CcTest::i_isolate();
106   Factory* factory = isolate->factory();
107 
108   HandleScope sc(isolate);
109 
110   FLOAT_TEST(Float32x4, 4)
111   INT_TEST(Int32x4, 4, int32_t)
112   INT_TEST(Uint32x4, 4, uint32_t)
113   BOOL_TEST(Bool32x4, 4)
114   INT_TEST(Int16x8, 8, int16_t)
115   INT_TEST(Uint16x8, 8, uint16_t)
116   BOOL_TEST(Bool16x8, 8)
117   INT_TEST(Int8x16, 16, int8_t)
118   INT_TEST(Uint8x16, 16, uint8_t)
119   BOOL_TEST(Bool8x16, 16)
120 }
121