 341610b8a1
			
		
	
	
		341610b8a1
		
			
		
	
	
	
	
		
			
			* fbt: added firmware_pvscheck & firmware_pvs targets for *nix * fbt: pvs support on Windows * fbt: additional fixes & docs for PVS support * fbt: fixes for updater env configuration * github: reworked pvs workflow * vscode: added PVS shortcut * pvs: added --ignore-ccache flag * fbt: pvs: opening web browser if there are warnings * fbt: pvs: added browser handler for mac * github: fixed report path for PVS * fbt: pvs: fixed report upload path * removed intentional PVS warning * fixed more PVS warnings * fixed secplus_v1 PVS warning * fbt: added PVSNOBROWSER flag * github: setting PVSNOBROWSER for pvs runs * fbt: less debug output Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			223 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			223 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #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
 |