blob: 443ad5ad21525cef5a3a626411bf674810541c75 [file] [log] [blame]
//===- subzero/crosstest/test_bitmanip.def - macros for tests -*- C++ -*---===//
//
// The Subzero Code Generator
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file defines macros for testing bit manipulation intrinsics.
//
//===----------------------------------------------------------------------===//
#ifndef TEST_BIT_MANIP_DEF
#define TEST_BIT_MANIP_DEF
#include "xdefs.h"
#define STR(s) #s
#define BMI_OPS \
/* inst */ \
X(ctlz) \
X(cttz) \
X(ctpop)
// #define X(inst)
#define BMI_TYPES \
/* type */ \
X(uint32) \
X(uint64)
// #define X(type)
#define FOR_ALL_BMI_TYPES_INST(F, inst) \
F(inst, uint32) \
F(inst, uint64)
#define FOR_ALL_BMI_OP_TYPES(X) \
FOR_ALL_BMI_TYPES_INST(X, ctlz) \
FOR_ALL_BMI_TYPES_INST(X, cttz) \
FOR_ALL_BMI_TYPES_INST(X, ctpop)
//#define X(inst, type)
#define BSWAP_TABLE \
/* type, builtin_name */ \
X(uint16_t, __builtin_bswap16) \
X(uint32, __builtin_bswap32) \
X(uint64, __builtin_bswap64)
#endif // TEST_BIT_MANIP_DEF