* WeatherStation: start
* SubGhz: rename protocol magellen -> magellan
* WeatherStation: err Unresolved symbols: {'subghz_protocol_decoder_base_get_string'}
* WeatherStation: fix Unresolved symbols: {'subghz_protocol_decoder_base_get_string'}
* Subghz: add set protocol_items
* WeatherStation: adding your protocols
* WS: add Infactory protocol
* WS: add history
* WS: add setting
* WS: add lock
* WS: add hopper frequency
* WS: fix history
* WS fix string_t -> FuriString*
* WS: add images
* WS: history record update when receiving data from the sensor again
* WS: add receiver info, delete extra code
* WS: add protocol ThermoPRO_TX4
* [FL-2900] SubGhz: Move icons in Sub-GHz
* WS: add Notification
* [FL-2890] SubGhz: Rename *_user files in resources to _user.example
* WS: add about scene
* WS: removing redundant code
* WS: add protocol Nexus-TH
* WS: add protocol GT_WT03
* WS: fix notification and rename "Weather Station" -> "Read Weather Station"
* SubGhz: partial unit tests fix
* SubGhz: fix unit_test
* SubGhz: remove dead code
* SubGhz: rename SubGhzPresetDefinition into SubGhzRadioPreset, cleanup subghz types.
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
82 lines
2.1 KiB
C
82 lines
2.1 KiB
C
#include "math.h"
|
|
|
|
uint64_t subghz_protocol_blocks_reverse_key(uint64_t key, uint8_t count_bit) {
|
|
uint64_t key_reverse = 0;
|
|
for(uint8_t i = 0; i < count_bit; i++) {
|
|
key_reverse = key_reverse << 1 | bit_read(key, i);
|
|
}
|
|
return key_reverse;
|
|
}
|
|
|
|
uint8_t subghz_protocol_blocks_get_parity(uint64_t key, uint8_t count_bit) {
|
|
uint8_t parity = 0;
|
|
for(uint8_t i = 0; i < count_bit; i++) {
|
|
parity += bit_read(key, i);
|
|
}
|
|
return parity & 0x01;
|
|
}
|
|
|
|
uint8_t subghz_protocol_blocks_crc4(
|
|
uint8_t const message[],
|
|
unsigned nBytes,
|
|
uint8_t polynomial,
|
|
uint8_t init) {
|
|
unsigned remainder = init << 4; // LSBs are unused
|
|
unsigned poly = polynomial << 4;
|
|
unsigned bit;
|
|
|
|
while(nBytes--) {
|
|
remainder ^= *message++;
|
|
for(bit = 0; bit < 8; bit++) {
|
|
if(remainder & 0x80) {
|
|
remainder = (remainder << 1) ^ poly;
|
|
} else {
|
|
remainder = (remainder << 1);
|
|
}
|
|
}
|
|
}
|
|
return remainder >> 4 & 0x0f; // discard the LSBs
|
|
}
|
|
|
|
uint8_t subghz_protocol_blocks_crc7(
|
|
uint8_t const message[],
|
|
unsigned nBytes,
|
|
uint8_t polynomial,
|
|
uint8_t init) {
|
|
unsigned remainder = init << 1; // LSB is unused
|
|
unsigned poly = polynomial << 1;
|
|
unsigned byte, bit;
|
|
|
|
for(byte = 0; byte < nBytes; ++byte) {
|
|
remainder ^= message[byte];
|
|
for(bit = 0; bit < 8; ++bit) {
|
|
if(remainder & 0x80) {
|
|
remainder = (remainder << 1) ^ poly;
|
|
} else {
|
|
remainder = (remainder << 1);
|
|
}
|
|
}
|
|
}
|
|
return remainder >> 1 & 0x7f; // discard the LSB
|
|
}
|
|
|
|
uint8_t subghz_protocol_blocks_crc8(
|
|
uint8_t const message[],
|
|
unsigned nBytes,
|
|
uint8_t polynomial,
|
|
uint8_t init) {
|
|
uint8_t remainder = init;
|
|
unsigned byte, bit;
|
|
|
|
for(byte = 0; byte < nBytes; ++byte) {
|
|
remainder ^= message[byte];
|
|
for(bit = 0; bit < 8; ++bit) {
|
|
if(remainder & 0x80) {
|
|
remainder = (remainder << 1) ^ polynomial;
|
|
} else {
|
|
remainder = (remainder << 1);
|
|
}
|
|
}
|
|
}
|
|
return remainder;
|
|
} |