OLD | NEW |
| 1 //===- subzero/crosstest/test_arith.cpp - Arithmetic operator tests -------===// |
| 2 // |
| 3 // The Subzero Code Generator |
| 4 // |
| 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. |
| 7 // |
| 8 //===----------------------------------------------------------------------===// |
| 9 // |
| 10 // Implementation for crosstesting arithmetic operations. |
| 11 // |
| 12 //===----------------------------------------------------------------------===// |
| 13 |
1 // This aims to test all the arithmetic bitcode instructions across | 14 // This aims to test all the arithmetic bitcode instructions across |
2 // all PNaCl primitive data types. | 15 // all PNaCl primitive data types. |
3 | 16 |
4 #include <stdint.h> | 17 #include <stdint.h> |
5 | 18 |
6 #include "test_arith.h" | 19 #include "test_arith.h" |
7 | 20 |
8 #define X(inst, op, isdiv) \ | 21 #define X(inst, op, isdiv) \ |
9 bool test##inst(bool a, bool b) { return a op b; } \ | 22 bool test##inst(bool a, bool b) { return a op b; } \ |
10 uint8_t test##inst(uint8_t a, uint8_t b) { return a op b; } \ | 23 uint8_t test##inst(uint8_t a, uint8_t b) { return a op b; } \ |
11 uint16_t test##inst(uint16_t a, uint16_t b) { return a op b; } \ | 24 uint16_t test##inst(uint16_t a, uint16_t b) { return a op b; } \ |
12 uint32_t test##inst(uint32_t a, uint32_t b) { return a op b; } \ | 25 uint32_t test##inst(uint32_t a, uint32_t b) { return a op b; } \ |
13 uint64_t test##inst(uint64_t a, uint64_t b) { return a op b; } \ | 26 uint64_t test##inst(uint64_t a, uint64_t b) { return a op b; } \ |
14 v4ui32 test##inst(v4ui32 a, v4ui32 b) { return a op b; } \ | 27 v4ui32 test##inst(v4ui32 a, v4ui32 b) { return a op b; } \ |
15 v8ui16 test##inst(v8ui16 a, v8ui16 b) { return a op b; } \ | 28 v8ui16 test##inst(v8ui16 a, v8ui16 b) { return a op b; } \ |
16 v16ui8 test##inst(v16ui8 a, v16ui8 b) { return a op b; } | 29 v16ui8 test##inst(v16ui8 a, v16ui8 b) { return a op b; } |
17 UINTOP_TABLE | 30 UINTOP_TABLE |
18 #undef X | 31 #undef X |
19 | 32 |
20 #define X(inst, op, isdiv) \ | 33 #define X(inst, op, isdiv) \ |
21 bool test##inst(bool a, bool b) { return a op b; } \ | 34 bool test##inst(bool a, bool b) { return a op b; } \ |
22 int8_t test##inst(int8_t a, int8_t b) { return a op b; } \ | 35 myint8_t test##inst(myint8_t a, myint8_t b) { return a op b; } \ |
23 int16_t test##inst(int16_t a, int16_t b) { return a op b; } \ | 36 int16_t test##inst(int16_t a, int16_t b) { return a op b; } \ |
24 int32_t test##inst(int32_t a, int32_t b) { return a op b; } \ | 37 int32_t test##inst(int32_t a, int32_t b) { return a op b; } \ |
25 int64_t test##inst(int64_t a, int64_t b) { return a op b; } \ | 38 int64_t test##inst(int64_t a, int64_t b) { return a op b; } \ |
26 v4si32 test##inst(v4si32 a, v4si32 b) { return a op b; } \ | 39 v4si32 test##inst(v4si32 a, v4si32 b) { return a op b; } \ |
27 v8si16 test##inst(v8si16 a, v8si16 b) { return a op b; } \ | 40 v8si16 test##inst(v8si16 a, v8si16 b) { return a op b; } \ |
28 v16si8 test##inst(v16si8 a, v16si8 b) { return a op b; } | 41 v16si8 test##inst(v16si8 a, v16si8 b) { return a op b; } |
29 SINTOP_TABLE | 42 SINTOP_TABLE |
30 #undef X | 43 #undef X |
31 | 44 |
32 #define X(inst, op, func) \ | 45 #define X(inst, op, func) \ |
33 float test##inst(float a, float b) { return func(a op b); } \ | 46 float test##inst(float a, float b) { return func(a op b); } \ |
34 double test##inst(double a, double b) { return func(a op b); } \ | 47 double test##inst(double a, double b) { return func(a op b); } \ |
35 v4f32 test##inst(v4f32 a, v4f32 b) { return func(a op b); } | 48 v4f32 test##inst(v4f32 a, v4f32 b) { return func(a op b); } |
36 FPOP_TABLE | 49 FPOP_TABLE |
37 #undef X | 50 #undef X |
OLD | NEW |