nRF51 SDK - S120 SoftDevice
 All Data Structures Functions Variables Typedefs Enumerations Enumerator Groups Pages

Hardware abstraction layer for managing the low-frequency clock (LFCLK) and the high-frequency clock (HFCLK). More...

Macros

#define NRF_CLOCK_TASK_SET   (1UL)
 
#define NRF_CLOCK_EVENT_CLEAR   (0UL)
 

Enumerations

enum  nrf_clock_lf_src_t {
  NRF_CLOCK_LF_SRC_RC = CLOCK_LFCLKSRC_SRC_RC,
  NRF_CLOCK_LF_SRC_Xtal = CLOCK_LFCLKSRC_SRC_Xtal,
  NRF_CLOCK_LF_SRC_Synth = CLOCK_LFCLKSRC_SRC_Synth
}
 Low-frequency clock sources. More...
 
enum  nrf_clock_hf_src_t {
  NRF_CLOCK_HF_SRC_RC = CLOCK_HFCLKSTAT_SRC_RC,
  NRF_CLOCK_HF_SRC_Xtal = CLOCK_HFCLKSTAT_SRC_Xtal
}
 High-frequency clock sources. More...
 
enum  nrf_clock_start_task_status_t {
  NRF_CLOCK_START_TASK_NOT_TRIGGERED = CLOCK_LFCLKRUN_STATUS_NotTriggered,
  NRF_CLOCK_START_TASK_TRIGGERED = CLOCK_LFCLKRUN_STATUS_Triggered
}
 Trigger status of task LFCLKSTART/HFCLKSTART. More...
 
enum  nrf_clock_xtalfreq_t {
  NRF_CLOCK_XTALFREQ_16MHz = CLOCK_XTALFREQ_XTALFREQ_16MHz,
  NRF_CLOCK_XTALFREQ_32MHz = CLOCK_XTALFREQ_XTALFREQ_32MHz
}
 Crystal frequency selection. More...
 
enum  nrf_clock_int_mask_t {
  NRF_CLOCK_INT_HF_STARTED_MASK = CLOCK_INTENSET_HFCLKSTARTED_Msk,
  NRF_CLOCK_INT_LF_STARTED_MASK = CLOCK_INTENSET_LFCLKSTARTED_Msk,
  NRF_CLOCK_INT_DONE_MASK = CLOCK_INTENSET_DONE_Msk,
  NRF_CLOCK_INT_CTTO_MASK = CLOCK_INTENSET_CTTO_Msk
}
 Interrupts. More...
 
enum  nrf_clock_tasks_t {
  NRF_CLOCK_TASKS_HFCLKSTART = offsetof(NRF_CLOCK_Type, TASKS_HFCLKSTART),
  NRF_CLOCK_TASKS_HFCLKSTOP = offsetof(NRF_CLOCK_Type, TASKS_HFCLKSTOP),
  NRF_CLOCK_TASKS_LFCLKSTART = offsetof(NRF_CLOCK_Type, TASKS_LFCLKSTART),
  NRF_CLOCK_TASKS_LFCLKSTOP = offsetof(NRF_CLOCK_Type, TASKS_LFCLKSTOP),
  NRF_CLOCK_TASKS_CAL = offsetof(NRF_CLOCK_Type, TASKS_CAL),
  NRF_CLOCK_TASKS_CTSTART = offsetof(NRF_CLOCK_Type, TASKS_CTSTART),
  NRF_CLOCK_TASKS_CTSTOP = offsetof(NRF_CLOCK_Type, TASKS_CTSTOP)
}
 Tasks. More...
 
enum  nrf_clock_events_t {
  NRF_CLOCK_EVENTS_HFCLKSTARTED = offsetof(NRF_CLOCK_Type, EVENTS_HFCLKSTARTED),
  NRF_CLOCK_EVENTS_LFCLKSTARTED = offsetof(NRF_CLOCK_Type, EVENTS_LFCLKSTARTED),
  NRF_CLOCK_EVENTS_DONE = offsetof(NRF_CLOCK_Type, EVENTS_DONE),
  NRF_CLOCK_EVENTS_CTTO = offsetof(NRF_CLOCK_Type, EVENTS_CTTO)
}
 Events. More...
 

Functions

