From 3c76c015fcd4b4a5aaa32d8d8c2838d3211a4bbb Mon Sep 17 00:00:00 2001 From: Piotr Koziar Date: Tue, 26 Nov 2024 12:29:00 +0100 Subject: [PATCH] modules: hal_nordic: use CLOCK_CONTROL_NRF2 for HFCLK request/release Makes 802.15.4 use the API under CONFIG_CLOCK_CONTROL_NRF2 in nrf_clock_control.h to request/release HFCLK. Previous HFCLK requesting/releasing on nRF54H20 was more of a workaround and could produce issues when comes to sharing the resources. Signed-off-by: Piotr Koziar --- .../platform/nrf_802154_clock_zephyr.c | 39 ++++--------------- 1 file changed, 8 insertions(+), 31 deletions(-) diff --git a/modules/hal_nordic/nrf_802154/sl_opensource/platform/nrf_802154_clock_zephyr.c b/modules/hal_nordic/nrf_802154/sl_opensource/platform/nrf_802154_clock_zephyr.c index f9da7537dc13..c307401c6574 100644 --- a/modules/hal_nordic/nrf_802154/sl_opensource/platform/nrf_802154_clock_zephyr.c +++ b/modules/hal_nordic/nrf_802154/sl_opensource/platform/nrf_802154_clock_zephyr.c @@ -11,12 +11,7 @@ #include #include -#if defined(CONFIG_CLOCK_CONTROL_NRF) #include -#include -#elif !defined(NRF54H_SERIES) -#error No implementation to start or stop HFCLK due to missing clock_control. -#endif static bool hfclk_is_running; @@ -35,7 +30,6 @@ bool nrf_802154_clock_hfclk_is_running(void) return hfclk_is_running; } -#if defined(CONFIG_CLOCK_CONTROL_NRF) static struct onoff_client hfclk_cli; @@ -48,6 +42,7 @@ static void hfclk_on_callback(struct onoff_manager *mgr, nrf_802154_clock_hfclk_ready(); } +#if defined(CONFIG_CLOCK_CONTROL_NRF) void nrf_802154_clock_hfclk_start(void) { int ret; @@ -75,40 +70,22 @@ void nrf_802154_clock_hfclk_stop(void) hfclk_is_running = false; } -#elif defined(NRF54H_SERIES) - -#define NRF_LRCCONF_RADIO_PD NRF_LRCCONF010 -/* HF clock time to ramp-up. */ -#define MAX_HFXO_RAMP_UP_TIME_US 550 - -static void hfclk_started_timer_handler(struct k_timer *dummy) -{ - hfclk_is_running = true; - nrf_802154_clock_hfclk_ready(); -} - -K_TIMER_DEFINE(hfclk_started_timer, hfclk_started_timer_handler, NULL); +#elif defined(CONFIG_CLOCK_CONTROL_NRF2) void nrf_802154_clock_hfclk_start(void) { - /* Use register directly, there is no support for that task in nrf_lrcconf_task_trigger. - * This code might cause troubles if there are other HFXO users in this CPU. - */ - NRF_LRCCONF_RADIO_PD->EVENTS_HFXOSTARTED = 0x0; - NRF_LRCCONF_RADIO_PD->TASKS_REQHFXO = 0x1; + sys_notify_init_callback(&hfclk_cli.notify, hfclk_on_callback); + int ret = nrf_clock_control_request(DEVICE_DT_GET(DT_NODELABEL(hfxo)), NULL, &hfclk_cli); - k_timer_start(&hfclk_started_timer, K_USEC(MAX_HFXO_RAMP_UP_TIME_US), K_NO_WAIT); + __ASSERT_NO_MSG(ret >= 0); } void nrf_802154_clock_hfclk_stop(void) { - /* Use register directly, there is no support for that task in nrf_lrcconf_task_trigger. - * This code might cause troubles if there are other HFXO users in this CPU. - */ - NRF_LRCCONF_RADIO_PD->TASKS_STOPREQHFXO = 0x1; - NRF_LRCCONF_RADIO_PD->EVENTS_HFXOSTARTED = 0x0; + int ret = nrf_clock_control_cancel_or_release(DEVICE_DT_GET(DT_NODELABEL(hfxo)), + NULL, &hfclk_cli); - hfclk_is_running = false; + __ASSERT_NO_MSG(ret >= 0); } #endif