| 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 |