Maxim Ibragimov / mbed-dev

Dependents:   Nucleo_F103RB_RTC_battery_bkup_pwr_off_okay

Fork of mbed-dev by mbed official

Committer:
mbed_official
Date:
Wed Mar 02 14:30:11 2016 +0000
Revision:
80:bdf1132a57cf
Parent:
0:9b334a45a8ff
Child:
144:ef7eb2e8f9f7
Synchronized with git revision de3b14ec9234d586b155fd24badc22775489a3dc

Full URL: https://github.com/mbedmicro/mbed/commit/de3b14ec9234d586b155fd24badc22775489a3dc/

latest changes to add arduino support, plus fixes for IOTSS BEID

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bogdanm 0:9b334a45a8ff 1 /* mbed Microcontroller Library
bogdanm 0:9b334a45a8ff 2 * Copyright (c) 2006-2015 ARM Limited
bogdanm 0:9b334a45a8ff 3 *
bogdanm 0:9b334a45a8ff 4 * Licensed under the Apache License, Version 2.0 (the "License");
bogdanm 0:9b334a45a8ff 5 * you may not use this file except in compliance with the License.
bogdanm 0:9b334a45a8ff 6 * You may obtain a copy of the License at
bogdanm 0:9b334a45a8ff 7 *
bogdanm 0:9b334a45a8ff 8 * http://www.apache.org/licenses/LICENSE-2.0
bogdanm 0:9b334a45a8ff 9 *
bogdanm 0:9b334a45a8ff 10 * Unless required by applicable law or agreed to in writing, software
bogdanm 0:9b334a45a8ff 11 * distributed under the License is distributed on an "AS IS" BASIS,
bogdanm 0:9b334a45a8ff 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
bogdanm 0:9b334a45a8ff 13 * See the License for the specific language governing permissions and
bogdanm 0:9b334a45a8ff 14 * limitations under the License.
bogdanm 0:9b334a45a8ff 15 */
bogdanm 0:9b334a45a8ff 16 #include <stddef.h>
bogdanm 0:9b334a45a8ff 17 #include "us_ticker_api.h"
bogdanm 0:9b334a45a8ff 18 #include "PeripheralNames.h"
bogdanm 0:9b334a45a8ff 19
bogdanm 0:9b334a45a8ff 20 #define US_TICKER_TIMER1 CMSDK_DUALTIMER1
bogdanm 0:9b334a45a8ff 21 #define US_TICKER_TIMER2 CMSDK_DUALTIMER2
mbed_official 80:bdf1132a57cf 22 #define US_TICKER_TIMER_IRQn DUALTIMER_IRQn
bogdanm 0:9b334a45a8ff 23
bogdanm 0:9b334a45a8ff 24 int us_ticker_inited = 0;
bogdanm 0:9b334a45a8ff 25
bogdanm 0:9b334a45a8ff 26 void us_ticker_init(void) {
bogdanm 0:9b334a45a8ff 27 if (us_ticker_inited) return;
bogdanm 0:9b334a45a8ff 28 us_ticker_inited = 1;
bogdanm 0:9b334a45a8ff 29
bogdanm 0:9b334a45a8ff 30 US_TICKER_TIMER1->TimerControl = 0x0; // disable timer
bogdanm 0:9b334a45a8ff 31 US_TICKER_TIMER2->TimerControl = 0x00; // disable timer
mbed_official 80:bdf1132a57cf 32 US_TICKER_TIMER1->TimerLoad = 0xFFFFFFFF;
mbed_official 80:bdf1132a57cf 33 US_TICKER_TIMER2->TimerLoad = 0xFFFFFFFF;
mbed_official 80:bdf1132a57cf 34
bogdanm 0:9b334a45a8ff 35 US_TICKER_TIMER1->TimerControl = 0x62; // enable interrupt and set to 32 bit counter and set to periodic mode
bogdanm 0:9b334a45a8ff 36 US_TICKER_TIMER2->TimerControl = 0x42; // enable interrupt and set to 32 bit counter
bogdanm 0:9b334a45a8ff 37
bogdanm 0:9b334a45a8ff 38 US_TICKER_TIMER1->TimerControl |= 0x80; // enable counter
bogdanm 0:9b334a45a8ff 39 US_TICKER_TIMER2->TimerControl |= 0x80; // enable counter
bogdanm 0:9b334a45a8ff 40
bogdanm 0:9b334a45a8ff 41 NVIC_SetVector(US_TICKER_TIMER_IRQn, (uint32_t)us_ticker_irq_handler);
bogdanm 0:9b334a45a8ff 42 NVIC_EnableIRQ(US_TICKER_TIMER_IRQn);
bogdanm 0:9b334a45a8ff 43 }
bogdanm 0:9b334a45a8ff 44
bogdanm 0:9b334a45a8ff 45 uint32_t us_ticker_read() {
bogdanm 0:9b334a45a8ff 46 uint32_t return_value = 0;
bogdanm 0:9b334a45a8ff 47 if (!us_ticker_inited)
bogdanm 0:9b334a45a8ff 48 us_ticker_init();
bogdanm 0:9b334a45a8ff 49 return_value = ((~US_TICKER_TIMER2->TimerValue)/25);
mbed_official 80:bdf1132a57cf 50 return return_value;
bogdanm 0:9b334a45a8ff 51 }
bogdanm 0:9b334a45a8ff 52
bogdanm 0:9b334a45a8ff 53 void us_ticker_set_interrupt(timestamp_t timestamp) {
bogdanm 0:9b334a45a8ff 54 int delta = 0;
bogdanm 0:9b334a45a8ff 55 if (!us_ticker_inited)
bogdanm 0:9b334a45a8ff 56 us_ticker_init();
bogdanm 0:9b334a45a8ff 57 delta = (int)(timestamp - us_ticker_read());
bogdanm 0:9b334a45a8ff 58 if (delta <= 0) {
bogdanm 0:9b334a45a8ff 59 // This event was in the past:
bogdanm 0:9b334a45a8ff 60 us_ticker_irq_handler();
bogdanm 0:9b334a45a8ff 61 return;
bogdanm 0:9b334a45a8ff 62 }
mbed_official 80:bdf1132a57cf 63 // enable interrupt
bogdanm 0:9b334a45a8ff 64 US_TICKER_TIMER1->TimerControl = 0x0; // disable timer
bogdanm 0:9b334a45a8ff 65 US_TICKER_TIMER1->TimerControl = 0x62; // enable interrupt and set to 32 bit counter and set to periodic mode
mbed_official 80:bdf1132a57cf 66 US_TICKER_TIMER1->TimerLoad = (delta)*25; //initialise the timer value
mbed_official 80:bdf1132a57cf 67 US_TICKER_TIMER1->TimerControl |= 0x80; //enable timer
bogdanm 0:9b334a45a8ff 68 }
bogdanm 0:9b334a45a8ff 69
bogdanm 0:9b334a45a8ff 70 void us_ticker_disable_interrupt(void) {
bogdanm 0:9b334a45a8ff 71
mbed_official 80:bdf1132a57cf 72 US_TICKER_TIMER1->TimerControl &= 0xDF;
mbed_official 80:bdf1132a57cf 73 US_TICKER_TIMER2->TimerControl &= 0xDF;
bogdanm 0:9b334a45a8ff 74
bogdanm 0:9b334a45a8ff 75 }
bogdanm 0:9b334a45a8ff 76
bogdanm 0:9b334a45a8ff 77 void us_ticker_clear_interrupt(void) {
bogdanm 0:9b334a45a8ff 78
mbed_official 80:bdf1132a57cf 79 US_TICKER_TIMER1->TimerIntClr = 0x1;
mbed_official 80:bdf1132a57cf 80 US_TICKER_TIMER2->TimerIntClr = 0x1;
bogdanm 0:9b334a45a8ff 81
bogdanm 0:9b334a45a8ff 82 }