mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2024-11-11 01:55:38 +08:00
41 lines
1 KiB
C
41 lines
1 KiB
C
//-----------------------------------------------------------------------------
|
|
// 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.
|
|
//-----------------------------------------------------------------------------
|
|
// Generic CRC calculation code.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#ifndef __PARITY_H
|
|
#define __PARITY_H
|
|
|
|
#include <stdint.h>
|
|
|
|
extern const uint8_t OddByteParity[256];
|
|
|
|
#define oddparity8(x) (OddByteParity[(x)])
|
|
|
|
|
|
extern const uint8_t EvenByteParity[256];
|
|
|
|
static inline bool /*__attribute__((always_inline))*/ evenparity8(const uint8_t x) {
|
|
#if !defined __i386__ || !defined __GNUC__
|
|
return EvenByteParity[x];
|
|
#else
|
|
uint8_t y;
|
|
__asm( "testb $255, %1\n"
|
|
"setpo %0\n" : "=r"(y) : "r"(x): );
|
|
return y;
|
|
#endif
|
|
}
|
|
|
|
|
|
static inline uint8_t evenparity32(uint32_t x)
|
|
{
|
|
x ^= x >> 16;
|
|
x ^= x >> 8;
|
|
return EvenByteParity[x & 0xff];
|
|
}
|
|
|
|
|
|
#endif /* __PARITY_H */
|