Skip to content

Commit 1a1507a

Browse files
author
Bogdan Marinescu
committed
Unification of wait functions
This commit adds two implementations for the mbed wait functions (wait, wait_ms, wait_us): - with the RTOS present, the wait functions will use `Thread::wait` for millisecond delays and a busy wait loop for sub-millisecond delays. - with the RTOS not present, the wait functions will always use a busy wait loop.
1 parent b171a9c commit 1a1507a

File tree

2 files changed

+64
-0
lines changed

2 files changed

+64
-0
lines changed

hal/common/mbed_wait_api.c renamed to hal/common/mbed_wait_api_no_rtos.c

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,11 @@
1313
* See the License for the specific language governing permissions and
1414
* limitations under the License.
1515
*/
16+
17+
// This implementation of the wait functions will be compiled only
18+
// if the RTOS is not present.
19+
#ifndef MBED_CONF_RTOS_PRESENT
20+
1621
#include "wait_api.h"
1722
#include "us_ticker_api.h"
1823

@@ -28,3 +33,6 @@ void wait_us(int us) {
2833
uint32_t start = us_ticker_read();
2934
while ((us_ticker_read() - start) < (uint32_t)us);
3035
}
36+
37+
#endif // #ifndef MBED_CONF_RTOS_PRESENT
38+

hal/common/mbed_wait_api_rtos.cpp

Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
/* mbed Microcontroller Library
2+
* Copyright (c) 2006-2013 ARM Limited
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License");
5+
* you may not use this file except in compliance with the License.
6+
* You may obtain a copy of the License at
7+
*
8+
* http://www.apache.org/licenses/LICENSE-2.0
9+
*
10+
* Unless required by applicable law or agreed to in writing, software
11+
* distributed under the License is distributed on an "AS IS" BASIS,
12+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
* See the License for the specific language governing permissions and
14+
* limitations under the License.
15+
*/
16+
17+
// This implementation of the wait functions will be compiled only
18+
// if the RTOS is present.
19+
#ifdef MBED_CONF_RTOS_PRESENT
20+
21+
#include "wait_api.h"
22+
#include "us_ticker_api.h"
23+
#include "rtos.h"
24+
#include "critical.h"
25+
26+
void wait(float s) {
27+
wait_us(s * 1000000.0f);
28+
}
29+
30+
void wait_ms(int ms) {
31+
wait_us(ms * 1000);
32+
}
33+
34+
// Wait for the given number of microseconds using a hardware timer
35+
// in a busy wait loop
36+
static void wait_us_busy(int us) {
37+
if (us > 0) {
38+
uint32_t start = us_ticker_read();
39+
while ((us_ticker_read() - start) < (uint32_t)us);
40+
}
41+
}
42+
43+
void wait_us(int us) {
44+
// Use the RTOS to wait for millisecond delays if possible
45+
int ms = us / 1000;
46+
if ((ms > 0) && core_util_are_interrupts_enabled()) {
47+
Thread::wait((uint32_t)ms);
48+
us -= ms * 1000;
49+
}
50+
// Use busy waiting for sub-millisecond delays, or for the whole
51+
// interval if interrupts are not enabled
52+
wait_us_busy(us);
53+
}
54+
55+
#endif // #if MBED_CONF_RTOS_PRESENT
56+

0 commit comments

Comments
 (0)