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