mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-11-10 06:54:19 +00:00
4705812d24
* Storage: remove unused error from SDInfo * FatFS: remove sd_spi_io * HAL: sd card api * Update: use sd hal * FatFS: use sd hal * Storage: use sd hal * API: sd hal * Fix TODO workflow * SD Hal: Fix source buffer overflow * fix for fix! * HAL: cleanup sd detection api * HAL: FURI_HAL_SD_SPI_DEBUG flag * HAL: FuriHalSdStatus -> FuriStatus * API: downgrade * Change define logic * HAL: presence
30 lines
1.5 KiB
Markdown
30 lines
1.5 KiB
Markdown
# Furi HAL Debugging
|
|
|
|
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.
|
|
|
|
|
|
## FuriHalOs
|
|
|
|
`--extra-define=FURI_HAL_OS_DEBUG` enables tick, tick suppression, idle and time flow.
|
|
|
|
There are 3 signals that will be exposed to external GPIO pins:
|
|
|
|
- `AWAKE` - `PA7` - High when system is busy with computations, low when sleeping. Can be used to track transitions to sleep mode.
|
|
- `TICK` - `PA6` - Flipped on system tick, only flips when no tick suppression in progress. Can be used to track tick skew and abnormal task scheduling.
|
|
- `SECOND` - `PA4` - Flipped each second. Can be used for tracing RT issue: time flow disturbance means system doesn't conforms Hard RT.
|
|
|
|
|
|
|
|
## FuriHalPower
|
|
|
|
`--extra-define=FURI_HAL_POWER_DEBUG` enables power subsystem mode transitions tracing.
|
|
|
|
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.
|
|
- `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.
|
|
|
|
## FuriHalSD
|
|
|
|
`--extra-define=FURI_HAL_SD_SPI_DEBUG` enables SD card SPI bus logging.
|