DBG
Detailed Description
Debug (DBG) Peripheral API.
This module contains functions to control the DBG peripheral of Silicon Labs 32-bit MCUs and SoCs. The Debug Interface is used to program and debug Silicon Labs devices.
| Enumerations | |
| enum | DBG_LockMode_TypeDef
         
         { dbgLockModeAllowErase = 1UL, dbgLockModePermanent = 2UL } | 
| Functions | |
| __STATIC_INLINE bool | DBG_Connected (void) | 
| Check if a debugger is connected (and debug session activated). | |
| void | DBG_DisableDebugAccess ( DBG_LockMode_TypeDef lockMode) | 
| __STATIC_INLINE void | DBG_EM2DebugEnable (bool enable) | 
| Enable or disable debug support while in EM2 mode. | |
| void | DBG_SWOEnable (unsigned int location) | 
| Enable Serial Wire Output (SWO) pin. | |
Enumeration Type Documentation
| enum DBG_LockMode_TypeDef | 
Function Documentation
| __STATIC_INLINE bool DBG_Connected | ( | void | 
            | ) | 
Check if a debugger is connected (and debug session activated).
Used to make run-time decisions depending on whether or not a debug session has been active since last reset, i.e., using a debug probe or similar. In some cases, special handling is required in that scenario.
- Returns
- True if a debug session is active since last reset, otherwise false.
        Definition at line
        
         84
        
        of file
        
         em_dbg.h
        
        .
       
| __STATIC_INLINE void DBG_EM2DebugEnable | ( | bool | 
            enable
            | ) | 
Enable or disable debug support while in EM2 mode.
- Warning
- Disabling debug support in EM2 will reduce current consumption with 1-2 uA, but some debuggers will have problems regaining control over a device which is in EM2 and has debug support disabled.
To remedy this, set the WSTK switch next to the battery holder to USB (powers down the EFR). Execute Simplicity Commander with command line parameters: "./commander.exe device recover" and then immediately move the switch to the AEM postion. An additional "./commander.exe device masserase" command completes the recovery procedure.
- Parameters
- 
         [in] enableBoolean true enables EM2 debug support, false disables. 
        Definition at line
        
         119
        
        of file
        
         em_dbg.h
        
        .
       
| void DBG_SWOEnable | ( | unsigned int | 
            location
            | ) | 
Enable Serial Wire Output (SWO) pin.
The SWO pin (sometimes denoted SWV, serial wire viewer) allows for miscellaneous output to be passed from the Cortex-M3 debug trace module to an external debug probe. By default, the debug trace module and pin output may be disabled.
Since the SWO pin is only useful when using a debugger, a suggested use of this function during startup may be:
* if (DBG_Connected())
* {
* DBG_SWOEnable(1);
* }
* 
       By checking if the debugger is attached, a setup leading to a higher energy consumption when the debugger is attached can be avoided when not using a debugger.
Another alternative may be to set the debugger tool chain to configure the required setup (similar to the content of this function) by some sort of toolchain scripting during its attach/reset procedure. In that case, the above suggested code for enabling the SWO pin is not required in the application.
- Parameters
- 
         [in] locationA pin location used for SWO pin on the application in use. 
        Definition at line
        
         96
        
        of file
        
         em_dbg.c
        
        .
       
References CMU_OscillatorEnable() , GPIO_DbgLocationSet() , GPIO_DbgSWOEnable() , GPIO_PinModeSet() , and gpioModePushPull .