Revert "drivers: timer: extend nrf_rtc_timer"
This reverts commit 26e297572a
.
Signed-off-by: Carles Cufi <carles.cufi@nordicsemi.no>
This commit is contained in:
parent
c7ec3db5e5
commit
38ce8d615d
3 changed files with 132 additions and 475 deletions
|
@ -11,25 +11,8 @@
|
|||
extern "C" {
|
||||
#endif
|
||||
|
||||
/** @brief Maximum allowed time span that is considered to be in the future.
|
||||
*/
|
||||
#define NRF_RTC_TIMER_MAX_SCHEDULE_SPAN BIT(23)
|
||||
|
||||
/** @brief RTC timer compare event handler.
|
||||
*
|
||||
* Called from RTC ISR context when processing a compare event.
|
||||
*
|
||||
* @param id Compare channel ID.
|
||||
*
|
||||
* @param expire_time An actual absolute expiration time set for a compare
|
||||
* channel. It can differ from the requested target time
|
||||
* and the difference can be used to determine whether the
|
||||
* time set was delayed.
|
||||
*
|
||||
* @param user_data Pointer to a user context data.
|
||||
*/
|
||||
typedef void (*z_nrf_rtc_timer_compare_handler_t)(int32_t id,
|
||||
uint64_t expire_time,
|
||||
uint32_t cc_value,
|
||||
void *user_data);
|
||||
|
||||
/** @brief Allocate RTC compare channel.
|
||||
|
@ -47,11 +30,11 @@ int32_t z_nrf_rtc_timer_chan_alloc(void);
|
|||
*/
|
||||
void z_nrf_rtc_timer_chan_free(int32_t chan);
|
||||
|
||||
/** @brief Read current absolute time.
|
||||
/** @brief Read current RTC counter value.
|
||||
*
|
||||
* @return Current absolute time.
|
||||
* @return Current RTC counter value.
|
||||
*/
|
||||
uint64_t z_nrf_rtc_timer_read(void);
|
||||
uint32_t z_nrf_rtc_timer_read(void);
|
||||
|
||||
/** @brief Get COMPARE event register address.
|
||||
*
|
||||
|
@ -93,52 +76,38 @@ uint32_t z_nrf_rtc_timer_compare_read(int32_t chan);
|
|||
|
||||
/** @brief Try to set compare channel to given value.
|
||||
*
|
||||
* Provided value is absolute and cannot be further in the future than
|
||||
* @c NRF_RTC_TIMER_MAX_SCHEDULE_SPAN. If given value is in the past then an RTC
|
||||
* interrupt is triggered immediately. Otherwise function continuously retries
|
||||
* to set compare register until value that is written is far enough in the
|
||||
* future and will generate an event. Because of that, compare register value
|
||||
* may be different than the one requested. During this operation interrupt
|
||||
* from that compare channel is disabled. Other interrupts are not locked during
|
||||
* this operation.
|
||||
* Provided value is absolute and cannot be further in future than half span of
|
||||
* the RTC counter. Function continouosly retries to set compare register until
|
||||
* value that is written is far enough in the future and will generate an event.
|
||||
* Because of that, compare register value may be different than the one
|
||||
* requested. During this operation interrupt from that compare channel is
|
||||
* disabled. Other interrupts are not locked during this operation.
|
||||
*
|
||||
* There is no option to abort the request once it is set. However, it can be
|
||||
* overwritten.
|
||||
*
|
||||
* @param chan Channel ID between 1 and CONFIG_NRF_RTC_TIMER_USER_CHAN_COUNT.
|
||||
*
|
||||
* @param target_time Absolute target time in ticks.
|
||||
* @param cc_value Absolute value. Values which are further distanced from
|
||||
* current counter value than half RTC span are considered in the past.
|
||||
*
|
||||
* @param handler User function called in the context of the RTC interrupt.
|
||||
*
|
||||
* @param user_data Data passed to the handler.
|
||||
*
|
||||
* @retval 0 if the compare channel was set successfully.
|
||||
* @retval -EINVAL if provided target time was further than
|
||||
* @c NRF_RTC_TIMER_MAX_SCHEDULE_SPAN ticks in the future.
|
||||
*/
|
||||
int z_nrf_rtc_timer_set(int32_t chan, uint64_t target_time,
|
||||
z_nrf_rtc_timer_compare_handler_t handler,
|
||||
void *user_data);
|
||||
|
||||
/** @brief Abort a timer requested with @ref z_nrf_rtc_timer_set.
|
||||
*
|
||||
* If an abort operation is performed too late it is still possible for an event
|
||||
* to fire. The user can detect a spurious event by comparing absolute time
|
||||
* provided in callback and a result of @ref z_nrf_rtc_timer_read. During this
|
||||
* operation interrupt from that compare channel is disabled. Other interrupts
|
||||
* are not locked during this operation.
|
||||
*
|
||||
* @param chan Channel ID between 1 and CONFIG_NRF_RTC_TIMER_USER_CHAN_COUNT.
|
||||
*/
|
||||
void z_nrf_rtc_timer_abort(int32_t chan);
|
||||
void z_nrf_rtc_timer_compare_set(int32_t chan, uint32_t cc_value,
|
||||
z_nrf_rtc_timer_compare_handler_t handler,
|
||||
void *user_data);
|
||||
|
||||
/** @brief Convert system clock time to RTC ticks.
|
||||
*
|
||||
* @p t can be absolute or relative. @p t cannot be further into the future
|
||||
* from now than the RTC range (e.g. 512 seconds if RTC is running at 32768 Hz).
|
||||
* @p t can be absolute or relative. @p t cannot be further from now than half
|
||||
* of the RTC range (e.g. 256 seconds if RTC is running at 32768 Hz).
|
||||
*
|
||||
* @retval Positive value represents @p t in RTC tick value.
|
||||
* @retval -EINVAL if @p t is out of range.
|
||||
*/
|
||||
uint64_t z_nrf_rtc_timer_get_ticks(k_timeout_t t);
|
||||
int z_nrf_rtc_timer_get_ticks(k_timeout_t t);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue