| //===- subzero/crosstest/test_arith.h - Test prototypes ---------*- C++ -*-===// |
| // |
| // The Subzero Code Generator |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file declares the function prototypes used for crosstesting arithmetic |
| // operations. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include <stdint.h> |
| #include "test_arith.def" |
| #include "xdefs.h" |
| |
| #include "vectors.h" |
| |
| #define X(inst, op, isdiv, isshift) \ |
| bool test##inst(bool a, bool b); \ |
| uint8_t test##inst(uint8_t a, uint8_t b); \ |
| uint16_t test##inst(uint16_t a, uint16_t b); \ |
| uint32_t test##inst(uint32_t a, uint32_t b); \ |
| uint64 test##inst(uint64 a, uint64 b); \ |
| v4ui32 test##inst(v4ui32 a, v4ui32 b); \ |
| v8ui16 test##inst(v8ui16 a, v8ui16 b); \ |
| v16ui8 test##inst(v16ui8 a, v16ui8 b); |
| UINTOP_TABLE |
| #undef X |
| |
| #define X(inst, op, isdiv, isshift) \ |
| bool test##inst(bool a, bool b); \ |
| myint8_t test##inst(myint8_t a, myint8_t b); \ |
| int16_t test##inst(int16_t a, int16_t b); \ |
| int32_t test##inst(int32_t a, int32_t b); \ |
| int64 test##inst(int64 a, int64 b); \ |
| v4si32 test##inst(v4si32 a, v4si32 b); \ |
| v8si16 test##inst(v8si16 a, v8si16 b); \ |
| v16si8 test##inst(v16si8 a, v16si8 b); |
| SINTOP_TABLE |
| #undef X |
| |
| float myFrem(float a, float b); |
| double myFrem(double a, double b); |
| v4f32 myFrem(v4f32 a, v4f32 b); |
| |
| #define X(inst, op, func) \ |
| float test##inst(float a, float b); \ |
| double test##inst(double a, double b); \ |
| v4f32 test##inst(v4f32 a, v4f32 b); |
| FPOP_TABLE |
| #undef X |
| |
| float mySqrt(float a); |
| double mySqrt(double a); |
| // mySqrt for v4f32 is currently unsupported. |
| |
| float myFabs(float a); |
| double myFabs(double a); |
| v4f32 myFabs(v4f32 a); |
| |
| #define X(mult_by) \ |
| bool testMultiplyBy##mult_by(bool a, bool); \ |
| bool testMultiplyByNeg##mult_by(bool a, bool); \ |
| uint8_t testMultiplyBy##mult_by(uint8_t a, uint8_t); \ |
| uint8_t testMultiplyByNeg##mult_by(uint8_t a, uint8_t); \ |
| uint16_t testMultiplyBy##mult_by(uint16_t a, uint16_t); \ |
| uint16_t testMultiplyByNeg##mult_by(uint16_t a, uint16_t); \ |
| uint32_t testMultiplyBy##mult_by(uint32_t a, uint32_t); \ |
| uint32_t testMultiplyByNeg##mult_by(uint32_t a, uint32_t); \ |
| uint64_t testMultiplyBy##mult_by(uint64_t a, uint64_t); \ |
| uint64_t testMultiplyByNeg##mult_by(uint64_t a, uint64_t); |
| MULIMM_TABLE |
| #undef X |