__STATIC_INLINE void nrf_clock_int_enable (uint32_t int_mask)
 Function for enabling a specific interrupt. More...
 
__STATIC_INLINE void nrf_clock_int_disable (uint32_t int_mask)
 Function for disabling a specific interrupt. More...
 
__STATIC_INLINE bool nrf_clock_int_enable_check (nrf_clock_int_mask_t int_mask)
 Function for retrieving the state of a specific interrupt. More...
 
__STATIC_INLINE uint32_t nrf_clock_task_address_get (nrf_clock_tasks_t task)
 Function for retrieving the address of a specific task. More...
 
__STATIC_INLINE void nrf_clock_task_set (nrf_clock_tasks_t task)
 Function for setting a specific task. More...
 
__STATIC_INLINE uint32_t nrf_clock_event_address_get (nrf_clock_events_t event)
 Function for retrieving the address of a specific event. More...
 
__STATIC_INLINE void nrf_clock_event_clear (nrf_clock_events_t event)
 Function for clearing a specific event. More...
 
__STATIC_INLINE bool nrf_clock_event_check (nrf_clock_events_t event)
 Function for retrieving the state of a specific event. More...
 
__STATIC_INLINE void nrf_clock_lf_src_set (nrf_clock_lf_src_t source)
 Function for changing the low-frequency clock source. More...
 
__STATIC_INLINE nrf_clock_lf_src_t nrf_clock_lf_src_get (void)
 Function for retrieving the selected source for the low-frequency clock. More...
 
__STATIC_INLINE nrf_clock_lf_src_t nrf_clock_lf_actv_src_get (void)
 Function for retrieving the active source of the low-frequency clock. More...
 
__STATIC_INLINE nrf_clock_lf_src_t nrf_clock_lf_srccopy_get (void)
 Function for retrieving the clock source for the LFCLK clock when the task LKCLKSTART is triggered. More...
 
__STATIC_INLINE bool nrf_clock_lf_is_running (void)
 Function for retrieving the state of the LFCLK clock. More...
 
__STATIC_INLINE
nrf_clock_start_task_status_t 
nrf_clock_lf_start_task_status_get (void)
 Function for retrieving the trigger status of the task LFCLKSTART. More...
 
__STATIC_INLINE nrf_clock_hf_src_t nrf_clock_hf_src_get (void)
 Function for retrieving the active source of the high-frequency clock. More...
 
__STATIC_INLINE bool nrf_clock_hf_is_running (void)
 Function for retrieving the state of the HFCLK clock. More...
 
__STATIC_INLINE
nrf_clock_start_task_status_t 
nrf_clock_hf_start_task_status_get (void)
 Function for retrieving the trigger status of the task HFCLKSTART. More...
 
__STATIC_INLINE
nrf_clock_xtalfreq_t 
nrf_clock_xtalfreq_get (void)
 Function for retrieving the frequency selection of the external crystal. More...
 
__STATIC_INLINE void nrf_clock_xtalfreq_set (nrf_clock_xtalfreq_t xtalfreq)
 Function for changing the frequency selection of the external crystal. More...
 
__STATIC_INLINE void nrf_clock_cal_timer_timeout_set (uint32_t interval)
 Function for changing the calibration timer interval. More...
 

Detailed Description

Hardware abstraction layer for managing the low-frequency clock (LFCLK) and the high-frequency clock (HFCLK).

Enumeration Type Documentation

Events.

Enumerator
NRF_CLOCK_EVENTS_HFCLKSTARTED 

HFCLK oscillator started.

NRF_CLOCK_EVENTS_LFCLKSTARTED 

LFCLK oscillator started.

NRF_CLOCK_EVENTS_DONE 

Calibration of LFCLK RC oscillator completed.

NRF_CLOCK_EVENTS_CTTO 

Calibration timer time-out.

High-frequency clock sources.

Enumerator
NRF_CLOCK_HF_SRC_RC 

Internal 16 MHz RC oscillator.

NRF_CLOCK_HF_SRC_Xtal 

External 16 MHz/32 MHz crystal oscillator.

Interrupts.

Enumerator
NRF_CLOCK_INT_HF_STARTED_MASK 

Interrupt on HFCLKSTARTED event.

NRF_CLOCK_INT_LF_STARTED_MASK 

Interrupt on LFCLKSTARTED event.

