blob: 71d824bdac2a58ef6e1d7736b0d2f14e8b0363ca [file] [log] [blame]
/*
* Copyright (c) 2018 - 2019 Nordic Semiconductor ASA
* Copyright (c) 2018 Ioannis Glaropoulos
*
* SPDX-License-Identifier: Apache-2.0
*/
#if defined(CONFIG_SOC_SERIES_NRF51X) || defined(CONFIG_SOC_COMPATIBLE_NRF52X)
#include <hal/nrf_ppi.h>
static inline void hal_radio_nrf_ppi_channels_enable(uint32_t mask)
{
nrf_ppi_channels_enable(NRF_PPI, mask);
}
static inline void hal_radio_nrf_ppi_channels_disable(uint32_t mask)
{
nrf_ppi_channels_disable(NRF_PPI, mask);
}
/*******************************************************************************
* Enable Radio on Event Timer tick:
* wire the EVENT_TIMER EVENTS_COMPARE[0] event to RADIO TASKS_TXEN/RXEN task.
*
* Use the pre-programmed PPI channels if possible (if TIMER0 is used as the
* EVENT_TIMER).
*/
#if (EVENT_TIMER_ID == 0)
/* PPI channel 20 is pre-programmed with the following fixed settings:
* EEP: TIMER0->EVENTS_COMPARE[0]
* TEP: RADIO->TASKS_TXEN
*/
#define HAL_RADIO_ENABLE_TX_ON_TICK_PPI 20
/* PPI channel 21 is pre-programmed with the following fixed settings:
* EEP: TIMER0->EVENTS_COMPARE[0]
* TEP: RADIO->TASKS_RXEN
*/
#define HAL_RADIO_ENABLE_RX_ON_TICK_PPI 21
static inline void hal_radio_enable_on_tick_ppi_config_and_enable(uint8_t trx)
{
/* No need to configure anything for the pre-programmed channels.
* Just enable and disable them accordingly.
*/
nrf_ppi_channels_disable(
NRF_PPI,
trx ? BIT(HAL_RADIO_ENABLE_RX_ON_TICK_PPI)
: BIT(HAL_RADIO_ENABLE_TX_ON_TICK_PPI));
nrf_ppi_channels_enable(
NRF_PPI,
trx ? BIT(HAL_RADIO_ENABLE_TX_ON_TICK_PPI)
: BIT(HAL_RADIO_ENABLE_RX_ON_TICK_PPI));
}
#else
#define HAL_RADIO_ENABLE_ON_TICK_PPI 2
#define HAL_RADIO_ENABLE_TX_ON_TICK_PPI HAL_RADIO_ENABLE_ON_TICK_PPI
#define HAL_RADIO_ENABLE_RX_ON_TICK_PPI HAL_RADIO_ENABLE_ON_TICK_PPI
static inline void hal_radio_enable_on_tick_ppi_config_and_enable(uint8_t trx)
{
uint32_t event_address = (trx ? (uint32_t)&(NRF_RADIO->TASKS_TXEN)
: (uint32_t)&(NRF_RADIO->TASKS_RXEN));
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_RADIO_ENABLE_ON_TICK_PPI,
(uint32_t)&(EVENT_TIMER->EVENTS_COMPARE[0]),
event_address);
nrf_ppi_channels_enable(NRF_PPI, BIT(HAL_RADIO_ENABLE_ON_TICK_PPI));
}
#endif /* (EVENT_TIMER_ID == 0) */
/*******************************************************************************
* Capture event timer on Address reception:
* wire the RADIO EVENTS_ADDRESS event to the
* EVENT_TIMER TASKS_CAPTURE[<address timer>] task.
*
* Use the pre-programmed PPI channel if possible (if TIMER0 is used as the
* EVENT_TIMER).
*/
#if (EVENT_TIMER_ID == 0)
/* PPI channel 26 is pre-programmed with the following fixed settings:
* EEP: RADIO->EVENTS_ADDRESS
* TEP: TIMER0->TASKS_CAPTURE[1]
*/
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI 26
static inline void hal_radio_recv_timeout_cancel_ppi_config(void)
{
/* No need to configure anything for the pre-programmed channel. */
}
#else
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI 3
static inline void hal_radio_recv_timeout_cancel_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI,
(uint32_t)&(NRF_RADIO->EVENTS_ADDRESS),
(uint32_t)&(EVENT_TIMER->TASKS_CAPTURE[1]));
}
#endif /* (EVENT_TIMER_ID == 0) */
/*******************************************************************************
* Disable Radio on HCTO:
* wire the EVENT_TIMER EVENTS_COMPARE[<HCTO timer>] event
* to the RADIO TASKS_DISABLE task.
*
* Use the pre-programmed PPI channel if possible (if TIMER0 is used as the
* EVENT_TIMER).
*/
#if (EVENT_TIMER_ID == 0)
/* PPI channel 22 is pre-programmed with the following fixed settings:
* EEP: TIMER0->EVENTS_COMPARE[1]
* TEP: RADIO->TASKS_DISABLE
*/
#define HAL_RADIO_DISABLE_ON_HCTO_PPI 22
static inline void hal_radio_disable_on_hcto_ppi_config(void)
{
/* No need to configure anything for the pre-programmed channel. */
}
#else
#define HAL_RADIO_DISABLE_ON_HCTO_PPI 4
static inline void hal_radio_disable_on_hcto_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_RADIO_DISABLE_ON_HCTO_PPI,
(uint32_t)&(EVENT_TIMER->EVENTS_COMPARE[1]),
(uint32_t)&(NRF_RADIO->TASKS_DISABLE));
}
#endif /* (EVENT_TIMER_ID == 0) */
/*******************************************************************************
* Capture event timer on Radio end:
* wire the RADIO EVENTS_END event to the
* EVENT_TIMER TASKS_CAPTURE[<radio end timer>] task.
*
* Use the pre-programmed PPI channel if possible (if TIMER0 is used as the
* EVENT_TIMER).
*/
#if (EVENT_TIMER_ID == 0)
/* PPI channel 27 is pre-programmed with the following fixed settings:
* EEP: RADIO->EVENTS_END
* TEP: TIMER0->TASKS_CAPTURE[2]
*/
#define HAL_RADIO_END_TIME_CAPTURE_PPI 27
static inline void hal_radio_end_time_capture_ppi_config(void)
{
/* No need to configure anything for the pre-programmed channel. */
}
#else
#define HAL_RADIO_END_TIME_CAPTURE_PPI 5
static inline void hal_radio_end_time_capture_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_RADIO_END_TIME_CAPTURE_PPI,
(uint32_t)&(NRF_RADIO->EVENTS_END),
(uint32_t)&(EVENT_TIMER->TASKS_CAPTURE[2]));
}
#endif /* (EVENT_TIMER_ID == 0) */
/*******************************************************************************
* Start event timer on RTC tick:
* wire the RTC0 EVENTS_COMPARE[2] event to EVENT_TIMER TASKS_START task.
*/
#define HAL_EVENT_TIMER_START_PPI 6
static inline void hal_event_timer_start_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_EVENT_TIMER_START_PPI,
(uint32_t)&(NRF_RTC0->EVENTS_COMPARE[2]),
(uint32_t)&(EVENT_TIMER->TASKS_START));
}
/*******************************************************************************
* Capture event timer on Radio ready:
* wire the RADIO EVENTS_READY event to the
* EVENT_TIMER TASKS_CAPTURE[<radio ready timer>] task.
*/
#define HAL_RADIO_READY_TIME_CAPTURE_PPI 7
static inline void hal_radio_ready_time_capture_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_RADIO_READY_TIME_CAPTURE_PPI,
(uint32_t)&(NRF_RADIO->EVENTS_READY),
(uint32_t)&(EVENT_TIMER->TASKS_CAPTURE[0]));
}
/*******************************************************************************
* Trigger encryption task upon address reception:
* wire the RADIO EVENTS_ADDRESS event to the CCM TASKS_CRYPT task.
*
* PPI channel 25 is pre-programmed with the following fixed settings:
* EEP: RADIO->EVENTS_ADDRESS
* TEP: CCM->TASKS_CRYPT
*/
#define HAL_TRIGGER_CRYPT_PPI 25
static inline void hal_trigger_crypt_ppi_config(void)
{
/* No need to configure anything for the pre-programmed channel. */
}
/*******************************************************************************
* Trigger automatic address resolution on Bit counter match:
* wire the RADIO EVENTS_BCMATCH event to the AAR TASKS_START task.
*
* PPI channel 23 is pre-programmed with the following fixed settings:
* EEP: RADIO->EVENTS_BCMATCH
* TEP: AAR->TASKS_START
*/
#define HAL_TRIGGER_AAR_PPI 23
static inline void hal_trigger_aar_ppi_config(void)
{
/* No need to configure anything for the pre-programmed channel. */
}
/*******************************************************************************
* Trigger Radio Rate override upon Rateboost event.
*/
#if defined(CONFIG_HAS_HW_NRF_RADIO_BLE_CODED)
#define HAL_TRIGGER_RATEOVERRIDE_PPI 14
static inline void hal_trigger_rateoverride_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_TRIGGER_RATEOVERRIDE_PPI,
(uint32_t)&(NRF_RADIO->EVENTS_RATEBOOST),
(uint32_t)&(NRF_CCM->TASKS_RATEOVERRIDE));
}
#endif /* CONFIG_HAS_HW_NRF_RADIO_BLE_CODED */
/******************************************************************************/
#if defined(CONFIG_BT_CTLR_GPIO_PA_PIN) || defined(CONFIG_BT_CTLR_GPIO_LNA_PIN)
#define HAL_ENABLE_PALNA_PPI 15
#define HAL_DISABLE_PALNA_PPI 16
static inline void hal_palna_ppi_setup(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_ENABLE_PALNA_PPI,
(uint32_t)&(EVENT_TIMER->EVENTS_COMPARE[2]),
(uint32_t)&(NRF_GPIOTE->TASKS_OUT[
CONFIG_BT_CTLR_PA_LNA_GPIOTE_CHAN]));
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_DISABLE_PALNA_PPI,
(uint32_t)&(NRF_RADIO->EVENTS_DISABLED),
(uint32_t)&(NRF_GPIOTE->TASKS_OUT[
CONFIG_BT_CTLR_PA_LNA_GPIOTE_CHAN]));
}
#endif /* CONFIG_BT_CTLR_GPIO_PA_PIN || CONFIG_BT_CTLR_GPIO_LNA_PIN */
/******************************************************************************/
#if !defined(CONFIG_BT_CTLR_TIFS_HW)
/* PPI setup used for SW-based auto-switching during TIFS. */
#if !defined(CONFIG_BT_CTLR_SW_SWITCH_SINGLE_TIMER)
/* Clear SW-switch timer on packet end:
* wire the RADIO EVENTS_END event to SW_SWITCH_TIMER TASKS_CLEAR task.
*
* Note: this PPI is not needed if we use a single TIMER instance in radio.c
*/
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI 8
static inline void hal_sw_switch_timer_clear_ppi_config(void)
{
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_SW_SWITCH_TIMER_CLEAR_PPI,
(uint32_t)&(NRF_RADIO->EVENTS_END),
(uint32_t)&(SW_SWITCH_TIMER->TASKS_CLEAR));
}
#else /* !CONFIG_BT_CTLR_SW_SWITCH_SINGLE_TIMER */
/* Clear event timer (sw-switch timer) on Radio end:
* wire the RADIO EVENTS_END event to the
* EVENT_TIMER TASKS_CLEAR task.
*
* Note: in nRF52X this PPI channel is forked for both capturing and clearing
* timer on RADIO EVENTS_END.
*/
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI HAL_RADIO_END_TIME_CAPTURE_PPI
static inline void hal_sw_switch_timer_clear_ppi_config(void)
{
nrf_ppi_fork_endpoint_setup(
NRF_PPI,
HAL_RADIO_END_TIME_CAPTURE_PPI,
(uint32_t)&(SW_SWITCH_TIMER->TASKS_CLEAR));
}
#endif /* !CONFIG_BT_CTLR_SW_SWITCH_SINGLE_TIMER */
/* The 2 adjacent PPI groups used for implementing SW_SWITCH_TIMER-based
* auto-switch for TIFS. 'index' must be 0 or 1.
*/
#define SW_SWITCH_TIMER_TASK_GROUP(index) \
(SW_SWITCH_TIMER_TASK_GROUP_BASE + index)
/* The 2 adjacent TIMER EVENTS_COMPARE event offsets used for implementing
* SW_SWITCH_TIMER-based auto-switch for TIFS. 'index' must be 0 or 1.
*/
#define SW_SWITCH_TIMER_EVTS_COMP(index) \
(SW_SWITCH_TIMER_EVTS_COMP_BASE + index)
/* Wire a SW SWITCH TIMER EVENTS_COMPARE[<cc_offset>] event
* to a PPI GROUP TASK DISABLE task (PPI group with index <index>).
* 2 adjacent PPIs (8 & 9) and 2 adjacent PPI groups are used for this wiring;
* <index> must be 0 or 1. <offset> must be a valid TIMER CC register offset.
*/
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE 9
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(index) \
(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE + index)
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(chan) \
NRF_PPI->CH[chan].EEP
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(cc_offset) \
((uint32_t)&(SW_SWITCH_TIMER->EVENTS_COMPARE[cc_offset]))
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(chan) \
NRF_PPI->CH[chan].TEP
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(index) \
((uint32_t)&(NRF_PPI->TASKS_CHG[SW_SWITCH_TIMER_TASK_GROUP(index)].DIS))
/* Wire the RADIO EVENTS_END event to one of the PPI GROUP TASK ENABLE task.
* 2 adjacent PPI groups are used for this wiring. 'index' must be 0 or 1.
*/
#if defined(CONFIG_SOC_NRF52805)
/* Because nRF52805 has limited number of programmable PPI channels,
* tIFS Trx SW switching on this SoC can be used only when pre-programmed
* PPI channels are also in use, i.e. when TIMER0 is the event timer.
*/
#if (EVENT_TIMER_ID == 0)
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI 2
#else
#error "tIFS Trx SW switch can be used on this SoC only with TIMER0 as the event timer"
#endif
#else /* -> !defined(CONFIG_SOC_NRF52805) */
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI 11
#endif
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_EVT \
((uint32_t)&(NRF_RADIO->EVENTS_END))
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_TASK(index) \
((uint32_t)&(NRF_PPI->TASKS_CHG[SW_SWITCH_TIMER_TASK_GROUP(index)].EN))
/*Enable Radio at specific time-stamp:
* wire the SW SWITCH TIMER EVENTS_COMPARE[<cc_offset>] event
* to RADIO TASKS_TXEN/RXEN task.
* 2 adjacent PPIs (11 & 12) are used for this wiring; <index> must be 0 or 1.
* <offset> must be a valid TIMER CC register offset.
*/
#if defined(CONFIG_SOC_NRF52805)
#if (EVENT_TIMER_ID == 0)
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE 3
#else
#error "tIFS Trx SW switch can be used on this SoC only with TIMER0 as the event timer"
#endif
#else /* -> !defined(CONFIG_SOC_NRF52805) */
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE 12
#endif
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI(index) \
(HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE + index)
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(chan) \
NRF_PPI->CH[chan].EEP
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_EVT(cc_offset) \
((uint32_t)&(SW_SWITCH_TIMER->EVENTS_COMPARE[cc_offset]))
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK(chan) \
NRF_PPI->CH[chan].TEP
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_TX \
((uint32_t)&(NRF_RADIO->TASKS_TXEN))
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_RX \
((uint32_t)&(NRF_RADIO->TASKS_RXEN))
static inline void hal_radio_sw_switch_setup(
uint8_t compare_reg,
uint8_t radio_enable_ppi,
uint8_t ppi_group_index)
{
/* Set up software switch mechanism for next Radio switch. */
/* Wire RADIO END event to PPI Group[<index>] enable task,
* over PPI[<HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI>]
*/
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI,
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_EVT,
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_TASK(ppi_group_index));
/* Wire SW Switch timer event <compare_reg> to the
* PPI[<radio_enable_ppi>] for enabling Radio. Do
* not wire the task; it is done by the caller of
* the function depending on the desired direction
* (TX/RX).
*/
nrf_ppi_event_endpoint_setup(
NRF_PPI,
radio_enable_ppi,
HAL_SW_SWITCH_RADIO_ENABLE_PPI_EVT(compare_reg));
}
static inline void hal_radio_txen_on_sw_switch(uint8_t ppi)
{
nrf_ppi_task_endpoint_setup(
NRF_PPI,
ppi,
HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_TX);
}
static inline void hal_radio_rxen_on_sw_switch(uint8_t ppi)
{
nrf_ppi_task_endpoint_setup(
NRF_PPI,
ppi,
HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_RX);
}
static inline void hal_radio_sw_switch_disable(void)
{
/* Disable the following PPI channels that implement SW Switch:
* - Clearing SW SWITCH TIMER on RADIO END event
* - Enabling SW SWITCH PPI Group on RADIO END event
*/
nrf_ppi_channels_disable(
NRF_PPI,
BIT(HAL_SW_SWITCH_TIMER_CLEAR_PPI) |
BIT(HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI));
}
static inline void hal_radio_sw_switch_cleanup(void)
{
hal_radio_sw_switch_disable();
nrf_ppi_group_disable(NRF_PPI, SW_SWITCH_TIMER_TASK_GROUP(0));
nrf_ppi_group_disable(NRF_PPI, SW_SWITCH_TIMER_TASK_GROUP(1));
}
#if defined(CONFIG_BT_CTLR_PHY_CODED) && \
defined(CONFIG_HAS_HW_NRF_RADIO_BLE_CODED)
/* The 2 adjacent TIMER EVENTS_COMPARE event offsets used for implementing
* SW_SWITCH_TIMER-based auto-switch for TIFS, when receiving in LE Coded PHY.
* 'index' must be 0 or 1.
*/
#define SW_SWITCH_TIMER_S2_EVTS_COMP(index) \
(SW_SWITCH_TIMER_EVTS_COMP_S2_BASE + index)
/* Wire the SW SWITCH TIMER EVENTS_COMPARE[<cc_offset>] event
* to RADIO TASKS_TXEN/RXEN task.
*/
#define HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE 17
#define HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI(index) \
(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE + index)
/* Cancel the SW switch timer running considering S8 timing:
* wire the RADIO EVENTS_RATEBOOST event to SW_SWITCH_TIMER TASKS_CAPTURE task.
*/
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI 19
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_EVT \
NRF_PPI->CH[HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI].EEP
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_EVT \
((uint32_t)&(NRF_RADIO->EVENTS_RATEBOOST))
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_TASK \
NRF_PPI->CH[HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI].TEP
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_TASK(index) \
((uint32_t)&(SW_SWITCH_TIMER->TASKS_CAPTURE[index]))
static inline void hal_radio_sw_switch_coded_tx_config_set(uint8_t ppi_en,
uint8_t ppi_dis, uint8_t cc_s2, uint8_t group_index)
{
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(ppi_en) =
HAL_SW_SWITCH_RADIO_ENABLE_PPI_EVT(cc_s2);
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK(ppi_en) =
HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_TX;
/* Wire the Group task disable
* to the S2 EVENTS_COMPARE.
*/
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(
ppi_dis) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(cc_s2);
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(
ppi_dis) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(
group_index);
/* Capture CC to cancel the timer that has assumed
* S8 reception, if packet will be received in S2.
*/
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_EVT =
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_EVT;
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_TASK =
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_TASK(
group_index);
nrf_ppi_channels_enable(
NRF_PPI,
BIT(HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI));
}
static inline void hal_radio_sw_switch_coded_config_clear(uint8_t ppi_en,
uint8_t ppi_dis, uint8_t cc_reg, uint8_t group_index)
{
/* Invalidate PPI used when RXing on LE Coded PHY. */
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(
ppi_en) = 0;
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK(
ppi_en) = 0;
/* Wire the Group task disable to the default EVENTS_COMPARE. */
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(
ppi_dis) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(cc_reg);
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(
ppi_dis) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(
group_index);
}
#else
static inline void hal_radio_group_task_disable_ppi_setup(void)
{
/* Wire SW SWITCH TIMER EVENTS COMPARE event <cc index-0> to
* PPI Group TASK [<index-0>] DISABLE task, over PPI<index-0>.
*/
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(0),
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(
SW_SWITCH_TIMER_EVTS_COMP(0)),
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(0));
/* Wire SW SWITCH TIMER event <compare index-1> to
* PPI Group[<index-1>] Disable Task, over PPI<index-1>.
*/
nrf_ppi_channel_endpoint_setup(
NRF_PPI,
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(1),
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(
SW_SWITCH_TIMER_EVTS_COMP(1)),
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(1));
}
#endif /* CONFIG_HAS_HW_NRF_RADIO_BLE_CODED */
static inline void hal_radio_sw_switch_ppi_group_setup(void)
{
/* Include the appropriate PPI channels in the two PPI Groups. */
#if !defined(CONFIG_BT_CTLR_PHY_CODED) || \
!defined(CONFIG_HAS_HW_NRF_RADIO_BLE_CODED)
NRF_PPI->CHG[SW_SWITCH_TIMER_TASK_GROUP(0)] =
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(0)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI(0));
NRF_PPI->CHG[SW_SWITCH_TIMER_TASK_GROUP(1)] =
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(1)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI(1));
#else
NRF_PPI->CHG[SW_SWITCH_TIMER_TASK_GROUP(0)] =
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(0)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI(0)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI(0));
NRF_PPI->CHG[SW_SWITCH_TIMER_TASK_GROUP(1)] =
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(1)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI(1)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI(1));
#endif /* CONFIG_BT_CTLR_PHY_CODED && CONFIG_HAS_HW_NRF_RADIO_BLE_CODED */
}
#endif /* !CONFIG_BT_CTLR_TIFS_HW */
#elif defined(CONFIG_SOC_NRF5340_CPUNET)
#include <hal/nrf_dppi.h>
static inline void hal_radio_nrf_ppi_channels_enable(uint32_t mask)
{
nrf_dppi_channels_enable(NRF_DPPIC, mask);
}
static inline void hal_radio_nrf_ppi_channels_disable(uint32_t mask)
{
nrf_dppi_channels_disable(NRF_DPPIC, mask);
}
/*******************************************************************************
* Enable Radio on Event Timer tick:
* wire the EVENT_TIMER EVENTS_COMPARE[0] event to RADIO TASKS_TXEN/RXEN task.
*/
#define HAL_RADIO_ENABLE_ON_TICK_PPI 0
#define HAL_RADIO_ENABLE_TX_ON_TICK_PPI HAL_RADIO_ENABLE_ON_TICK_PPI
#define HAL_RADIO_ENABLE_RX_ON_TICK_PPI HAL_RADIO_ENABLE_ON_TICK_PPI
#define HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_EVT \
EVENT_TIMER->PUBLISH_COMPARE[0]
#define HAL_RADIO_ENABLE_ON_TICK_PPI_EVT \
(((HAL_RADIO_ENABLE_ON_TICK_PPI << TIMER_PUBLISH_COMPARE_CHIDX_Pos) \
& TIMER_PUBLISH_COMPARE_CHIDX_Msk) | \
((TIMER_PUBLISH_COMPARE_EN_Enabled << TIMER_PUBLISH_COMPARE_EN_Pos) \
& TIMER_PUBLISH_COMPARE_EN_Msk))
#define HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_TX \
NRF_RADIO->SUBSCRIBE_TXEN
#define HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_RX \
NRF_RADIO->SUBSCRIBE_RXEN
#define HAL_RADIO_ENABLE_ON_TICK_PPI_TASK_TX_SET \
(((HAL_RADIO_ENABLE_ON_TICK_PPI << RADIO_SUBSCRIBE_TXEN_CHIDX_Pos) \
& RADIO_SUBSCRIBE_TXEN_CHIDX_Msk) | \
((RADIO_SUBSCRIBE_TXEN_EN_Enabled << \
RADIO_SUBSCRIBE_TXEN_EN_Pos) \
& RADIO_SUBSCRIBE_TXEN_EN_Msk))
#define HAL_RADIO_ENABLE_ON_TICK_PPI_TASK_RX_SET \
(((HAL_RADIO_ENABLE_ON_TICK_PPI << RADIO_SUBSCRIBE_RXEN_CHIDX_Pos) \
& RADIO_SUBSCRIBE_RXEN_CHIDX_Msk) | \
((RADIO_SUBSCRIBE_RXEN_EN_Enabled << RADIO_SUBSCRIBE_RXEN_EN_Pos) \
& RADIO_SUBSCRIBE_RXEN_EN_Msk))
static inline void hal_radio_enable_on_tick_ppi_config_and_enable(uint8_t trx)
{
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_EVT =
HAL_RADIO_ENABLE_ON_TICK_PPI_EVT;
if (trx) {
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_TX =
HAL_RADIO_ENABLE_ON_TICK_PPI_TASK_TX_SET;
/* Address nRF5340 Engineering A Errata 16 */
if (IS_ENABLED(CONFIG_BT_CTLR_TIFS_HW)) {
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_RX = 0;
}
} else {
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_RX =
HAL_RADIO_ENABLE_ON_TICK_PPI_TASK_RX_SET;
/* Address nRF5340 Engineering A Errata 16 */
if (IS_ENABLED(CONFIG_BT_CTLR_TIFS_HW)) {
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_TX = 0;
}
}
nrf_dppi_channels_enable(
NRF_DPPIC, BIT(HAL_RADIO_ENABLE_ON_TICK_PPI));
}
/*******************************************************************************
* Capture event timer on Address reception:
* wire the RADIO EVENTS_ADDRESS event to the
* EVENT_TIMER TASKS_CAPTURE[<address timer>] task.
*/
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI 3
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_REGISTER_EVT \
NRF_RADIO->PUBLISH_ADDRESS
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_EVT \
(((HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI << \
RADIO_PUBLISH_ADDRESS_CHIDX_Pos) \
& RADIO_PUBLISH_ADDRESS_CHIDX_Msk) | \
((RADIO_PUBLISH_ADDRESS_EN_Enabled << RADIO_PUBLISH_ADDRESS_EN_Pos) \
& RADIO_PUBLISH_ADDRESS_EN_Msk))
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_REGISTER_TASK \
EVENT_TIMER->SUBSCRIBE_CAPTURE[1]
#define HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_TASK \
(((HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI << \
TIMER_SUBSCRIBE_CAPTURE_CHIDX_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_CHIDX_Msk) | \
((TIMER_SUBSCRIBE_CAPTURE_EN_Enabled << \
TIMER_SUBSCRIBE_CAPTURE_EN_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_EN_Msk))
static inline void hal_radio_recv_timeout_cancel_ppi_config(void)
{
HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_REGISTER_EVT =
HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_EVT;
HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_REGISTER_TASK =
HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI_TASK;
}
/*******************************************************************************
* Disable Radio on HCTO:
* wire the EVENT_TIMER EVENTS_COMPARE[<HCTO timer>] event
* to the RADIO TASKS_DISABLE task.
*/
#define HAL_RADIO_DISABLE_ON_HCTO_PPI 4
#define HAL_RADIO_DISABLE_ON_HCTO_PPI_REGISTER_EVT \
EVENT_TIMER->PUBLISH_COMPARE[1]
#define HAL_RADIO_DISABLE_ON_HCTO_PPI_EVT \
(((HAL_RADIO_DISABLE_ON_HCTO_PPI << \
TIMER_PUBLISH_COMPARE_CHIDX_Pos) \
& TIMER_PUBLISH_COMPARE_CHIDX_Msk) | \
((TIMER_PUBLISH_COMPARE_EN_Enabled << TIMER_PUBLISH_COMPARE_EN_Pos) \
& TIMER_PUBLISH_COMPARE_EN_Msk))
#define HAL_RADIO_DISABLE_ON_HCTO_PPI_REGISTER_TASK \
NRF_RADIO->SUBSCRIBE_DISABLE
#define HAL_RADIO_DISABLE_ON_HCTO_PPI_TASK \
(((HAL_RADIO_DISABLE_ON_HCTO_PPI << \
RADIO_SUBSCRIBE_DISABLE_CHIDX_Pos) \
& RADIO_SUBSCRIBE_DISABLE_CHIDX_Msk) | \
((RADIO_SUBSCRIBE_DISABLE_EN_Enabled << \
RADIO_SUBSCRIBE_DISABLE_EN_Pos) \
& RADIO_SUBSCRIBE_DISABLE_EN_Msk))
static inline void hal_radio_disable_on_hcto_ppi_config(void)
{
HAL_RADIO_DISABLE_ON_HCTO_PPI_REGISTER_EVT =
HAL_RADIO_DISABLE_ON_HCTO_PPI_EVT;
HAL_RADIO_DISABLE_ON_HCTO_PPI_REGISTER_TASK =
HAL_RADIO_DISABLE_ON_HCTO_PPI_TASK;
}
/*******************************************************************************
* Capture event timer on Radio end:
* wire the RADIO EVENTS_END event to the
* EVENT_TIMER TASKS_CAPTURE[<radio end timer>] task.
*/
#define HAL_RADIO_END_TIME_CAPTURE_PPI 5
#define HAL_RADIO_END_TIME_CAPTURE_PPI_REGISTER_EVT \
(NRF_RADIO->PUBLISH_END)
#define HAL_RADIO_END_TIME_CAPTURE_PPI_EVT \
(((HAL_RADIO_END_TIME_CAPTURE_PPI << RADIO_PUBLISH_END_CHIDX_Pos) \
& RADIO_PUBLISH_END_CHIDX_Msk) | \
((RADIO_PUBLISH_END_EN_Enabled << RADIO_PUBLISH_END_EN_Pos) \
& RADIO_PUBLISH_END_EN_Msk))
#define HAL_RADIO_END_TIME_CAPTURE_PPI_REGISTER_TASK \
(EVENT_TIMER->SUBSCRIBE_CAPTURE[2])
#define HAL_RADIO_END_TIME_CAPTURE_PPI_TASK \
(((HAL_RADIO_END_TIME_CAPTURE_PPI << \
TIMER_SUBSCRIBE_CAPTURE_CHIDX_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_CHIDX_Msk) | \
((TIMER_SUBSCRIBE_CAPTURE_EN_Enabled << \
TIMER_SUBSCRIBE_CAPTURE_EN_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_EN_Msk))
static inline void hal_radio_end_time_capture_ppi_config(void)
{
HAL_RADIO_END_TIME_CAPTURE_PPI_REGISTER_EVT =
HAL_RADIO_END_TIME_CAPTURE_PPI_EVT;
HAL_RADIO_END_TIME_CAPTURE_PPI_REGISTER_TASK =
HAL_RADIO_END_TIME_CAPTURE_PPI_TASK;
}
/*******************************************************************************
* Start event timer on RTC tick:
* wire the RTC0 EVENTS_COMPARE[2] event to EVENT_TIMER TASKS_START task.
*/
#define HAL_EVENT_TIMER_START_PPI 1
#define HAL_EVENT_TIMER_START_PPI_REGISTER_EVT \
NRF_RTC0->PUBLISH_COMPARE[2]
#define HAL_EVENT_TIMER_START_PPI_EVT \
(((HAL_EVENT_TIMER_START_PPI << RTC_PUBLISH_COMPARE_CHIDX_Pos) \
& RTC_PUBLISH_COMPARE_CHIDX_Msk) | \
((RTC_PUBLISH_COMPARE_EN_Enabled << RTC_PUBLISH_COMPARE_EN_Pos) \
& RTC_PUBLISH_COMPARE_EN_Msk))
#define HAL_EVENT_TIMER_START_PPI_REGISTER_TASK \
EVENT_TIMER->SUBSCRIBE_START
#define HAL_EVENT_TIMER_START_PPI_TASK \
(((HAL_EVENT_TIMER_START_PPI << TIMER_SUBSCRIBE_START_CHIDX_Pos) \
& TIMER_SUBSCRIBE_START_CHIDX_Msk) | \
((TIMER_SUBSCRIBE_START_EN_Enabled << TIMER_SUBSCRIBE_START_EN_Pos) \
& TIMER_SUBSCRIBE_START_EN_Msk))
static inline void hal_event_timer_start_ppi_config(void)
{
HAL_EVENT_TIMER_START_PPI_REGISTER_EVT =
HAL_EVENT_TIMER_START_PPI_EVT;
HAL_EVENT_TIMER_START_PPI_REGISTER_TASK =
HAL_EVENT_TIMER_START_PPI_TASK;
}
/*******************************************************************************
* Capture event timer on Radio ready:
* wire the RADIO EVENTS_READY event to the
* EVENT_TIMER TASKS_CAPTURE[<radio ready timer>] task.
*/
#define HAL_RADIO_READY_TIME_CAPTURE_PPI 2
#define HAL_RADIO_READY_TIME_CAPTURE_PPI_REGISTER_EVT \
NRF_RADIO->PUBLISH_READY
#define HAL_RADIO_READY_TIME_CAPTURE_PPI_EVT \
(((HAL_RADIO_READY_TIME_CAPTURE_PPI << \
RADIO_PUBLISH_READY_CHIDX_Pos) \
& RADIO_PUBLISH_READY_CHIDX_Msk) | \
((RADIO_PUBLISH_READY_EN_Enabled << RADIO_PUBLISH_READY_EN_Pos) \
& RADIO_PUBLISH_READY_EN_Msk))
#define HAL_RADIO_READY_TIME_CAPTURE_PPI_REGISTER_TASK \
EVENT_TIMER->SUBSCRIBE_CAPTURE[0]
#define HAL_RADIO_READY_TIME_CAPTURE_PPI_TASK \
(((HAL_RADIO_READY_TIME_CAPTURE_PPI << \
TIMER_SUBSCRIBE_CAPTURE_CHIDX_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_CHIDX_Msk) | \
((TIMER_SUBSCRIBE_CAPTURE_EN_Enabled << \
TIMER_SUBSCRIBE_CAPTURE_EN_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_EN_Msk))
static inline void hal_radio_ready_time_capture_ppi_config(void)
{
HAL_RADIO_READY_TIME_CAPTURE_PPI_REGISTER_EVT =
HAL_RADIO_READY_TIME_CAPTURE_PPI_EVT;
HAL_RADIO_READY_TIME_CAPTURE_PPI_REGISTER_TASK =
HAL_RADIO_READY_TIME_CAPTURE_PPI_TASK;
}
/*******************************************************************************
* Trigger encryption task upon address reception:
* wire the RADIO EVENTS_ADDRESS event to the CCM TASKS_CRYPT task.
*
* Note: we do not need an additional PPI, since we have already set up
* a PPI to publish RADIO ADDRESS event.
*/
#define HAL_TRIGGER_CRYPT_PPI HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI
#define HAL_TRIGGER_CRYPT_PPI_REGISTER_EVT \
NRF_RADIO->PUBLISH_ADDRESS
#define HAL_TRIGGER_CRYPT_PPI_EVT \
(((HAL_TRIGGER_CRYPT_PPI << RADIO_PUBLISH_ADDRESS_CHIDX_Pos) \
& RADIO_PUBLISH_ADDRESS_CHIDX_Msk) | \
((RADIO_PUBLISH_ADDRESS_EN_Enabled << RADIO_PUBLISH_ADDRESS_EN_Pos) \
& RADIO_PUBLISH_ADDRESS_EN_Msk))
#define HAL_TRIGGER_CRYPT_PPI_REGISTER_TASK \
NRF_CCM->SUBSCRIBE_CRYPT
#define HAL_TRIGGER_CRYPT_PPI_TASK \
(((HAL_TRIGGER_CRYPT_PPI << CCM_SUBSCRIBE_CRYPT_CHIDX_Pos) \
& CCM_SUBSCRIBE_CRYPT_CHIDX_Msk) | \
((CCM_SUBSCRIBE_CRYPT_EN_Enabled << CCM_SUBSCRIBE_CRYPT_EN_Pos) \
& CCM_SUBSCRIBE_CRYPT_EN_Msk))
static inline void hal_trigger_crypt_ppi_config(void)
{
HAL_TRIGGER_CRYPT_PPI_REGISTER_EVT =
HAL_TRIGGER_CRYPT_PPI_EVT;
HAL_TRIGGER_CRYPT_PPI_REGISTER_TASK =
HAL_TRIGGER_CRYPT_PPI_TASK;
}
/*******************************************************************************
* Trigger automatic address resolution on Bit counter match:
* wire the RADIO EVENTS_BCMATCH event to the AAR TASKS_START task.
*/
#define HAL_TRIGGER_AAR_PPI 6
#define HAL_TRIGGER_AAR_PPI_REGISTER_EVT \
NRF_RADIO->PUBLISH_BCMATCH
#define HAL_TRIGGER_AAR_PPI_EVT \
(((HAL_TRIGGER_AAR_PPI << RADIO_PUBLISH_BCMATCH_CHIDX_Pos) \
& RADIO_PUBLISH_BCMATCH_CHIDX_Msk) | \
((RADIO_PUBLISH_BCMATCH_EN_Enabled << RADIO_PUBLISH_BCMATCH_EN_Pos) \
& RADIO_PUBLISH_BCMATCH_EN_Msk))
#define HAL_TRIGGER_AAR_PPI_REGISTER_TASK \
NRF_AAR->SUBSCRIBE_START
#define HAL_TRIGGER_AAR_PPI_TASK \
(((HAL_TRIGGER_AAR_PPI << AAR_SUBSCRIBE_START_CHIDX_Pos) \
& AAR_SUBSCRIBE_START_CHIDX_Msk) | \
((AAR_SUBSCRIBE_START_EN_Enabled << AAR_SUBSCRIBE_START_EN_Pos) \
& AAR_SUBSCRIBE_START_EN_Msk))
static inline void hal_trigger_aar_ppi_config(void)
{
HAL_TRIGGER_AAR_PPI_REGISTER_EVT =
HAL_TRIGGER_AAR_PPI_EVT;
HAL_TRIGGER_AAR_PPI_REGISTER_TASK =
HAL_TRIGGER_AAR_PPI_TASK;
}
/*******************************************************************************
* Trigger Radio Rate override upon Rateboost event.
*/
#define HAL_TRIGGER_RATEOVERRIDE_PPI 13
#define HAL_TRIGGER_RATEOVERRIDE_PPI_REGISTER_EVT \
NRF_RADIO->PUBLISH_RATEBOOST
#define HAL_TRIGGER_RATEOVERRIDE_PPI_EVT \
(((HAL_TRIGGER_RATEOVERRIDE_PPI << \
RADIO_PUBLISH_RATEBOOST_CHIDX_Pos) \
& RADIO_PUBLISH_RATEBOOST_CHIDX_Msk) | \
((RADIO_PUBLISH_RATEBOOST_EN_Enabled << \
RADIO_PUBLISH_RATEBOOST_EN_Pos) \
& RADIO_PUBLISH_RATEBOOST_EN_Msk))
#define HAL_TRIGGER_RATEOVERRIDE_PPI_REGISTER_TASK \
NRF_CCM->SUBSCRIBE_RATEOVERRIDE
#define HAL_TRIGGER_RATEOVERRIDE_PPI_TASK \
(((HAL_TRIGGER_RATEOVERRIDE_PPI << \
CCM_SUBSCRIBE_RATEOVERRIDE_CHIDX_Pos) \
& CCM_SUBSCRIBE_RATEOVERRIDE_CHIDX_Msk) | \
((CCM_SUBSCRIBE_RATEOVERRIDE_EN_Enabled << \
CCM_SUBSCRIBE_RATEOVERRIDE_EN_Pos) \
& CCM_SUBSCRIBE_RATEOVERRIDE_EN_Msk))
static inline void hal_trigger_rateoverride_ppi_config(void)
{
HAL_TRIGGER_RATEOVERRIDE_PPI_REGISTER_EVT =
HAL_TRIGGER_RATEOVERRIDE_PPI_EVT;
HAL_TRIGGER_RATEOVERRIDE_PPI_REGISTER_TASK =
HAL_TRIGGER_RATEOVERRIDE_PPI_TASK;
}
/******************************************************************************/
#if !defined(CONFIG_BT_CTLR_TIFS_HW)
/* DPPI setup used for SW-based auto-switching during TIFS. */
/* Clear SW-switch timer on packet end:
* wire the RADIO EVENTS_END event to SW_SWITCH_TIMER TASKS_CLEAR task.
*
* Note: we do not need an additional PPI, since we have already set up
* a PPI to publish RADIO END event.
*/
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI HAL_RADIO_END_TIME_CAPTURE_PPI
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_EVT \
(NRF_RADIO->PUBLISH_END)
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI_EVT \
(((HAL_SW_SWITCH_TIMER_CLEAR_PPI << RADIO_PUBLISH_END_CHIDX_Pos) \
& RADIO_PUBLISH_END_CHIDX_Msk) | \
((RADIO_PUBLISH_END_EN_Enabled << RADIO_PUBLISH_END_EN_Pos) \
& RADIO_PUBLISH_END_EN_Msk))
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_TASK \
(SW_SWITCH_TIMER->SUBSCRIBE_CLEAR)
#define HAL_SW_SWITCH_TIMER_CLEAR_PPI_TASK \
(((HAL_SW_SWITCH_TIMER_CLEAR_PPI << TIMER_SUBSCRIBE_CLEAR_CHIDX_Pos) \
& TIMER_SUBSCRIBE_CLEAR_CHIDX_Msk) | \
((TIMER_SUBSCRIBE_CLEAR_EN_Enabled << TIMER_SUBSCRIBE_CLEAR_EN_Pos) \
& TIMER_SUBSCRIBE_CLEAR_EN_Msk))
static inline void hal_sw_switch_timer_clear_ppi_config(void)
{
HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_EVT =
HAL_SW_SWITCH_TIMER_CLEAR_PPI_EVT;
HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_TASK =
HAL_SW_SWITCH_TIMER_CLEAR_PPI_TASK;
}
/* The 2 adjacent PPI groups used for implementing SW_SWITCH_TIMER-based
* auto-switch for TIFS. 'index' must be 0 or 1.
*/
#define SW_SWITCH_TIMER_TASK_GROUP(index) \
(SW_SWITCH_TIMER_TASK_GROUP_BASE + index)
/* The 2 adjacent TIMER EVENTS_COMPARE event offsets used for implementing
* SW_SWITCH_TIMER-based auto-switch for TIFS. 'index' must be 0 or 1.
*/
#define SW_SWITCH_TIMER_EVTS_COMP(index) \
(SW_SWITCH_TIMER_EVTS_COMP_BASE + index)
/* The 2 adjacent TIMER EVENTS_COMPARE event offsets used for implementing
* SW_SWITCH_TIMER-based auto-switch for TIFS, when receiving on LE Coded
* PHY. 'index' must be 0 or 1.
*/
#define SW_SWITCH_TIMER_S2_EVTS_COMP(index) \
(SW_SWITCH_TIMER_EVTS_COMP_S2_BASE + index)
/* Wire a SW SWITCH TIMER EVENTS_COMPARE[<cc_offset>] event
* to a PPI GROUP TASK DISABLE task (PPI group with index <index>).
* 2 adjacent PPIs (8 & 9) and 2 adjacent PPI groups are used for this wiring;
* <index> must be 0 or 1. <offset> must be a valid TIMER CC register offset.
*/
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE 8
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(index) \
(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE + index)
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(cc_offset) \
SW_SWITCH_TIMER->PUBLISH_COMPARE[cc_offset]
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(chan) \
(((chan << TIMER_PUBLISH_COMPARE_CHIDX_Pos) \
& TIMER_PUBLISH_COMPARE_CHIDX_Msk) | \
((TIMER_PUBLISH_COMPARE_EN_Enabled << TIMER_PUBLISH_COMPARE_EN_Pos) \
& TIMER_PUBLISH_COMPARE_EN_Msk))
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(index) \
NRF_DPPIC->SUBSCRIBE_CHG[SW_SWITCH_TIMER_TASK_GROUP(index)].DIS
#define HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(chan) \
(((chan << DPPIC_SUBSCRIBE_CHG_DIS_CHIDX_Pos) \
& DPPIC_SUBSCRIBE_CHG_DIS_CHIDX_Msk) | \
((DPPIC_SUBSCRIBE_CHG_DIS_EN_Enabled << \
DPPIC_SUBSCRIBE_CHG_DIS_EN_Pos) \
& DPPIC_SUBSCRIBE_CHG_DIS_EN_Msk))
/* Enable the SW Switch PPI Group on RADIO END Event.
*
* Note: we do not need an additional PPI, since we have already set up
* a PPI to publish RADIO END event.
*/
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI HAL_SW_SWITCH_TIMER_CLEAR_PPI
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_EVT \
(NRF_RADIO->PUBLISH_END)
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_EVT \
(((HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI << \
RADIO_PUBLISH_END_CHIDX_Pos) \
& RADIO_PUBLISH_END_CHIDX_Msk) | \
((RADIO_PUBLISH_END_EN_Enabled << RADIO_PUBLISH_END_EN_Pos) \
& RADIO_PUBLISH_END_EN_Msk))
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_TASK(index) \
(NRF_DPPIC->SUBSCRIBE_CHG[SW_SWITCH_TIMER_TASK_GROUP(index)].EN)
#define HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_TASK \
(((HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI << \
DPPIC_SUBSCRIBE_CHG_EN_CHIDX_Pos) \
& DPPIC_SUBSCRIBE_CHG_EN_CHIDX_Msk) | \
((DPPIC_SUBSCRIBE_CHG_EN_EN_Enabled << \
DPPIC_SUBSCRIBE_CHG_EN_EN_Pos) \
& DPPIC_SUBSCRIBE_CHG_EN_EN_Msk))
/* Enable Radio on SW Switch timer event.
* Wire a SW SWITCH TIMER EVENTS_COMPARE[<cc_offset>] event
* to a RADIO Enable task (TX or RX).
*
* Note:
* We use the same PPI as for disabling the SW Switch PPI groups,
* since we need to listen for the same event (SW Switch event).
*
* We use the same PPI for the alternative SW Switch Timer compare
* event.
*/
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE 8
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI(index) \
(HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE + index)
#define HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE \
HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE
#define HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI(index) \
(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE + index)
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(cc_offset) \
SW_SWITCH_TIMER->PUBLISH_COMPARE[cc_offset]
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_EVT(chan) \
(((chan << TIMER_PUBLISH_COMPARE_CHIDX_Pos) \
& TIMER_PUBLISH_COMPARE_CHIDX_Msk) | \
((TIMER_PUBLISH_COMPARE_EN_Enabled << TIMER_PUBLISH_COMPARE_EN_Pos) \
& TIMER_PUBLISH_COMPARE_EN_Msk))
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK_TX \
NRF_RADIO->SUBSCRIBE_TXEN
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK_RX \
NRF_RADIO->SUBSCRIBE_RXEN
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_TX_SET(chan) \
(((chan << RADIO_SUBSCRIBE_TXEN_CHIDX_Pos) \
& RADIO_SUBSCRIBE_TXEN_CHIDX_Msk) | \
((RADIO_SUBSCRIBE_TXEN_EN_Enabled << \
RADIO_SUBSCRIBE_TXEN_EN_Pos) \
& RADIO_SUBSCRIBE_TXEN_EN_Msk))
#define HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_RX_SET(chan) \
(((chan << RADIO_SUBSCRIBE_RXEN_CHIDX_Pos) \
& RADIO_SUBSCRIBE_RXEN_CHIDX_Msk) | \
((RADIO_SUBSCRIBE_RXEN_EN_Enabled << RADIO_SUBSCRIBE_RXEN_EN_Pos) \
& RADIO_SUBSCRIBE_RXEN_EN_Msk))
/* Cancel the SW switch timer running considering S8 timing:
* wire the RADIO EVENTS_RATEBOOST event to SW_SWITCH_TIMER TASKS_CAPTURE task.
*
* Note: We already have a PPI where we publish the RATEBOOST event.
*/
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI HAL_TRIGGER_RATEOVERRIDE_PPI
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_EVT \
NRF_RADIO->PUBLISH_RATEBOOST
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_EVT \
(((HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI << \
RADIO_PUBLISH_RATEBOOST_CHIDX_Pos) \
& RADIO_PUBLISH_RATEBOOST_CHIDX_Msk) | \
((RADIO_PUBLISH_RATEBOOST_EN_Enabled << \
RADIO_PUBLISH_RATEBOOST_EN_Pos) \
& RADIO_PUBLISH_RATEBOOST_EN_Msk))
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_TASK(cc_reg) \
SW_SWITCH_TIMER->SUBSCRIBE_CAPTURE[cc_reg]
#define HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_TASK \
(((HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI << \
TIMER_SUBSCRIBE_CAPTURE_CHIDX_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_CHIDX_Msk) | \
((TIMER_SUBSCRIBE_CAPTURE_EN_Enabled << \
TIMER_SUBSCRIBE_CAPTURE_EN_Pos) \
& TIMER_SUBSCRIBE_CAPTURE_EN_Msk))
static inline void hal_radio_sw_switch_setup(
uint8_t compare_reg,
uint8_t radio_enable_ppi,
uint8_t ppi_group_index)
{
/* Set up software switch mechanism for next Radio switch. */
/* Wire RADIO END event to PPI Group[<index>] enable task,
* over PPI[<HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI>]
*/
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_EVT =
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_EVT;
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_TASK(ppi_group_index) =
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_TASK;
/* Sanity build-time check that
* - SW SWITCH Timer Clear
* - Radio End Capture, and
* - Group Enable
* tasks are all going to be subscribed on the same PPI.
*/
BUILD_ASSERT(
&HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_EVT ==
&HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_EVT,
"SW SWitch Timer Clear and Group Disable"
" not on the same PPI channel.");
BUILD_ASSERT(
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_EVT ==
HAL_SW_SWITCH_TIMER_CLEAR_PPI_EVT,
"SW SWitch Timer Clear and Group Disable"
" not on the same PPI channel.");
BUILD_ASSERT(
&HAL_RADIO_END_TIME_CAPTURE_PPI_REGISTER_EVT ==
&HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_EVT,
"Radio End Timer Capture and Group Disable"
" not on the same PPI channel.");
BUILD_ASSERT(
HAL_RADIO_END_TIME_CAPTURE_PPI_EVT ==
HAL_SW_SWITCH_TIMER_CLEAR_PPI_EVT,
"Radio End Timer Capture and Group Disable"
" not on the same PPI channel.");
/* We need to un-subscribe the other group from the PPI channel. */
if (ppi_group_index == 0) {
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_TASK(1) = 0;
} else if (ppi_group_index == 1) {
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_TASK(0) = 0;
}
/* Wire SW Switch timer event <compare_reg> to the
* PPI[<radio_enable_ppi>] for enabling Radio. Do
* not wire the task; it is done by the caller of
* the function depending on the desired direction
* (TX/RX).
*/
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(compare_reg) =
HAL_SW_SWITCH_RADIO_ENABLE_PPI_EVT(radio_enable_ppi);
}
static inline void hal_radio_txen_on_sw_switch(uint8_t ppi)
{
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK_TX =
HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_TX_SET(ppi);
}
static inline void hal_radio_rxen_on_sw_switch(uint8_t ppi)
{
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_TASK_RX =
HAL_SW_SWITCH_RADIO_ENABLE_PPI_TASK_RX_SET(ppi);
}
static inline void hal_radio_sw_switch_disable(void)
{
/* We cannot deactivate the PPI channels, as other tasks
* are subscribed to RADIO_END event, i.e on the same channel.
* So we simply cancel the task subscription.
*/
HAL_SW_SWITCH_TIMER_CLEAR_PPI_REGISTER_TASK = 0;
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_TASK(0) = 0;
HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI_REGISTER_TASK(1) = 0;
}
static inline void hal_radio_sw_switch_cleanup(void)
{
hal_radio_sw_switch_disable();
nrf_dppi_channels_disable(NRF_DPPIC,
(BIT(HAL_SW_SWITCH_TIMER_CLEAR_PPI) |
BIT(HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI)));
nrf_dppi_group_disable(NRF_DPPIC, SW_SWITCH_TIMER_TASK_GROUP(0));
nrf_dppi_group_disable(NRF_DPPIC, SW_SWITCH_TIMER_TASK_GROUP(1));
}
static inline void hal_radio_sw_switch_coded_tx_config_set(uint8_t ppi_en,
uint8_t ppi_dis, uint8_t cc_s2, uint8_t group_index)
{
/* Publish the SW Switch Timer Compare event for S2 timing
* to the PPI that will be used to trigger Radio enable.
*/
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(cc_s2) =
HAL_SW_SWITCH_RADIO_ENABLE_PPI_EVT(ppi_en);
/* The Radio Enable Task is already subscribed to the channel. */
/* Wire the Group task disable to the S2 EVENTS_COMPARE. */
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(cc_s2) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(ppi_dis);
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(group_index) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(ppi_dis);
/* Capture CC to cancel the timer that has assumed
* S8 reception, if packet will be received in S2.
*/
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_EVT =
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_EVT;
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_REGISTER_TASK(
SW_SWITCH_TIMER_EVTS_COMP(group_index)) =
HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI_TASK;
nrf_dppi_channels_enable(NRF_DPPIC,
BIT(HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI));
}
static inline void hal_radio_sw_switch_coded_config_clear(uint8_t ppi_en,
uint8_t ppi_dis, uint8_t cc_reg, uint8_t group_index)
{
/* Invalidate subscription of S2 timer Compare used when
* RXing on LE Coded PHY.
*
* Note: we do not un-subscribe the Radio enable task because
* we use the same PPI for both SW Switch Timer compare events.
*/
HAL_SW_SWITCH_RADIO_ENABLE_PPI_REGISTER_EVT(
SW_SWITCH_TIMER_S2_EVTS_COMP(group_index)) = 0;
/* Wire the Group[group_index] task disable to the default
* SW Switch Timer EVENTS_COMPARE.
*/
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(
cc_reg) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(
ppi_dis);
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(
group_index) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(
ppi_dis);
}
static inline void hal_radio_sw_switch_ppi_group_setup(void)
{
/* Include the appropriate PPI channels in the two PPI Groups, used for
* SW-based TIFS.
*
* Note that this needs to be done before any SUBSCRIBE task
* registers are written, therefore, we clear the task registers
* here.
*/
NRF_DPPIC->SUBSCRIBE_CHG[SW_SWITCH_TIMER_TASK_GROUP(0)].EN = 0;
NRF_DPPIC->SUBSCRIBE_CHG[SW_SWITCH_TIMER_TASK_GROUP(0)].DIS = 0;
NRF_DPPIC->SUBSCRIBE_CHG[SW_SWITCH_TIMER_TASK_GROUP(1)].EN = 0;
NRF_DPPIC->SUBSCRIBE_CHG[SW_SWITCH_TIMER_TASK_GROUP(1)].DIS = 0;
NRF_DPPIC->TASKS_CHG[SW_SWITCH_TIMER_TASK_GROUP(0)].DIS = 1;
NRF_DPPIC->TASKS_CHG[SW_SWITCH_TIMER_TASK_GROUP(1)].DIS = 1;
/* Include the appropriate PPI channels in the two PPI Groups. */
NRF_DPPIC->CHG[SW_SWITCH_TIMER_TASK_GROUP(0)] =
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(0)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI(0));
NRF_DPPIC->CHG[SW_SWITCH_TIMER_TASK_GROUP(1)] =
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(1)) |
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI(1));
/* Sanity build-time check that RADIO Enable and Group Disable
* tasks are going to be subscribed on the same PPIs.
*/
BUILD_ASSERT(
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE ==
HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE,
"Radio enable and Group disable not on the same PPI channels.");
/* Address nRF5340 Engineering A Errata 16 */
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_TX = 0;
HAL_RADIO_ENABLE_ON_TICK_PPI_REGISTER_TASK_RX = 0;
}
static inline void hal_radio_group_task_disable_ppi_setup(void)
{
/* Wire SW SWITCH TIMER EVENTS COMPARE event <cc index-0> to
* PPI Group TASK [<index-0>] DISABLE task, over PPI<index-0>.
*/
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(
SW_SWITCH_TIMER_EVTS_COMP(0)) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(0));
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(0) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(0));
/* Wire SW SWITCH TIMER event <compare index-1> to
* PPI Group[<index-1>] Disable Task, over PPI<index-1>.
*/
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_EVT(
SW_SWITCH_TIMER_EVTS_COMP(1)) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_EVT(
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(1));
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_REGISTER_TASK(1) =
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_TASK(
HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI(1));
}
#endif
#endif /* CONFIG_SOC_SERIES_NRF51X || CONFIG_SOC_COMPATIBLE_NRF52X */
/******************************************************************************/
#define HAL_USED_PPI_CHANNELS \
(BIT(HAL_RADIO_ENABLE_TX_ON_TICK_PPI) | \
BIT(HAL_RADIO_ENABLE_RX_ON_TICK_PPI) | \
BIT(HAL_RADIO_RECV_TIMEOUT_CANCEL_PPI) | \
BIT(HAL_RADIO_DISABLE_ON_HCTO_PPI) | \
BIT(HAL_RADIO_END_TIME_CAPTURE_PPI) | \
BIT(HAL_EVENT_TIMER_START_PPI) | \
BIT(HAL_RADIO_READY_TIME_CAPTURE_PPI) | \
BIT(HAL_TRIGGER_CRYPT_PPI) | \
BIT(HAL_TRIGGER_AAR_PPI) | \
HAL_USED_PPI_CHANNELS_2 | HAL_USED_PPI_CHANNELS_3 | \
HAL_USED_PPI_CHANNELS_4 | HAL_USED_PPI_CHANNELS_5)
#if defined(HAL_TRIGGER_RATEOVERRIDE_PPI)
#define HAL_USED_PPI_CHANNELS_2 \
BIT(HAL_TRIGGER_RATEOVERRIDE_PPI)
#else
#define HAL_USED_PPI_CHANNELS_2 0
#endif
#if defined(HAL_ENABLE_PALNA_PPI)
#define HAL_USED_PPI_CHANNELS_3 \
(BIT(HAL_ENABLE_PALNA_PPI) | \
BIT(HAL_DISABLE_PALNA_PPI))
#else
#define HAL_USED_PPI_CHANNELS_3 0
#endif
#if defined(HAL_SW_SWITCH_TIMER_CLEAR_PPI)
#define HAL_USED_PPI_CHANNELS_4 \
(BIT(HAL_SW_SWITCH_TIMER_CLEAR_PPI) | \
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE) | \
BIT(HAL_SW_SWITCH_GROUP_TASK_DISABLE_PPI_BASE + 1) | \
BIT(HAL_SW_SWITCH_GROUP_TASK_ENABLE_PPI) | \
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE) | \
BIT(HAL_SW_SWITCH_RADIO_ENABLE_PPI_BASE + 1))
#else
#define HAL_USED_PPI_CHANNELS_4 0
#endif
#if defined(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE)
#define HAL_USED_PPI_CHANNELS_5 \
(BIT(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE) | \
BIT(HAL_SW_SWITCH_RADIO_ENABLE_S2_PPI_BASE + 1) | \
BIT(HAL_SW_SWITCH_TIMER_S8_DISABLE_PPI))
#else
#define HAL_USED_PPI_CHANNELS_5 0
#endif
BUILD_ASSERT(
(HAL_USED_PPI_CHANNELS & NRFX_PPI_CHANNELS_USED_BY_PWM_SW) == 0,
"PPI channels used by the Bluetooth controller overlap with those "
"assigned to the pwm_nrf5_sw driver.");
#if defined(SW_SWITCH_TIMER_TASK_GROUP_BASE)
#define HAL_USED_PPI_GROUPS \
(BIT(SW_SWITCH_TIMER_TASK_GROUP_BASE) | \
BIT(SW_SWITCH_TIMER_TASK_GROUP_BASE + 1))
#else
#define HAL_USED_PPI_GROUPS 0
#endif