274c12fc56
* Streams: string stream * String stream: updated insert/delete api * Streams: generic stream interface and string stream implementation * Streams: helpers for insert and delete_and_insert * FFF: now compatible with streams * MinUnit: introduced tests with arguments * FFF: stream access violation * Streams: copy data between streams * Streams: file stream * FFF: documentation * FFStream: documentation * FFF: alloc as file * MinUnit: support for nested tests * Streams: changed delete_and_insert, now it returns success flag. Added ability dump stream inner parameters and data to cout. * FFF: simplified file open function * Streams: unit tests * FFF: tests * Streams: declare cache_size constant as define, to allow variable modified arrays * FFF: lib moved to a separate folder * iButton: new FFF * RFID: new FFF * Animations: new FFF * IR: new FFF * NFC: new FFF * Flipper file format: delete lib * U2F: new FFF * Subghz: new FFF and streams * Streams: read line * Streams: split * FuriCore: implement memset with extra asserts * FuriCore: implement extra heap asserts without inventing memset * Scene manager: protected access to the scene id stack with a size check * NFC worker: dirty fix for issue where hal_nfc was busy on app start * Furi: update allocator to erase memory on allocation. Replace furi_alloc with malloc. * FuriCore: cleanup memmgr code. * Furi HAL: furi_hal_init is split into critical and non-critical parts. The critical part is currently clock and console. * Memmgr: added ability to track allocations and deallocations through console. * FFStream: some speedup * Streams, FF: minor fixes * Tests: restore * File stream: a slightly more thread-safe version of file_stream_delete_and_insert Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
227 lines
6.6 KiB
C
227 lines
6.6 KiB
C
#pragma once
|
|
|
|
#include <m-string.h>
|
|
#include <furi_hal.h>
|
|
#include <stdint.h>
|
|
#include <flipper_format/flipper_format.h>
|
|
|
|
#define bit_read(value, bit) (((value) >> (bit)) & 0x01)
|
|
#define bit_set(value, bit) ((value) |= (1UL << (bit)))
|
|
#define bit_clear(value, bit) ((value) &= ~(1UL << (bit)))
|
|
#define bit_write(value, bit, bitvalue) (bitvalue ? bit_set(value, bit) : bit_clear(value, bit))
|
|
|
|
#define SUBGHZ_TX_PIN_HIGH()
|
|
#define SUBGHZ_TX_PIN_LOW()
|
|
#define DURATION_DIFF(x, y) ((x < y) ? (y - x) : (x - y))
|
|
|
|
#define SUBGHZ_APP_FOLDER "/any/subghz"
|
|
#define SUBGHZ_RAW_FOLDER "/ext/subghz"
|
|
#define SUBGHZ_APP_EXTENSION ".sub"
|
|
#define SUBGHZ_ENCODER_UPLOAD_MAX_SIZE 2048
|
|
|
|
#define SUBGHZ_PARSER_TAG "SubGhzParser"
|
|
#define SUBGHZ_KEY_FILE_VERSION 1
|
|
#define SUBGHZ_KEY_FILE_TYPE "Flipper SubGhz Key File"
|
|
|
|
#define SUBGHZ_RAW_FILE_VERSION 1
|
|
#define SUBGHZ_RAW_FILE_TYPE "Flipper SubGhz RAW File"
|
|
|
|
typedef enum {
|
|
SubGhzProtocolCommonTypeUnknown,
|
|
SubGhzProtocolCommonTypeStatic,
|
|
SubGhzProtocolCommonTypeDynamic,
|
|
SubGhzProtocolCommonTypeRAW,
|
|
} SubGhzProtocolCommonType;
|
|
|
|
typedef struct SubGhzProtocolCommon SubGhzProtocolCommon;
|
|
typedef struct SubGhzProtocolCommonEncoder SubGhzProtocolCommonEncoder;
|
|
typedef struct SubGhzProtocolCommonLoad SubGhzProtocolCommonLoad;
|
|
|
|
typedef void (*SubGhzProtocolCommonCallback)(SubGhzProtocolCommon* parser, void* context);
|
|
|
|
typedef void (*SubGhzProtocolCommonToStr)(SubGhzProtocolCommon* instance, string_t output);
|
|
|
|
//Get string to save
|
|
typedef bool (
|
|
*SubGhzProtocolCommonSaveFile)(SubGhzProtocolCommon* instance, FlipperFormat* flipper_format);
|
|
|
|
//Load protocol from file
|
|
typedef bool (*SubGhzProtocolCommonLoadFromFile)(
|
|
FlipperFormat* flipper_format,
|
|
SubGhzProtocolCommon* instance,
|
|
const char* file_path);
|
|
//Load protocol
|
|
typedef void (*SubGhzProtocolCommonLoadFromRAW)(SubGhzProtocolCommon* instance, void* context);
|
|
//Get upload encoder protocol
|
|
typedef bool (*SubGhzProtocolCommonEncoderGetUpLoad)(
|
|
SubGhzProtocolCommon* instance,
|
|
SubGhzProtocolCommonEncoder* encoder);
|
|
|
|
typedef LevelDuration (*SubGhzProtocolCommonEncoderCallback)(void* context);
|
|
typedef void (*SubGhzProtocolCommonEncoderCallbackEnd)(void* context);
|
|
|
|
struct SubGhzProtocolCommon {
|
|
const char* name;
|
|
uint16_t te_long;
|
|
uint16_t te_short;
|
|
uint16_t te_delta;
|
|
uint8_t code_count_bit;
|
|
uint8_t code_last_count_bit;
|
|
uint64_t code_found;
|
|
uint64_t code_last_found;
|
|
uint8_t code_min_count_bit_for_found;
|
|
uint8_t btn;
|
|
uint8_t header_count;
|
|
SubGhzProtocolCommonType type_protocol;
|
|
uint32_t te_last;
|
|
uint32_t serial;
|
|
uint32_t parser_step;
|
|
uint16_t cnt;
|
|
|
|
/* Standard Callback for on rx complete event */
|
|
SubGhzProtocolCommonCallback callback;
|
|
void* context;
|
|
|
|
/* Dump To String */
|
|
SubGhzProtocolCommonToStr to_string;
|
|
/* Get string to save */
|
|
SubGhzProtocolCommonSaveFile to_save_file;
|
|
/* Load protocol from file */
|
|
SubGhzProtocolCommonLoadFromFile to_load_protocol_from_file;
|
|
/* Load protocol from RAW data */
|
|
SubGhzProtocolCommonLoadFromRAW to_load_protocol;
|
|
/* Get upload encoder protocol */
|
|
SubGhzProtocolCommonEncoderGetUpLoad get_upload_protocol;
|
|
};
|
|
|
|
struct SubGhzProtocolCommonEncoder {
|
|
bool start;
|
|
size_t repeat;
|
|
size_t front;
|
|
size_t size_upload;
|
|
LevelDuration* upload;
|
|
|
|
SubGhzProtocolCommonEncoderCallback callback;
|
|
SubGhzProtocolCommonEncoderCallbackEnd callback_end;
|
|
void* context;
|
|
void* context_end;
|
|
};
|
|
|
|
struct SubGhzProtocolCommonLoad {
|
|
uint64_t code_found;
|
|
uint8_t code_count_bit;
|
|
uint32_t param1;
|
|
uint32_t param2;
|
|
uint32_t param3;
|
|
};
|
|
|
|
/** Allocate SubGhzProtocolCommonEncoder
|
|
*
|
|
* @return SubGhzProtocolCommonEncoder*
|
|
*/
|
|
SubGhzProtocolCommonEncoder* subghz_protocol_encoder_common_alloc();
|
|
|
|
/** Free SubGhzProtocolCommonEncoder
|
|
*
|
|
* @param instance
|
|
*/
|
|
void subghz_protocol_encoder_common_free(SubGhzProtocolCommonEncoder* instance);
|
|
|
|
void subghz_protocol_encoder_common_set_callback(
|
|
SubGhzProtocolCommonEncoder* instance,
|
|
SubGhzProtocolCommonEncoderCallback callback,
|
|
void* context);
|
|
|
|
void subghz_protocol_encoder_common_set_callback_end(
|
|
SubGhzProtocolCommonEncoder* instance,
|
|
SubGhzProtocolCommonEncoderCallbackEnd callback_end,
|
|
void* context_end);
|
|
|
|
/** Get count repeat left
|
|
*
|
|
* @param instance - SubGhzProtocolCommonEncoder instance
|
|
* @return count repeat left
|
|
*/
|
|
size_t subghz_encoder_common_get_repeat_left(SubGhzProtocolCommonEncoder* instance);
|
|
|
|
/** Get LevelDuration this encoder step
|
|
*
|
|
* @param context - SubGhzProtocolCommonEncoder context
|
|
* @return LevelDuration this step
|
|
*/
|
|
LevelDuration subghz_protocol_encoder_common_yield(void* context);
|
|
|
|
/** Add data bit to code_found
|
|
*
|
|
* @param common - SubGhzProtocolCommon common
|
|
* @param bit - add bit
|
|
*/
|
|
void subghz_protocol_common_add_bit(SubGhzProtocolCommon* common, uint8_t bit);
|
|
|
|
/** Checking that the duration is included in the interval
|
|
*
|
|
* @param common - SubGhzProtocolCommon common
|
|
* @param duration duration reference
|
|
* @param duration_check duration checked
|
|
* @return true on success
|
|
*/
|
|
bool subghz_protocol_common_check_interval(
|
|
SubGhzProtocolCommon* common,
|
|
uint32_t duration,
|
|
uint16_t duration_check);
|
|
|
|
/** Bit-by-bit data mirroring
|
|
*
|
|
* @param key - data to mirror
|
|
* @param count_bit number of data bits
|
|
* @return mirrored data
|
|
*/
|
|
uint64_t subghz_protocol_common_reverse_key(uint64_t key, uint8_t count_bit);
|
|
|
|
/** Callback protocol
|
|
*
|
|
* @param instance - SubGhzProtocolCommon* instance
|
|
* @param callback
|
|
* @param context
|
|
*/
|
|
void subghz_protocol_common_set_callback(
|
|
SubGhzProtocolCommon* instance,
|
|
SubGhzProtocolCommonCallback callback,
|
|
void* context);
|
|
|
|
/** outputting information from the parser
|
|
*
|
|
* @param instance - SubGhzProtocolCommon* instance
|
|
* @param output - output string
|
|
*/
|
|
void subghz_protocol_common_to_str(SubGhzProtocolCommon* instance, string_t output);
|
|
|
|
/** Converting a string to a HEX array
|
|
*
|
|
* @param str - string data
|
|
* @param buff - uint8_t* buff
|
|
* @param len - size buff
|
|
* @return bool
|
|
*/
|
|
bool subghz_protocol_common_read_hex(string_t str, uint8_t* buff, uint16_t len);
|
|
|
|
/** Adding data to a file
|
|
*
|
|
* @param instance - SubGhzProtocolCommon instance
|
|
* @param flipper_format - FlipperFormat
|
|
* @return bool
|
|
*/
|
|
bool subghz_protocol_common_to_save_file(
|
|
SubGhzProtocolCommon* instance,
|
|
FlipperFormat* flipper_format);
|
|
|
|
/** Loading data to a file
|
|
*
|
|
* @param instance - SubGhzProtocolCommon instance
|
|
* @param flipper_format - FlipperFormat
|
|
* @return bool
|
|
*/
|
|
bool subghz_protocol_common_to_load_protocol_from_file(
|
|
SubGhzProtocolCommon* instance,
|
|
FlipperFormat* flipper_format);
|