NRF_CLOCK_INT_DONE_MASK 

Interrupt on DONE event.

NRF_CLOCK_INT_CTTO_MASK 

Interrupt on CTTO event.

Low-frequency clock sources.

Used by LFCLKSRC, LFCLKSTAT, and LFCLKSRCCOPY registers.

Enumerator
NRF_CLOCK_LF_SRC_RC 

Internal 32 kHz RC oscillator.

NRF_CLOCK_LF_SRC_Xtal 

External 32 kHz crystal.

NRF_CLOCK_LF_SRC_Synth 

Internal 32 kHz synthesizer from HFCLK system clock.

Trigger status of task LFCLKSTART/HFCLKSTART.

Used by LFCLKRUN and HFCLKRUN registers.

Enumerator
NRF_CLOCK_START_TASK_NOT_TRIGGERED 

Task LFCLKSTART/HFCLKSTART has not been triggered.

NRF_CLOCK_START_TASK_TRIGGERED 

Task LFCLKSTART/HFCLKSTART has been triggered.

Tasks.

The NRF_CLOCK_TASKS_LFCLKSTOP task cannot be set when the low-frequency clock is not running. The NRF_CLOCK_TASKS_HFCLKSTOP task cannot be set when the high-frequency clock is not running.

Enumerator
NRF_CLOCK_TASKS_HFCLKSTART 

Start HFCLK clock source.

NRF_CLOCK_TASKS_HFCLKSTOP 

Stop HFCLK clock source.

NRF_CLOCK_TASKS_LFCLKSTART 

Start LFCLK clock source.

NRF_CLOCK_TASKS_LFCLKSTOP 

Stop LFCLK clock source.

NRF_CLOCK_TASKS_CAL 

Start calibration of LFCLK RC oscillator.

NRF_CLOCK_TASKS_CTSTART 

Start calibration timer.

NRF_CLOCK_TASKS_CTSTOP 

Stop calibration timer.

Crystal frequency selection.

Enumerator
NRF_CLOCK_XTALFREQ_16MHz 

16 MHz crystal.

NRF_CLOCK_XTALFREQ_32MHz 

32 MHz crystal.

Function Documentation

__STATIC_INLINE void nrf_clock_cal_timer_timeout_set ( uint32_t  interval)

Function for changing the calibration timer interval.

Parameters
[in]intervalNew calibration timer interval in 0.25 s resolution (range: 0.25 seconds to 31.75 seconds).
__STATIC_INLINE uint32_t nrf_clock_event_address_get ( nrf_clock_events_t  event)

Function for retrieving the address of a specific event.

This function can be used by the PPI module.

Parameters
[in]eventEvent.
Return values
addressof requested event register
__STATIC_INLINE bool nrf_clock_event_check ( nrf_clock_events_t  event)

Function for retrieving the state of a specific event.

Parameters
[in]eventEvent.
Return values
trueIf the event is set.
falseIf the event is not set.
__STATIC_INLINE void nrf_clock_event_clear ( nrf_clock_events_t  event)

Function for clearing a specific event.

Parameters
[in]eventEvent.
__STATIC_INLINE bool nrf_clock_hf_is_running ( void  )

Function for retrieving the state of the HFCLK clock.

Return values
falseIf the HFCLK clock is not running.
trueIf the HFCLK clock is running.
__STATIC_INLINE nrf_clock_hf_src_t nrf_clock_hf_src_get ( void  )

Function for retrieving the active source of the high-frequency clock.

Return values
NRF_CLOCK_HF_SRC_RCIf the internal 16 MHz RC oscillator is the active source of the high-frequency clock.
NRF_CLOCK_HF_SRC_XtalIf an external 16 MHz/32 MHz crystal oscillator is the active source of the high-frequency clock.
__STATIC_INLINE nrf_clock_start_task_status_t nrf_clock_hf_start_task_status_get ( void  )

Function for retrieving the trigger status of the task HFCLKSTART.

Return values
NRF_CLOCK_START_TASK_NOT_TRIGGEREDIf the task HFCLKSTART has not been triggered.
NRF_CLOCK_START_TASK_TRIGGEREDIf the task HFCLKSTART has been triggered.
__STATIC_INLINE void nrf_clock_int_disable ( uint32_t  int_mask)

Function for disabling a specific interrupt.

