General-Purpose Input-Output#
Modules#
Typedefs#
GPIO interrupt callback function pointer.
Functions#
Configure the GPIO pin interrupt.
Set the pin mode for a GPIO pin.
Get the GPIO pin status.
Set a single pin in GPIO configuration register to 1.
Set a single pin in GPIO configuration register to 0.
Toggle a single pin in GPIO port register.
Read the pad value for a single pin in a GPIO port.
Set bits GPIO data out register to 1.
Set bits in configuration register for a port to 0.
Get the current setting for a GPIO configuration register.
Get the current setting for a pin in a GPIO configuration register.
Set the direction for a GPIO pin.
Get the direction GPIO.
Enable the receiver bit in the PAD configuration register.
Disable the receiver bit in the PAD configuration register.
Select the pad(0 to 21).
Select drive strength of a GPIO pin.
Select the Driver disabled state control.
Select AND/OR of the group interrupt.
Clear the group interrupt status.
Get the group interrupt status.
Configure the group interrupt wake up the interrupt.
Configure the MCU HP group interrupts.
Get the polarity of group interrupt.
Configure the polarity of group interrupt.
Get the level/edge event of group interrupt.
Set the level/edge event of group interrupt.
Unmask the group interrupts.
Mask the group interrupts.
Disable HP/ULP GPIO clock.
Enable HP/ULP GPIO clock.
Configure the ULP group interrupt.
Enable the group interrupts.
Disable the group interrupts.
Select the slew rate.
Select the drive strength.
Select the driver-disabled state control.
Disable the receiver bit for ULP.
Enable the receiver bit for ULP.
Configure the MCU ULP GPIO pin interrupt.
Set the NPSS GPIO pin MUX(mode).
Enable/disable NPSS GPIO receiver.
Set the direction of the NPSS GPIO.
Get the direction of the NPSS GPIO.
Control the NPSS GPIO pin value.
Get the NPSS GPIO pin value.
Select the NPSS GPIO polarity.
Set the UULP NPSS GPIO to wake up interrupt.
Clear the UULP NPSS GPIO to wake up interrupt.
Mask the NPSS GPIO interrupt.
Unmask the NPSS GPIO interrupt.
Clear the NPSS GPIO interrupt.
Get the NPSS GPIO interrupt status.
Clear one or more pending ULP GPIO interrupts.
Clear the ULP group interrupt.
Configure the UULP GPIO pin interrupt.
Toggle the UULP pin.
Indicate UULP GPIO PAD configuration.
Get the release, SQA, and development version numbers of the GPIO peripheral.
Macros#
Typedef Documentation#
sl_gpio_irq_callback_t#
typedef void(* sl_gpio_irq_callback_t) (void) )(void)
GPIO interrupt callback function pointer.
Function Documentation#
sl_gpio_driver_clear_interrupts#
STATIC __INLINE sl_status_t sl_gpio_driver_clear_interrupts (uint32_t flags)
Type | Direction | Argument Name | Description |
---|---|---|---|
uint32_t | N/A | flags |
sl_gpio_driver_configure_interrupt#
sl_status_t sl_gpio_driver_configure_interrupt (sl_gpio_t * gpio, uint32_t int_no, sl_gpio_interrupt_flag_t flags, sl_gpio_irq_callback_t gpio_callback, uint32_t * avl_intr_no)
Configure the GPIO pin interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
uint32_t | [in] | int_no | - The interrupt number to trigger. |
sl_gpio_interrupt_flag_t | [in] | flags | - Interrupt configuration flags |
sl_gpio_irq_callback_t | [in] | gpio_callback | - IRQ function pointer |
uint32_t * | [out] | avl_intr_no | - Pointer to the available interrupt number. SL_GPIO_INTERRUPT_UNAVAILABLE (0xFF) no available interrupt |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_set_pin_mode#
sl_status_t sl_gpio_driver_set_pin_mode (sl_gpio_t * gpio, sl_gpio_mode_t mode, uint32_t output_value)
Set the pin mode for a GPIO pin.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
sl_gpio_mode_t | [in] | mode | - The desired pin mode. |
uint32_t | [in] | output_value | - A value to set for the pin in the GPIO register. The GPIO setting is important for some input mode configurations. |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_get_pin_mode#
sl_status_t sl_gpio_driver_get_pin_mode (sl_gpio_t * gpio, sl_gpio_mode_t * mode)
Get the GPIO pin status.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
sl_gpio_mode_t * | [in] | mode | - The desired pin mode. |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode();
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_init#
sl_status_t sl_gpio_driver_init (void )
Type | Direction | Argument Name | Description |
---|---|---|---|
void | N/A |
sl_gpio_driver_set_pin#
STATIC __INLINE sl_status_t sl_gpio_driver_set_pin (sl_gpio_t * gpio)
Set a single pin in GPIO configuration register to 1.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode(); sl_si91x_gpio_driver_set_pin_direction();
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_clear_pin#
STATIC __INLINE sl_status_t sl_gpio_driver_clear_pin (sl_gpio_t * gpio)
Set a single pin in GPIO configuration register to 0.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(); for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode(); sl_si91x_gpio_driver_set_pin_direction();
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_toggle_pin#
STATIC __INLINE sl_status_t sl_gpio_driver_toggle_pin (sl_gpio_t * gpio)
Toggle a single pin in GPIO port register.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode()sl_si91x_gpio_driver_set_pin_direction()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_get_pin#
STATIC __INLINE sl_status_t sl_gpio_driver_get_pin (sl_gpio_t * gpio, uint8_t * pin_value)
Read the pad value for a single pin in a GPIO port.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
uint8_t * | N/A | pin_value |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode()sl_si91x_gpio_driver_set_pin_direction()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_gpio_driver_set_port#
STATIC __INLINE sl_status_t sl_gpio_driver_set_port (sl_gpio_port_t port, uint32_t pins)
Set bits GPIO data out register to 1.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint32_t | [in] | pins | - The GPIO pins in a port are set to 1's. |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode(); sl_si91x_gpio_driver_set_pin_direction();
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_gpio_driver_clear_port#
STATIC __INLINE sl_status_t sl_gpio_driver_clear_port (sl_gpio_port_t port, uint32_t pins)
Set bits in configuration register for a port to 0.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint32_t | [in] | pins | - The GPIO pins in a port to clear. |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode()sl_si91x_gpio_driver_set_pin_direction()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_gpio_driver_get_port_output#
STATIC __INLINE sl_status_t sl_gpio_driver_get_port_output (sl_gpio_port_t port, uint32_t * port_value)
Get the current setting for a GPIO configuration register.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint32_t * | N/A | port_value |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode()sl_si91x_gpio_driver_set_pin_direction()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_gpio_driver_get_pin_output#
STATIC __INLINE uint8_t sl_gpio_driver_get_pin_output (sl_gpio_t * gpio)
Get the current setting for a pin in a GPIO configuration register.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_t * | [in] | gpio | - Pointer to the structure of type sl_gpio_t |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_gpio_driver_set_pin_mode()sl_si91x_gpio_driver_set_pin_direction()
Returns
The GPIO pin value '0' - Output '1' - Input
sl_gpio_driver_set_port_output_value#
STATIC __INLINE sl_status_t sl_gpio_driver_set_port_output_value (sl_gpio_port_t port, uint32_t val, uint32_t mask)
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | N/A | port | |
uint32_t | N/A | val | |
uint32_t | N/A | mask |
sl_gpio_driver_set_slew_rate#
STATIC __INLINE sl_status_t sl_gpio_driver_set_slew_rate (sl_gpio_port_t port, uint32_t slewrate, uint32_t slewrate_alt)
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | N/A | port | |
uint32_t | N/A | slewrate | |
uint32_t | N/A | slewrate_alt |
sl_gpio_driver_get_port_input#
STATIC __INLINE uint32_t sl_gpio_driver_get_port_input (sl_gpio_port_t port)
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | N/A | port |
sl_gpio_driver_toggle_port_output#
STATIC __INLINE sl_status_t sl_gpio_driver_toggle_port_output (sl_gpio_port_t port, uint32_t pins)
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_gpio_port_t | N/A | port | |
uint32_t | N/A | pins |
sl_gpio_driver_enable_interrupts#
STATIC __INLINE sl_status_t sl_gpio_driver_enable_interrupts (uint32_t flags)
Type | Direction | Argument Name | Description |
---|---|---|---|
uint32_t | N/A | flags |
sl_gpio_driver_disable_interrupts#
STATIC __INLINE sl_status_t sl_gpio_driver_disable_interrupts (uint32_t flags)
Type | Direction | Argument Name | Description |
---|---|---|---|
uint32_t | N/A | flags |
sl_gpio_driver_set_interrupts#
STATIC __INLINE sl_status_t sl_gpio_driver_set_interrupts (uint32_t flags)
Type | Direction | Argument Name | Description |
---|---|---|---|
uint32_t | N/A | flags |
sl_gpio_driver_get_pending_interrupts#
STATIC __INLINE uint32_t sl_gpio_driver_get_pending_interrupts (void )
Type | Direction | Argument Name | Description |
---|---|---|---|
void | N/A |
sl_gpio_driver_get_enabled_interrupts#
STATIC __INLINE uint32_t sl_gpio_driver_get_enabled_interrupts (void )
Type | Direction | Argument Name | Description |
---|---|---|---|
void | N/A |
sl_gpio_driver_get_enabled_pending_interrupts#
STATIC __INLINE uint32_t sl_gpio_driver_get_enabled_pending_interrupts (void )
Type | Direction | Argument Name | Description |
---|---|---|---|
void | N/A |
sl_si91x_gpio_driver_set_pin_direction#
sl_status_t sl_si91x_gpio_driver_set_pin_direction (uint8_t port, uint8_t pin, sl_si91x_gpio_direction_t direction)
Set the direction for a GPIO pin.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint8_t | [in] | pin | - The pin number on the port. HP instance has total 57 GPIO pins. Port 0, 1, 2 has 16 pins each. Port 3 has 9 pins. ULP instance has total 12 pins. |
sl_si91x_gpio_direction_t | [in] | direction | - pin direction of type sl_si91x_gpio_direction_t '0' - Output '1' - Input |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_pin_direction#
uint8_t sl_si91x_gpio_driver_get_pin_direction (uint8_t port, uint8_t pin)
Get the direction GPIO.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint8_t | [in] | pin | - The pin number on the port. HP instance has total 57 GPIO pins. Port 0, 1, 2 has 16 pins each. Port 3 has 9 pins. ULP instance has total 12 pins. |
sl_si91x_gpio_driver_enable_pad_selection(), for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance. sl_si91x_gpio_driver_set_pin_direction()sl_si91x_gpio_driver_get_pin_direction()
Returns
Returns the direction of the pin. '0' - Output '1' - Input
sl_si91x_gpio_driver_enable_pad_receiver#
sl_status_t sl_si91x_gpio_driver_enable_pad_receiver (uint8_t gpio_num)
Enable the receiver bit in the PAD configuration register.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use. |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_disable_pad_receiver#
sl_status_t sl_si91x_gpio_driver_disable_pad_receiver (uint8_t gpio_num)
Disable the receiver bit in the PAD configuration register.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use. |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_enable_pad_selection#
sl_status_t sl_si91x_gpio_driver_enable_pad_selection (uint8_t gpio_padnum)
Select the pad(0 to 21).
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_padnum | - PAD number to be use |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_pad_driver_strength#
sl_status_t sl_si91x_gpio_driver_select_pad_driver_strength (uint8_t gpio_num, sl_si91x_gpio_driver_strength_select_t strength)
Select drive strength of a GPIO pin.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use |
sl_si91x_gpio_driver_strength_select_t | [in] | strength | - Drive strength selector(E1,E2) of type sl_si91x_gpio_driver_strength_select_t possible values are 0, for two_milli_amps (E1=0,E2=0) 1, for four_milli_amps (E1=0,E2=1) 2, for eight_milli_amps (E1=1,E2=0) 3, for twelve_milli_amps(E1=1,E2=1) |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_pad_driver_disable_state#
sl_status_t sl_si91x_gpio_driver_select_pad_driver_disable_state (uint8_t gpio_num, sl_si91x_gpio_driver_disable_state_t disable_state)
Select the Driver disabled state control.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use |
sl_si91x_gpio_driver_disable_state_t | [in] | disable_state | - driver disable state of type sl_si91x_gpio_driver_disable_state_t possible values are 0, for HiZ (P1=0,P2=0) 1, for Pull-up (P1=0,P2=1) 2, for Pull-down (P1=1,P2=0) 3, for Repeater (P1=1,P2=1) |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_group_interrupt_and_or#
sl_status_t sl_si91x_gpio_driver_select_group_interrupt_and_or (uint8_t port, sl_si91x_group_interrupt_t group_interrupt, sl_si91x_gpio_and_or_t and_or)
Select AND/OR of the group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - Group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_and_or_t | [in] | and_or | - AND/OR of GPIO group interrupts of type sl_si91x_gpio_and_or_t '0' - AND '1' - OR |
If multiple interrupts on same port (or) different are to be generated, then use this API. Example: Consider port 0: pin 2,3 and port 3: pin 1,2 for interrupt generation. Choose OR, any of the selected pin is fine for group interrupt generation Choose AND, all the selected pins are necessary for group interrupt generation
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_clear_group_interrupt#
sl_status_t sl_si91x_gpio_driver_clear_group_interrupt (sl_si91x_group_interrupt_t group_interrupt)
Clear the group interrupt status.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_group_interrupt_t | [in] | group_interrupt | - Group interrupt number of type sl_si91x_group_interrupt_t |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_group_interrupt_status#
uint32_t sl_si91x_gpio_driver_get_group_interrupt_status (uint8_t port, sl_si91x_group_interrupt_t group_interrupt)
Get the group interrupt status.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - Group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns the group interrupt status register 1, when interrupt is enabled 0, when interrupt is disabled
sl_si91x_gpio_driver_select_group_interrupt_wakeup#
sl_status_t sl_si91x_gpio_driver_select_group_interrupt_wakeup (uint8_t port, sl_si91x_group_interrupt_t group_interrupt, sl_si91x_gpio_wakeup_t flags)
Configure the group interrupt wake up the interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - Group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_wakeup_t | [in] | flags | - GPIO group interrupt wake up flag of type sl_si91x_gpio_wakeup_t '1' - enable '0' - disable |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_configure_group_interrupt#
sl_status_t sl_si91x_gpio_driver_configure_group_interrupt (sl_si91x_gpio_group_interrupt_config_t * configuration, sl_gpio_irq_callback_t gpio_callback, gpio_callback)
Configure the MCU HP group interrupts.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_gpio_group_interrupt_config_t * | [in] | configuration | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_gpio_irq_callback_t | [in] | gpio_callback | - configuration pointer to sl_si91x_gpio_group_interrupt_config_t structure |
[in] | gpio_callback | - IRQ function pointer |
Returns
returns status 0 if successful, else error code. SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_group_interrupt_polarity#
uint8_t sl_si91x_gpio_driver_get_group_interrupt_polarity (sl_si91x_group_interrupt_t group_interrupt, uint8_t port, uint8_t pin)
Get the polarity of group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint8_t | [in] | pin | - The pin number on the port. HP instance has total 57 GPIO pins. Port 0, 1, 2 has 16 pins each. Port 3 has 9 pins. ULP instance has total 12 pins. |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns group interrupt polarity 1, when GPIO pin status is '1' 0, when GPIO pin status is '0'
sl_si91x_gpio_driver_set_group_interrupt_polarity#
sl_status_t sl_si91x_gpio_driver_set_group_interrupt_polarity (sl_si91x_group_interrupt_t group_interrupt, uint8_t port, uint8_t pin, sl_si91x_gpio_polarity_t polarity)
Configure the polarity of group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint8_t | [in] | pin | - The pin number on the port. HP instance has total 57 GPIO pins. Port 0, 1, 2 has 16 pins each. Port 3 has 9 pins. ULP instance has total 12 pins. |
sl_si91x_gpio_polarity_t | [in] | polarity | - polarity of GPIO group interrupt of type sl_si91x_gpio_polarity_t 1, group interrupt gets generated when GPIO pin status is '1' 0, group interrupt gets generated when GPIO pin status is '0' |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_group_interrupt_level_edge#
uint8_t sl_si91x_gpio_driver_get_group_interrupt_level_edge (uint8_t port, sl_si91x_group_interrupt_t group_interrupt)
Get the level/edge event of group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns group interrupt level_edge 1, for Edge 0, for Level
sl_si91x_gpio_driver_set_group_interrupt_level_edge#
sl_status_t sl_si91x_gpio_driver_set_group_interrupt_level_edge (uint8_t port, sl_si91x_group_interrupt_t group_interrupt, sl_si91x_gpio_level_edge_t level_edge)
Set the level/edge event of group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_level_edge_t | [in] | level_edge | - GPIO level edge group interrupt of type sl_si91x_gpio_level_edge_t 1, for Edge 0, for Level |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_unmask_group_interrupt#
sl_status_t sl_si91x_gpio_driver_unmask_group_interrupt (uint8_t port, sl_si91x_group_interrupt_t group_interrupt)
Unmask the group interrupts.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_mask_group_interrupt#
sl_status_t sl_si91x_gpio_driver_mask_group_interrupt (uint8_t port, sl_si91x_group_interrupt_t group_interrupt)
Mask the group interrupts.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_disable_clock#
sl_status_t sl_si91x_gpio_driver_disable_clock (sl_si91x_gpio_select_clock_t clock)
Disable HP/ULP GPIO clock.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_gpio_select_clock_t | [in] | clock | - Selects M4 clock or ULP clock of type sl_si91x_gpio_select_clock_t 0, for M4 GPIO CLK 1, for ULP GPIO CLK |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_enable_clock#
sl_status_t sl_si91x_gpio_driver_enable_clock (sl_si91x_gpio_select_clock_t clock)
Enable HP/ULP GPIO clock.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_gpio_select_clock_t | [in] | clock | - Selects M4 clock or ULP clock of type sl_si91x_gpio_select_clock_t 0, for M4 GPIO CLK 1, for ULP GPIO CLK |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_configure_ulp_group_interrupt#
sl_status_t sl_si91x_gpio_driver_configure_ulp_group_interrupt (sl_si91x_gpio_group_interrupt_config_t * configuration, sl_gpio_irq_callback_t gpio_callback)
Configure the ULP group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_gpio_group_interrupt_config_t * | [in] | configuration | - configuration pointer to sl_si91x_gpio_group_interrupt_config_t structure |
sl_gpio_irq_callback_t | [in] | gpio_callback | - IRQ function pointer |
Configure ULP GPIO group interrupts.
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_set_pin_direction() Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
Returns
returns status 0 if successful, else error code. SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_enable_group_interrupt#
sl_status_t sl_si91x_gpio_driver_enable_group_interrupt (sl_si91x_group_interrupt_t group_interrupt, uint8_t port, uint8_t pin)
Enable the group interrupts.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint8_t | [in] | pin | - The pin number on the port. HP instance has total 57 GPIO pins. Port 0, 1, 2 has 16 pins each. Port 3 has 9 pins. ULP instance has total 12 pins. |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_disable_group_interrupt#
sl_status_t sl_si91x_gpio_driver_disable_group_interrupt (sl_si91x_group_interrupt_t group_interrupt, uint8_t port, uint8_t pin)
Disable the group interrupts.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_group_interrupt_t | [in] | group_interrupt | - GPIO group interrupt number of type sl_si91x_group_interrupt_t |
uint8_t | [in] | port | - The port to associate with the pin. HP instance - PORT 0,1,2,3 ULP instance - PORT 4 |
uint8_t | [in] | pin | - The pin number on the port. HP instance has total 57 GPIO pins. Port 0, 1, 2 has 16 pins each. Port 3 has 9 pins. ULP instance has total 12 pins. |
sl_si91x_gpio_driver_enable_clock, for HP instance
sl_si91x_gpio_driver_enable_pad_receiver(), for HP instance
sl_si91x_gpio_driver_enable_ulp_pad_receiver(), for ULP instance Use corresponding pad receiver API for corresponding GPIO instance.
sl_si91x_gpio_driver_configure_ulp_group_interrupt(), for HP instance
sl_si91x_gpio_driver_configure_ulp_group_interrupt, for ULP instance Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_ulp_pad_slew_rate#
sl_status_t sl_si91x_gpio_driver_select_ulp_pad_slew_rate (uint8_t gpio_num, sl_si91x_gpio_slew_rate_t slew_rate)
Select the slew rate.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use |
sl_si91x_gpio_slew_rate_t | [in] | slew_rate | - slew rate of type sl_si91x_gpio_slew_rate_t '0' - Slow '1' - Fast |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_ulp_pad_driver_strength#
sl_status_t sl_si91x_gpio_driver_select_ulp_pad_driver_strength (uint8_t gpio_num, sl_si91x_gpio_driver_strength_select_t strength)
Select the drive strength.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use |
sl_si91x_gpio_driver_strength_select_t | [in] | strength | - Drive strength selector(E1,E2) of type sl_si91x_gpio_driver_strength_select_t 0, for two_milli_amps (E1=0,E2=0) 1, for four_milli_amps (E1=0,E2=1) 2, for eight_milli_amps (E1=1,E2=0) 3, for twelve_milli_amps(E1=1,E2=1) |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_ulp_pad_driver_disable_state#
sl_status_t sl_si91x_gpio_driver_select_ulp_pad_driver_disable_state (uint8_t gpio_num, sl_si91x_gpio_driver_disable_state_t disable_state)
Select the driver-disabled state control.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be use |
sl_si91x_gpio_driver_disable_state_t | [in] | disable_state | - driver disable state of type sl_si91x_gpio_driver_disable_state_t 0, for HiZ (P1=0,P2=0) 1, for Pull up (P1=0,P2=1) 2, for Pull down (P1=1,P2=0) 3, for Repeater (P1=1,P2=1) |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_disable_ulp_pad_receiver#
sl_status_t sl_si91x_gpio_driver_disable_ulp_pad_receiver (uint8_t gpio_num)
Disable the receiver bit for ULP.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be used |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_enable_ulp_pad_receiver#
sl_status_t sl_si91x_gpio_driver_enable_ulp_pad_receiver (uint8_t gpio_num)
Enable the receiver bit for ULP.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | gpio_num | - GPIO number to be used |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_configure_ulp_pin_interrupt#
sl_status_t sl_si91x_gpio_driver_configure_ulp_pin_interrupt (uint8_t int_no, sl_si91x_gpio_interrupt_config_flag_t flags, sl_si91x_gpio_pin_ulp_t pin, sl_gpio_irq_callback_t gpio_callback)
Configure the MCU ULP GPIO pin interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | int_no | - The interrupt number to trigger. |
sl_si91x_gpio_interrupt_config_flag_t | [in] | flags | - Interrupt configuration flags of type sl_si91x_gpio_interrupt_config_flag_t |
sl_si91x_gpio_pin_ulp_t | [in] | pin | - GPIO pin number |
sl_gpio_irq_callback_t | [in] | gpio_callback | - IRQ function pointer |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_set_uulp_npss_pin_mux#
sl_status_t sl_si91x_gpio_driver_set_uulp_npss_pin_mux (uint8_t pin, sl_si91x_uulp_npss_mode_t mode)
Set the NPSS GPIO pin MUX(mode).
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - NPSS GPIO pin number(0...4) of type sl_si91x_uulp_npss_mode_t |
sl_si91x_uulp_npss_mode_t | [in] | mode | - NPSS GPIO MUX value |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_select_uulp_npss_receiver#
sl_status_t sl_si91x_gpio_driver_select_uulp_npss_receiver (uint8_t pin, sl_si91x_gpio_receiver_t receiver)
Enable/disable NPSS GPIO receiver.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - is NPSS GPIO pin number (0...4) |
sl_si91x_gpio_receiver_t | [in] | receiver | - is enable/disable NPSS GPIO receiver of type sl_si91x_gpio_receiver_t '1' - Enable '0' - Disable |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_set_uulp_npss_direction#
sl_status_t sl_si91x_gpio_driver_set_uulp_npss_direction (uint8_t pin, sl_si91x_gpio_direction_t direction)
Set the direction of the NPSS GPIO.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - is NPSS GPIO pin number (0...4) |
sl_si91x_gpio_direction_t | [in] | direction | - is direction value (Input / Output) of type sl_si91x_gpio_direction_t '1' - Input Direction '0' - Output Direction |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_uulp_npss_direction#
uint8_t sl_si91x_gpio_driver_get_uulp_npss_direction (uint8_t pin)
Get the direction of the NPSS GPIO.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - is NPSS GPIO pin number(0...4) |
Returns
returns the GPIO pin direction
1, Input Direction
0, Output Direction
sl_si91x_gpio_driver_set_uulp_npss_pin_value#
sl_status_t sl_si91x_gpio_driver_set_uulp_npss_pin_value (uint8_t pin, sl_si91x_gpio_pin_value_t pin_value)
Control the NPSS GPIO pin value.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - is NPSS GPIO pin number (0...4) of type sl_si91x_gpio_pin_value_t |
sl_si91x_gpio_pin_value_t | [in] | pin_value | - is NPSS GPIO pin value '0' - Output '1' - Input |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_uulp_npss_pin#
uint8_t sl_si91x_gpio_driver_get_uulp_npss_pin (uint8_t pin)
Get the NPSS GPIO pin value.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - is NPSS GPIO pin number (0...4) |
Returns
returns the pin logical state of pin '0' - Output '1' - Input
sl_si91x_gpio_driver_select_uulp_npss_polarity#
sl_status_t sl_si91x_gpio_driver_select_uulp_npss_polarity (uint8_t pin, sl_si91x_gpio_polarity_t polarity)
Select the NPSS GPIO polarity.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - is NPSS GPIO pin number (0...4) |
sl_si91x_gpio_polarity_t | [in] | polarity | - GPIO polarity sl_si91x_gpio_polarity_t '1' - High '0' - Low |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_set_uulp_npss_wakeup_interrupt#
sl_status_t sl_si91x_gpio_driver_set_uulp_npss_wakeup_interrupt (uint8_t npssgpio_interrupt)
Set the UULP NPSS GPIO to wake up interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | npssgpio_interrupt | - OR'ed values of the NPSS GPIO interrupts |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_clear_uulp_npss_wakeup_interrupt#
sl_status_t sl_si91x_gpio_driver_clear_uulp_npss_wakeup_interrupt (uint8_t npssgpio_interrupt)
Clear the UULP NPSS GPIO to wake up interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | npssgpio_interrupt | - OR'ed values of the NPSS GPIO interrupts |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_mask_uulp_npss_interrupt#
sl_status_t sl_si91x_gpio_driver_mask_uulp_npss_interrupt (uint8_t npssgpio_interrupt)
Mask the NPSS GPIO interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | npssgpio_interrupt | - OR'ed values of the NPSS GPIO interrupts |
sl_si91x_gpio_set_uulp_pad_configuration()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_unmask_uulp_npss_interrupt#
sl_status_t sl_si91x_gpio_driver_unmask_uulp_npss_interrupt (uint8_t npssgpio_interrupt)
Unmask the NPSS GPIO interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | npssgpio_interrupt | - OR'ed values of the NPSS GPIO interrupts |
sl_si91x_gpio_set_uulp_pad_configuration()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_clear_uulp_interrupt#
sl_status_t sl_si91x_gpio_driver_clear_uulp_interrupt (uint8_t npssgpio_interrupt)
Clear the NPSS GPIO interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | npssgpio_interrupt | - OR'ed values of the NPSS GPIO interrupts |
sl_si91x_gpio_set_uulp_pad_configuration()
sl_si91x_gpio_configure_uulp_interrupt()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_uulp_interrupt_status#
uint8_t sl_si91x_gpio_driver_get_uulp_interrupt_status (void )
Get the NPSS GPIO interrupt status.
Type | Direction | Argument Name | Description |
---|---|---|---|
void | [in] |
sl_si91x_gpio_set_uulp_pad_configuration()
sl_si91x_gpio_configure_uulp_interrupt()
Returns
returns the UULP INTR status. 1, interrupt has been raised 0, interrupt is masked or not raised
sl_si91x_gpio_driver_clear_ulp_interrupt#
sl_status_t sl_si91x_gpio_driver_clear_ulp_interrupt (uint32_t flags)
Clear one or more pending ULP GPIO interrupts.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint32_t | [in] | flags | : ULP GPIO interrupt sources to clear. |
sl_si91x_gpio_configure_ulp_pin_interrupt()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_clear_ulp_group_interrupt#
sl_status_t sl_si91x_gpio_driver_clear_ulp_group_interrupt (sl_si91x_group_interrupt_t group_interrupt)
Clear the ULP group interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_group_interrupt_t | [in] | group_interrupt | - Group interrupt number of type sl_si91x_group_interrupt_t |
sl_si91x_gpio_driver_set_pin_direction()sl_si91x_gpio_driver_configure_ulp_group_interrupt() Use corresponding group interrupt configuration API for corresponding GPIO instance.
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_configure_uulp_interrupt#
sl_status_t sl_si91x_gpio_driver_configure_uulp_interrupt (sl_si91x_gpio_interrupt_config_flag_t flags, uint8_t npssgpio_interrupt, sl_gpio_irq_callback_t gpio_callback)
Configure the UULP GPIO pin interrupt.
Type | Direction | Argument Name | Description |
---|---|---|---|
sl_si91x_gpio_interrupt_config_flag_t | [in] | flags | - Interrupt configuration flags of type sl_si91x_gpio_interrupt_config_flag_t |
uint8_t | [in] | npssgpio_interrupt | - OR'ed values of the NPSS GPIO interrupts |
sl_gpio_irq_callback_t | [in] | gpio_callback | - IRQ function pointer |
sl_si91x_gpio_set_uulp_pad_configuration()
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_toggle_uulp_npss_pin#
sl_status_t sl_si91x_gpio_driver_toggle_uulp_npss_pin (uint8_t pin)
Toggle the UULP pin.
Type | Direction | Argument Name | Description |
---|---|---|---|
uint8_t | [in] | pin | - UULP pin number to toggle |
Returns
returns status 0 if successful, else error code. SL_STATUS_INVALID_PARAMETER (0x0021) - The parameter is invalid argument SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_set_uulp_pad_configuration#
sl_status_t sl_si91x_gpio_driver_set_uulp_pad_configuration (uulp_pad_config_t * pad_config)
Indicate UULP GPIO PAD configuration.
Type | Direction | Argument Name | Description |
---|---|---|---|
uulp_pad_config_t * | [in] | pad_config | : PAD configuration pointer to uulp_pad_config_t structure |
Returns
returns status 0 if successful, else error code. SL_STATUS_NULL_POINTER (0x0022) - The parameter is null pointer SL_STATUS _OK (0X000) - Success
sl_si91x_gpio_driver_get_version#
sl_si91x_gpio_version_t sl_si91x_gpio_driver_get_version (void )
Get the release, SQA, and development version numbers of the GPIO peripheral.
Type | Direction | Argument Name | Description |
---|---|---|---|
void | [in] |
Returns
returns structure of type sl_si91x_gpio_version_t