mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-11-30 16:29:12 +00:00
1f4020240b
Fix critical issue with keeloq manufacturer name random change. Now you can emulate any manufacturer system with proper key handling. Came Atomo parcel counter increasing and emulation. Beta test (need rework signal header and make button counter cycle array for encoder).
157 lines
5.2 KiB
C
157 lines
5.2 KiB
C
#pragma once
|
|
|
|
#include "base.h"
|
|
|
|
#define SUBGHZ_PROTOCOL_KEELOQ_NAME "KeeLoq"
|
|
|
|
typedef struct SubGhzProtocolDecoderKeeloq SubGhzProtocolDecoderKeeloq;
|
|
typedef struct SubGhzProtocolEncoderKeeloq SubGhzProtocolEncoderKeeloq;
|
|
|
|
extern const SubGhzProtocolDecoder subghz_protocol_keeloq_decoder;
|
|
extern const SubGhzProtocolEncoder subghz_protocol_keeloq_encoder;
|
|
extern const SubGhzProtocol subghz_protocol_keeloq;
|
|
|
|
void keeloq_reset_mfname();
|
|
|
|
/**
|
|
* Allocate SubGhzProtocolEncoderKeeloq.
|
|
* @param environment Pointer to a SubGhzEnvironment instance
|
|
* @return SubGhzProtocolEncoderKeeloq* pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
*/
|
|
void* subghz_protocol_encoder_keeloq_alloc(SubGhzEnvironment* environment);
|
|
|
|
/**
|
|
* Free SubGhzProtocolEncoderKeeloq.
|
|
* @param context Pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
*/
|
|
void subghz_protocol_encoder_keeloq_free(void* context);
|
|
|
|
/**
|
|
* Key generation from simple data.
|
|
* @param context Pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
* @param flipper_format Pointer to a FlipperFormat instance
|
|
* @param serial Serial number, 28 bit
|
|
* @param btn Button number, 4 bit
|
|
* @param cnt Counter value, 16 bit
|
|
* @param manufacture_name Name of manufacturer's key
|
|
* @param frequency Transmission frequency, Hz
|
|
* @param preset Modulation, FuriHalSubGhzPreset
|
|
* @return true On success
|
|
*/
|
|
bool subghz_protocol_keeloq_create_data(
|
|
void* context,
|
|
FlipperFormat* flipper_format,
|
|
uint32_t serial,
|
|
uint8_t btn,
|
|
uint16_t cnt,
|
|
const char* manufacture_name,
|
|
uint32_t frequency,
|
|
FuriHalSubGhzPreset preset);
|
|
|
|
/**
|
|
* Key generation for BFT.
|
|
* @param context Pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
* @param flipper_format Pointer to a FlipperFormat instance
|
|
* @param serial Serial number, 28 bit
|
|
* @param btn Button number, 4 bit
|
|
* @param cnt Counter value, 16 bit
|
|
* @param seed Seed value, 32 bit
|
|
* @param manufacture_name Name of manufacturer's key
|
|
* @param frequency Transmission frequency, Hz
|
|
* @param preset Modulation, FuriHalSubGhzPreset
|
|
* @return true On success
|
|
*/
|
|
bool subghz_protocol_keeloq_bft_create_data(
|
|
void* context,
|
|
FlipperFormat* flipper_format,
|
|
uint32_t serial,
|
|
uint8_t btn,
|
|
uint16_t cnt,
|
|
uint32_t seed,
|
|
const char* manufacture_name,
|
|
uint32_t frequency,
|
|
FuriHalSubGhzPreset preset);
|
|
|
|
/**
|
|
* Deserialize and generating an upload to send.
|
|
* @param context Pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
* @param flipper_format Pointer to a FlipperFormat instance
|
|
* @return true On success
|
|
*/
|
|
bool subghz_protocol_encoder_keeloq_deserialize(void* context, FlipperFormat* flipper_format);
|
|
|
|
/**
|
|
* Forced transmission stop.
|
|
* @param context Pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
*/
|
|
void subghz_protocol_encoder_keeloq_stop(void* context);
|
|
|
|
/**
|
|
* Getting the level and duration of the upload to be loaded into DMA.
|
|
* @param context Pointer to a SubGhzProtocolEncoderKeeloq instance
|
|
* @return LevelDuration
|
|
*/
|
|
LevelDuration subghz_protocol_encoder_keeloq_yield(void* context);
|
|
|
|
/**
|
|
* Allocate SubGhzProtocolDecoderKeeloq.
|
|
* @param environment Pointer to a SubGhzEnvironment instance
|
|
* @return SubGhzProtocolDecoderKeeloq* pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
*/
|
|
void* subghz_protocol_decoder_keeloq_alloc(SubGhzEnvironment* environment);
|
|
|
|
/**
|
|
* Free SubGhzProtocolDecoderKeeloq.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
*/
|
|
void subghz_protocol_decoder_keeloq_free(void* context);
|
|
|
|
/**
|
|
* Reset decoder SubGhzProtocolDecoderKeeloq.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
*/
|
|
void subghz_protocol_decoder_keeloq_reset(void* context);
|
|
|
|
/**
|
|
* Parse a raw sequence of levels and durations received from the air.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
* @param level Signal level true-high false-low
|
|
* @param duration Duration of this level in, us
|
|
*/
|
|
void subghz_protocol_decoder_keeloq_feed(void* context, bool level, uint32_t duration);
|
|
|
|
/**
|
|
* Getting the hash sum of the last randomly received parcel.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
* @return hash Hash sum
|
|
*/
|
|
uint8_t subghz_protocol_decoder_keeloq_get_hash_data(void* context);
|
|
|
|
/**
|
|
* Serialize data SubGhzProtocolDecoderKeeloq.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
* @param flipper_format Pointer to a FlipperFormat instance
|
|
* @param frequency The frequency at which the signal was received, Hz
|
|
* @param preset The modulation on which the signal was received, FuriHalSubGhzPreset
|
|
* @return true On success
|
|
*/
|
|
bool subghz_protocol_decoder_keeloq_serialize(
|
|
void* context,
|
|
FlipperFormat* flipper_format,
|
|
uint32_t frequency,
|
|
FuriHalSubGhzPreset preset);
|
|
|
|
/**
|
|
* Deserialize data SubGhzProtocolDecoderKeeloq.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
* @param flipper_format Pointer to a FlipperFormat instance
|
|
* @return true On success
|
|
*/
|
|
bool subghz_protocol_decoder_keeloq_deserialize(void* context, FlipperFormat* flipper_format);
|
|
|
|
/**
|
|
* Getting a textual representation of the received data.
|
|
* @param context Pointer to a SubGhzProtocolDecoderKeeloq instance
|
|
* @param output Resulting text
|
|
*/
|
|
void subghz_protocol_decoder_keeloq_get_string(void* context, string_t output);
|