mirror of
https://github.com/Next-Flip/Momentum-Firmware.git
synced 2026-04-24 03:29:57 -07:00
Merge branch 'dev' of https://github.com/DarkFlippers/unleashed-firmware into xfw-dev
This commit is contained in:
@@ -247,6 +247,11 @@ static void infrared_free(Infrared* infrared) {
|
|||||||
|
|
||||||
furi_string_free(infrared->file_path);
|
furi_string_free(infrared->file_path);
|
||||||
|
|
||||||
|
// Disable 5v power if was enabled for external module
|
||||||
|
if(furi_hal_power_is_otg_enabled()) {
|
||||||
|
furi_hal_power_disable_otg();
|
||||||
|
}
|
||||||
|
|
||||||
free(infrared);
|
free(infrared);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -480,10 +485,6 @@ int32_t infrared_app(char* p) {
|
|||||||
|
|
||||||
view_dispatcher_run(infrared->view_dispatcher);
|
view_dispatcher_run(infrared->view_dispatcher);
|
||||||
|
|
||||||
if(furi_hal_power_is_otg_enabled()) {
|
|
||||||
furi_hal_power_disable_otg();
|
|
||||||
}
|
|
||||||
|
|
||||||
infrared_free(infrared);
|
infrared_free(infrared);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,10 +3,10 @@
|
|||||||
enum SubmenuIndex {
|
enum SubmenuIndex {
|
||||||
SubmenuIndexUniversalRemotes,
|
SubmenuIndexUniversalRemotes,
|
||||||
SubmenuIndexLearnNewRemote,
|
SubmenuIndexLearnNewRemote,
|
||||||
SubmenuIndexLearnNewRemoteRaw,
|
|
||||||
SubmenuIndexSavedRemotes,
|
SubmenuIndexSavedRemotes,
|
||||||
SubmenuIndexDebug,
|
SubmenuIndexDebugSettings,
|
||||||
SubmenuIndexDebugSettings
|
SubmenuIndexLearnNewRemoteRaw,
|
||||||
|
SubmenuIndexDebug
|
||||||
};
|
};
|
||||||
|
|
||||||
static void infrared_scene_start_submenu_callback(void* context, uint32_t index) {
|
static void infrared_scene_start_submenu_callback(void* context, uint32_t index) {
|
||||||
@@ -37,6 +37,12 @@ void infrared_scene_start_on_enter(void* context) {
|
|||||||
SubmenuIndexSavedRemotes,
|
SubmenuIndexSavedRemotes,
|
||||||
infrared_scene_start_submenu_callback,
|
infrared_scene_start_submenu_callback,
|
||||||
infrared);
|
infrared);
|
||||||
|
submenu_add_item(
|
||||||
|
submenu,
|
||||||
|
"GPIO Settings",
|
||||||
|
SubmenuIndexDebugSettings,
|
||||||
|
infrared_scene_start_submenu_callback,
|
||||||
|
infrared);
|
||||||
|
|
||||||
submenu_add_lockable_item(
|
submenu_add_lockable_item(
|
||||||
submenu,
|
submenu,
|
||||||
@@ -54,14 +60,6 @@ void infrared_scene_start_on_enter(void* context) {
|
|||||||
infrared,
|
infrared,
|
||||||
!infrared->app_state.is_debug_enabled,
|
!infrared->app_state.is_debug_enabled,
|
||||||
"Enable\nDebug!");
|
"Enable\nDebug!");
|
||||||
submenu_add_lockable_item(
|
|
||||||
submenu,
|
|
||||||
"Debug Settings",
|
|
||||||
SubmenuIndexDebugSettings,
|
|
||||||
infrared_scene_start_submenu_callback,
|
|
||||||
infrared,
|
|
||||||
!infrared->app_state.is_debug_enabled,
|
|
||||||
"Enable\nDebug!");
|
|
||||||
|
|
||||||
const uint32_t submenu_index =
|
const uint32_t submenu_index =
|
||||||
scene_manager_get_scene_state(scene_manager, InfraredSceneStart);
|
scene_manager_get_scene_state(scene_manager, InfraredSceneStart);
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ ADD_SCENE(subghz, set_fix, SetFix)
|
|||||||
ADD_SCENE(subghz, set_cnt, SetCnt)
|
ADD_SCENE(subghz, set_cnt, SetCnt)
|
||||||
ADD_SCENE(subghz, set_seed, SetSeed)
|
ADD_SCENE(subghz, set_seed, SetSeed)
|
||||||
ADD_SCENE(subghz, frequency_analyzer, FrequencyAnalyzer)
|
ADD_SCENE(subghz, frequency_analyzer, FrequencyAnalyzer)
|
||||||
ADD_SCENE(subghz, ext_module_settings, ExtModuleSettings)
|
ADD_SCENE(subghz, radio_settings, ExtModuleSettings)
|
||||||
ADD_SCENE(subghz, read_raw, ReadRAW)
|
ADD_SCENE(subghz, read_raw, ReadRAW)
|
||||||
ADD_SCENE(subghz, more_raw, MoreRAW)
|
ADD_SCENE(subghz, more_raw, MoreRAW)
|
||||||
ADD_SCENE(subghz, decode_raw, DecodeRAW)
|
ADD_SCENE(subghz, decode_raw, DecodeRAW)
|
||||||
|
|||||||
@@ -1,12 +1,6 @@
|
|||||||
#include "../subghz_i.h"
|
#include "../subghz_i.h"
|
||||||
#include "../helpers/subghz_custom_event.h"
|
#include "../helpers/subghz_custom_event.h"
|
||||||
|
|
||||||
static uint8_t value_index_exm;
|
|
||||||
static uint8_t value_index_dpin;
|
|
||||||
static uint8_t value_index_cnt;
|
|
||||||
static uint8_t value_index_pwr;
|
|
||||||
static uint8_t value_index_time;
|
|
||||||
|
|
||||||
#define EXT_MODULES_COUNT (sizeof(radio_modules_variables_text) / sizeof(char* const))
|
#define EXT_MODULES_COUNT (sizeof(radio_modules_variables_text) / sizeof(char* const))
|
||||||
const char* const radio_modules_variables_text[] = {
|
const char* const radio_modules_variables_text[] = {
|
||||||
"Internal",
|
"Internal",
|
||||||
@@ -31,19 +25,16 @@ const char* const debug_pin_text[DEBUG_P_COUNT] = {
|
|||||||
"17(1W)",
|
"17(1W)",
|
||||||
};
|
};
|
||||||
|
|
||||||
#define DEBUG_COUNTER_COUNT 6
|
#define DEBUG_COUNTER_COUNT 3
|
||||||
const char* const debug_counter_text[DEBUG_COUNTER_COUNT] = {
|
const char* const debug_counter_text[DEBUG_COUNTER_COUNT] = {
|
||||||
"+1",
|
"+1",
|
||||||
"+2",
|
"+2",
|
||||||
"+3",
|
"+3",
|
||||||
"+4",
|
|
||||||
"+5",
|
|
||||||
"+10",
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static void subghz_scene_ext_module_changed(VariableItem* item) {
|
static void subghz_scene_ext_module_changed(VariableItem* item) {
|
||||||
SubGhz* subghz = variable_item_get_context(item);
|
SubGhz* subghz = variable_item_get_context(item);
|
||||||
value_index_exm = variable_item_get_current_value_index(item);
|
uint8_t value_index_exm = variable_item_get_current_value_index(item);
|
||||||
|
|
||||||
variable_item_set_current_value_text(item, radio_modules_variables_text[value_index_exm]);
|
variable_item_set_current_value_text(item, radio_modules_variables_text[value_index_exm]);
|
||||||
|
|
||||||
@@ -80,15 +71,6 @@ static void subghz_scene_receiver_config_set_debug_counter(VariableItem* item) {
|
|||||||
case 2:
|
case 2:
|
||||||
furi_hal_subghz_set_rolling_counter_mult(3);
|
furi_hal_subghz_set_rolling_counter_mult(3);
|
||||||
break;
|
break;
|
||||||
case 3:
|
|
||||||
furi_hal_subghz_set_rolling_counter_mult(4);
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
furi_hal_subghz_set_rolling_counter_mult(5);
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
furi_hal_subghz_set_rolling_counter_mult(10);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -122,20 +104,21 @@ static void subghz_scene_receiver_config_set_timestamp_file_names(VariableItem*
|
|||||||
subghz_last_settings_save(subghz->last_settings);
|
subghz_last_settings_save(subghz->last_settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
void subghz_scene_ext_module_settings_on_enter(void* context) {
|
void subghz_scene_radio_settings_on_enter(void* context) {
|
||||||
SubGhz* subghz = context;
|
SubGhz* subghz = context;
|
||||||
|
|
||||||
VariableItemList* variable_item_list = subghz->variable_item_list;
|
VariableItemList* variable_item_list = subghz->variable_item_list;
|
||||||
|
uint8_t value_index;
|
||||||
|
|
||||||
value_index_exm = furi_hal_subghz.radio_type;
|
value_index = furi_hal_subghz.radio_type;
|
||||||
VariableItem* item = variable_item_list_add(
|
VariableItem* item = variable_item_list_add(
|
||||||
variable_item_list, "Module", EXT_MODULES_COUNT, subghz_scene_ext_module_changed, subghz);
|
variable_item_list, "Module", EXT_MODULES_COUNT, subghz_scene_ext_module_changed, subghz);
|
||||||
|
|
||||||
variable_item_list_set_enter_callback(
|
variable_item_list_set_enter_callback(
|
||||||
variable_item_list, subghz_ext_module_start_var_list_enter_callback, subghz);
|
variable_item_list, subghz_ext_module_start_var_list_enter_callback, subghz);
|
||||||
|
|
||||||
variable_item_set_current_value_index(item, value_index_exm);
|
variable_item_set_current_value_index(item, value_index);
|
||||||
variable_item_set_current_value_text(item, radio_modules_variables_text[value_index_exm]);
|
variable_item_set_current_value_text(item, radio_modules_variables_text[value_index]);
|
||||||
|
|
||||||
item = variable_item_list_add(
|
item = variable_item_list_add(
|
||||||
subghz->variable_item_list,
|
subghz->variable_item_list,
|
||||||
@@ -143,9 +126,9 @@ void subghz_scene_ext_module_settings_on_enter(void* context) {
|
|||||||
EXT_MOD_POWER_COUNT,
|
EXT_MOD_POWER_COUNT,
|
||||||
subghz_scene_receiver_config_set_ext_mod_power,
|
subghz_scene_receiver_config_set_ext_mod_power,
|
||||||
subghz);
|
subghz);
|
||||||
value_index_pwr = furi_hal_subghz_get_external_power_disable();
|
value_index = furi_hal_subghz_get_external_power_disable();
|
||||||
variable_item_set_current_value_index(item, value_index_pwr);
|
variable_item_set_current_value_index(item, value_index);
|
||||||
variable_item_set_current_value_text(item, ext_mod_power_text[value_index_pwr]);
|
variable_item_set_current_value_text(item, ext_mod_power_text[value_index]);
|
||||||
|
|
||||||
item = variable_item_list_add(
|
item = variable_item_list_add(
|
||||||
subghz->variable_item_list,
|
subghz->variable_item_list,
|
||||||
@@ -153,21 +136,9 @@ void subghz_scene_ext_module_settings_on_enter(void* context) {
|
|||||||
TIMESTAMP_NAMES_COUNT,
|
TIMESTAMP_NAMES_COUNT,
|
||||||
subghz_scene_receiver_config_set_timestamp_file_names,
|
subghz_scene_receiver_config_set_timestamp_file_names,
|
||||||
subghz);
|
subghz);
|
||||||
value_index_time = furi_hal_subghz_get_timestamp_file_names();
|
value_index = furi_hal_subghz_get_timestamp_file_names();
|
||||||
variable_item_set_current_value_index(item, value_index_time);
|
variable_item_set_current_value_index(item, value_index);
|
||||||
variable_item_set_current_value_text(item, timestamp_names_text[value_index_time]);
|
variable_item_set_current_value_text(item, timestamp_names_text[value_index]);
|
||||||
|
|
||||||
item = variable_item_list_add(
|
|
||||||
subghz->variable_item_list,
|
|
||||||
"Debug Pin",
|
|
||||||
DEBUG_P_COUNT,
|
|
||||||
subghz_scene_receiver_config_set_debug_pin,
|
|
||||||
subghz);
|
|
||||||
value_index_dpin = subghz_txrx_get_debug_pin_state(subghz->txrx);
|
|
||||||
variable_item_set_current_value_index(item, value_index_dpin);
|
|
||||||
variable_item_set_current_value_text(item, debug_pin_text[value_index_dpin]);
|
|
||||||
variable_item_set_locked(
|
|
||||||
item, !furi_hal_rtc_is_flag_set(FuriHalRtcFlagDebug), "Enable\nDebug!");
|
|
||||||
|
|
||||||
item = variable_item_list_add(
|
item = variable_item_list_add(
|
||||||
subghz->variable_item_list,
|
subghz->variable_item_list,
|
||||||
@@ -177,48 +148,49 @@ void subghz_scene_ext_module_settings_on_enter(void* context) {
|
|||||||
subghz);
|
subghz);
|
||||||
switch(furi_hal_subghz_get_rolling_counter_mult()) {
|
switch(furi_hal_subghz_get_rolling_counter_mult()) {
|
||||||
case 1:
|
case 1:
|
||||||
value_index_cnt = 0;
|
value_index = 0;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
value_index_cnt = 1;
|
value_index = 1;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
value_index_cnt = 2;
|
value_index = 2;
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
value_index_cnt = 3;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
value_index_cnt = 4;
|
|
||||||
break;
|
|
||||||
case 10:
|
|
||||||
value_index_cnt = 5;
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
variable_item_set_current_value_index(item, value_index_cnt);
|
variable_item_set_current_value_index(item, value_index);
|
||||||
variable_item_set_current_value_text(item, debug_counter_text[value_index_cnt]);
|
variable_item_set_current_value_text(item, debug_counter_text[value_index]);
|
||||||
|
|
||||||
|
item = variable_item_list_add(
|
||||||
|
subghz->variable_item_list,
|
||||||
|
"Debug Pin",
|
||||||
|
DEBUG_P_COUNT,
|
||||||
|
subghz_scene_receiver_config_set_debug_pin,
|
||||||
|
subghz);
|
||||||
|
value_index = subghz_txrx_get_debug_pin_state(subghz->txrx);
|
||||||
|
variable_item_set_current_value_index(item, value_index);
|
||||||
|
variable_item_set_current_value_text(item, debug_pin_text[value_index]);
|
||||||
variable_item_set_locked(
|
variable_item_set_locked(
|
||||||
item, !furi_hal_rtc_is_flag_set(FuriHalRtcFlagDebug), "Enable\nDebug!");
|
item, !furi_hal_rtc_is_flag_set(FuriHalRtcFlagDebug), "Enable\nDebug!");
|
||||||
|
|
||||||
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdVariableItemList);
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdVariableItemList);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool subghz_scene_ext_module_settings_on_event(void* context, SceneManagerEvent event) {
|
bool subghz_scene_radio_settings_on_event(void* context, SceneManagerEvent event) {
|
||||||
SubGhz* subghz = context;
|
SubGhz* subghz = context;
|
||||||
UNUSED(subghz);
|
UNUSED(subghz);
|
||||||
UNUSED(event);
|
UNUSED(event);
|
||||||
|
|
||||||
// Set selected radio module
|
// Set selected radio module
|
||||||
furi_hal_subghz_select_radio_type(value_index_exm);
|
furi_hal_subghz_select_radio_type(subghz->last_settings->external_module_enabled);
|
||||||
furi_hal_subghz_init_radio_type(value_index_exm);
|
furi_hal_subghz_init_radio_type(subghz->last_settings->external_module_enabled);
|
||||||
|
|
||||||
furi_hal_subghz_enable_ext_power();
|
furi_hal_subghz_enable_ext_power();
|
||||||
|
|
||||||
// Check if module is present, if no -> show error
|
// Check if module is present, if no -> show error
|
||||||
if(!furi_hal_subghz_check_radio()) {
|
if(!furi_hal_subghz_check_radio()) {
|
||||||
value_index_exm = 0;
|
subghz->last_settings->external_module_enabled = false;
|
||||||
furi_hal_subghz_select_radio_type(SubGhzRadioInternal);
|
furi_hal_subghz_select_radio_type(SubGhzRadioInternal);
|
||||||
furi_hal_subghz_init_radio_type(SubGhzRadioInternal);
|
furi_hal_subghz_init_radio_type(SubGhzRadioInternal);
|
||||||
furi_string_set(subghz->error_str, "Please connect\nexternal radio");
|
furi_string_set(subghz->error_str, "Please connect\nexternal radio");
|
||||||
@@ -228,7 +200,7 @@ bool subghz_scene_ext_module_settings_on_event(void* context, SceneManagerEvent
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void subghz_scene_ext_module_settings_on_exit(void* context) {
|
void subghz_scene_radio_settings_on_exit(void* context) {
|
||||||
SubGhz* subghz = context;
|
SubGhz* subghz = context;
|
||||||
variable_item_list_reset(subghz->variable_item_list);
|
variable_item_list_reset(subghz->variable_item_list);
|
||||||
}
|
}
|
||||||
@@ -3,7 +3,6 @@
|
|||||||
#include <stm32wbxx_ll_lptim.h>
|
#include <stm32wbxx_ll_lptim.h>
|
||||||
#include <stm32wbxx_ll_bus.h>
|
#include <stm32wbxx_ll_bus.h>
|
||||||
#include <stm32wbxx_ll_rcc.h>
|
#include <stm32wbxx_ll_rcc.h>
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
// Timer used for tickless idle
|
// Timer used for tickless idle
|
||||||
#define FURI_HAL_IDLE_TIMER_MAX 0xFFFF
|
#define FURI_HAL_IDLE_TIMER_MAX 0xFFFF
|
||||||
|
|||||||
Reference in New Issue
Block a user