mirror of https://github.com/ARMmbed/mbed-os.git
commit
e979bd60eb
|
@ -70,7 +70,7 @@ void us_ticker_insert_event(ticker_event_t *obj, timestamp_t timestamp, uint32_t
|
||||||
ticker_event_t *prev = NULL, *p = head;
|
ticker_event_t *prev = NULL, *p = head;
|
||||||
while (p != NULL) {
|
while (p != NULL) {
|
||||||
/* check if we come before p */
|
/* check if we come before p */
|
||||||
if ((int64_t)(timestamp - p->timestamp) < 0) {
|
if ((signedTimestamp_t)(timestamp - p->timestamp) < 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* go to the next element */
|
/* go to the next element */
|
||||||
|
|
|
@ -22,7 +22,8 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef uint64_t timestamp_t;
|
typedef uint32_t timestamp_t;
|
||||||
|
typedef int32_t signedTimestamp_t; /* The signed version of the above declaration. */
|
||||||
|
|
||||||
uint32_t us_ticker_read(void);
|
uint32_t us_ticker_read(void);
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "cmsis.h"
|
#include "cmsis.h"
|
||||||
#include "PeripheralNames.h"
|
#include "PeripheralNames.h"
|
||||||
#include "app_timer.h"
|
#include "app_timer.h"
|
||||||
|
#include "projectconfig.h"
|
||||||
|
|
||||||
static bool us_ticker_inited = false;
|
static bool us_ticker_inited = false;
|
||||||
static volatile bool us_ticker_appTimerRunning = false;
|
static volatile bool us_ticker_appTimerRunning = false;
|
||||||
|
@ -29,7 +30,7 @@ void us_ticker_init(void)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
APP_TIMER_INIT(0 /*CFG_TIMER_PRESCALER*/ , 1 /*CFG_TIMER_MAX_INSTANCE*/, 1 /*CFG_TIMER_OPERATION_QUEUE_SIZE*/, false /*CFG_SCHEDULER_ENABLE*/);
|
APP_TIMER_INIT(CFG_TIMER_PRESCALER, CFG_TIMER_MAX_INSTANCE, CFG_TIMER_OPERATION_QUEUE_SIZE, CFG_SCHEDULER_ENABLE);
|
||||||
|
|
||||||
us_ticker_inited = true;
|
us_ticker_inited = true;
|
||||||
}
|
}
|
||||||
|
@ -40,7 +41,7 @@ uint32_t us_ticker_read()
|
||||||
us_ticker_init();
|
us_ticker_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
timestamp_t value;
|
uint64_t value;
|
||||||
app_timer_cnt_get(&value); /* This returns the RTC counter (which is fed by the 32khz crystal clock source) */
|
app_timer_cnt_get(&value); /* This returns the RTC counter (which is fed by the 32khz crystal clock source) */
|
||||||
return ((value * 1000000) / (uint32_t)APP_TIMER_CLOCK_FREQ); /* Return a pseudo microsecond counter value.
|
return ((value * 1000000) / (uint32_t)APP_TIMER_CLOCK_FREQ); /* Return a pseudo microsecond counter value.
|
||||||
* This is only as precise as the 32khz low-freq
|
* This is only as precise as the 32khz low-freq
|
||||||
|
@ -72,7 +73,7 @@ void us_ticker_set_interrupt(timestamp_t timestamp)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
timestamp_t currentCounter64;
|
uint64_t currentCounter64;
|
||||||
app_timer_cnt_get(¤tCounter64);
|
app_timer_cnt_get(¤tCounter64);
|
||||||
uint32_t currentCounter = currentCounter64 & MAX_RTC_COUNTER_VAL;
|
uint32_t currentCounter = currentCounter64 & MAX_RTC_COUNTER_VAL;
|
||||||
uint32_t targetCounter = ((uint32_t)((timestamp * (uint64_t)APP_TIMER_CLOCK_FREQ) / 1000000) + 1) & MAX_RTC_COUNTER_VAL;
|
uint32_t targetCounter = ((uint32_t)((timestamp * (uint64_t)APP_TIMER_CLOCK_FREQ) / 1000000) + 1) & MAX_RTC_COUNTER_VAL;
|
||||||
|
@ -94,13 +95,17 @@ void us_ticker_set_interrupt(timestamp_t timestamp)
|
||||||
void us_ticker_disable_interrupt(void)
|
void us_ticker_disable_interrupt(void)
|
||||||
{
|
{
|
||||||
if (us_ticker_appTimerRunning) {
|
if (us_ticker_appTimerRunning) {
|
||||||
app_timer_stop(us_ticker_appTimerID);
|
if (app_timer_stop(us_ticker_appTimerID) == NRF_SUCCESS) {
|
||||||
|
us_ticker_appTimerRunning = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void us_ticker_clear_interrupt(void)
|
void us_ticker_clear_interrupt(void)
|
||||||
{
|
{
|
||||||
if (us_ticker_appTimerRunning) {
|
if (us_ticker_appTimerRunning) {
|
||||||
app_timer_stop(us_ticker_appTimerID);
|
if (app_timer_stop(us_ticker_appTimerID) == NRF_SUCCESS) {
|
||||||
|
us_ticker_appTimerRunning = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue