IPC HAL
- group nrf_ipc_hal
Hardware access layer for managing the Interprocessor Communication (IPC) peripheral.
Enums
-
enum nrf_ipc_task_t
IPC tasks.
Values:
-
enumerator NRF_IPC_TASK_SEND_0
Trigger events on channels enabled in SEND_CNF[0].
-
enumerator NRF_IPC_TASK_SEND_1
Trigger events on channels enabled in SEND_CNF[1].
-
enumerator NRF_IPC_TASK_SEND_2
Trigger events on channels enabled in SEND_CNF[2].
-
enumerator NRF_IPC_TASK_SEND_3
Trigger events on channels enabled in SEND_CNF[3].
-
enumerator NRF_IPC_TASK_SEND_4
Trigger events on channels enabled in SEND_CNF[4].
-
enumerator NRF_IPC_TASK_SEND_5
Trigger events on channels enabled in SEND_CNF[5].
-
enumerator NRF_IPC_TASK_SEND_6
Trigger events on channels enabled in SEND_CNF[6].
-
enumerator NRF_IPC_TASK_SEND_7
Trigger events on channels enabled in SEND_CNF[7].
-
enumerator NRF_IPC_TASK_SEND_8
Trigger events on channels enabled in SEND_CNF[8].
-
enumerator NRF_IPC_TASK_SEND_9
Trigger events on channels enabled in SEND_CNF[9].
-
enumerator NRF_IPC_TASK_SEND_10
Trigger events on channels enabled in SEND_CNF[10].
-
enumerator NRF_IPC_TASK_SEND_11
Trigger events on channels enabled in SEND_CNF[11].
-
enumerator NRF_IPC_TASK_SEND_12
Trigger events on channels enabled in SEND_CNF[12].
-
enumerator NRF_IPC_TASK_SEND_13
Trigger events on channels enabled in SEND_CNF[13].
-
enumerator NRF_IPC_TASK_SEND_14
Trigger events on channels enabled in SEND_CNF[14].
-
enumerator NRF_IPC_TASK_SEND_15
Trigger events on channels enabled in SEND_CNF[15].
-
enumerator NRF_IPC_TASK_SEND_0
-
enum nrf_ipc_event_t
IPC events.
Values:
-
enumerator NRF_IPC_EVENT_RECEIVE_0
Event received on the IPC channels enabled in RECEIVE_CNF[0] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_1
Event received on the IPC channels enabled in RECEIVE_CNF[1] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_2
Event received on the IPC channels enabled in RECEIVE_CNF[2] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_3
Event received on the IPC channels enabled in RECEIVE_CNF[3] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_4
Event received on the IPC channels enabled in RECEIVE_CNF[4] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_5
Event received on the IPC channels enabled in RECEIVE_CNF[5] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_6
Event received on the IPC channels enabled in RECEIVE_CNF[6] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_7
Event received on the IPC channels enabled in RECEIVE_CNF[7] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_8
Event received on the IPC channels enabled in RECEIVE_CNF[8] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_9
Event received on the IPC channels enabled in RECEIVE_CNF[9] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_10
Event received on the IPC channels enabled in RECEIVE_CNF[10] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_11
Event received on the IPC channels enabled in RECEIVE_CNF[11] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_12
Event received on the IPC channels enabled in RECEIVE_CNF[12] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_13
Event received on the IPC channels enabled in RECEIVE_CNF[13] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_14
Event received on the IPC channels enabled in RECEIVE_CNF[14] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_15
Event received on the IPC channels enabled in RECEIVE_CNF[15] register.
-
enumerator NRF_IPC_EVENT_RECEIVE_0
-
enum nrf_ipc_channel_t
IPC channel positions.
Values:
-
enumerator NRF_IPC_CHANNEL_0
Bitmask position for IPC channel 0.
-
enumerator NRF_IPC_CHANNEL_1
Bitmask position for IPC channel 1.
-
enumerator NRF_IPC_CHANNEL_2
Bitmask position for IPC channel 2.
-
enumerator NRF_IPC_CHANNEL_3
Bitmask position for IPC channel 3.
-
enumerator NRF_IPC_CHANNEL_4
Bitmask position for IPC channel 4.
-
enumerator NRF_IPC_CHANNEL_5
Bitmask position for IPC channel 5.
-
enumerator NRF_IPC_CHANNEL_6
Bitmask position for IPC channel 6.
-
enumerator NRF_IPC_CHANNEL_7
Bitmask position for IPC channel 7.
-
enumerator NRF_IPC_CHANNEL_8
Bitmask position for IPC channel 8.
-
enumerator NRF_IPC_CHANNEL_9
Bitmask position for IPC channel 9.
-
enumerator NRF_IPC_CHANNEL_10
Bitmask position for IPC channel 10.
-
enumerator NRF_IPC_CHANNEL_11
Bitmask position for IPC channel 11.
-
enumerator NRF_IPC_CHANNEL_12
Bitmask position for IPC channel 12.
-
enumerator NRF_IPC_CHANNEL_13
Bitmask position for IPC channel 13.
-
enumerator NRF_IPC_CHANNEL_14
Bitmask position for IPC channel 14.
-
enumerator NRF_IPC_CHANNEL_15
Bitmask position for IPC channel 15.
-
enumerator NRF_IPC_CHANNEL_0
-
enum nrf_ipc_int_mask_t
IPC interrupts.
Values:
-
enumerator NRF_IPC_INT_RECEIVE_0
Interrupt on receive event 0.
-
enumerator NRF_IPC_INT_RECEIVE_1
Interrupt on receive event 1.
-
enumerator NRF_IPC_INT_RECEIVE_2
Interrupt on receive event 2.
-
enumerator NRF_IPC_INT_RECEIVE_3
Interrupt on receive event 3.
-
enumerator NRF_IPC_INT_RECEIVE_4
Interrupt on receive event 4.
-
enumerator NRF_IPC_INT_RECEIVE_5
Interrupt on receive event 5.
-
enumerator NRF_IPC_INT_RECEIVE_6
Interrupt on receive event 6.
-
enumerator NRF_IPC_INT_RECEIVE_7
Interrupt on receive event 7.
-
enumerator NRF_IPC_INT_RECEIVE_8
Interrupt on receive event 8.
-
enumerator NRF_IPC_INT_RECEIVE_9
Interrupt on receive event 9.
-
enumerator NRF_IPC_INT_RECEIVE_10
Interrupt on receive event 10.
-
enumerator NRF_IPC_INT_RECEIVE_11
Interrupt on receive event 11.
-
enumerator NRF_IPC_INT_RECEIVE_12
Interrupt on receive event 12.
-
enumerator NRF_IPC_INT_RECEIVE_13
Interrupt on receive event 13.
-
enumerator NRF_IPC_INT_RECEIVE_14
Interrupt on receive event 14.
-
enumerator NRF_IPC_INT_RECEIVE_15
Interrupt on receive event 15.
-
enumerator NRF_IPC_INT_RECEIVE_0
Functions
-
NRF_STATIC_INLINE void nrf_ipc_task_trigger(NRF_IPC_Type *p_reg, nrf_ipc_task_t task)
Function for triggering the specified IPC task.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
task – [in] Task to be triggered.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_task_address_get(NRF_IPC_Type const *p_reg, nrf_ipc_task_t task)
Function for getting the address of the specified IPC task register.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
task – [in] Specified task.
- Returns:
Address of the specified task register.
-
NRF_STATIC_INLINE void nrf_ipc_event_clear(NRF_IPC_Type *p_reg, nrf_ipc_event_t event)
Function for clearing the specified IPC event.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
event – [in] Event to clear.
-
NRF_STATIC_INLINE bool nrf_ipc_event_check(NRF_IPC_Type const *p_reg, nrf_ipc_event_t event)
Function for retrieving the state of the IPC event.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
event – [in] Event to be checked.
- Return values:
true – The event has been generated.
false – The event has not been generated.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_event_address_get(NRF_IPC_Type const *p_reg, nrf_ipc_event_t event)
Function for getting the address of the specified IPC event register.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
event – [in] Specified event.
- Returns:
Address of the specified event register.
-
NRF_STATIC_INLINE void nrf_ipc_int_enable(NRF_IPC_Type *p_reg, uint32_t mask)
Function for enabling specified interrupts.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
mask – [in] Mask of interrupts to be enabled.
-
NRF_STATIC_INLINE void nrf_ipc_int_disable(NRF_IPC_Type *p_reg, uint32_t mask)
Function for disabling specified interrupts.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
mask – [in] Mask of interrupts to be disabled.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_int_enable_check(NRF_IPC_Type const *p_reg, uint32_t mask)
Function for checking if the specified interrupts are enabled.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
mask – [in] Mask of interrupts to be checked.
- Returns:
Mask of enabled interrupts.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_int_pending_get(NRF_IPC_Type const *p_reg)
Function for retrieving the state of pending interrupts of the receive event.
States of pending interrupt are saved as a bitmask. First position corresponds with EVENTS_RECEIVE[0] event, second one with EVENTS_RECEIVE[1] etc. One set at particular position means that interrupt for event is pending.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
- Returns:
Bitmask with information about pending interrupts of EVENTS_RECEIVE[n] events.
-
NRF_STATIC_INLINE void nrf_ipc_subscribe_set(NRF_IPC_Type *p_reg, nrf_ipc_task_t task, uint8_t channel)
Function for setting the DPPI subscribe configuration for a given IPC task.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
task – [in] Task for which to set the configuration.
channel – [in] DPPI channel through which to subscribe events.
-
NRF_STATIC_INLINE void nrf_ipc_subscribe_clear(NRF_IPC_Type *p_reg, nrf_ipc_task_t task)
Function for clearing the DPPI subscribe configuration for a given IPC task.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
task – [in] Task for which to clear the configuration.
-
NRF_STATIC_INLINE void nrf_ipc_publish_set(NRF_IPC_Type *p_reg, nrf_ipc_event_t event, uint8_t channel)
Function for setting the DPPI publish configuration for a given IPC event.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
event – [in] Event for which to set the configuration.
channel – [in] DPPI channel through which to publish the event.
-
NRF_STATIC_INLINE void nrf_ipc_publish_clear(NRF_IPC_Type *p_reg, nrf_ipc_event_t event)
Function for clearing the DPPI publish configuration for a given IPC event.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
event – [in] Event for which to clear the configuration.
-
NRF_STATIC_INLINE void nrf_ipc_send_config_set(NRF_IPC_Type *p_reg, uint8_t index, uint32_t channels_mask)
Function for setting the configuration of the specified send task.
channels_mask
bitmask must be created with nrf_ipc_channel_t values: NRF_IPC_CHANNEL_0 | NRF_IPC_CHANNEL_1 | … | NRF_IPC_CHANNEL_nNote
This function overrides current configuration.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
index – [in] Index of the send task.
channels_mask – [in] Bitmask specifying channels that are to be enabled for this task.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_send_config_get(NRF_IPC_Type *const p_reg, uint8_t index)
Function for getting the configuration of the specified send task.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
index – [in] Index of the send event configuration.
- Return values:
Bitmask – of channels enabled for this task.
-
NRF_STATIC_INLINE void nrf_ipc_receive_config_set(NRF_IPC_Type *p_reg, uint8_t index, uint32_t channels_mask)
Function for assigning receive event to the IPC channels.
channels_mask
bitmask must be created with nrf_ipc_channel_t values: NRF_IPC_CHANNEL_0 | NRF_IPC_CHANNEL_1 | … | NRF_IPC_CHANNEL_nNote
This function overrides current configuration.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
index – [in] Index of the receive event configuration.
channels_mask – [in] Bitmask with IPC channels from which the receive event will generate interrupts.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_receive_config_get(NRF_IPC_Type *const p_reg, uint8_t index)
Function for getting receive event configuration.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
index – [in] Index of the receive event configuration.
- Returns:
Mask of channels connected with receive event.
-
NRF_STATIC_INLINE void nrf_ipc_gpmem_set(NRF_IPC_Type *p_reg, uint8_t index, uint32_t data)
Function for storing data in general purpose memory cell.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
index – [in] Index of the general purpose memory cell.
data – [in] Data to be stored.
-
NRF_STATIC_INLINE uint32_t nrf_ipc_gpmem_get(NRF_IPC_Type const *p_reg, uint8_t index)
Function for getting value of the general purpose memory cell.
- Parameters:
p_reg – [in] Pointer to the structure of registers of the peripheral.
index – [in] Index of the general purpose memory cell.
- Returns:
Stored data.
-
NRF_STATIC_INLINE nrf_ipc_task_t nrf_ipc_send_task_get(uint8_t index)
Function for getting SEND task by its index.
- Parameters:
index – [in] Index of the SEND task.
- Returns:
SEND task.
-
NRF_STATIC_INLINE nrf_ipc_event_t nrf_ipc_receive_event_get(uint8_t index)
Function for getting RECEIVE event by its index.
- Parameters:
index – [in] Index of the RECEIVE event.
- Returns:
RECEIVE event.
-
enum nrf_ipc_task_t