OLD | NEW |
1 //===- subzero/crosstest/test_cast_main.cpp - Driver for tests ------------===// | 1 //===- subzero/crosstest/test_cast_main.cpp - Driver for tests ------------===// |
2 // | 2 // |
3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
4 // | 4 // |
5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
7 // | 7 // |
8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
9 // | 9 // |
10 // Driver for crosstesting cast operations. | 10 // Driver for crosstesting cast operations. |
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
108 } | 108 } |
109 COMPARE_VEC(cast, FromType, ToType, Value, FromTypeString, ToTypeString); | 109 COMPARE_VEC(cast, FromType, ToType, Value, FromTypeString, ToTypeString); |
110 } | 110 } |
111 } | 111 } |
112 | 112 |
113 int main(int argc, char **argv) { | 113 int main(int argc, char **argv) { |
114 size_t TotalTests = 0; | 114 size_t TotalTests = 0; |
115 size_t Passes = 0; | 115 size_t Passes = 0; |
116 size_t Failures = 0; | 116 size_t Failures = 0; |
117 | 117 |
118 volatile bool ValsUi1[] = { false, true }; | 118 volatile bool ValsUi1[] = {false, true}; |
119 static const size_t NumValsUi1 = sizeof(ValsUi1) / sizeof(*ValsUi1); | 119 static const size_t NumValsUi1 = sizeof(ValsUi1) / sizeof(*ValsUi1); |
120 volatile uint8_t ValsUi8[] = { 0, 1, 0x7e, 0x7f, 0x80, 0x81, 0xfe, 0xff }; | 120 volatile uint8_t ValsUi8[] = {0, 1, 0x7e, 0x7f, 0x80, 0x81, 0xfe, 0xff}; |
121 static const size_t NumValsUi8 = sizeof(ValsUi8) / sizeof(*ValsUi8); | 121 static const size_t NumValsUi8 = sizeof(ValsUi8) / sizeof(*ValsUi8); |
122 | 122 |
123 volatile myint8_t ValsSi8[] = { 0, 1, 0x7e, 0x7f, 0x80, 0x81, 0xfe, 0xff }; | 123 volatile myint8_t ValsSi8[] = {0, 1, 0x7e, 0x7f, 0x80, 0x81, 0xfe, 0xff}; |
124 static const size_t NumValsSi8 = sizeof(ValsSi8) / sizeof(*ValsSi8); | 124 static const size_t NumValsSi8 = sizeof(ValsSi8) / sizeof(*ValsSi8); |
125 | 125 |
126 volatile uint16_t ValsUi16[] = { 0, 1, 0x7e, 0x7f, 0x80, | 126 volatile uint16_t ValsUi16[] = {0, 1, 0x7e, 0x7f, 0x80, |
127 0x81, 0xfe, 0xff, 0x7ffe, 0x7fff, | 127 0x81, 0xfe, 0xff, 0x7ffe, 0x7fff, |
128 0x8000, 0x8001, 0xfffe, 0xffff }; | 128 0x8000, 0x8001, 0xfffe, 0xffff}; |
129 static const size_t NumValsUi16 = sizeof(ValsUi16) / sizeof(*ValsUi16); | 129 static const size_t NumValsUi16 = sizeof(ValsUi16) / sizeof(*ValsUi16); |
130 | 130 |
131 volatile int16_t ValsSi16[] = { 0, 1, 0x7e, 0x7f, 0x80, | 131 volatile int16_t ValsSi16[] = {0, 1, 0x7e, 0x7f, 0x80, |
132 0x81, 0xfe, 0xff, 0x7ffe, 0x7fff, | 132 0x81, 0xfe, 0xff, 0x7ffe, 0x7fff, |
133 0x8000, 0x8001, 0xfffe, 0xffff }; | 133 0x8000, 0x8001, 0xfffe, 0xffff}; |
134 static const size_t NumValsSi16 = sizeof(ValsSi16) / sizeof(*ValsSi16); | 134 static const size_t NumValsSi16 = sizeof(ValsSi16) / sizeof(*ValsSi16); |
135 | 135 |
136 volatile size_t ValsUi32[] = { | 136 volatile size_t ValsUi32[] = {0, 1, 0x7e, 0x7f, |
137 0, 1, 0x7e, 0x7f, 0x80, | 137 0x80, 0x81, 0xfe, 0xff, |
138 0x81, 0xfe, 0xff, 0x7ffe, 0x7fff, | 138 0x7ffe, 0x7fff, 0x8000, 0x8001, |
139 0x8000, 0x8001, 0xfffe, 0xffff, 0x7ffffffe, | 139 0xfffe, 0xffff, 0x7ffffffe, 0x7fffffff, |
140 0x7fffffff, 0x80000000, 0x80000001, 0xfffffffe, 0xffffffff | 140 0x80000000, 0x80000001, 0xfffffffe, 0xffffffff}; |
141 }; | |
142 static const size_t NumValsUi32 = sizeof(ValsUi32) / sizeof(*ValsUi32); | 141 static const size_t NumValsUi32 = sizeof(ValsUi32) / sizeof(*ValsUi32); |
143 | 142 |
144 volatile size_t ValsSi32[] = { | 143 volatile size_t ValsSi32[] = {0, 1, 0x7e, 0x7f, |
145 0, 1, 0x7e, 0x7f, 0x80, | 144 0x80, 0x81, 0xfe, 0xff, |
146 0x81, 0xfe, 0xff, 0x7ffe, 0x7fff, | 145 0x7ffe, 0x7fff, 0x8000, 0x8001, |
147 0x8000, 0x8001, 0xfffe, 0xffff, 0x7ffffffe, | 146 0xfffe, 0xffff, 0x7ffffffe, 0x7fffffff, |
148 0x7fffffff, 0x80000000, 0x80000001, 0xfffffffe, 0xffffffff | 147 0x80000000, 0x80000001, 0xfffffffe, 0xffffffff}; |
149 }; | |
150 static const size_t NumValsSi32 = sizeof(ValsSi32) / sizeof(*ValsSi32); | 148 static const size_t NumValsSi32 = sizeof(ValsSi32) / sizeof(*ValsSi32); |
151 | 149 |
152 volatile uint64_t ValsUi64[] = { | 150 volatile uint64_t ValsUi64[] = { |
153 0, 1, 0x7e, | 151 0, 1, 0x7e, |
154 0x7f, 0x80, 0x81, | 152 0x7f, 0x80, 0x81, |
155 0xfe, 0xff, 0x7ffe, | 153 0xfe, 0xff, 0x7ffe, |
156 0x7fff, 0x8000, 0x8001, | 154 0x7fff, 0x8000, 0x8001, |
157 0xfffe, 0xffff, 0x7ffffffe, | 155 0xfffe, 0xffff, 0x7ffffffe, |
158 0x7fffffff, 0x80000000, 0x80000001, | 156 0x7fffffff, 0x80000000, 0x80000001, |
159 0xfffffffe, 0xffffffff, 0x100000000ull, | 157 0xfffffffe, 0xffffffff, 0x100000000ull, |
160 0x100000001ull, 0x7ffffffffffffffeull, 0x7fffffffffffffffull, | 158 0x100000001ull, 0x7ffffffffffffffeull, 0x7fffffffffffffffull, |
161 0x8000000000000000ull, 0x8000000000000001ull, 0xfffffffffffffffeull, | 159 0x8000000000000000ull, 0x8000000000000001ull, 0xfffffffffffffffeull, |
162 0xffffffffffffffffull | 160 0xffffffffffffffffull}; |
163 }; | |
164 static const size_t NumValsUi64 = sizeof(ValsUi64) / sizeof(*ValsUi64); | 161 static const size_t NumValsUi64 = sizeof(ValsUi64) / sizeof(*ValsUi64); |
165 | 162 |
166 volatile int64_t ValsSi64[] = { | 163 volatile int64_t ValsSi64[] = { |
167 0, 1, 0x7e, | 164 0, 1, 0x7e, |
168 0x7f, 0x80, 0x81, | 165 0x7f, 0x80, 0x81, |
169 0xfe, 0xff, 0x7ffe, | 166 0xfe, 0xff, 0x7ffe, |
170 0x7fff, 0x8000, 0x8001, | 167 0x7fff, 0x8000, 0x8001, |
171 0xfffe, 0xffff, 0x7ffffffe, | 168 0xfffe, 0xffff, 0x7ffffffe, |
172 0x7fffffff, 0x80000000, 0x80000001, | 169 0x7fffffff, 0x80000000, 0x80000001, |
173 0xfffffffe, 0xffffffff, 0x100000000ll, | 170 0xfffffffe, 0xffffffff, 0x100000000ll, |
174 0x100000001ll, 0x7ffffffffffffffell, 0x7fffffffffffffffll, | 171 0x100000001ll, 0x7ffffffffffffffell, 0x7fffffffffffffffll, |
175 0x8000000000000000ll, 0x8000000000000001ll, 0xfffffffffffffffell, | 172 0x8000000000000000ll, 0x8000000000000001ll, 0xfffffffffffffffell, |
176 0xffffffffffffffffll | 173 0xffffffffffffffffll}; |
177 }; | |
178 static const size_t NumValsSi64 = sizeof(ValsSi64) / sizeof(*ValsSi64); | 174 static const size_t NumValsSi64 = sizeof(ValsSi64) / sizeof(*ValsSi64); |
179 | 175 |
180 static const double NegInf = -1.0 / 0.0; | 176 static const double NegInf = -1.0 / 0.0; |
181 static const double PosInf = 1.0 / 0.0; | 177 static const double PosInf = 1.0 / 0.0; |
182 static const double Nan = 0.0 / 0.0; | 178 static const double Nan = 0.0 / 0.0; |
183 static const double NegNan = -0.0 / 0.0; | 179 static const double NegNan = -0.0 / 0.0; |
184 volatile float ValsF32[] = FP_VALUE_ARRAY(NegInf, PosInf, NegNan, Nan); | 180 volatile float ValsF32[] = FP_VALUE_ARRAY(NegInf, PosInf, NegNan, Nan); |
185 static const size_t NumValsF32 = sizeof(ValsF32) / sizeof(*ValsF32); | 181 static const size_t NumValsF32 = sizeof(ValsF32) / sizeof(*ValsF32); |
186 | 182 |
187 volatile double ValsF64[] = FP_VALUE_ARRAY(NegInf, PosInf, NegNan, Nan); | 183 volatile double ValsF64[] = FP_VALUE_ARRAY(NegInf, PosInf, NegNan, Nan); |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
245 } | 241 } |
246 testVector<v4ui32, v4f32>(TotalTests, Passes, Failures, "v4ui32", "v4f32"); | 242 testVector<v4ui32, v4f32>(TotalTests, Passes, Failures, "v4ui32", "v4f32"); |
247 testVector<v4si32, v4f32>(TotalTests, Passes, Failures, "v4si32", "v4f32"); | 243 testVector<v4si32, v4f32>(TotalTests, Passes, Failures, "v4si32", "v4f32"); |
248 testVector<v4f32, v4si32>(TotalTests, Passes, Failures, "v4f32", "v4si32"); | 244 testVector<v4f32, v4si32>(TotalTests, Passes, Failures, "v4f32", "v4si32"); |
249 testVector<v4f32, v4ui32>(TotalTests, Passes, Failures, "v4f32", "v4ui32"); | 245 testVector<v4f32, v4ui32>(TotalTests, Passes, Failures, "v4f32", "v4ui32"); |
250 | 246 |
251 std::cout << "TotalTests=" << TotalTests << " Passes=" << Passes | 247 std::cout << "TotalTests=" << TotalTests << " Passes=" << Passes |
252 << " Failures=" << Failures << "\n"; | 248 << " Failures=" << Failures << "\n"; |
253 return Failures; | 249 return Failures; |
254 } | 250 } |
OLD | NEW |