The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
Kojto
Date:
Wed Jul 19 16:46:19 2017 +0100
Revision:
147:a97add6d7e64
Parent:
146:22da6e220af6
Child:
152:235179ab3f27
Release 147 of the mbed library.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 128:9bcdf88f62b0 1 /* mbed Microcontroller Library
<> 128:9bcdf88f62b0 2 * Copyright (c) 2006-2013 ARM Limited
<> 128:9bcdf88f62b0 3 *
<> 128:9bcdf88f62b0 4 * Licensed under the Apache License, Version 2.0 (the "License");
<> 128:9bcdf88f62b0 5 * you may not use this file except in compliance with the License.
<> 128:9bcdf88f62b0 6 * You may obtain a copy of the License at
<> 128:9bcdf88f62b0 7 *
<> 128:9bcdf88f62b0 8 * http://www.apache.org/licenses/LICENSE-2.0
<> 128:9bcdf88f62b0 9 *
<> 128:9bcdf88f62b0 10 * Unless required by applicable law or agreed to in writing, software
<> 128:9bcdf88f62b0 11 * distributed under the License is distributed on an "AS IS" BASIS,
<> 128:9bcdf88f62b0 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
<> 128:9bcdf88f62b0 13 * See the License for the specific language governing permissions and
<> 128:9bcdf88f62b0 14 * limitations under the License.
<> 128:9bcdf88f62b0 15 */
<> 128:9bcdf88f62b0 16 #ifndef MBED_TICKER_H
<> 128:9bcdf88f62b0 17 #define MBED_TICKER_H
<> 128:9bcdf88f62b0 18
<> 128:9bcdf88f62b0 19 #include "drivers/TimerEvent.h"
<> 128:9bcdf88f62b0 20 #include "platform/Callback.h"
<> 138:093f2bd7b9eb 21 #include "platform/mbed_toolchain.h"
AnnaBridge 146:22da6e220af6 22 #include "platform/NonCopyable.h"
<> 128:9bcdf88f62b0 23
<> 128:9bcdf88f62b0 24 namespace mbed {
<> 128:9bcdf88f62b0 25 /** \addtogroup drivers */
<> 128:9bcdf88f62b0 26
<> 128:9bcdf88f62b0 27 /** A Ticker is used to call a function at a recurring interval
<> 128:9bcdf88f62b0 28 *
<> 128:9bcdf88f62b0 29 * You can use as many seperate Ticker objects as you require.
<> 128:9bcdf88f62b0 30 *
AnnaBridge 145:64910690c574 31 * @note Synchronization level: Interrupt safe
<> 128:9bcdf88f62b0 32 *
<> 128:9bcdf88f62b0 33 * Example:
<> 128:9bcdf88f62b0 34 * @code
<> 128:9bcdf88f62b0 35 * // Toggle the blinking led after 5 seconds
<> 128:9bcdf88f62b0 36 *
<> 128:9bcdf88f62b0 37 * #include "mbed.h"
<> 128:9bcdf88f62b0 38 *
<> 128:9bcdf88f62b0 39 * Ticker timer;
<> 128:9bcdf88f62b0 40 * DigitalOut led1(LED1);
<> 128:9bcdf88f62b0 41 * DigitalOut led2(LED2);
<> 128:9bcdf88f62b0 42 *
<> 128:9bcdf88f62b0 43 * int flip = 0;
<> 128:9bcdf88f62b0 44 *
<> 128:9bcdf88f62b0 45 * void attime() {
<> 128:9bcdf88f62b0 46 * flip = !flip;
<> 128:9bcdf88f62b0 47 * }
<> 128:9bcdf88f62b0 48 *
<> 128:9bcdf88f62b0 49 * int main() {
<> 128:9bcdf88f62b0 50 * timer.attach(&attime, 5);
<> 128:9bcdf88f62b0 51 * while(1) {
<> 128:9bcdf88f62b0 52 * if(flip == 0) {
<> 128:9bcdf88f62b0 53 * led1 = !led1;
<> 128:9bcdf88f62b0 54 * } else {
<> 128:9bcdf88f62b0 55 * led2 = !led2;
<> 128:9bcdf88f62b0 56 * }
<> 128:9bcdf88f62b0 57 * wait(0.2);
<> 128:9bcdf88f62b0 58 * }
<> 128:9bcdf88f62b0 59 * }
<> 128:9bcdf88f62b0 60 * @endcode
AnnaBridge 145:64910690c574 61 * @ingroup drivers
<> 128:9bcdf88f62b0 62 */
AnnaBridge 146:22da6e220af6 63 class Ticker : public TimerEvent, private NonCopyable<Ticker> {
<> 128:9bcdf88f62b0 64
<> 128:9bcdf88f62b0 65 public:
<> 128:9bcdf88f62b0 66 Ticker() : TimerEvent() {
<> 128:9bcdf88f62b0 67 }
<> 128:9bcdf88f62b0 68
<> 128:9bcdf88f62b0 69 Ticker(const ticker_data_t *data) : TimerEvent(data) {
<> 128:9bcdf88f62b0 70 data->interface->init();
<> 128:9bcdf88f62b0 71 }
<> 128:9bcdf88f62b0 72
<> 128:9bcdf88f62b0 73 /** Attach a function to be called by the Ticker, specifiying the interval in seconds
<> 128:9bcdf88f62b0 74 *
<> 128:9bcdf88f62b0 75 * @param func pointer to the function to be called
<> 128:9bcdf88f62b0 76 * @param t the time between calls in seconds
<> 128:9bcdf88f62b0 77 */
<> 128:9bcdf88f62b0 78 void attach(Callback<void()> func, float t) {
<> 128:9bcdf88f62b0 79 attach_us(func, t * 1000000.0f);
<> 128:9bcdf88f62b0 80 }
<> 128:9bcdf88f62b0 81
<> 128:9bcdf88f62b0 82 /** Attach a member function to be called by the Ticker, specifiying the interval in seconds
<> 128:9bcdf88f62b0 83 *
<> 128:9bcdf88f62b0 84 * @param obj pointer to the object to call the member function on
<> 128:9bcdf88f62b0 85 * @param method pointer to the member function to be called
<> 128:9bcdf88f62b0 86 * @param t the time between calls in seconds
<> 128:9bcdf88f62b0 87 * @deprecated
<> 128:9bcdf88f62b0 88 * The attach function does not support cv-qualifiers. Replaced by
<> 128:9bcdf88f62b0 89 * attach(callback(obj, method), t).
<> 128:9bcdf88f62b0 90 */
<> 128:9bcdf88f62b0 91 template<typename T, typename M>
<> 128:9bcdf88f62b0 92 MBED_DEPRECATED_SINCE("mbed-os-5.1",
<> 128:9bcdf88f62b0 93 "The attach function does not support cv-qualifiers. Replaced by "
<> 128:9bcdf88f62b0 94 "attach(callback(obj, method), t).")
<> 128:9bcdf88f62b0 95 void attach(T *obj, M method, float t) {
<> 128:9bcdf88f62b0 96 attach(callback(obj, method), t);
<> 128:9bcdf88f62b0 97 }
<> 128:9bcdf88f62b0 98
<> 128:9bcdf88f62b0 99 /** Attach a function to be called by the Ticker, specifiying the interval in micro-seconds
<> 128:9bcdf88f62b0 100 *
AnnaBridge 145:64910690c574 101 * @param func pointer to the function to be called
<> 128:9bcdf88f62b0 102 * @param t the time between calls in micro-seconds
<> 128:9bcdf88f62b0 103 */
AnnaBridge 145:64910690c574 104 void attach_us(Callback<void()> func, us_timestamp_t t) {
<> 138:093f2bd7b9eb 105 _function = func;
<> 128:9bcdf88f62b0 106 setup(t);
<> 128:9bcdf88f62b0 107 }
<> 128:9bcdf88f62b0 108
<> 128:9bcdf88f62b0 109 /** Attach a member function to be called by the Ticker, specifiying the interval in micro-seconds
<> 128:9bcdf88f62b0 110 *
AnnaBridge 145:64910690c574 111 * @param obj pointer to the object to call the member function on
AnnaBridge 145:64910690c574 112 * @param method pointer to the member function to be called
<> 128:9bcdf88f62b0 113 * @param t the time between calls in micro-seconds
<> 128:9bcdf88f62b0 114 * @deprecated
<> 128:9bcdf88f62b0 115 * The attach_us function does not support cv-qualifiers. Replaced by
<> 128:9bcdf88f62b0 116 * attach_us(callback(obj, method), t).
<> 128:9bcdf88f62b0 117 */
<> 128:9bcdf88f62b0 118 template<typename T, typename M>
<> 128:9bcdf88f62b0 119 MBED_DEPRECATED_SINCE("mbed-os-5.1",
<> 128:9bcdf88f62b0 120 "The attach_us function does not support cv-qualifiers. Replaced by "
<> 128:9bcdf88f62b0 121 "attach_us(callback(obj, method), t).")
AnnaBridge 145:64910690c574 122 void attach_us(T *obj, M method, us_timestamp_t t) {
<> 128:9bcdf88f62b0 123 attach_us(Callback<void()>(obj, method), t);
<> 128:9bcdf88f62b0 124 }
<> 128:9bcdf88f62b0 125
<> 128:9bcdf88f62b0 126 virtual ~Ticker() {
<> 128:9bcdf88f62b0 127 detach();
<> 128:9bcdf88f62b0 128 }
<> 128:9bcdf88f62b0 129
<> 128:9bcdf88f62b0 130 /** Detach the function
<> 128:9bcdf88f62b0 131 */
<> 128:9bcdf88f62b0 132 void detach();
<> 128:9bcdf88f62b0 133
<> 128:9bcdf88f62b0 134 protected:
AnnaBridge 145:64910690c574 135 void setup(us_timestamp_t t);
<> 128:9bcdf88f62b0 136 virtual void handler();
<> 128:9bcdf88f62b0 137
<> 128:9bcdf88f62b0 138 protected:
AnnaBridge 145:64910690c574 139 us_timestamp_t _delay; /**< Time delay (in microseconds) for re-setting the multi-shot callback. */
<> 128:9bcdf88f62b0 140 Callback<void()> _function; /**< Callback. */
<> 128:9bcdf88f62b0 141 };
<> 128:9bcdf88f62b0 142
<> 128:9bcdf88f62b0 143 } // namespace mbed
<> 128:9bcdf88f62b0 144
<> 128:9bcdf88f62b0 145 #endif