 4418e73b26
			
		
	
	
		4418e73b26
		
			
		
	
	
	
	
		
			
			* ToolBox: add manchester-decoder and manchester-encoder * SubGhz: add new FM config cc1101 * Subghz: add protocol Kia * SubGhz: fix receiving the last packet Nero Radio * SubGhz: app protocol CAME Twin (TW2EE/TW4EE) * SubGhz: add protocol CAME Atomo (AT03EV/ AT04EV) * F7: sync with F6 * SubGhz: add frequency analyzer * SubGhz: remove space from file name * SubGhz: frequency analyzer add filter and fix view * [FL-1939] GubGhz: Frequency analyzer redesign * SubGhz: fix incorrect subghz api call sequence in frequency analyzer worker Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
		
			
				
	
	
		
			278 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			278 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
 | |
| #include "subghz_parser.h"
 | |
| #include "protocols/subghz_protocol_came.h"
 | |
| #include "protocols/subghz_protocol_came_twee.h"
 | |
| #include "protocols/subghz_protocol_came_atomo.h"
 | |
| #include "protocols/subghz_protocol_cfm.h"
 | |
| #include "protocols/subghz_protocol_keeloq.h"
 | |
| #include "protocols/subghz_protocol_nice_flo.h"
 | |
| #include "protocols/subghz_protocol_nice_flor_s.h"
 | |
| #include "protocols/subghz_protocol_princeton.h"
 | |
| #include "protocols/subghz_protocol_gate_tx.h"
 | |
| #include "protocols/subghz_protocol_ido.h"
 | |
| #include "protocols/subghz_protocol_faac_slh.h"
 | |
| #include "protocols/subghz_protocol_nero_sketch.h"
 | |
| #include "protocols/subghz_protocol_star_line.h"
 | |
| #include "protocols/subghz_protocol_nero_radio.h"
 | |
| #include "protocols/subghz_protocol_scher_khan.h"
 | |
| #include "protocols/subghz_protocol_kia.h"
 | |
| 
 | |
| #include "subghz_keystore.h"
 | |
| 
 | |
| #include <furi.h>
 | |
| #include <m-string.h>
 | |
| 
 | |
| typedef enum {
 | |
|     SubGhzProtocolTypeCame,
 | |
|     SubGhzProtocolTypeCameTwee,
 | |
|     SubGhzProtocolTypeCameAtomo,
 | |
|     SubGhzProtocolTypeKeeloq,
 | |
|     SubGhzProtocolTypeNiceFlo,
 | |
|     SubGhzProtocolTypeNiceFlorS,
 | |
|     SubGhzProtocolTypePrinceton,
 | |
|     SubGhzProtocolTypeGateTX,
 | |
|     SubGhzProtocolTypeIDo,
 | |
|     SubGhzProtocolTypeFaacSLH,
 | |
|     SubGhzProtocolTypeNeroSketch,
 | |
|     SubGhzProtocolTypeStarLine,
 | |
|     SubGhzProtocolTypeNeroRadio,
 | |
|     SubGhzProtocolTypeScherKhan,
 | |
|     SubGhzProtocolTypeKIA,
 | |
| 
 | |
|     SubGhzProtocolTypeMax,
 | |
| } SubGhzProtocolType;
 | |
| 
 | |
| struct SubGhzParser {
 | |
|     SubGhzKeystore* keystore;
 | |
| 
 | |
|     SubGhzProtocolCommon* protocols[SubGhzProtocolTypeMax];
 | |
| 
 | |
|     SubGhzProtocolTextCallback text_callback;
 | |
|     void* text_callback_context;
 | |
|     SubGhzProtocolCommonCallbackDump parser_callback;
 | |
|     void* parser_callback_context;
 | |
| };
 | |
| 
 | |
| static void subghz_parser_text_rx_callback(SubGhzProtocolCommon* parser, void* context) {
 | |
|     SubGhzParser* instance = context;
 | |
| 
 | |
|     string_t output;
 | |
|     string_init(output);
 | |
|     subghz_protocol_common_to_str((SubGhzProtocolCommon*)parser, output);
 | |
|     if(instance->text_callback) {
 | |
|         instance->text_callback(output, instance->text_callback_context);
 | |
|     } else {
 | |
|         printf("%s", string_get_cstr(output));
 | |
|     }
 | |
|     string_clear(output);
 | |
| }
 | |
