//----------------------------------------------------------------------------- // Hagen Fritsch - June 2010 // // This code is licensed to you under the terms of the GNU GPL, version 2 or, // at your option, any later version. See the LICENSE.txt file for the text of // the license. // //----------------------------------------------------------------------------- // Interlib Definitions //----------------------------------------------------------------------------- #ifndef __COMMON_H #define __COMMON_H #ifdef __cplusplus extern "C" { #endif #include #include #include typedef unsigned char byte_t; #ifdef _MSC_VER typedef DWORD uint32_t; typedef BYTE uint8_t; #define PACKED // stuff #else #include #include #define PACKED __attribute__((packed)) #endif // debug #define DBG_NONE 0 // no messages #define DBG_ERROR 1 // errors only #define DBG_INFO 2 // errors + info messages #define DBG_DEBUG 3 // errors + info + debug messages #define DBG_EXTENDED 4 // errors + info + debug + breaking debug messages extern int DBGLEVEL; // reader voltage field detector #define MF_MINFIELDV 4000 #ifndef MIN # define MIN(a, b) (((a) < (b)) ? (a) : (b)) #endif #ifndef MAX # define MAX(a, b) (((a) > (b)) ? (a) : (b)) #endif #ifndef ABS # define ABS(a) ( ((a)<0) ? -(a) : (a) ) #endif #define RAMFUNC __attribute((long_call, section(".ramfunc"))) #ifndef ROTR # define ROTR(x,n) (((uintmax_t)(x) >> (n)) | ((uintmax_t)(x) << ((sizeof(x) * 8) - (n)))) #endif #ifndef ROTL # define ROTL(x,n) (((uintmax_t)(x) << (n)) | ((uintmax_t)(x) >> ((sizeof(x) * 8) - (n)))) #endif // endian change for 64bit #ifdef __GNUC__ #ifndef BSWAP_64 #define BSWAP_64(x) __builtin_bswap64(x) #endif #else #ifdef _MSC_VER #ifndef BSWAP_64 #define BSWAP_64(x) _byteswap_uint64(x) #endif #else #ifndef BSWAP_64 #define BSWAP_64(x) \ (((uint64_t)(x) << 56) | \ (((uint64_t)(x) << 40) & 0xff000000000000ULL) | \ (((uint64_t)(x) << 24) & 0xff0000000000ULL) | \ (((uint64_t)(x) << 8) & 0xff00000000ULL) | \ (((uint64_t)(x) >> 8) & 0xff000000ULL) | \ (((uint64_t)(x) >> 24) & 0xff0000ULL) | \ (((uint64_t)(x) >> 40) & 0xff00ULL) | \ ((uint64_t)(x) >> 56)) #endif #endif #endif // endian change for 32bit #ifdef __GNUC__ #ifndef BSWAP_32 #define BSWAP_32(x) __builtin_bswap32(x) #endif #else #ifdef _MSC_VER #ifndef BSWAP_32 #define BSWAP_32(x) _byteswap_ulong(x) #endif #else #ifndef BSWAP_32 # define BSWAP_32(x) \ ((((x) & 0xff000000) >> 24) | (((x) & 0x00ff0000) >> 8) | \ (((x) & 0x0000ff00) << 8) | (((x) & 0x000000ff) << 24)) #endif #endif #endif #define EVEN 0 #define ODD 1 // Nibble logic #ifndef NIBBLE_HIGH # define NIBBLE_HIGH(b) ( (b & 0xF0) >> 4 ) #endif #ifndef NIBBLE_LOW # define NIBBLE_LOW(b) ( b & 0x0F ) #endif #ifndef CRUMB # define CRUMB(b,p) (((b & (0x3 << p) ) >> p ) & 0xF) #endif #ifndef SWAP_NIBBLE # define SWAP_NIBBLE(b) ( (NIBBLE_LOW(b)<< 4) | NIBBLE_HIGH(b)) #endif // Binary Encoded Digit #ifndef BCD2DEC # define BCD2DEC(bcd) HornerScheme(bcd, 0x10, 10) #endif #ifndef DEC2BCD # define DEC2BCD(dec) HornerScheme(dec, 10, 0x10) #endif #ifdef __cplusplus } #endif #endif