mbed library sources
Dependents: Encrypted my_mbed lklk CyaSSL_DTLS_Cellular ... more
Superseded
This library was superseded by mbed-dev - https://os.mbed.com/users/mbed_official/code/mbed-dev/.
Development branch of the mbed library sources. This library is kept in synch with the latest changes from the mbed SDK and it is not guaranteed to work.
If you are looking for a stable and tested release, please import one of the official mbed library releases:
Import librarymbed
The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.
Diff: targets/hal/TARGET_NORDIC/TARGET_MCU_NRF51822/us_ticker.c
- Revision:
- 300:55638feb26a4
- Parent:
- 270:e2babe29baf8
- Child:
- 304:89b9c3a9a045
--- a/targets/hal/TARGET_NORDIC/TARGET_MCU_NRF51822/us_ticker.c Wed Aug 27 04:00:07 2014 +0100 +++ b/targets/hal/TARGET_NORDIC/TARGET_MCU_NRF51822/us_ticker.c Wed Aug 27 08:45:06 2014 +0100 @@ -21,107 +21,109 @@ #define US_TICKER_TIMER NRF_TIMER1 #define US_TICKER_TIMER_IRQn TIMER1_IRQn -int us_ticker_inited = 0; -volatile uint16_t overflow=0; //overflow value that forms the upper 16 bits of the counter -volatile uint16_t timeStamp=0; +int us_ticker_inited = 0; +volatile uint16_t overflow = 0; //overflow value that forms the upper 16 bits of the counter +volatile uint16_t timeStamp = 0; #ifdef __cplusplus extern "C" { -#endif -void TIMER1_IRQHandler(void){ +#endif - if ((US_TICKER_TIMER->EVENTS_COMPARE[1] != 0) && - ((US_TICKER_TIMER->INTENSET & TIMER_INTENSET_COMPARE1_Msk) != 0)) - { - US_TICKER_TIMER->EVENTS_COMPARE[1] = 0; - overflow++; - US_TICKER_TIMER->CC[1] =0xFFFF; - if(timeStamp>0) - { - timeStamp--; - if(timeStamp==0) - { - us_ticker_clear_interrupt(); - us_ticker_disable_interrupt(); - us_ticker_irq_handler(); - return; - } - } +void TIMER1_IRQHandler(void) +{ + if ((US_TICKER_TIMER->EVENTS_COMPARE[1] != 0) && + ((US_TICKER_TIMER->INTENSET & TIMER_INTENSET_COMPARE1_Msk) != 0)) { + US_TICKER_TIMER->EVENTS_COMPARE[1] = 0; + overflow++; + US_TICKER_TIMER->CC[1] = 0xFFFF; + if (timeStamp>0) { + timeStamp--; + if (timeStamp==0) { + us_ticker_clear_interrupt(); + us_ticker_disable_interrupt(); + us_ticker_irq_handler(); + return; + } + } } - if ((US_TICKER_TIMER->EVENTS_COMPARE[0] != 0) && - ((US_TICKER_TIMER->INTENSET & TIMER_INTENSET_COMPARE0_Msk) != 0)) - { - us_ticker_clear_interrupt(); - us_ticker_disable_interrupt(); - if(timeStamp==0) - us_ticker_irq_handler(); + if ((US_TICKER_TIMER->EVENTS_COMPARE[0] != 0) && + ((US_TICKER_TIMER->INTENSET & TIMER_INTENSET_COMPARE0_Msk) != 0)) { + us_ticker_clear_interrupt(); + us_ticker_disable_interrupt(); + if (timeStamp==0) { + us_ticker_irq_handler(); + } } - } + #ifdef __cplusplus } -#endif -void us_ticker_init(void){ - if (us_ticker_inited && US_TICKER_TIMER->POWER){ +#endif +void us_ticker_init(void) +{ + if (us_ticker_inited && US_TICKER_TIMER->POWER) { return; } - + us_ticker_inited = 1; - + US_TICKER_TIMER->POWER = 0; US_TICKER_TIMER->POWER = 1; - + US_TICKER_TIMER->MODE = TIMER_MODE_MODE_Timer; - - US_TICKER_TIMER->PRESCALER = 4; - US_TICKER_TIMER->BITMODE = TIMER_BITMODE_BITMODE_16Bit; - US_TICKER_TIMER->TASKS_CLEAR =1; - US_TICKER_TIMER->CC[1] = 0xFFFF; - US_TICKER_TIMER->INTENSET = TIMER_INTENSET_COMPARE1_Set << TIMER_INTENSET_COMPARE1_Pos; - + + US_TICKER_TIMER->PRESCALER = 4; + US_TICKER_TIMER->BITMODE = TIMER_BITMODE_BITMODE_16Bit; + US_TICKER_TIMER->TASKS_CLEAR = 1; + US_TICKER_TIMER->CC[1] = 0xFFFF; + US_TICKER_TIMER->INTENSET = TIMER_INTENSET_COMPARE1_Set << TIMER_INTENSET_COMPARE1_Pos; + NVIC_SetPriority(US_TICKER_TIMER_IRQn, 3); NVIC_EnableIRQ(US_TICKER_TIMER_IRQn); - + US_TICKER_TIMER->TASKS_START = 0x01; } -uint32_t us_ticker_read(){ - if (!us_ticker_inited || US_TICKER_TIMER->POWER==0){ +uint32_t us_ticker_read() +{ + if (!us_ticker_inited || (US_TICKER_TIMER->POWER==0)) { us_ticker_init(); } - - uint16_t bufferedOverFlow = overflow; - US_TICKER_TIMER->TASKS_CAPTURE[2] = 1; - - if(overflow!=bufferedOverFlow){ - bufferedOverFlow = overflow; - US_TICKER_TIMER->TASKS_CAPTURE[2] = 1; - } - return (((uint32_t)bufferedOverFlow<<16) | US_TICKER_TIMER->CC[2]); + + uint16_t bufferedOverFlow = overflow; + US_TICKER_TIMER->TASKS_CAPTURE[2] = 1; + + if (overflow!=bufferedOverFlow) { + bufferedOverFlow = overflow; + US_TICKER_TIMER->TASKS_CAPTURE[2] = 1; + } + return (((uint32_t)bufferedOverFlow << 16) | US_TICKER_TIMER->CC[2]); } -void us_ticker_set_interrupt(unsigned int timestamp){ - if (!us_ticker_inited || US_TICKER_TIMER->POWER==0) - { +void us_ticker_set_interrupt(unsigned int timestamp) +{ + if (!us_ticker_inited || (US_TICKER_TIMER->POWER == 0)) { us_ticker_init(); - } - - US_TICKER_TIMER->TASKS_CAPTURE[0] = 1; - uint16_t tsUpper16 = (uint16_t)((timestamp-us_ticker_read())>>16); - if(tsUpper16>0){ - if(timeStamp ==0 || timeStamp> tsUpper16){ - timeStamp = tsUpper16; - } - } - else{ - US_TICKER_TIMER->INTENSET |= TIMER_INTENSET_COMPARE0_Set << TIMER_INTENSET_COMPARE0_Pos; - US_TICKER_TIMER->CC[0] += timestamp-us_ticker_read(); - } + } + + US_TICKER_TIMER->TASKS_CAPTURE[0] = 1; + uint16_t tsUpper16 = (uint16_t)((timestamp - us_ticker_read()) >> 16); + if (tsUpper16>0) { + if ((timeStamp ==0) || (timeStamp> tsUpper16)) { + timeStamp = tsUpper16; + } + } else { + US_TICKER_TIMER->INTENSET |= TIMER_INTENSET_COMPARE0_Set << TIMER_INTENSET_COMPARE0_Pos; + US_TICKER_TIMER->CC[0] += timestamp - us_ticker_read(); + } } -void us_ticker_disable_interrupt(void){ +void us_ticker_disable_interrupt(void) +{ US_TICKER_TIMER->INTENCLR = TIMER_INTENCLR_COMPARE0_Clear << TIMER_INTENCLR_COMPARE0_Pos; } -void us_ticker_clear_interrupt(void){ + +void us_ticker_clear_interrupt(void) +{ US_TICKER_TIMER->EVENTS_COMPARE[0] = 0; }