| 
 | |
| static void subghz_parser_parser_rx_callback(SubGhzProtocolCommon* parser, void* context) {
 | |
|     SubGhzParser* instance = context;
 | |
|     if(instance->parser_callback) {
 | |
|         instance->parser_callback(parser, instance->parser_callback_context);
 | |
|     }
 | |
| }
 | |
| 
 | |
| SubGhzParser* subghz_parser_alloc() {
 | |
|     SubGhzParser* instance = furi_alloc(sizeof(SubGhzParser));
 | |
| 
 | |
|     instance->keystore = subghz_keystore_alloc();
 | |
| 
 | |
|     instance->protocols[SubGhzProtocolTypeCame] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_came_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeCameTwee] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_came_twee_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeCameAtomo] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_came_atomo_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeKeeloq] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_keeloq_alloc(instance->keystore);
 | |
|     instance->protocols[SubGhzProtocolTypePrinceton] =
 | |
|         (SubGhzProtocolCommon*)subghz_decoder_princeton_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeNiceFlo] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_nice_flo_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeNiceFlorS] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_nice_flor_s_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeGateTX] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_gate_tx_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeIDo] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_ido_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeFaacSLH] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_faac_slh_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeNeroSketch] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_nero_sketch_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeStarLine] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_star_line_alloc(instance->keystore);
 | |
|     instance->protocols[SubGhzProtocolTypeNeroRadio] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_nero_radio_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeScherKhan] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_scher_khan_alloc();
 | |
|     instance->protocols[SubGhzProtocolTypeKIA] =
 | |
|         (SubGhzProtocolCommon*)subghz_protocol_kia_alloc();
 | |
| 
 | |
|     return instance;
 | |
| }
 | |
| 
 | |
| void subghz_parser_free(SubGhzParser* instance) {
 | |
|     furi_assert(instance);
 | |
| 
 | |
|     subghz_protocol_came_free((SubGhzProtocolCame*)instance->protocols[SubGhzProtocolTypeCame]);
 | |
|     subghz_protocol_came_twee_free(
 | |
|         (SubGhzProtocolCameTwee*)instance->protocols[SubGhzProtocolTypeCameTwee]);
 | |
|     subghz_protocol_came_atomo_free(
 | |
|         (SubGhzProtocolCameAtomo*)instance->protocols[SubGhzProtocolTypeCameAtomo]);
 | |
|     subghz_protocol_keeloq_free(
 | |
|         (SubGhzProtocolKeeloq*)instance->protocols[SubGhzProtocolTypeKeeloq]);
 | |
|     subghz_decoder_princeton_free(
 | |
|         (SubGhzDecoderPrinceton*)instance->protocols[SubGhzProtocolTypePrinceton]);
 | |
|     subghz_protocol_nice_flo_free(
 | |
|         (SubGhzProtocolNiceFlo*)instance->protocols[SubGhzProtocolTypeNiceFlo]);
 | |
|     subghz_protocol_nice_flor_s_free(
 | |
|         (SubGhzProtocolNiceFlorS*)instance->protocols[SubGhzProtocolTypeNiceFlorS]);
 | |
|     subghz_protocol_gate_tx_free(
 | |
|         (SubGhzProtocolGateTX*)instance->protocols[SubGhzProtocolTypeGateTX]);
 | |
|     subghz_protocol_ido_free((SubGhzProtocolIDo*)instance->protocols[SubGhzProtocolTypeIDo]);
 | |
|     subghz_protocol_faac_slh_free(
 | |
|         (SubGhzProtocolFaacSLH*)instance->protocols[SubGhzProtocolTypeFaacSLH]);
 | |
|     subghz_protocol_nero_sketch_free(
 | |
|         (SubGhzProtocolNeroSketch*)instance->protocols[SubGhzProtocolTypeNeroSketch]);
 | |
|     subghz_protocol_star_line_free(
 | |
|         (SubGhzProtocolStarLine*)instance->protocols[SubGhzProtocolTypeStarLine]);
 | |
|     subghz_protocol_nero_radio_free(
 | |
|         (SubGhzProtocolNeroRadio*)instance->protocols[SubGhzProtocolTypeNeroRadio]);
 | |
|     subghz_protocol_scher_khan_free(
 | |
|         (SubGhzProtocolScherKhan*)instance->protocols[SubGhzProtocolTypeScherKhan]);
 | |
|     subghz_protocol_kia_free((SubGhzProtocolKIA*)instance->protocols[SubGhzProtocolTypeKIA]);
 | |
| 
 | |
|     subghz_keystore_free(instance->keystore);
 | |
| 
 | |
|     free(instance);
 | |
| }
 | |
