Skip to content

Commit 569159b

Browse files
authored
Merge pull request #6057 from ARMmbed/release-candidate
Release candidate for mbed-os-5.7.5
2 parents caeaa49 + 27109be commit 569159b

File tree

511 files changed

+199183
-2783
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

511 files changed

+199183
-2783
lines changed

TESTS/mbed_drivers/ticker/main.cpp

Lines changed: 38 additions & 67 deletions
Original file line numberDiff line numberDiff line change
@@ -38,50 +38,36 @@ volatile uint32_t multi_counter;
3838
DigitalOut led1(LED1);
3939
DigitalOut led2(LED2);
4040

41-
Ticker *volatile ticker1;
42-
Ticker *volatile ticker2;
4341
Timer gtimer;
44-
4542
volatile int ticker_count = 0;
46-
volatile bool print_tick = false;
47-
48-
void ticker_callback_1_switch_to_2(void);
49-
void ticker_callback_2_switch_to_1(void);
5043

51-
void increment_ticker_counter(void)
52-
{
53-
++callback_trigger_count;
54-
}
5544

5645
void switch_led1_state(void)
5746
{
58-
led1 = !led1;
47+
// blink 3 times per second
48+
if((callback_trigger_count % 333) == 0) {
49+
led1 = !led1;
50+
}
5951
}
6052

6153
void switch_led2_state(void)
6254
{
63-
led2 = !led2;
55+
// blink 3 times per second
56+
// make led2 blink at the same callback_trigger_count value as led1
57+
if(((callback_trigger_count - 1) % 333) == 0) {
58+
led2 = !led2;
59+
}
6460
}
6561

66-
void ticker_callback_1_switch_to_2(void)
62+
void ticker_callback_1(void)
6763
{
6864
++callback_trigger_count;
69-
// If ticker is NULL then it is being or has been deleted
70-
if (ticker1) {
71-
ticker1->detach();
72-
ticker1->attach_us(ticker_callback_2_switch_to_1, ONE_MILLI_SEC);
73-
}
7465
switch_led1_state();
7566
}
7667

77-
void ticker_callback_2_switch_to_1(void)
68+
void ticker_callback_2(void)
7869
{
7970
++callback_trigger_count;
80-
// If ticker is NULL then it is being or has been deleted
81-
if (ticker2) {
82-
ticker2->detach();
83-
ticker2->attach_us(ticker_callback_1_switch_to_2, ONE_MILLI_SEC);
84-
}
8571
switch_led2_state();
8672
}
8773

@@ -106,9 +92,8 @@ void increment_multi_counter(void)
10692

