X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Falgo%2Fcrc.h;h=c5c1eefddb5b161061bb66e9c7e4d53385f91ef0;hb=369b505bc0aed841c8e7452f2be09a95900885db;hp=3fb3381292bf18a4164f99b38d5bc12b2c3eaefe;hpb=99176a7ff060c88b8261d7f7f0a44e72c6d45aeb;p=bertos.git diff --git a/bertos/algo/crc.h b/bertos/algo/crc.h index 3fb33812..c5c1eefd 100644 --- a/bertos/algo/crc.h +++ b/bertos/algo/crc.h @@ -71,7 +71,7 @@ extern const uint16_t crc16tab[256]; * \param c New octet (range 0-255) * \param oldcrc Previous CRC16 value (referenced twice, beware of side effects) */ -#if CPU_HARVARD && !(ARCH & defined(ARCH_BOOT)) +#if CPU_HARVARD && !(defined(ARCH_BOOT) && (ARCH & ARCH_BOOT)) #define UPDCRC16(c, oldcrc) (pgm_read_uint16_t(&crc16tab[((oldcrc) >> 8) ^ ((unsigned char)(c))]) ^ ((oldcrc) << 8)) #else #define UPDCRC16(c, oldcrc) ((crc16tab[((oldcrc) >> 8) ^ ((unsigned char)(c))]) ^ ((oldcrc) << 8)) @@ -86,7 +86,7 @@ extern const uint16_t crc16tab[256]; */ INLINE uint16_t updcrc16(uint8_t c, uint16_t oldcrc) { -#if CPU_HARVARD && !(ARCH & defined(ARCH_BOOT)) +#if CPU_HARVARD && !(defined(ARCH_BOOT) && (ARCH & ARCH_BOOT)) return pgm_read_uint16_t(&crc16tab[(oldcrc >> 8) ^ c]) ^ (oldcrc << 8); #else return crc16tab[(oldcrc >> 8) ^ c] ^ (oldcrc << 8);