GPIO - General Purpose Input/Output
Description
General Purpose Input/Output (GPIO) API.
This module contains functions to control the GPIO peripheral of Silicon Labs 32-bit MCUs and SoCs. The GPIO peripheral is used for pin configuration and direct pin manipulation and sensing as well as routing for peripheral pin connections.
Functions |
|
void | GPIO_DbgLocationSet (unsigned int location) |
Sets the pin location of the debug pins (Serial Wire interface).
|
|
void | GPIO_DriveModeSet ( GPIO_Port_TypeDef port, GPIO_DriveMode_TypeDef mode) |
Sets drive mode for a GPIO port.
|
|
void | GPIO_ExtIntConfig ( GPIO_Port_TypeDef port, unsigned int pin, unsigned int intNo, bool risingEdge, bool fallingEdge, bool enable) |
Configure the GPIO external pin interrupt.
|
|
void | GPIO_PinModeSet ( GPIO_Port_TypeDef port, unsigned int pin, GPIO_Mode_TypeDef mode, unsigned int out) |
Set the mode for a GPIO pin.
|
|
GPIO_Mode_TypeDef | GPIO_PinModeGet ( GPIO_Port_TypeDef port, unsigned int pin) |
Get the mode for a GPIO pin.
|
|
void | GPIO_DbgSWDClkEnable (bool enable) |
Enable/disable serial wire clock pin.
|
|
void | GPIO_DbgSWDIOEnable (bool enable) |
Enable/disable serial wire data I/O pin.
|
|
void | GPIO_DbgSWOEnable (bool enable) |
Enable/Disable serial wire output pin.
|
|
void | GPIO_InputSenseSet (uint32_t val, uint32_t mask) |
Enable/disable input sensing.
|
|
void | GPIO_IntClear (uint32_t flags) |
Clear one or more pending GPIO interrupts.
|
|
void | GPIO_IntDisable (uint32_t flags) |
Disable one or more GPIO interrupts.
|
|
void | GPIO_IntEnable (uint32_t flags) |
Enable one or more GPIO interrupts.
|
|
uint32_t | GPIO_EnabledIntGet (void) |
Get enabled GPIO interrupts.
|
|
uint32_t | GPIO_IntGet (void) |
Get pending GPIO interrupts.
|
|
uint32_t | GPIO_IntGetEnabled (void) |
Get enabled and pending GPIO interrupt flags.
|
|
void | GPIO_IntSet (uint32_t flags) |
Set one or more pending GPIO interrupts from SW.
|
|
void | GPIO_Lock (void) |
Lock the GPIO configuration.
|
|
unsigned int | GPIO_PinInGet ( GPIO_Port_TypeDef port, unsigned int pin) |
Read the pad value for a single pin in a GPIO port.
|
|
void | GPIO_PinLock ( GPIO_Port_TypeDef port, unsigned int pin) |
Lock all GPIO configuration settings for a given pin.
|
|
void | GPIO_PinOutClear ( GPIO_Port_TypeDef port, unsigned int pin) |
Set a single pin in GPIO data out port register to 0.
|
|
unsigned int | GPIO_PinOutGet ( GPIO_Port_TypeDef port, unsigned int pin) |
Get current setting for a pin in a GPIO port data out register.
|
|
void | GPIO_PinOutSet ( GPIO_Port_TypeDef port, unsigned int pin) |
Set a single pin in GPIO data out register to 1.
|
|
void | GPIO_PinOutToggle ( GPIO_Port_TypeDef port, unsigned int pin) |
Toggle a single pin in GPIO port data out register.
|
|
uint32_t | GPIO_PortInGet ( GPIO_Port_TypeDef port) |
Read the pad values for GPIO port.
|
|
void | GPIO_PortOutClear ( GPIO_Port_TypeDef port, uint32_t pins) |
Set bits in DOUT register for a port to 0.
|
|
uint32_t | GPIO_PortOutGet ( GPIO_Port_TypeDef port) |
Get the current setting for a GPIO port data out register.
|
|
void | GPIO_PortOutSet ( GPIO_Port_TypeDef port, uint32_t pins) |
Set bits GPIO data out register to 1.
|
|
void | GPIO_PortOutSetVal ( GPIO_Port_TypeDef port, uint32_t val, uint32_t mask) |
Set GPIO port data out register.
|
|
void | GPIO_PortOutToggle ( GPIO_Port_TypeDef port, uint32_t pins) |
Toggle pins in GPIO port data out register.
|
|
void | GPIO_Unlock (void) |
Unlock the GPIO configuration.
|
|
SL_DEPRECATED_API_SDK_4_1 void | GPIO_IntConfig ( GPIO_Port_TypeDef port, unsigned int pin, bool risingEdge, bool fallingEdge, bool enable) |
Configure GPIO interrupt.
|
|
Enumerations |
|
enum |
GPIO_Port_TypeDef
{
gpioPortA = 0, gpioPortB = 1, gpioPortC = 2, gpioPortD = 3, gpioPortE = 4, gpioPortF = 5 } |
GPIO ports IDs.
|
|
enum |
GPIO_DriveMode_TypeDef
{
gpioDriveModeStandard = GPIO_P_CTRL_DRIVEMODE_STANDARD, gpioDriveModeLowest = GPIO_P_CTRL_DRIVEMODE_LOWEST, gpioDriveModeHigh = GPIO_P_CTRL_DRIVEMODE_HIGH, gpioDriveModeLow = GPIO_P_CTRL_DRIVEMODE_LOW } |
GPIO drive mode.
|
|
enum |
GPIO_Mode_TypeDef
{
gpioModeDisabled = _GPIO_P_MODEL_MODE0_DISABLED, gpioModeInput = _GPIO_P_MODEL_MODE0_INPUT, gpioModeInputPull = _GPIO_P_MODEL_MODE0_INPUTPULL, gpioModeInputPullFilter = _GPIO_P_MODEL_MODE0_INPUTPULLFILTER, gpioModePushPull = _GPIO_P_MODEL_MODE0_PUSHPULL, gpioModePushPullDrive = _GPIO_P_MODEL_MODE0_PUSHPULLDRIVE, gpioModeWiredOr = _GPIO_P_MODEL_MODE0_WIREDOR, gpioModeWiredOrPullDown = _GPIO_P_MODEL_MODE0_WIREDORPULLDOWN, gpioModeWiredAnd = _GPIO_P_MODEL_MODE0_WIREDAND, gpioModeWiredAndFilter = _GPIO_P_MODEL_MODE0_WIREDANDFILTER, gpioModeWiredAndPullUp = _GPIO_P_MODEL_MODE0_WIREDANDPULLUP, gpioModeWiredAndPullUpFilter = _GPIO_P_MODEL_MODE0_WIREDANDPULLUPFILTER, gpioModeWiredAndDrive = _GPIO_P_MODEL_MODE0_WIREDANDDRIVE, gpioModeWiredAndDriveFilter = _GPIO_P_MODEL_MODE0_WIREDANDDRIVEFILTER, gpioModeWiredAndDrivePullUp = _GPIO_P_MODEL_MODE0_WIREDANDDRIVEPULLUP, gpioModeWiredAndDrivePullUpFilter = _GPIO_P_MODEL_MODE0_WIREDANDDRIVEPULLUPFILTER } |
Pin mode.
|
|
Function Documentation
◆ GPIO_DbgLocationSet()
void GPIO_DbgLocationSet | ( | unsigned int |
location
|
) |
Sets the pin location of the debug pins (Serial Wire interface).
- Note
- Changing the pins used for debugging uncontrolled, may result in a lockout.
- Parameters
-
[in] location
The debug pin location to use (0-3).
◆ GPIO_DriveModeSet()
void GPIO_DriveModeSet | ( | GPIO_Port_TypeDef |
port,
|
GPIO_DriveMode_TypeDef |
mode
|
||
) |
Sets drive mode for a GPIO port.
- Parameters
-
[in] port
The GPIO port to access. [in] mode
Drive mode to use for the port.
◆ GPIO_ExtIntConfig()
void GPIO_ExtIntConfig | ( | GPIO_Port_TypeDef |
port,
|
unsigned int |
pin,
|
||
unsigned int |
intNo,
|
||
bool |
risingEdge,
|
||
bool |
fallingEdge,
|
||
bool |
enable
|
||
) |
Configure the GPIO external pin interrupt.
It is recommended to disable interrupts before configuring the GPIO pin interrupt. See GPIO_IntDisable() for more information.
The GPIO interrupt handler must be in place before enabling the interrupt.
Notice that any pending interrupt for the selected interrupt is cleared by this function.
- Note
-
On series 0 devices, the pin number parameter is not used. The pin number used on these devices is hardwired to the interrupt with the same number.
On series 1 devices, the pin number can be selected freely within a group. Interrupt numbers are divided into 4 groups (intNo / 4) and valid pin number within the interrupt groups are: 0: pins 0-3 (interrupt number 0-3) 1: pins 4-7 (interrupt number 4-7) 2: pins 8-11 (interrupt number 8-11) 3: pins 12-15 (interrupt number 12-15)
- Parameters
-
[in] port
The port to associate with the pin
.[in] pin
The pin number on the port. [in] intNo
The interrupt number to trigger. [in] risingEdge
Set to true if the interrupt will be enabled on the rising edge. Otherwise, false. [in] fallingEdge
Set to true if the interrupt will be enabled on the falling edge. Otherwise, false. [in] enable
Set to true if the interrupt will be enabled after the configuration is complete. False to leave disabled. See GPIO_IntDisable() and GPIO_IntEnable() .
◆ GPIO_PinModeSet()
void GPIO_PinModeSet | ( | GPIO_Port_TypeDef |
port,
|
unsigned int |
pin,
|
||
GPIO_Mode_TypeDef |
mode,
|
||
unsigned int |
out
|
||
) |
Set the mode for a GPIO pin.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin number in the port. [in] mode
The desired pin mode. [in] out
A value to set for the pin in the DOUT register. The DOUT setting is important for some input mode configurations to determine the pull-up/down direction.
◆ GPIO_PinModeGet()
GPIO_Mode_TypeDef GPIO_PinModeGet | ( | GPIO_Port_TypeDef |
port,
|
unsigned int |
pin
|
||
) |
Get the mode for a GPIO pin.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin number in the port.
- Returns
- The pin mode.
◆ GPIO_DbgSWDClkEnable()
|
inline |
Enable/disable serial wire clock pin.
- Note
- Disabling SWDClk will disable the debug interface, which may result in a lockout if done early in startup (before debugger is able to halt core).
- Parameters
-
[in] enable
- false - disable serial wire clock.
- true - enable serial wire clock (default after reset).
◆ GPIO_DbgSWDIOEnable()
|
inline |
Enable/disable serial wire data I/O pin.
- Note
- Disabling SWDClk will disable the debug interface, which may result in a lockout if done early in startup (before debugger is able to halt core).
- Parameters
-
[in] enable
- false - disable serial wire data pin.
- true - enable serial wire data pin (default after reset).
◆ GPIO_DbgSWOEnable()
|
inline |
Enable/Disable serial wire output pin.
- Note
- Enabling this pin is not sufficient to fully enable serial wire output, which is also dependent on issues outside the GPIO module. Refer to DBG_SWOEnable() .
- Warning
- If debug port is locked, SWO pin is not disabled automatically. To avoid information leakage through SWO, disable SWO pin after locking debug port.
- Parameters
-
[in] enable
- false - disable serial wire viewer pin (default after reset).
- true - enable serial wire viewer pin.
◆ GPIO_InputSenseSet()
|
inline |
Enable/disable input sensing.
Disabling input sensing if not used, can save some energy consumption.
- Parameters
-
[in] val
Bitwise logic OR of one or more of: - GPIO_INSENSE_INT - interrupt input sensing.
- GPIO_INSENSE_PRS - peripheral reflex system input sensing.
[in] mask
Mask containing bitwise logic OR of bits similar as for val
used to indicate which input sense options to disable/enable.
◆ GPIO_IntClear()
|
inline |
Clear one or more pending GPIO interrupts.
- Parameters
-
[in] flags
Bitwise logic OR of GPIO interrupt sources to clear.
◆ GPIO_IntDisable()
|
inline |
Disable one or more GPIO interrupts.
- Parameters
-
[in] flags
GPIO interrupt sources to disable.
◆ GPIO_IntEnable()
|
inline |
Enable one or more GPIO interrupts.
- Note
- Depending on the use, a pending interrupt may already be set prior to enabling the interrupt. To ignore a pending interrupt, consider using GPIO_IntClear() prior to enabling the interrupt.
- Parameters
-
[in] flags
GPIO interrupt sources to enable.
◆ GPIO_EnabledIntGet()
|
inline |
Get enabled GPIO interrupts.
- Returns
- Enabled GPIO interrupt sources.
◆ GPIO_IntGet()
|
inline |
Get pending GPIO interrupts.
- Returns
- GPIO interrupt sources pending.
◆ GPIO_IntGetEnabled()
|
inline |
Get enabled and pending GPIO interrupt flags.
Useful for handling more interrupt sources in the same interrupt handler.
- Note
- Interrupt flags are not cleared by the use of this function.
- Returns
-
Pending and enabled GPIO interrupt sources. The return value is the bitwise AND combination of
- the OR combination of enabled interrupt sources in GPIO_IEN register and
- the OR combination of valid interrupt flags in GPIO_IF register.
◆ GPIO_IntSet()
|
inline |
Set one or more pending GPIO interrupts from SW.
- Parameters
-
[in] flags
GPIO interrupt sources to set to pending.
◆ GPIO_Lock()
|
inline |
Lock the GPIO configuration.
◆ GPIO_PinInGet()
|
inline |
Read the pad value for a single pin in a GPIO port.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin number to read.
- Returns
- The pin value, 0 or 1.
◆ GPIO_PinLock()
|
inline |
Lock all GPIO configuration settings for a given pin.
The lock can only be cleared by a chip reset.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin number to lock.
◆ GPIO_PinOutClear()
|
inline |
Set a single pin in GPIO data out port register to 0.
- Note
- To ensure that the setting takes effect on the output pad, the pin must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin to set.
◆ GPIO_PinOutGet()
|
inline |
Get current setting for a pin in a GPIO port data out register.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin to get setting for.
- Returns
- The DOUT setting for the requested pin, 0 or 1.
◆ GPIO_PinOutSet()
|
inline |
Set a single pin in GPIO data out register to 1.
- Note
- To ensure that the setting takes effect on the output pad, the pin must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin to set.
◆ GPIO_PinOutToggle()
|
inline |
Toggle a single pin in GPIO port data out register.
- Note
- To ensure that the setting takes effect on the output pad, the pin must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] pin
The pin to toggle.
◆ GPIO_PortInGet()
|
inline |
Read the pad values for GPIO port.
- Parameters
-
[in] port
The GPIO port to access.
- Returns
- The pad values for the GPIO port.
◆ GPIO_PortOutClear()
|
inline |
Set bits in DOUT register for a port to 0.
- Note
- To ensure that the setting takes effect on the output pad, the pin must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] pins
Bit mask for bits to clear in DOUT register.
◆ GPIO_PortOutGet()
|
inline |
Get the current setting for a GPIO port data out register.
- Parameters
-
[in] port
The GPIO port to access.
- Returns
- The data out setting for the requested port.
◆ GPIO_PortOutSet()
|
inline |
Set bits GPIO data out register to 1.
- Note
- To ensure that the setting takes effect on the respective output pads, the pins must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] pins
Bit mask for bits to set to 1 in DOUT register.
◆ GPIO_PortOutSetVal()
|
inline |
Set GPIO port data out register.
- Note
- To ensure that the setting takes effect on the respective output pads, the pins must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] val
Value to write to port data out register. [in] mask
Mask indicating which bits to modify.
◆ GPIO_PortOutToggle()
|
inline |
Toggle pins in GPIO port data out register.
- Note
- To ensure that the setting takes effect on the output pad, the pin must be configured properly. If not, it will take effect whenever the pin has been properly configured.
- Parameters
-
[in] port
The GPIO port to access. [in] pins
Bit mask with pins to toggle.
◆ GPIO_Unlock()
|
inline |
Unlock the GPIO configuration.
◆ GPIO_IntConfig()
|
inline |
Configure GPIO interrupt.
If reconfiguring a GPIO interrupt that is already enabled, it is generally recommended to disable it first, see GPIO_IntDisable() .
The actual GPIO interrupt handler must be in place before enabling the interrupt.
Notice that any pending interrupt for the selected pin is cleared by this function.
- Note
- A certain pin number can only be associated with one port; i.e., if GPIO interrupt 1 is assigned to port A/pin 1, then it is not possible to use pin 1 from any other ports for interrupts. Refer to the reference manual. On devices which implement GPIO_EXTIPINSEL registers a more flexible approach is possible, refer to GPIO_ExtIntConfig() .
- Parameters
-
[in] port
The port to associate with pin
.[in] pin
The pin number on the port ( == GPIO EXTI interrupt number). [in] risingEdge
Set to true if interrupts will be enabled on rising edge, otherwise false. [in] fallingEdge
Set to true if interrupts will be enabled on falling edge, otherwise false. [in] enable
Set to true if interrupt will be enabled after configuration completed, false to leave disabled. See GPIO_IntDisable() and GPIO_IntEnable() .
Enumeration Type Documentation
◆ GPIO_Port_TypeDef
enum GPIO_Port_TypeDef |
◆ GPIO_DriveMode_TypeDef
◆ GPIO_Mode_TypeDef
enum GPIO_Mode_TypeDef |
Pin mode.
For more details on each mode, refer to the reference manual.