Skip to content

Commit 2f127cb

Browse files
authored
Merge pull request #2274 from ARMmbed/unified_wait
Unification of wait functions
2 parents 0712b8a + 49606cd commit 2f127cb

File tree

2 files changed

+58
-0
lines changed

2 files changed

+58
-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: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
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+
void wait_us(int us) {
35+
uint32_t start = us_ticker_read();
36+
// Use the RTOS to wait for millisecond delays if possible
37+
int ms = us / 1000;
38+
if ((ms > 0) && core_util_are_interrupts_enabled()) {
39+
Thread::wait((uint32_t)ms);
40+
us -= ms * 1000;
41+
}
42+
// Use busy waiting for sub-millisecond delays, or for the whole
43+
// interval if interrupts are not enabled
44+
if (us > 0) {
45+
while((us_ticker_read() - start) < (uint32_t)us);
46+
}
47+
}
48+
49+
#endif // #if MBED_CONF_RTOS_PRESENT
50+

0 commit comments

Comments
 (0)