mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-12-13 05:06:30 +04:00
Merge branch 'ofw-dev' into dev
This commit is contained in:
@@ -138,7 +138,6 @@ static void desktop_auto_lock_inhibit(Desktop* desktop) {
|
|||||||
|
|
||||||
void desktop_lock(Desktop* desktop) {
|
void desktop_lock(Desktop* desktop) {
|
||||||
furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
|
furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
|
||||||
furi_hal_rtc_set_pin_fails(0);
|
|
||||||
|
|
||||||
if(desktop->settings.pin_code.length) {
|
if(desktop->settings.pin_code.length) {
|
||||||
Cli* cli = furi_record_open(RECORD_CLI);
|
Cli* cli = furi_record_open(RECORD_CLI);
|
||||||
@@ -162,6 +161,7 @@ void desktop_unlock(Desktop* desktop) {
|
|||||||
scene_manager_search_and_switch_to_previous_scene(desktop->scene_manager, DesktopSceneMain);
|
scene_manager_search_and_switch_to_previous_scene(desktop->scene_manager, DesktopSceneMain);
|
||||||
desktop_auto_lock_arm(desktop);
|
desktop_auto_lock_arm(desktop);
|
||||||
furi_hal_rtc_reset_flag(FuriHalRtcFlagLock);
|
furi_hal_rtc_reset_flag(FuriHalRtcFlagLock);
|
||||||
|
furi_hal_rtc_set_pin_fails(0);
|
||||||
|
|
||||||
if(desktop->settings.pin_code.length) {
|
if(desktop->settings.pin_code.length) {
|
||||||
Cli* cli = furi_record_open(RECORD_CLI);
|
Cli* cli = furi_record_open(RECORD_CLI);
|
||||||
|
|||||||
@@ -55,7 +55,6 @@ static void desktop_scene_pin_input_back_callback(void* context) {
|
|||||||
static void desktop_scene_pin_input_done_callback(const PinCode* pin_code, void* context) {
|
static void desktop_scene_pin_input_done_callback(const PinCode* pin_code, void* context) {
|
||||||
Desktop* desktop = (Desktop*)context;
|
Desktop* desktop = (Desktop*)context;
|
||||||
if(desktop_pin_compare(&desktop->settings.pin_code, pin_code)) {
|
if(desktop_pin_compare(&desktop->settings.pin_code, pin_code)) {
|
||||||
furi_hal_rtc_set_pin_fails(0);
|
|
||||||
view_dispatcher_send_custom_event(desktop->view_dispatcher, DesktopPinInputEventUnlocked);
|
view_dispatcher_send_custom_event(desktop->view_dispatcher, DesktopPinInputEventUnlocked);
|
||||||
} else {
|
} else {
|
||||||
uint32_t pin_fails = furi_hal_rtc_get_pin_fails();
|
uint32_t pin_fails = furi_hal_rtc_get_pin_fails();
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ Only two parameters are mandatory: **_appid_** and **_apptype_**. Others are opt
|
|||||||
The following parameters are used only for [FAPs](./AppsOnSDCard.md):
|
The following parameters are used only for [FAPs](./AppsOnSDCard.md):
|
||||||
|
|
||||||
- **sources**: list of strings, file name masks used for gathering sources within the app folder. The default value of `["*.c*"]` includes C and C++ source files. Applications cannot use the `"lib"` folder for their own source code, as it is reserved for **fap_private_libs**.
|
- **sources**: list of strings, file name masks used for gathering sources within the app folder. The default value of `["*.c*"]` includes C and C++ source files. Applications cannot use the `"lib"` folder for their own source code, as it is reserved for **fap_private_libs**.
|
||||||
- **fap_version**: tuple, 2 numbers in the form of (x,y): application version to be embedded within .fap file. The default value is (0,1), meaning version "0.1".
|
- **fap_version**: string, application version. The default value is "0.1". You can also use a tuple of 2 numbers in the form of (x,y) to specify the version. It is also possible to add more dot-separated parts to the version, like patch number, but only major and minor version numbers are stored in the built .fap.
|
||||||
- **fap_icon**: name of a `.png` file, 1-bit color depth, 10x10px, to be embedded within `.fap` file.
|
- **fap_icon**: name of a `.png` file, 1-bit color depth, 10x10px, to be embedded within `.fap` file.
|
||||||
- **fap_libs**: list of extra libraries to link the application against. Provides access to extra functions that are not exported as a part of main firmware at the expense of increased `.fap` file size and RAM consumption.
|
- **fap_libs**: list of extra libraries to link the application against. Provides access to extra functions that are not exported as a part of main firmware at the expense of increased `.fap` file size and RAM consumption.
|
||||||
- **fap_category**: string, may be empty. App subcategory, also determines the path of the FAP within the apps folder in the file system.
|
- **fap_category**: string, may be empty. App subcategory, also determines the path of the FAP within the apps folder in the file system.
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# Furi HAL Debugging
|
# Furi HAL Debugging
|
||||||
|
|
||||||
Some Furi subsystem got additional debugging features that can be enabled by adding additional defines to firmware compilation.
|
Some Furi subsystems got additional debugging features that can be enabled by adding additional defines to firmware compilation.
|
||||||
Usually they are used for low level tracing and profiling or signal redirection/duplication.
|
Usually they are used for low level tracing and profiling or signal redirection/duplication.
|
||||||
|
|
||||||
|
|
||||||
@@ -23,4 +23,4 @@ There are 3 signals that will be exposed to external GPIO pins:
|
|||||||
There are 2 signals that will be exposed to external GPIO pins:
|
There are 2 signals that will be exposed to external GPIO pins:
|
||||||
|
|
||||||
- `WFI` - `PB2` - Light sleep (wait for interrupt) used. Basically this is lightest and most non-breaking things power save mode. All function and debug should work correctly in this mode.
|
- `WFI` - `PB2` - Light sleep (wait for interrupt) used. Basically this is lightest and most non-breaking things power save mode. All function and debug should work correctly in this mode.
|
||||||
- `STOP` - `PC3` - STOP mode used. Platform deep sleep mode. Extremely fragile mode where most of the silicon is disabled or in unusable state. Debugging MCU in this mode is nearly impossible.
|
- `STOP` - `PC3` - STOP mode used. Platform deep sleep mode. Extremely fragile mode where most of the silicon is disabled or in unusable state. Debugging MCU in this mode is nearly impossible.
|
||||||
|
|||||||
@@ -196,7 +196,10 @@ class FlipperAppStateHelper:
|
|||||||
self.set_debug_mode(False)
|
self.set_debug_mode(False)
|
||||||
|
|
||||||
def set_debug_mode(self, mode: bool) -> None:
|
def set_debug_mode(self, mode: bool) -> None:
|
||||||
gdb.execute(f"set variable furi_hal_debug_gdb_session_active = {int(mode)}")
|
try:
|
||||||
|
gdb.execute(f"set variable furi_hal_debug_gdb_session_active = {int(mode)}")
|
||||||
|
except gdb.error as e:
|
||||||
|
print(f"Failed to set debug mode: {e}")
|
||||||
|
|
||||||
|
|
||||||
# Init additional 'fap-set-debug-elf-root' command and set up hooks
|
# Init additional 'fap-set-debug-elf-root' command and set up hooks
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ class FlipperApplication:
|
|||||||
|
|
||||||
# .fap-specific
|
# .fap-specific
|
||||||
sources: List[str] = field(default_factory=lambda: ["*.c*"])
|
sources: List[str] = field(default_factory=lambda: ["*.c*"])
|
||||||
fap_version: Tuple[int] = field(default_factory=lambda: (0, 1))
|
fap_version: str | Tuple[int] = "0.1"
|
||||||
fap_icon: Optional[str] = None
|
fap_icon: Optional[str] = None
|
||||||
fap_libs: List[str] = field(default_factory=list)
|
fap_libs: List[str] = field(default_factory=list)
|
||||||
fap_category: str = ""
|
fap_category: str = ""
|
||||||
@@ -84,6 +84,13 @@ class FlipperApplication:
|
|||||||
def __post_init__(self):
|
def __post_init__(self):
|
||||||
if self.apptype == FlipperAppType.PLUGIN:
|
if self.apptype == FlipperAppType.PLUGIN:
|
||||||
self.stack_size = 0
|
self.stack_size = 0
|
||||||
|
if isinstance(self.fap_version, str):
|
||||||
|
try:
|
||||||
|
self.fap_version = tuple(int(v) for v in self.fap_version.split("."))
|
||||||
|
except ValueError:
|
||||||
|
raise FlipperManifestException(
|
||||||
|
f"Invalid version string '{self.fap_version}'. Must be in the form 'major.minor'"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class AppManager:
|
class AppManager:
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ App(
|
|||||||
stack_size=2 * 1024,
|
stack_size=2 * 1024,
|
||||||
fap_category="Examples",
|
fap_category="Examples",
|
||||||
# Optional values
|
# Optional values
|
||||||
# fap_version=(0, 1), # (major, minor)
|
# fap_version="0.1",
|
||||||
fap_icon="@FBT_APPID@.png", # 10x10 1-bit PNG
|
fap_icon="@FBT_APPID@.png", # 10x10 1-bit PNG
|
||||||
# fap_description="A simple app",
|
# fap_description="A simple app",
|
||||||
# fap_author="J. Doe",
|
# fap_author="J. Doe",
|
||||||
|
|||||||
Reference in New Issue
Block a user