| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- #include "subghz_history.h"
- #include <lib/subghz/protocols/subghz_protocol_keeloq.h>
- #include <lib/subghz/protocols/subghz_protocol_star_line.h>
- #include <lib/subghz/protocols/subghz_protocol_princeton.h>
- #include <furi.h>
- #include <m-string.h>
- #define SUBGHZ_HISTORY_MAX 50
- typedef struct SubGhzHistoryStruct SubGhzHistoryStruct;
- struct SubGhzHistoryStruct {
- const char* name;
- const char* manufacture_name;
- uint8_t type_protocol;
- uint8_t code_count_bit;
- uint64_t code_found;
- uint16_t te;
- FuriHalSubGhzPreset preset;
- uint32_t real_frequency;
- };
- struct SubGhzHistory {
- uint32_t last_update_timestamp;
- uint16_t last_index_write;
- uint64_t code_last_found;
- SubGhzHistoryStruct history[SUBGHZ_HISTORY_MAX];
- SubGhzProtocolCommonLoad data;
- };
- SubGhzHistory* subghz_history_alloc(void) {
- SubGhzHistory* instance = furi_alloc(sizeof(SubGhzHistory));
- return instance;
- }
- void subghz_history_free(SubGhzHistory* instance) {
- furi_assert(instance);
- free(instance);
- }
- void subghz_history_set_frequency_preset(
- SubGhzHistory* instance,
- uint16_t idx,
- uint32_t frequency,
- FuriHalSubGhzPreset preset) {
- furi_assert(instance);
- if(instance->last_index_write >= SUBGHZ_HISTORY_MAX) return;
- instance->history[idx].preset = preset;
- instance->history[idx].real_frequency = frequency;
- }
- uint32_t subghz_history_get_frequency(SubGhzHistory* instance, uint16_t idx) {
- furi_assert(instance);
- return instance->history[idx].real_frequency;
- }
- FuriHalSubGhzPreset subghz_history_get_preset(SubGhzHistory* instance, uint16_t idx) {
- furi_assert(instance);
- return instance->history[idx].preset;
- }
- void subghz_history_clean(SubGhzHistory* instance) {
- furi_assert(instance);
- instance->last_index_write = 0;
- instance->code_last_found = 0;
- }
- uint16_t subghz_history_get_item(SubGhzHistory* instance) {
- furi_assert(instance);
- return instance->last_index_write;
- }
- uint8_t subghz_history_get_type_protocol(SubGhzHistory* instance, uint16_t idx) {
- furi_assert(instance);
- return instance->history[idx].type_protocol;
- }
- const char* subghz_history_get_name(SubGhzHistory* instance, uint16_t idx) {
- furi_assert(instance);
- return instance->history[idx].name;
- }
- SubGhzProtocolCommonLoad* subghz_history_get_raw_data(SubGhzHistory* instance, uint16_t idx) {
- furi_assert(instance);
- instance->data.code_found = instance->history[idx].code_found;
- instance->data.code_count_bit = instance->history[idx].code_count_bit;
- instance->data.param1 = instance->history[idx].te;
- return &instance->data;
- }
- bool subghz_history_get_text_space_left(SubGhzHistory* instance, string_t output) {
- furi_assert(instance);
- if(instance->last_index_write == SUBGHZ_HISTORY_MAX) {
- if(output != NULL) string_printf(output, "Memory is FULL");
- return true;
- }
- if(output != NULL)
- string_printf(output, "%02u/%02u", instance->last_index_write, SUBGHZ_HISTORY_MAX);
- return false;
- }
- void subghz_history_get_text_item_menu(SubGhzHistory* instance, string_t output, uint16_t idx) {
- if(instance->history[idx].code_count_bit < 33) {
- string_printf(
- output,
- "%s %lX",
- instance->history[idx].name,
- (uint32_t)(instance->history[idx].code_found & 0xFFFFFFFF));
- } else {
- string_t str_buff;
- string_init(str_buff);
- if(strcmp(instance->history[idx].name, "KeeLoq") == 0) {
- string_set(str_buff, "KL ");
- string_cat(str_buff, instance->history[idx].manufacture_name);
- } else if(strcmp(instance->history[idx].name, "Star Line") == 0) {
- string_set(str_buff, "SL ");
- string_cat(str_buff, instance->history[idx].manufacture_name);
- } else {
- string_set(str_buff, instance->history[idx].name);
- }
- string_printf(
- output,
- "%s %lX%08lX",
- string_get_cstr(str_buff),
- (uint32_t)(instance->history[idx].code_found >> 32),
- (uint32_t)(instance->history[idx].code_found & 0xFFFFFFFF));
- string_clear(str_buff);
- }
- }
- bool subghz_history_add_to_history(
- SubGhzHistory* instance,
- void* context,
- uint32_t frequency,
- FuriHalSubGhzPreset preset) {
- furi_assert(instance);
- furi_assert(context);
- SubGhzProtocolCommon* protocol = context;
- if(instance->last_index_write >= SUBGHZ_HISTORY_MAX) return false;
- if((instance->code_last_found == (protocol->code_last_found & 0xFFFF0FFFFFFFFFFF)) &&
- ((millis() - instance->last_update_timestamp) < 500)) {
- instance->last_update_timestamp = millis();
- return false;
- }
- instance->code_last_found = protocol->code_last_found & 0xFFFF0FFFFFFFFFFF;
- instance->last_update_timestamp = millis();
- instance->history[instance->last_index_write].real_frequency = frequency;
- instance->history[instance->last_index_write].preset = preset;
- instance->history[instance->last_index_write].te = 0;
- instance->history[instance->last_index_write].manufacture_name = NULL;
- instance->history[instance->last_index_write].name = protocol->name;
- instance->history[instance->last_index_write].code_count_bit = protocol->code_last_count_bit;
- instance->history[instance->last_index_write].code_found = protocol->code_last_found;
- if(strcmp(protocol->name, "KeeLoq") == 0) {
- instance->history[instance->last_index_write].manufacture_name =
- subghz_protocol_keeloq_find_and_get_manufacture_name(protocol);
- } else if(strcmp(protocol->name, "Star Line") == 0) {
- instance->history[instance->last_index_write].manufacture_name =
- subghz_protocol_star_line_find_and_get_manufacture_name(protocol);
- } else if(strcmp(protocol->name, "Princeton") == 0) {
- instance->history[instance->last_index_write].te =
- subghz_protocol_princeton_get_te(protocol);
- }
- instance->history[instance->last_index_write].type_protocol = protocol->type_protocol;
- instance->last_index_write++;
- return true;
- }
|