Generic PPI Layer

group nrfx_gppi

Helper layer that provides the common functionality of PPI and DPPI drivers.

Use PPI and DPPI drivers directly. This layer is provided only to help create generic code that can be built for SoCs equipped with either of these peripherals. When using this layer, take into account that there are significant differences between the PPI and DPPI interfaces that affect the behavior of this layer.

One difference is that PPI allows associating of one task or event with more than one channel, whereas DPPI does not allow this. In DPPI, the second association overwrites the first one. Consequently, this helper layer cannot be used in applications that need to connect a task or event to multiple channels.

Another difference is that in DPPI one channel can be associated with multiple tasks and multiple events, while in PPI this is not possible (with the exception of the association of a second task as a fork). Because of this difference, it is important to clear the previous endpoints of the channel that is to be reused with some different ones. Otherwise, the behavior of this helper layer will be different, depending on the actual interface used: in DPPI the channel configuration will be extended with the new endpoints, and in PPI the new endpoints will replace the previous ones.

Enums

enum nrfx_gppi_channel_group_t

Generic PPI channel groups.

Values:

enumerator NRFX_GPPI_CHANNEL_GROUP0

Channel group 0.

enumerator NRFX_GPPI_CHANNEL_GROUP1

Channel group 1.

enumerator NRFX_GPPI_CHANNEL_GROUP2

Channel group 2.

enumerator NRFX_GPPI_CHANNEL_GROUP3

Channel group 3.

enumerator NRFX_GPPI_CHANNEL_GROUP4

Channel group 4.

enumerator NRFX_GPPI_CHANNEL_GROUP5

Channel group 5.

enum nrfx_gppi_task_t

Generic PPI tasks.

Values:

enumerator NRFX_GPPI_TASK_CHG0_EN

Task for enabling channel group 0

enumerator NRFX_GPPI_TASK_CHG0_DIS

Task for disabling channel group 0

enumerator NRFX_GPPI_TASK_CHG1_EN

Task for enabling channel group 1

enumerator NRFX_GPPI_TASK_CHG1_DIS

Task for disabling channel group 1

enumerator NRFX_GPPI_TASK_CHG2_EN

Task for enabling channel group 2

enumerator NRFX_GPPI_TASK_CHG2_DIS

Task for disabling channel group 2

enumerator NRFX_GPPI_TASK_CHG3_EN

Task for enabling channel group 3

enumerator NRFX_GPPI_TASK_CHG3_DIS

Task for disabling channel group 3

enumerator NRFX_GPPI_TASK_CHG4_EN

Task for enabling channel group 4

enumerator NRFX_GPPI_TASK_CHG4_DIS

Task for disabling channel group 4

enumerator NRFX_GPPI_TASK_CHG5_EN

Task for enabling channel group 5

enumerator NRFX_GPPI_TASK_CHG5_DIS

Task for disabling channel group 5

Functions

__STATIC_INLINE bool nrfx_gppi_channel_check(uint8_t channel)

Function for checking if a given channel is enabled.

Parameters:
  • channel[in] Channel to check.

Return values:
  • true – The channel is enabled.

  • false – The channel is not enabled.

__STATIC_INLINE void nrfx_gppi_channels_disable_all(void)

Function for disabling all channels.

__STATIC_INLINE void nrfx_gppi_channels_enable(uint32_t mask)

Function for enabling multiple channels.

The bits in mask value correspond to particular channels. This means that writing 1 to bit 0 enables channel 0, writing 1 to bit 1 enables channel 1, etc.

Parameters:
  • mask[in] Channel mask.

__STATIC_INLINE void nrfx_gppi_channels_disable(uint32_t mask)

Function for disabling multiple channels.

The bits in mask value correspond to particular channels. This means that writing 1 to bit 0 disables channel 0, writing 1 to bit 1 disables channel 1, etc.

Parameters:
  • mask[in] Channel mask.

__STATIC_INLINE void nrfx_gppi_event_endpoint_setup(uint8_t channel, uint32_t eep)

Function for associating a given channel with the specified event register.

This function sets the DPPI publish configuration for a given event or sets the PPI event endpoint register.

Parameters:
  • channel[in] Channel to which to assign the event.

  • eep[in] Address of the event register.

__STATIC_INLINE void nrfx_gppi_task_endpoint_setup(uint8_t channel, uint32_t tep)

Function for associating a given channel with the specified task register.

This function sets the DPPI subscribe configuration for a given task or sets the PPI task endpoint register.

Parameters:
  • channel[in] Channel to which to assign the task.

  • tep[in] Address of the task register.

__STATIC_INLINE void nrfx_gppi_channel_endpoints_setup(uint8_t channel, uint32_t eep, uint32_t tep)

Function for setting up the event and task endpoints for a given channel.

Parameters:
  • channel[in] Channel to which the given endpoints are assigned.

  • eep[in] Address of the event register.

  • tep[in] Address of the task register.

__STATIC_INLINE void nrfx_gppi_event_endpoint_clear(uint8_t channel, uint32_t eep)

Function for clearing the DPPI publish configuration for a given event register or for clearing the PPI event endpoint register.

Parameters:
  • channel[in] Channel for which to clear the event endpoint. Not used in DPPI.

  • eep[in] Address of the event register. Not used in PPI.

