mbed-os for GR-LYCHEE
Dependents: mbed-os-example-blinky-gr-lychee GR-Boads_Camera_sample GR-Boards_Audio_Recoder GR-Boads_Camera_DisplayApp ... more
Diff: features/frameworks/utest/source/utest_shim.cpp
- Revision:
- 0:f782d9c66c49
diff -r 000000000000 -r f782d9c66c49 features/frameworks/utest/source/utest_shim.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/features/frameworks/utest/source/utest_shim.cpp Fri Feb 02 05:42:23 2018 +0000 @@ -0,0 +1,149 @@ +/**************************************************************************** + * Copyright (c) 2015, ARM Limited, All Rights Reserved + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + **************************************************************************** + */ + +#include "utest/utest_shim.h" +#include "utest/utest_stack_trace.h" + +#if UTEST_SHIM_SCHEDULER_USE_MINAR +#include "minar/minar.h" + +static int32_t utest_minar_init() +{ + return 0; +} +static void *utest_minar_post(const utest_v1_harness_callback_t callback, const uint32_t delay_ms) +{ + void *handle = minar::Scheduler::postCallback(callback).delay(minar::milliseconds(delay_ms)).getHandle(); + return handle; +} +static int32_t utest_minar_cancel(void *handle) +{ + int32_t ret = minar::Scheduler::cancelCallback(handle); + return ret; +} +static int32_t utest_minar_run() +{ + return 0; +} +extern "C" { +static const utest_v1_scheduler_t utest_v1_scheduler = +{ + utest_minar_init, + utest_minar_post, + utest_minar_cancel, + utest_minar_run +}; +utest_v1_scheduler_t utest_v1_get_scheduler() +{ + return utest_v1_scheduler; +} +} + +#elif UTEST_SHIM_SCHEDULER_USE_US_TICKER +#ifdef YOTTA_MBED_HAL_VERSION_STRING +# include "mbed-hal/us_ticker_api.h" +#else +# include "mbed.h" +#endif + +// only one callback is active at any given time +static volatile utest_v1_harness_callback_t minimal_callback; +static volatile utest_v1_harness_callback_t ticker_callback; + +// Timeout object used to control the scheduling of test case callbacks +SingletonPtr<Timeout> utest_timeout_object; + +static void ticker_handler() +{ + UTEST_LOG_FUNCTION(); + minimal_callback = ticker_callback; +} + +static int32_t utest_us_ticker_init() +{ + UTEST_LOG_FUNCTION(); + // initialize the Timeout object to makes sure it is not initialized in + // interrupt context. + utest_timeout_object.get(); + return 0; +} +static void *utest_us_ticker_post(const utest_v1_harness_callback_t callback, timestamp_t delay_ms) +{ + UTEST_LOG_FUNCTION(); + timestamp_t delay_us = delay_ms *1000; + + if (delay_ms) { + ticker_callback = callback; + // fire the interrupt in 1000us * delay_ms + utest_timeout_object->attach_us(ticker_handler, delay_us); + + } + else { + minimal_callback = callback; + } + + // return a bogus handle + return (void*)1; +} +static int32_t utest_us_ticker_cancel(void *handle) +{ + UTEST_LOG_FUNCTION(); + (void) handle; + utest_timeout_object->detach(); + return 0; +} +static int32_t utest_us_ticker_run() +{ + UTEST_LOG_FUNCTION(); + while(1) + { + // check if a new callback has been set + if (minimal_callback) + { + // copy the callback + utest_v1_harness_callback_t callback = minimal_callback; + // reset the shared callback + minimal_callback = NULL; + // execute the copied callback + callback(); + } + } +} + + +extern "C" { +static const utest_v1_scheduler_t utest_v1_scheduler = +{ + utest_us_ticker_init, + utest_us_ticker_post, + utest_us_ticker_cancel, + utest_us_ticker_run +}; +utest_v1_scheduler_t utest_v1_get_scheduler() +{ + UTEST_LOG_FUNCTION(); + return utest_v1_scheduler; +} +} +#endif + +#ifdef YOTTA_CORE_UTIL_VERSION_STRING +// their functionality is implemented using the CriticalSectionLock class +void utest_v1_enter_critical_section(void) {} +void utest_v1_leave_critical_section(void) {} +#endif