| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- #pragma once
- #include <stdbool.h>
- #include <stdint.h>
- #include <stddef.h>
- #define bit_read(value, bit) (((value) >> (bit)) & 0x01)
- #define bit_set(value, bit) \
- ({ \
- __typeof__(value) _one = (1); \
- (value) |= (_one << (bit)); \
- })
- #define bit_clear(value, bit) \
- ({ \
- __typeof__(value) _one = (1); \
- (value) &= ~(_one << (bit)); \
- })
- #define bit_write(value, bit, bitvalue) (bitvalue ? bit_set(value, bit) : bit_clear(value, bit))
- #define DURATION_DIFF(x, y) (((x) < (y)) ? ((y) - (x)) : ((x) - (y)))
- #ifdef __cplusplus
- extern "C" {
- #endif
- /** Flip the data bitwise
- *
- * @param key In data
- * @param bit_count number of data bits
- *
- * @return Reverse data
- */
- uint64_t subghz_protocol_blocks_reverse_key(uint64_t key, uint8_t bit_count);
- /** Get parity the data bitwise
- *
- * @param key In data
- * @param bit_count number of data bits
- *
- * @return parity
- */
- uint8_t subghz_protocol_blocks_get_parity(uint64_t key, uint8_t bit_count);
- /** CRC-4
- *
- * @param message array of bytes to check
- * @param size number of bytes in message
- * @param polynomial CRC polynomial
- * @param init starting crc value
- *
- * @return CRC value
- */
- uint8_t subghz_protocol_blocks_crc4(
- uint8_t const message[],
- size_t size,
- uint8_t polynomial,
- uint8_t init);
- /** CRC-7
- *
- * @param message array of bytes to check
- * @param size number of bytes in message
- * @param polynomial CRC polynomial
- * @param init starting crc value
- *
- * @return CRC value
- */
- uint8_t subghz_protocol_blocks_crc7(
- uint8_t const message[],
- size_t size,
- uint8_t polynomial,
- uint8_t init);
- /** Generic Cyclic Redundancy Check CRC-8. Example polynomial: 0x31 = x8 + x5 +
- * x4 + 1 (x8 is implicit) Example polynomial: 0x80 = x8 + x7 (a normal
- * bit-by-bit parity XOR)
- *
- * @param message array of bytes to check
- * @param size number of bytes in message
- * @param polynomial byte is from x^7 to x^0 (x^8 is implicitly one)
- * @param init starting crc value
- *
- * @return CRC value
- */
- uint8_t subghz_protocol_blocks_crc8(
- uint8_t const message[],
- size_t size,
- uint8_t polynomial,
- uint8_t init);
- /** "Little-endian" Cyclic Redundancy Check CRC-8 LE Input and output are
- * reflected, i.e. least significant bit is shifted in first
- *
- * @param message array of bytes to check
- * @param size number of bytes in message
- * @param polynomial CRC polynomial
- * @param init starting crc value
- *
- * @return CRC value
- */
- uint8_t subghz_protocol_blocks_crc8le(
- uint8_t const message[],
- size_t size,
- uint8_t polynomial,
- uint8_t init);
- /** CRC-16 LSB. Input and output are reflected, i.e. least significant bit is
- * shifted in first. Note that poly and init already need to be reflected
- *
- * @param message array of bytes to check
- * @param size number of bytes in message
- * @param polynomial CRC polynomial
- * @param init starting crc value
- *
- * @return CRC value
- */
- uint16_t subghz_protocol_blocks_crc16lsb(
- uint8_t const message[],
- size_t size,
- uint16_t polynomial,
- uint16_t init);
- /** CRC-16
- *
- * @param message array of bytes to check
- * @param size number of bytes in message
- * @param polynomial CRC polynomial
- * @param init starting crc value
- *
- * @return CRC value
- */
- uint16_t subghz_protocol_blocks_crc16(
- uint8_t const message[],
- size_t size,
- uint16_t polynomial,
- uint16_t init);
- /** Digest-8 by "LFSR-based Toeplitz hash"
- *
- * @param message bytes of message data
- * @param size number of bytes to digest
- * @param gen key stream generator, needs to includes the MSB if the
- * LFSR is rolling
- * @param key initial key
- *
- * @return digest value
- */
- uint8_t subghz_protocol_blocks_lfsr_digest8(
- uint8_t const message[],
- size_t size,
- uint8_t gen,
- uint8_t key);
- /** Digest-8 by "LFSR-based Toeplitz hash", byte reflect, bit reflect
- *
- * @param message bytes of message data
- * @param size number of bytes to digest
- * @param gen key stream generator, needs to includes the MSB if the
- * LFSR is rolling
- * @param key initial key
- *
- * @return digest value
- */
- uint8_t subghz_protocol_blocks_lfsr_digest8_reflect(
- uint8_t const message[],
- size_t size,
- uint8_t gen,
- uint8_t key);
- /** Digest-16 by "LFSR-based Toeplitz hash"
- *
- * @param message bytes of message data
- * @param size number of bytes to digest
- * @param gen key stream generator, needs to includes the MSB if the
- * LFSR is rolling
- * @param key initial key
- *
- * @return digest value
- */
- uint16_t subghz_protocol_blocks_lfsr_digest16(
- uint8_t const message[],
- size_t size,
- uint16_t gen,
- uint16_t key);
- /** Compute Addition of a number of bytes
- *
- * @param message bytes of message data
- * @param size number of bytes to sum
- *
- * @return summation value
- */
- uint8_t subghz_protocol_blocks_add_bytes(uint8_t const message[], size_t size);
- /** Compute bit parity of a single byte (8 bits)
- *
- * @param byte single byte to check
- *
- * @return 1 odd parity, 0 even parity
- */
- uint8_t subghz_protocol_blocks_parity8(uint8_t byte);
- /** Compute bit parity of a number of bytes
- *
- * @param message bytes of message data
- * @param size number of bytes to sum
- *
- * @return 1 odd parity, 0 even parity
- */
- uint8_t subghz_protocol_blocks_parity_bytes(uint8_t const message[], size_t size);
- /** Compute XOR (byte-wide parity) of a number of bytes
- *
- * @param message bytes of message data
- * @param size number of bytes to sum
- *
- * @return summation value, per bit-position 1 odd parity, 0 even parity
- */
- uint8_t subghz_protocol_blocks_xor_bytes(uint8_t const message[], size_t size);
- #ifdef __cplusplus
- }
- #endif
|