27 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			1.4 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.
 | 
