diff options
| author | tmk <nobody@nowhere> | 2014-11-24 15:36:53 +0900 | 
|---|---|---|
| committer | tmk <nobody@nowhere> | 2014-11-24 15:36:53 +0900 | 
| commit | ed52ebb9870a26496b13a0565c1aaca8ded3465b (patch) | |
| tree | cddad806a3408e05bc29310254c564ee94e3e710 /common/mbed | |
| parent | eb90ed6238426db9367e294abfaefb5de07564f5 (diff) | |
| parent | e2077cad45f1736e878e317c43bd94117c61b5e0 (diff) | |
Merge branch 'merge_rn42'
Diffstat (limited to 'common/mbed')
| -rw-r--r-- | common/mbed/bootloader.c | 4 | ||||
| -rw-r--r-- | common/mbed/suspend.c | 6 | ||||
| -rw-r--r-- | common/mbed/timer.c | 41 | ||||
| -rw-r--r-- | common/mbed/xprintf.cpp | 46 | ||||
| -rw-r--r-- | common/mbed/xprintf.h | 17 | 
5 files changed, 114 insertions, 0 deletions
| diff --git a/common/mbed/bootloader.c b/common/mbed/bootloader.c new file mode 100644 index 0000000000..b51e83943a --- /dev/null +++ b/common/mbed/bootloader.c @@ -0,0 +1,4 @@ +#include "bootloader.h" + + +void bootloader_jump(void) {} diff --git a/common/mbed/suspend.c b/common/mbed/suspend.c new file mode 100644 index 0000000000..32651574f8 --- /dev/null +++ b/common/mbed/suspend.c @@ -0,0 +1,6 @@ +#include <stdbool.h> + + +void suspend_power_down(void) {} +bool suspend_wakeup_condition(void) { return true; } +void suspend_wakeup_init(void) {} diff --git a/common/mbed/timer.c b/common/mbed/timer.c new file mode 100644 index 0000000000..c357ceb786 --- /dev/null +++ b/common/mbed/timer.c @@ -0,0 +1,41 @@ +#include "cmsis.h" +#include "timer.h" + +/* Mill second tick count */ +volatile uint32_t timer_count = 0; + +/* Timer interrupt handler */ +void SysTick_Handler(void)  { +    timer_count++; +} + +void timer_init(void) +{ +    timer_count = 0; +    SysTick_Config(SystemCoreClock / 1000); /* 1ms tick */ +} + +void timer_clear(void) +{ +    timer_count = 0; +} + +uint16_t timer_read(void) +{ +    return (uint16_t)(timer_count & 0xFFFF); +} + +uint32_t timer_read32(void) +{ +    return timer_count; +} + +uint16_t timer_elapsed(uint16_t last) +{ +    return TIMER_DIFF_16(timer_read(), last); +} + +uint32_t timer_elapsed32(uint32_t last) +{ +    return TIMER_DIFF_32(timer_read32(), last); +} diff --git a/common/mbed/xprintf.cpp b/common/mbed/xprintf.cpp new file mode 100644 index 0000000000..4342b79f80 --- /dev/null +++ b/common/mbed/xprintf.cpp @@ -0,0 +1,46 @@ +#include <cstdarg> +//#include <stdarg.h> +#include "mbed.h" +#include "mbed/xprintf.h" + + +#define STRING_STACK_LIMIT    120 + +/* mbed Serial */ +Serial ser(UART_TX, UART_RX); + +/* TODO: Need small implementation for embedded */ +int xprintf(const char* format, ...) +{ +    /* copy from mbed/common/RawSerial.cpp */ +    std::va_list arg; +    va_start(arg, format); +    int len = vsnprintf(NULL, 0, format, arg); +    if (len < STRING_STACK_LIMIT) { +        char temp[STRING_STACK_LIMIT]; +        vsprintf(temp, format, arg); +        ser.puts(temp); +    } else { +        char *temp = new char[len + 1]; +        vsprintf(temp, format, arg); +        ser.puts(temp); +        delete[] temp; +    } +    va_end(arg); +    return len; + +/* Fail: __builtin_va_arg_pack? + * https://gcc.gnu.org/onlinedocs/gcc-4.3.5/gcc/Constructing-Calls.html#Constructing-Calls +    void *arg = __builtin_apply_args(); +    void *ret = __builtin_apply((void*)(&(ser.printf)), arg, 100); +    __builtin_return(ret) +*/ +/* Fail: varargs can not be passed to printf +    //int r = ser.printf("test %i\r\n", 123); +    va_list arg; +    va_start(arg, format); +    int r = ser.printf(format, arg); +    va_end(arg); +    return r; +*/ +} diff --git a/common/mbed/xprintf.h b/common/mbed/xprintf.h new file mode 100644 index 0000000000..26bc529e5b --- /dev/null +++ b/common/mbed/xprintf.h @@ -0,0 +1,17 @@ +#ifndef XPRINTF_H +#define XPRINTF_H + +//#define xprintf(format, ...)            __xprintf(format, ##__VA_ARGS__) + +#ifdef __cplusplus +extern "C" { +#endif + +int xprintf(const char *format, ...); + +#ifdef __cplusplus +} +#endif + + +#endif | 