Parameters
[in]int_maskInterrupt.
__STATIC_INLINE void nrf_clock_int_enable ( uint32_t  int_mask)

Function for enabling a specific interrupt.

Parameters
[in]int_maskInterrupt.
__STATIC_INLINE bool nrf_clock_int_enable_check ( nrf_clock_int_mask_t  int_mask)

Function for retrieving the state of a specific interrupt.

Parameters
[in]int_maskInterrupt.
Return values
trueInterrupt is enabled.
falseInterrupt is not enabled.
__STATIC_INLINE nrf_clock_lf_src_t nrf_clock_lf_actv_src_get ( void  )

Function for retrieving the active source of the low-frequency clock.

Return values
NRF_CLOCK_LF_SRC_RCIf the internal 32 kHz RC oscillator is the active source of the low-frequency clock.
NRF_CLOCK_LF_SRC_XtalIf an external 32 kHz crystal oscillator is the active source of the low-frequency clock.
NRF_CLOCK_LF_SRC_SynthIf the internal 32 kHz synthesizer from the HFCLK is the active source of the low-frequency clock.
__STATIC_INLINE bool nrf_clock_lf_is_running ( void  )

Function for retrieving the state of the LFCLK clock.

Return values
falseIf the LFCLK clock is not running.
trueIf the LFCLK clock is running.
__STATIC_INLINE nrf_clock_lf_src_t nrf_clock_lf_src_get ( void  )

Function for retrieving the selected source for the low-frequency clock.

Return values
NRF_CLOCK_LF_SRC_RCIf the internal 32 kHz RC oscillator is the selected source for the low-frequency clock.
NRF_CLOCK_LF_SRC_XtalIf an external 32 kHz crystal oscillator is the selected source for the low-frequency clock.
NRF_CLOCK_LF_SRC_SynthIf the internal 32 kHz synthesizer from the HFCLK is the selected source for the low-frequency clock.
__STATIC_INLINE void nrf_clock_lf_src_set ( nrf_clock_lf_src_t  source)

Function for changing the low-frequency clock source.

This function cannot be called when the low-frequency clock is running.

Parameters
[in]sourceNew low-frequency clock source.
__STATIC_INLINE nrf_clock_lf_src_t nrf_clock_lf_srccopy_get ( void  )

Function for retrieving the clock source for the LFCLK clock when the task LKCLKSTART is triggered.

Return values
NRF_CLOCK_LF_SRC_RCIf the internal 32 kHz RC oscillator is running and generating the LFCLK clock.
NRF_CLOCK_LF_SRC_XtalIf an external 32 kHz crystal oscillator is running and generating the LFCLK clock.
NRF_CLOCK_LF_SRC_SynthIf the internal 32 kHz synthesizer from the HFCLK is running and generating the LFCLK clock.
__STATIC_INLINE nrf_clock_start_task_status_t nrf_clock_lf_start_task_status_get ( void  )

Function for retrieving the trigger status of the task LFCLKSTART.

Return values
NRF_CLOCK_START_TASK_NOT_TRIGGEREDIf the task LFCLKSTART has not been triggered.
NRF_CLOCK_START_TASK_TRIGGEREDIf the task LFCLKSTART has been triggered.
__STATIC_INLINE uint32_t nrf_clock_task_address_get ( nrf_clock_tasks_t  task)

Function for retrieving the address of a specific task.

This function can be used by the PPI module.

Parameters
[in]taskTask.
Return values
addressof requested task register
__STATIC_INLINE void nrf_clock_task_set ( nrf_clock_tasks_t  task)

Function for setting a specific task.

Parameters
[in]taskTask.
__STATIC_INLINE nrf_clock_xtalfreq_t nrf_clock_xtalfreq_get ( void  )

Function for retrieving the frequency selection of the external crystal.

Return values
NRF_CLOCK_XTALFREQ_16MHzIf a 16 MHz crystal is used as source for the HFCLK oscillator.
NRF_CLOCK_XTALFREQ_32MHzIf a 32 MHz crystal is used as source for the HFCLK oscillator.
__STATIC_INLINE void nrf_clock_xtalfreq_set ( nrf_clock_xtalfreq_t  xtalfreq)

Function for changing the frequency selection of the external crystal.

Parameters
[in]xtalfreqNew frequency selection for the external crystal.