__STATIC_INLINE void nrfx_gppi_task_endpoint_clear(uint8_t channel, uint32_t tep)

Function for clearing the DPPI subscribe configuration for a given task register or for clearing the PPI task endpoint register.

Parameters:
  • channel[in] Channel from which to disconnect the task enpoint. Not used in DPPI.

  • tep[in] Address of the task register. Not used in PPI.

__STATIC_INLINE void nrfx_gppi_fork_endpoint_setup(uint8_t channel, uint32_t fork_tep)

Function for setting up the task endpoint for a given PPI fork or for associating the DPPI channel with an additional task register.

Parameters:
  • channel[in] Channel to which the given fork endpoint is assigned.

  • fork_tep[in] Address of the task register.

__STATIC_INLINE void nrfx_gppi_fork_endpoint_clear(uint8_t channel, uint32_t fork_tep)

Function for clearing the task endpoint for a given PPI fork or for clearing the DPPI subscribe register.

Parameters:
  • channel[in] Channel for which to clear the fork endpoint. Not used in DPPI.

  • fork_tep[in] Address of the task register. Not used in PPI.

__STATIC_INLINE void nrfx_gppi_channels_include_in_group(uint32_t channel_mask, nrfx_gppi_channel_group_t channel_group)

Function for including multiple channels in a channel group.

Parameters:
  • channel_mask[in] Channels to be included in the group.

  • channel_group[in] Channel group.

__STATIC_INLINE void nrfx_gppi_channels_remove_from_group(uint32_t channel_mask, nrfx_gppi_channel_group_t channel_group)

Function for removing multiple channels from a channel group.

Parameters:
  • channel_mask[in] Channels to be removed from the group.

  • channel_group[in] Channel group.

__STATIC_INLINE void nrfx_gppi_group_clear(nrfx_gppi_channel_group_t channel_group)

Function for removing all channels from a channel group.

Parameters:
  • channel_group[in] Channel group.

__STATIC_INLINE void nrfx_gppi_group_enable(nrfx_gppi_channel_group_t channel_group)

Function for enabling a channel group.

Parameters:
  • channel_group[in] Channel group.

__STATIC_INLINE void nrfx_gppi_group_disable(nrfx_gppi_channel_group_t channel_group)

Function for disabling a group.

Parameters:
  • channel_group[in] Channel group.

__STATIC_INLINE void nrfx_gppi_task_trigger(nrfx_gppi_task_t task)

Function for activating a task.

Parameters:
  • task[in] Task to be activated.

__STATIC_INLINE uint32_t nrfx_gppi_task_address_get(nrfx_gppi_task_t task)

Function for returning the address of a specific task register.

Parameters:
  • task[in] PPI or DPPI task.

Returns:

Address of the requested task register.

__STATIC_INLINE nrfx_gppi_task_t nrfx_gppi_group_disable_task_get(nrfx_gppi_channel_group_t group)

Function for returning the address of a channel group disable task.

Parameters:
  • group[in] Channel group.

Returns:

Disable task address of the specified group.

__STATIC_INLINE nrfx_gppi_task_t nrfx_gppi_group_enable_task_get(nrfx_gppi_channel_group_t group)

Function for returning the address of a channel group enable task.

Parameters:
  • group[in] Channel group.

Returns:

Enable task address of the specified group.

__STATIC_INLINE nrfx_err_t nrfx_gppi_channel_alloc(uint8_t *p_channel)

Function for allocating a channel.

Parameters:
  • p_channel[out] After successful allocation, index of the allocated channel.

Return values:
  • NRFX_SUCCESS – Channel was successfully allocated.

  • NRFX_ERROR_NO_MEM – There is no available channel to be used.

  • NRFX_ERROR_NOT_SUPPORTED – Driver is not enabled.

__STATIC_INLINE nrfx_err_t nrfx_gppi_channel_free(uint8_t channel)

Function for freeing a channel.

Parameters:
  • channel[in] (D)PPI channel to be freed.

Return values:
  • NRFX_SUCCESS – The channel was successfully freed.

  • NRFX_ERROR_INVALID_PARAM – The specified channel is not allocated or is not user-configurable.

  • NRFX_ERROR_NOT_SUPPORTED – Driver is not enabled.

__STATIC_INLINE nrfx_err_t nrfx_gppi_group_alloc(nrfx_gppi_channel_group_t *p_group)

Function for allocating a channel group.

Parameters:
  • p_group[out] Pointer to the (D)PPI channel group that has been allocated.

Return values:
  • NRFX_SUCCESS – The channel group was successfully allocated.

  • NRFX_ERROR_NO_MEM – There is no available channel group to be used.

  • NRFX_ERROR_NOT_SUPPORTED – Driver is not enabled.

__STATIC_INLINE nrfx_err_t nrfx_gppi_group_free(nrfx_gppi_channel_group_t group)

Function for freeing a channel group.

Parameters:
  • group[in] (D)PPI channel group to be freed.

Return values:
  • NRFX_SUCCESS – The channel was successfully freed.

  • NRFX_ERROR_INVALID_PARAM – The specified channel is not allocated or is not user-configurable.

  • NRFX_ERROR_NOT_SUPPORTED – Driver is not enabled.