You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

51 lines
1.2 KiB

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