| 
 | |
| SubGhzProtocolCommon* subghz_parser_get_by_name(SubGhzParser* instance, const char* name) {
 | |
|     SubGhzProtocolCommon* result = NULL;
 | |
| 
 | |
|     for(size_t i = 0; i < SubGhzProtocolTypeMax; i++) {
 | |
|         if(strcmp(instance->protocols[i]->name, name) == 0) {
 | |
|             result = instance->protocols[i];
 | |
|             break;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| void subghz_parser_enable_dump_text(
 | |
|     SubGhzParser* instance,
 | |
|     SubGhzProtocolTextCallback callback,
 | |
|     void* context) {
 | |
|     furi_assert(instance);
 | |
| 
 | |
|     for(size_t i = 0; i < SubGhzProtocolTypeMax; i++) {
 | |
|         subghz_protocol_common_set_callback(
 | |
|             instance->protocols[i], subghz_parser_text_rx_callback, instance);
 | |
|     }
 | |
| 
 | |
|     instance->text_callback = callback;
 | |
|     instance->text_callback_context = context;
 | |
| }
 | |
| 
 | |
| void subghz_parser_enable_dump(
 | |
|     SubGhzParser* instance,
 | |
|     SubGhzProtocolCommonCallbackDump callback,
 | |
|     void* context) {
 | |
|     furi_assert(instance);
 | |
| 
 | |
|     for(size_t i = 0; i < SubGhzProtocolTypeMax; i++) {
 | |
|         subghz_protocol_common_set_callback(
 | |
|             instance->protocols[i], subghz_parser_parser_rx_callback, instance);
 | |
|     }
 | |
| 
 | |
|     instance->parser_callback = callback;
 | |
|     instance->parser_callback_context = context;
 | |
| }
 | |
| 
 | |
| void subghz_parser_load_nice_flor_s_file(SubGhzParser* instance, const char* file_name) {
 | |
|     subghz_protocol_nice_flor_s_name_file(
 | |
|         (SubGhzProtocolNiceFlorS*)instance->protocols[SubGhzProtocolTypeNiceFlorS], file_name);
 | |
| }
 | |
| 
 | |
| void subghz_parser_load_keeloq_file(SubGhzParser* instance, const char* file_name) {
 | |
|     subghz_keystore_load(instance->keystore, file_name);
 | |
| }
 | |
| 
 | |
| void subghz_parser_reset(SubGhzParser* instance) {
 | |
|     subghz_protocol_came_reset((SubGhzProtocolCame*)instance->protocols[SubGhzProtocolTypeCame]);
 | |
|     subghz_protocol_came_twee_reset(
 | |
|         (SubGhzProtocolCameTwee*)instance->protocols[SubGhzProtocolTypeCameTwee]);
 | |
|     subghz_protocol_came_atomo_reset(
 | |
|         (SubGhzProtocolCameAtomo*)instance->protocols[SubGhzProtocolTypeCameAtomo]);
 | |
|     subghz_protocol_keeloq_reset(
 | |
|         (SubGhzProtocolKeeloq*)instance->protocols[SubGhzProtocolTypeKeeloq]);
 | |
|     subghz_decoder_princeton_reset(
 | |
|         (SubGhzDecoderPrinceton*)instance->protocols[SubGhzProtocolTypePrinceton]);
 | |
|     subghz_protocol_nice_flo_reset(
 | |
|         (SubGhzProtocolNiceFlo*)instance->protocols[SubGhzProtocolTypeNiceFlo]);
 | |
|     subghz_protocol_nice_flor_s_reset(
 | |
|         (SubGhzProtocolNiceFlorS*)instance->protocols[SubGhzProtocolTypeNiceFlorS]);
 | |
|     subghz_protocol_gate_tx_reset(
 | |
|         (SubGhzProtocolGateTX*)instance->protocols[SubGhzProtocolTypeGateTX]);
 | |
|     subghz_protocol_ido_reset((SubGhzProtocolIDo*)instance->protocols[SubGhzProtocolTypeIDo]);
 | |
|     subghz_protocol_faac_slh_reset(
 | |
|         (SubGhzProtocolFaacSLH*)instance->protocols[SubGhzProtocolTypeFaacSLH]);
 | |
|     subghz_protocol_nero_sketch_reset(
 | |
|         (SubGhzProtocolNeroSketch*)instance->protocols[SubGhzProtocolTypeNeroSketch]);
 | |
|     subghz_protocol_star_line_reset(
 | |
|         (SubGhzProtocolStarLine*)instance->protocols[SubGhzProtocolTypeStarLine]);
 | |
|     subghz_protocol_nero_radio_reset(
 | |
|         (SubGhzProtocolNeroRadio*)instance->protocols[SubGhzProtocolTypeNeroRadio]);
 | |
|     subghz_protocol_scher_khan_reset(
 | |
|         (SubGhzProtocolScherKhan*)instance->protocols[SubGhzProtocolTypeScherKhan]);
 | |
|     subghz_protocol_kia_reset((SubGhzProtocolKIA*)instance->protocols[SubGhzProtocolTypeKIA]);
 | |
| }
 | |
| 
 | |
| void subghz_parser_parse(SubGhzParser* instance, bool level, uint32_t duration) {
 | |
|     subghz_protocol_came_parse(
 | |
|         (SubGhzProtocolCame*)instance->protocols[SubGhzProtocolTypeCame], level, duration);
 | |
|     subghz_protocol_came_twee_parse(
 | |
|         (SubGhzProtocolCameTwee*)instance->protocols[SubGhzProtocolTypeCameTwee], level, duration);
 | |
|     subghz_protocol_came_atomo_parse(
 | |
|         (SubGhzProtocolCameAtomo*)instance->protocols[SubGhzProtocolTypeCameAtomo],
 | |
|         level,
 | |
|         duration);
 | |
|     subghz_protocol_keeloq_parse(
 | |
|         (SubGhzProtocolKeeloq*)instance->protocols[SubGhzProtocolTypeKeeloq], level, duration);
 | |
|     subghz_decoder_princeton_parse(
 | |
|         (SubGhzDecoderPrinceton*)instance->protocols[SubGhzProtocolTypePrinceton],
 | |
|         level,
 | |
|         duration);
 | |
|     subghz_protocol_nice_flo_parse(
 | |
|         (SubGhzProtocolNiceFlo*)instance->protocols[SubGhzProtocolTypeNiceFlo], level, duration);
 | |
|     subghz_protocol_nice_flor_s_parse(
 | |
|         (SubGhzProtocolNiceFlorS*)instance->protocols[SubGhzProtocolTypeNiceFlorS],
 | |
|         level,
 | |
|         duration);
 | |
|     subghz_protocol_gate_tx_parse(
 | |
|         (SubGhzProtocolGateTX*)instance->protocols[SubGhzProtocolTypeGateTX], level, duration);
 | |
|     subghz_protocol_ido_parse(
 | |
|         (SubGhzProtocolIDo*)instance->protocols[SubGhzProtocolTypeIDo], level, duration);
 | |
|     subghz_protocol_faac_slh_parse(
 | |
|         (SubGhzProtocolFaacSLH*)instance->protocols[SubGhzProtocolTypeFaacSLH], level, duration);
 | |
|     subghz_protocol_nero_sketch_parse(
 | |
|         (SubGhzProtocolNeroSketch*)instance->protocols[SubGhzProtocolTypeNeroSketch],
 | |
|         level,
 | |
|         duration);
 | |
|     subghz_protocol_star_line_parse(
 | |
|         (SubGhzProtocolStarLine*)instance->protocols[SubGhzProtocolTypeStarLine], level, duration);
 | |
|     subghz_protocol_nero_radio_parse(
 | |
|         (SubGhzProtocolNeroRadio*)instance->protocols[SubGhzProtocolTypeNeroRadio],
 | |
|         level,
 | |
|         duration);
 | |
|     subghz_protocol_scher_khan_parse(
 | |
|         (SubGhzProtocolScherKhan*)instance->protocols[SubGhzProtocolTypeScherKhan],
 | |
|         level,
 | |
|         duration);
 | |
|     subghz_protocol_kia_parse(
 | |
|         (SubGhzProtocolKIA*)instance->protocols[SubGhzProtocolTypeKIA], level, duration);
 | |
| }
 |