|
@@ -16,12 +16,13 @@ bool subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
uint64_t key,
|
|
uint64_t key,
|
|
|
uint32_t bit,
|
|
uint32_t bit,
|
|
|
uint32_t frequency,
|
|
uint32_t frequency,
|
|
|
- FuriHalSubGhzPreset preset) {
|
|
|
|
|
|
|
+ const char* preset_name) {
|
|
|
furi_assert(context);
|
|
furi_assert(context);
|
|
|
SubGhz* subghz = context;
|
|
SubGhz* subghz = context;
|
|
|
|
|
|
|
|
bool res = false;
|
|
bool res = false;
|
|
|
|
|
|
|
|
|
|
+ subghz_preset_init(subghz, preset_name, frequency, NULL, 0);
|
|
|
subghz->txrx->decoder_result =
|
|
subghz->txrx->decoder_result =
|
|
|
subghz_receiver_search_decoder_base_by_name(subghz->txrx->receiver, protocol_name);
|
|
subghz_receiver_search_decoder_base_by_name(subghz->txrx->receiver, protocol_name);
|
|
|
|
|
|
|
@@ -35,7 +36,7 @@ bool subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
Stream* fff_data_stream = flipper_format_get_raw_stream(subghz->txrx->fff_data);
|
|
Stream* fff_data_stream = flipper_format_get_raw_stream(subghz->txrx->fff_data);
|
|
|
stream_clean(fff_data_stream);
|
|
stream_clean(fff_data_stream);
|
|
|
if(!subghz_protocol_decoder_base_serialize(
|
|
if(!subghz_protocol_decoder_base_serialize(
|
|
|
- subghz->txrx->decoder_result, subghz->txrx->fff_data, frequency, preset)) {
|
|
|
|
|
|
|
+ subghz->txrx->decoder_result, subghz->txrx->fff_data, subghz->txrx->preset)) {
|
|
|
FURI_LOG_E(TAG, "Unable to serialize");
|
|
FURI_LOG_E(TAG, "Unable to serialize");
|
|
|
break;
|
|
break;
|
|
|
}
|
|
}
|
|
@@ -177,12 +178,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
case SubmenuIndexPricenton:
|
|
case SubmenuIndexPricenton:
|
|
|
key = (key & 0x00FFFFF0) | 0x4; //btn 0x1, 0x2, 0x4, 0x8
|
|
key = (key & 0x00FFFFF0) | 0x4; //btn 0x1, 0x2, 0x4, 0x8
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_PRINCETON_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 24,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_PRINCETON_NAME, key, 24, 433920000, "AM650")) {
|
|
|
uint32_t te = 400;
|
|
uint32_t te = 400;
|
|
|
flipper_format_update_uint32(subghz->txrx->fff_data, "TE", (uint32_t*)&te, 1);
|
|
flipper_format_update_uint32(subghz->txrx->fff_data, "TE", (uint32_t*)&te, 1);
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
@@ -191,60 +187,35 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
case SubmenuIndexNiceFlo12bit:
|
|
case SubmenuIndexNiceFlo12bit:
|
|
|
key = (key & 0x0000FFF0) | 0x1; //btn 0x1, 0x2, 0x4
|
|
key = (key & 0x0000FFF0) | 0x1; //btn 0x1, 0x2, 0x4
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_NICE_FLO_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 12,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_NICE_FLO_NAME, key, 12, 433920000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
|
case SubmenuIndexNiceFlo24bit:
|
|
case SubmenuIndexNiceFlo24bit:
|
|
|
key = (key & 0x00FFFFF0) | 0x4; //btn 0x1, 0x2, 0x4, 0x8
|
|
key = (key & 0x00FFFFF0) | 0x4; //btn 0x1, 0x2, 0x4, 0x8
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_NICE_FLO_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 24,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_NICE_FLO_NAME, key, 24, 433920000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
|
case SubmenuIndexCAME12bit:
|
|
case SubmenuIndexCAME12bit:
|
|
|
key = (key & 0x0000FFF0) | 0x1; //btn 0x1, 0x2, 0x4
|
|
key = (key & 0x0000FFF0) | 0x1; //btn 0x1, 0x2, 0x4
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_CAME_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 12,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_CAME_NAME, key, 12, 433920000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
|
case SubmenuIndexCAME24bit:
|
|
case SubmenuIndexCAME24bit:
|
|
|
key = (key & 0x00FFFFF0) | 0x4; //btn 0x1, 0x2, 0x4, 0x8
|
|
key = (key & 0x00FFFFF0) | 0x4; //btn 0x1, 0x2, 0x4, 0x8
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_CAME_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 24,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_CAME_NAME, key, 24, 433920000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
|
case SubmenuIndexLinear_300_00:
|
|
case SubmenuIndexLinear_300_00:
|
|
|
key = (key & 0x3FF);
|
|
key = (key & 0x3FF);
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_LINEAR_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 10,
|
|
|
|
|
- 300000000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_LINEAR_NAME, key, 10, 300000000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
@@ -252,12 +223,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
key = (key & 0x0FFFFFF0);
|
|
key = (key & 0x0FFFFFF0);
|
|
|
key = 0x003FFF7200000000 | (key ^ 0xE0E0E0EE);
|
|
key = 0x003FFF7200000000 | (key ^ 0xE0E0E0EE);
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_CAME_TWEE_NAME,
|
|
|
|
|
- key,
|
|
|
|
|
- 54,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_CAME_TWEE_NAME, key, 54, 433920000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
@@ -271,18 +237,15 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
key = (key & 0x00F0FF00) | 0xF << 16 | 0x40; //btn 0xF, 0xC, 0xA, 0x6 (?)
|
|
key = (key & 0x00F0FF00) | 0xF << 16 | 0x40; //btn 0xF, 0xC, 0xA, 0x6 (?)
|
|
|
uint64_t rev_key = subghz_protocol_blocks_reverse_key(key, 24);
|
|
uint64_t rev_key = subghz_protocol_blocks_reverse_key(key, 24);
|
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
if(subghz_scene_set_type_submenu_gen_data_protocol(
|
|
|
- subghz,
|
|
|
|
|
- SUBGHZ_PROTOCOL_GATE_TX_NAME,
|
|
|
|
|
- rev_key,
|
|
|
|
|
- 24,
|
|
|
|
|
- 433920000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ subghz, SUBGHZ_PROTOCOL_GATE_TX_NAME, rev_key, 24, 433920000, "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
|
case SubmenuIndexDoorHan_433_92:
|
|
case SubmenuIndexDoorHan_433_92:
|
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_KEELOQ_NAME);
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_KEELOQ_NAME);
|
|
|
|
|
+ subghz_preset_init(
|
|
|
|
|
+ subghz, "AM650", subghz_setting_get_default_frequency(subghz->setting), NULL, 0);
|
|
|
if(subghz->txrx->transmitter) {
|
|
if(subghz->txrx->transmitter) {
|
|
|
subghz_protocol_keeloq_create_data(
|
|
subghz_protocol_keeloq_create_data(
|
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
@@ -291,8 +254,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
0x2,
|
|
0x2,
|
|
|
0x0003,
|
|
0x0003,
|
|
|
"DoorHan",
|
|
"DoorHan",
|
|
|
- subghz_setting_get_default_frequency(subghz->setting),
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async);
|
|
|
|
|
|
|
+ subghz->txrx->preset);
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
} else {
|
|
} else {
|
|
|
generated_protocol = false;
|
|
generated_protocol = false;
|
|
@@ -307,6 +269,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
case SubmenuIndexDoorHan_315_00:
|
|
case SubmenuIndexDoorHan_315_00:
|
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_KEELOQ_NAME);
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_KEELOQ_NAME);
|
|
|
|
|
+ subghz_preset_init(subghz, "AM650", 315000000, NULL, 0);
|
|
|
if(subghz->txrx->transmitter) {
|
|
if(subghz->txrx->transmitter) {
|
|
|
subghz_protocol_keeloq_create_data(
|
|
subghz_protocol_keeloq_create_data(
|
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
@@ -315,8 +278,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
0x2,
|
|
0x2,
|
|
|
0x0003,
|
|
0x0003,
|
|
|
"DoorHan",
|
|
"DoorHan",
|
|
|
- 315000000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async);
|
|
|
|
|
|
|
+ subghz->txrx->preset);
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
} else {
|
|
} else {
|
|
|
generated_protocol = false;
|
|
generated_protocol = false;
|
|
@@ -338,7 +300,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
(uint64_t)key << 32 | 0xE6000000,
|
|
(uint64_t)key << 32 | 0xE6000000,
|
|
|
42,
|
|
42,
|
|
|
315000000,
|
|
315000000,
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
@@ -352,13 +314,14 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
(uint64_t)key << 32 | 0xE6000000,
|
|
(uint64_t)key << 32 | 0xE6000000,
|
|
|
42,
|
|
42,
|
|
|
390000000,
|
|
390000000,
|
|
|
- FuriHalSubGhzPresetOok650Async)) {
|
|
|
|
|
|
|
+ "AM650")) {
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
}
|
|
}
|
|
|
break;
|
|
break;
|
|
|
case SubmenuIndexSecPlus_v2_310_00:
|
|
case SubmenuIndexSecPlus_v2_310_00:
|
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_SECPLUS_V2_NAME);
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_SECPLUS_V2_NAME);
|
|
|
|
|
+ subghz_preset_init(subghz, "AM650", 310000000, NULL, 0);
|
|
|
if(subghz->txrx->transmitter) {
|
|
if(subghz->txrx->transmitter) {
|
|
|
subghz_protocol_secplus_v2_create_data(
|
|
subghz_protocol_secplus_v2_create_data(
|
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
@@ -366,8 +329,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
key,
|
|
key,
|
|
|
0x68,
|
|
0x68,
|
|
|
0xE500000,
|
|
0xE500000,
|
|
|
- 310000000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async);
|
|
|
|
|
|
|
+ subghz->txrx->preset);
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
} else {
|
|
} else {
|
|
|
generated_protocol = false;
|
|
generated_protocol = false;
|
|
@@ -377,6 +339,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
case SubmenuIndexSecPlus_v2_315_00:
|
|
case SubmenuIndexSecPlus_v2_315_00:
|
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_SECPLUS_V2_NAME);
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_SECPLUS_V2_NAME);
|
|
|
|
|
+ subghz_preset_init(subghz, "AM650", 315000000, NULL, 0);
|
|
|
if(subghz->txrx->transmitter) {
|
|
if(subghz->txrx->transmitter) {
|
|
|
subghz_protocol_secplus_v2_create_data(
|
|
subghz_protocol_secplus_v2_create_data(
|
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
@@ -384,8 +347,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
key,
|
|
key,
|
|
|
0x68,
|
|
0x68,
|
|
|
0xE500000,
|
|
0xE500000,
|
|
|
- 315000000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async);
|
|
|
|
|
|
|
+ subghz->txrx->preset);
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
} else {
|
|
} else {
|
|
|
generated_protocol = false;
|
|
generated_protocol = false;
|
|
@@ -395,6 +357,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
case SubmenuIndexSecPlus_v2_390_00:
|
|
case SubmenuIndexSecPlus_v2_390_00:
|
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
subghz->txrx->transmitter = subghz_transmitter_alloc_init(
|
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_SECPLUS_V2_NAME);
|
|
subghz->txrx->environment, SUBGHZ_PROTOCOL_SECPLUS_V2_NAME);
|
|
|
|
|
+ subghz_preset_init(subghz, "AM650", 390000000, NULL, 0);
|
|
|
if(subghz->txrx->transmitter) {
|
|
if(subghz->txrx->transmitter) {
|
|
|
subghz_protocol_secplus_v2_create_data(
|
|
subghz_protocol_secplus_v2_create_data(
|
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
subghz_transmitter_get_protocol_instance(subghz->txrx->transmitter),
|
|
@@ -402,8 +365,7 @@ bool subghz_scene_set_type_on_event(void* context, SceneManagerEvent event) {
|
|
|
key,
|
|
key,
|
|
|
0x68,
|
|
0x68,
|
|
|
0xE500000,
|
|
0xE500000,
|
|
|
- 390000000,
|
|
|
|
|
- FuriHalSubGhzPresetOok650Async);
|
|
|
|
|
|
|
+ subghz->txrx->preset);
|
|
|
generated_protocol = true;
|
|
generated_protocol = true;
|
|
|
} else {
|
|
} else {
|
|
|
generated_protocol = false;
|
|
generated_protocol = false;
|