10793
/* Tests is to measure the accuracy of Ticker over a period of time
10894
*
109-
* 1) DUT would start to update callback_trigger_count every milli sec, in 2x callback we use 2 tickers
110-
* to update the count alternatively.
111-
* 2) Host would query what is current count base_time, Device responds by the callback_trigger_count
95+
* 1) DUT would start to update callback_trigger_count every milli sec
96+
* 2) Host would query what is current count base_time, Device responds by the callback_trigger_count.
11297
* 3) Host after waiting for measurement stretch. It will query for device time again final_time.
11398
* 4) Host computes the drift considering base_time, final_time, transport delay and measurement stretch
11499
* 5) Finally host send the results back to device pass/fail based on tolerance.
@@ -119,9 +104,14 @@ void test_case_1x_ticker()
119104
char _key[11] = { };
120105
char _value[128] = { };
121106
int expected_key = 1;
107+
Ticker ticker;
108+
109+
led1 = 1;
110+
led2 = 1;
111+
callback_trigger_count = 0;
122112

123113
greentea_send_kv("timing_drift_check_start", 0);
124-
ticker1->attach_us(&increment_ticker_counter, ONE_MILLI_SEC);
114+
ticker.attach_us(&ticker_callback_1, ONE_MILLI_SEC);
125115

126116
// wait for 1st signal from host
127117
do {
@@ -140,18 +130,32 @@ void test_case_1x_ticker()
140130
TEST_ASSERT_EQUAL_STRING_MESSAGE("pass", _key,"Host side script reported a fail...");
141131
}
142132

143-
void test_case_2x_callbacks()
133+
/* Tests is to measure the accuracy of Ticker over a period of time
134+
*
135+
* 1) DUT would start to update callback_trigger_count every milli sec, we use 2 tickers
136+
* to update the count alternatively.
137+
* 2) Host would query what is current count base_time, Device responds by the callback_trigger_count
138+
* 3) Host after waiting for measurement stretch. It will query for device time again final_time.
139+
* 4) Host computes the drift considering base_time, final_time, transport delay and measurement stretch
140+
* 5) Finally host send the results back to device pass/fail based on tolerance.
141+
* 6) More details on tests can be found in timing_drift_auto.py
142+
*/
143+
void test_case_2x_ticker()
144144
{
145145
char _key[11] = { };
146146
char _value[128] = { };
147147
int expected_key = 1;
148+
Ticker ticker1, ticker2;
148149

149150
led1 = 0;
150-
led2 = 0;
151+
led2 = 1;
151152
callback_trigger_count = 0;
152153

154+
ticker1.attach_us(ticker_callback_1, 2 * ONE_MILLI_SEC);
155+
// delay second ticker to have a pair of tickers tick every one millisecond
156+
wait_us(ONE_MILLI_SEC);
153157
greentea_send_kv("timing_drift_check_start", 0);
154-
ticker1->attach_us(ticker_callback_1_switch_to_2, ONE_MILLI_SEC);
158+
ticker2.attach_us(ticker_callback_2, 2 * ONE_MILLI_SEC);
155159

156160
// wait for 1st signal from host
157161
do {
@@ -303,39 +307,6 @@ void test_attach_us_time(void)
303307
}
304308

305309

306-
utest::v1::status_t one_ticker_case_setup_handler_t(const Case *const source, const size_t index_of_case)
307-
{
308-
ticker1 = new Ticker();
309-
return greentea_case_setup_handler(source, index_of_case);
310-
}
311-
312-
utest::v1::status_t two_ticker_case_setup_handler_t(const Case *const source, const size_t index_of_case)
313-
{
314-
ticker1 = new Ticker();
315-
ticker2 = new Ticker();
316-
return utest::v1::greentea_case_setup_handler(source, index_of_case);
317-
}
318-
319-
utest::v1::status_t one_ticker_case_teardown_handler_t(const Case *const source, const size_t passed, const size_t failed, const utest::v1::failure_t reason)
320-
{
321-
Ticker *temp1 = ticker1;
322-
ticker1 = NULL;
323-
delete temp1;
324-
return utest::v1::greentea_case_teardown_handler(source, passed, failed, reason);
325-
}
326-
327-
utest::v1::status_t two_ticker_case_teardown_handler_t(const Case *const source, const size_t passed, const size_t failed, const utest::v1::failure_t reason)
328-
{
329-
Ticker *temp1 = ticker1;
330-
Ticker *temp2 = ticker2;
331-
ticker1 = NULL;
332-
ticker2 = NULL;
333-
delete temp1;
334-
delete temp2;
335-
return utest::v1::greentea_case_teardown_handler(source, passed, failed, reason);
336-
}
337-
338-
339310
// Test cases
340311
Case cases[] = {
341312
Case("Test attach for 0.01s and time measure", test_attach_time<10000>),
@@ -347,8 +318,8 @@ Case cases[] = {
347318
Case("Test detach", test_detach),
348319
Case("Test multi call and time measure", test_multi_call_time),
349320
Case("Test multi ticker", test_multi_ticker),
350-
Case("Test timers: 1x ticker", one_ticker_case_setup_handler_t,test_case_1x_ticker, one_ticker_case_teardown_handler_t),
351-
Case("Test timers: 2x callbacks", two_ticker_case_setup_handler_t,test_case_2x_callbacks, two_ticker_case_teardown_handler_t)
321+
Case("Test timers: 1x ticker", test_case_1x_ticker),
322+
Case("Test timers: 2x ticker", test_case_2x_ticker)
352323
};
353324

354325
utest::v1::status_t greentea_test_setup(const size_t number_of_cases)
Lines changed: 145 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,145 @@
1+
/* mbed Microcontroller Library
2+
* Copyright (c) 2018 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+
#ifndef MBED_TESTFILEHANDLE_H
17+
#define MBED_TESTFILEHANDLE_H
18+
19+
#include "platform/FileHandle.h"
20+
21+
22+
#define POS_IS_VALID(pos) (pos >= 0 && pos < _end)
23+
#define NEW_POS_IS_VALID(pos) (pos >= 0 && pos < (int32_t)FILE_SIZE)
24+
#define SEEK_POS_IS_VALID(pos) (pos >= 0 && pos <= _end)
25+
#define INVALID_POS (-1)
26+
27+
template<uint32_t FILE_SIZE>
28+
class TestFile : public FileHandle {
29+
public:
30+
TestFile(): _pos(0), _end(0) {}
31+
~TestFile() {}
32+
33+
enum FunctionName {
34+
fnNone, fnRead, fnWrite, fnSeek, fnClose, fnIsatty
35+
};
36+
37+
virtual ssize_t read(void *buffer, size_t size)
38+
{
39+
ssize_t read;
40+
_fnCalled = fnRead;
41+
42+
for(read = 0; (size_t)read < size; read++)
43+
{
44+
if(POS_IS_VALID(_pos)) {
45+
((uint8_t*)buffer)[read] = _data[_pos++];
46+
} else {
47+
break;
48+
}
49+
} // for
50+
return read;
51+
}
52+
53+
virtual ssize_t write(const void *buffer, size_t size)
54+
{
55+
ssize_t written;
56+
_fnCalled = fnWrite;
57+
58+
for(written = 0; (size_t)written < size; written++)
59+
{
60+
if(NEW_POS_IS_VALID(_pos)) {
61+
_data[_pos++] = ((uint8_t*)buffer)[written];
62+
} else {
63+
if(0 == written) {
64+
return -ENOSPC;
65+
}
66+
break;
67+
}
68+
if(_end < _pos) {
69+
_end++;
70+
}
71+
} // for
72+
return written;
73+
}
74+
75+
virtual off_t seek(off_t offset, int whence)
76+
{
77+
_fnCalled = fnSeek;
78+
int32_t new_pos = INVALID_POS;
79+
80+
switch(whence)
81+
{
82+
case SEEK_SET:
83+
new_pos = offset;
84+
break;
85+
86+
case SEEK_CUR:
87+
new_pos = _pos + offset;
88+
break;
89+
90+
case SEEK_END:
91+
new_pos = _end - offset;
92+
break;
93+
94+
default:
95+
// nothing todo
96+
break;
97+
}
98+
99+
if(SEEK_POS_IS_VALID(new_pos)) {
100+
_pos = new_pos;
101+
} else {
102+
return -EINVAL;
103+
}
104+
105+
return _pos;
106+
}
107+
108+
virtual int close()
109+
{
110+
_fnCalled = fnClose;
111+
return 0;
112+
}
113+
114+
115+
static void resetFunctionCallHistory()
116+
{
117+
_fnCalled = fnNone;
118+
}
119+
120+
static bool functionCalled(FunctionName name)
121+
{
122+
return (name == _fnCalled);
123+
}
124+
125+
static FunctionName getFunctionCalled()
126+
{
127+
return _fnCalled;
128+
}
129+
130+
private:
131+
132+
// stores last function call name
133+
static FunctionName _fnCalled;
134+
135+
// file storage
136+
uint8_t _data[FILE_SIZE];
137+
138+
int32_t _pos, _end;
139+
};
140+
141+
template<uint32_t FILE_SIZE>
142+
typename TestFile<FILE_SIZE>::FunctionName TestFile<FILE_SIZE>::_fnCalled;
143+
144+
145+
#endif // MBED_TESTFILEHANDLE_H

0 commit comments

Comments
 (0)