From d3da3bd9b2bc6aead60a7b1ca36888e4fc03c5d8 Mon Sep 17 00:00:00 2001 From: BernardXiong Date: Sun, 31 Dec 2017 16:43:08 +0800 Subject: [PATCH] [libc] move clock_time to time. --- components/libc/compilers/newlib/syscalls.c | 372 +++++++++--------- components/libc/pthreads/pthread.c | 3 - components/libc/pthreads/pthread.h | 31 -- components/libc/pthreads/pthread_internal.h | 2 +- components/libc/{timer => time}/SConscript | 4 +- .../libc/{pthreads => time}/clock_time.c | 76 +++- components/libc/time/clock_time.h | 58 +++ components/libc/{timer => time}/posix_sleep.c | 0 8 files changed, 306 insertions(+), 240 deletions(-) rename components/libc/{timer => time}/SConscript (59%) rename components/libc/{pthreads => time}/clock_time.c (71%) create mode 100644 components/libc/time/clock_time.h rename components/libc/{timer => time}/posix_sleep.c (100%) diff --git a/components/libc/compilers/newlib/syscalls.c b/components/libc/compilers/newlib/syscalls.c index 52d2361a0..514dda147 100644 --- a/components/libc/compilers/newlib/syscalls.c +++ b/components/libc/compilers/newlib/syscalls.c @@ -17,86 +17,86 @@ int _close_r(struct _reent *ptr, int fd) { #ifndef RT_USING_DFS - return 0; + return 0; #else - return close(fd); + return close(fd); #endif } int _execve_r(struct _reent *ptr, const char * name, char *const *argv, char *const *env) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _fcntl_r(struct _reent *ptr, int fd, int cmd, int arg) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _fork_r(struct _reent *ptr) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _fstat_r(struct _reent *ptr, int fd, struct stat *pstat) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _getpid_r(struct _reent *ptr) { - return 0; + return 0; } int _isatty_r(struct _reent *ptr, int fd) { - if (fd >=0 && fd < 3) return 1; + if (fd >=0 && fd < 3) return 1; - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _kill_r(struct _reent *ptr, int pid, int sig) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _link_r(struct _reent *ptr, const char *old, const char *new) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } _off_t _lseek_r(struct _reent *ptr, int fd, _off_t pos, int whence) { #ifndef RT_USING_DFS - return 0; + return 0; #else - _off_t rc; + _off_t rc; - rc = lseek(fd, pos, whence); - return rc; + rc = lseek(fd, pos, whence); + return rc; #endif } @@ -104,12 +104,12 @@ int _mkdir_r(struct _reent *ptr, const char *name, int mode) { #ifndef RT_USING_DFS - return 0; + return 0; #else - int rc; + int rc; - rc = mkdir(name, mode); - return rc; + rc = mkdir(name, mode); + return rc; #endif } @@ -117,12 +117,12 @@ int _open_r(struct _reent *ptr, const char *file, int flags, int mode) { #ifndef RT_USING_DFS - return 0; + return 0; #else - int rc; + int rc; - rc = open(file, flags, mode); - return rc; + rc = open(file, flags, mode); + return rc; #endif } @@ -130,12 +130,12 @@ _ssize_t _read_r(struct _reent *ptr, int fd, void *buf, size_t nbytes) { #ifndef RT_USING_DFS - return 0; + return 0; #else - _ssize_t rc; + _ssize_t rc; - rc = read(fd, buf, nbytes); - return rc; + rc = read(fd, buf, nbytes); + return rc; #endif } @@ -143,62 +143,62 @@ int _rename_r(struct _reent *ptr, const char *old, const char *new) { #ifndef RT_USING_DFS - return 0; + return 0; #else - int rc; + int rc; - rc = rename(old, new); - return rc; + rc = rename(old, new); + return rc; #endif } void * _sbrk_r(struct _reent *ptr, ptrdiff_t incr) { - /* no use this routine to get memory */ - return RT_NULL; + /* no use this routine to get memory */ + return RT_NULL; } int _stat_r(struct _reent *ptr, const char *file, struct stat *pstat) { #ifndef RT_USING_DFS - return 0; + return 0; #else - int rc; + int rc; - rc = stat(file, pstat); - return rc; + rc = stat(file, pstat); + return rc; #endif } _CLOCK_T_ _times_r(struct _reent *ptr, struct tms *ptms) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } int _unlink_r(struct _reent *ptr, const char *file) { #ifndef RT_USING_DFS - return 0; + return 0; #else - int rc; + int rc; - rc = unlink(file); - return rc; + rc = unlink(file); + return rc; #endif } int _wait_r(struct _reent *ptr, int *status) { - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } #ifdef RT_USING_DEVICE @@ -206,133 +206,127 @@ _ssize_t _write_r(struct _reent *ptr, int fd, const void *buf, size_t nbytes) { #ifndef RT_USING_DFS - if (fd == 0) - { - rt_device_t console; + if (fd == 0) + { + rt_device_t console; - console = rt_console_get_device(); - if (console) return rt_device_write(console, -1, buf, nbytes); - } + console = rt_console_get_device(); + if (console) return rt_device_write(console, -1, buf, nbytes); + } return 0; #else - _ssize_t rc; + _ssize_t rc; - rc = write(fd, buf, nbytes); - return rc; + rc = write(fd, buf, nbytes); + return rc; #endif } #endif -#ifndef RT_USING_PTHREADS +#ifdef RT_USING_PTHREADS -#ifndef MILLISECOND_PER_SECOND -#define MILLISECOND_PER_SECOND 1000UL -#endif +#include +/* POSIX timer provides clock_gettime function */ +#include +int +_gettimeofday_r(struct _reent *ptr, struct timeval *__tp, void *__tzp) +{ + struct timespec tp; -#ifndef MICROSECOND_PER_SECOND -#define MICROSECOND_PER_SECOND 1000000UL -#endif + if (clock_gettime(CLOCK_REALTIME, &tp) == 0) + { + if (__tp != RT_NULL) + { + __tp->tv_sec = tp.tv_sec; + __tp->tv_usec = tp.tv_nsec / 1000UL; + } -#ifndef NANOSECOND_PER_SECOND -#define NANOSECOND_PER_SECOND 1000000000UL -#endif + return tp.tv_sec; + } + + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; +} -#define MILLISECOND_PER_TICK (MILLISECOND_PER_SECOND / RT_TICK_PER_SECOND) -#define MICROSECOND_PER_TICK (MICROSECOND_PER_SECOND / RT_TICK_PER_SECOND) -#define NANOSECOND_PER_TICK (NANOSECOND_PER_SECOND / RT_TICK_PER_SECOND) +#else + +#define MILLISECOND_PER_SECOND 1000UL +#define MICROSECOND_PER_SECOND 1000000UL +#define NANOSECOND_PER_SECOND 1000000000UL +#define MILLISECOND_PER_TICK (MILLISECOND_PER_SECOND / RT_TICK_PER_SECOND) +#define MICROSECOND_PER_TICK (MICROSECOND_PER_SECOND / RT_TICK_PER_SECOND) +#define NANOSECOND_PER_TICK (NANOSECOND_PER_SECOND / RT_TICK_PER_SECOND) struct timeval _timevalue = {0}; #ifdef RT_USING_DEVICE static void libc_system_time_init(void) { - time_t time; - rt_tick_t tick; - rt_device_t device; + time_t time; + rt_tick_t tick; + rt_device_t device; - time = 0; - device = rt_device_find("rtc"); - if (device != RT_NULL) - { - /* get realtime seconds */ - rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time); - } + time = 0; + device = rt_device_find("rtc"); + if (device != RT_NULL) + { + /* get realtime seconds */ + rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time); + } - /* get tick */ - tick = rt_tick_get(); + /* get tick */ + tick = rt_tick_get(); - _timevalue.tv_usec = MICROSECOND_PER_SECOND - (tick%RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK; - _timevalue.tv_sec = time - tick/RT_TICK_PER_SECOND - 1; + _timevalue.tv_usec = MICROSECOND_PER_SECOND - (tick%RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK; + _timevalue.tv_sec = time - tick/RT_TICK_PER_SECOND - 1; } #endif int libc_get_time(struct timespec *time) { - rt_tick_t tick; - static rt_bool_t inited = 0; + rt_tick_t tick; + static rt_bool_t inited = 0; - RT_ASSERT(time != RT_NULL); + RT_ASSERT(time != RT_NULL); - /* initialize system time */ - if (inited == 0) - { - libc_system_time_init(); - inited = 1; - } + /* initialize system time */ + if (inited == 0) + { + libc_system_time_init(); + inited = 1; + } - /* get tick */ - tick = rt_tick_get(); + /* get tick */ + tick = rt_tick_get(); - time->tv_sec = _timevalue.tv_sec + tick / RT_TICK_PER_SECOND; - time->tv_nsec = (_timevalue.tv_usec + (tick % RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK) * 1000; + time->tv_sec = _timevalue.tv_sec + tick / RT_TICK_PER_SECOND; + time->tv_nsec = (_timevalue.tv_usec + (tick % RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK) * 1000; - return 0; + return 0; } int _gettimeofday_r(struct _reent *ptr, struct timeval *__tp, void *__tzp) { - struct timespec tp; - - if (libc_get_time(&tp) == 0) - { - if (__tp != RT_NULL) - { - __tp->tv_sec = tp.tv_sec; - __tp->tv_usec = tp.tv_nsec / 1000UL; - } - - return tp.tv_sec; - } - - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; -} -#else -/* POSIX thread provides clock_gettime function */ -#include -int -_gettimeofday_r(struct _reent *ptr, struct timeval *__tp, void *__tzp) -{ - struct timespec tp; + struct timespec tp; - if (clock_gettime(CLOCK_REALTIME, &tp) == 0) - { - if (__tp != RT_NULL) - { - __tp->tv_sec = tp.tv_sec; - __tp->tv_usec = tp.tv_nsec / 1000UL; - } + if (libc_get_time(&tp) == 0) + { + if (__tp != RT_NULL) + { + __tp->tv_sec = tp.tv_sec; + __tp->tv_usec = tp.tv_nsec / 1000UL; + } - return tp.tv_sec; - } + return tp.tv_sec; + } - /* return "not supported" */ - ptr->_errno = ENOTSUP; - return -1; + /* return "not supported" */ + ptr->_errno = ENOTSUP; + return -1; } #endif @@ -340,64 +334,64 @@ _gettimeofday_r(struct _reent *ptr, struct timeval *__tp, void *__tzp) void * _malloc_r (struct _reent *ptr, size_t size) { - void* result; + void* result; - result = (void*)rt_malloc (size); - if (result == RT_NULL) - { - ptr->_errno = ENOMEM; - } + result = (void*)rt_malloc (size); + if (result == RT_NULL) + { + ptr->_errno = ENOMEM; + } - return result; + return result; } void * _realloc_r (struct _reent *ptr, void *old, size_t newlen) { - void* result; + void* result; - result = (void*)rt_realloc (old, newlen); - if (result == RT_NULL) - { - ptr->_errno = ENOMEM; - } + result = (void*)rt_realloc (old, newlen); + if (result == RT_NULL) + { + ptr->_errno = ENOMEM; + } - return result; + return result; } void *_calloc_r (struct _reent *ptr, size_t size, size_t len) { - void* result; + void* result; - result = (void*)rt_calloc (size, len); - if (result == RT_NULL) - { - ptr->_errno = ENOMEM; - } + result = (void*)rt_calloc (size, len); + if (result == RT_NULL) + { + ptr->_errno = ENOMEM; + } - return result; + return result; } void _free_r (struct _reent *ptr, void *addr) { - rt_free (addr); + rt_free (addr); } void _exit (int status) { #ifdef RT_USING_MODULE - rt_module_t module; + rt_module_t module; - module = rt_module_self(); - if (module != RT_NULL) - { - struct rt_list_node *list; - struct rt_object *object; + module = rt_module_self(); + if (module != RT_NULL) + { + struct rt_list_node *list; + struct rt_object *object; - rt_enter_critical(); - + rt_enter_critical(); + /* delete all threads in the module */ list = &module->module_object[RT_Object_Class_Thread].object_list; while (list->next != list) @@ -414,19 +408,19 @@ _exit (int status) rt_thread_delete((rt_thread_t)object); } } - /* delete main thread */ - rt_thread_delete(module->module_thread); - rt_exit_critical(); + /* delete main thread */ + rt_thread_delete(module->module_thread); + rt_exit_critical(); - /* re-schedule */ - rt_schedule(); - } + /* re-schedule */ + rt_schedule(); + } #endif - - rt_kprintf("thread:%s exit with %d\n", rt_thread_self()->name, status); - RT_ASSERT(0); + + rt_kprintf("thread:%s exit with %d\n", rt_thread_self()->name, status); + RT_ASSERT(0); - while (1); + while (1); } void @@ -438,7 +432,7 @@ _system(const char *s) void __libc_init_array(void) { - /* we not use __libc init_aray to initialize C++ objects */ + /* we not use __libc init_aray to initialize C++ objects */ } void abort(void) @@ -453,5 +447,5 @@ void abort(void) rt_schedule(); } - while (1); + while (1); } diff --git a/components/libc/pthreads/pthread.c b/components/libc/pthreads/pthread.c index f88dda9ab..12ec1d764 100644 --- a/components/libc/pthreads/pthread.c +++ b/components/libc/pthreads/pthread.c @@ -27,9 +27,6 @@ int pthread_system_init(void) { - /* initialize clock and time */ - clock_time_system_init(); - /* initialize key area */ pthread_key_system_init(); /* initialize posix mqueue */ diff --git a/components/libc/pthreads/pthread.h b/components/libc/pthreads/pthread.h index d79a065fe..b60aa3747 100644 --- a/components/libc/pthreads/pthread.h +++ b/components/libc/pthreads/pthread.h @@ -276,35 +276,4 @@ int pthread_barrier_init(pthread_barrier_t *barrier, int pthread_barrier_wait(pthread_barrier_t *barrier); -/* posix clock and timer */ -#define MILLISECOND_PER_SECOND 1000UL -#define MICROSECOND_PER_SECOND 1000000UL -#define NANOSECOND_PER_SECOND 1000000000UL - -#define MILLISECOND_PER_TICK (MILLISECOND_PER_SECOND / RT_TICK_PER_SECOND) -#define MICROSECOND_PER_TICK (MICROSECOND_PER_SECOND / RT_TICK_PER_SECOND) -#define NANOSECOND_PER_TICK (NANOSECOND_PER_SECOND / RT_TICK_PER_SECOND) - -#ifndef CLOCK_REALTIME -#define CLOCK_REALTIME 1 -#endif - -#define CLOCK_CPUTIME_ID 2 - -#ifndef CLOCK_PROCESS_CPUTIME_ID -#define CLOCK_PROCESS_CPUTIME_ID CLOCK_CPUTIME_ID -#endif -#ifndef CLOCK_THREAD_CPUTIME_ID -#define CLOCK_THREAD_CPUTIME_ID CLOCK_CPUTIME_ID #endif - -#ifndef CLOCK_MONOTONIC -#define CLOCK_MONOTONIC 4 -#endif - -int clock_getres (clockid_t clockid, struct timespec *res); -int clock_gettime (clockid_t clockid, struct timespec *tp); -int clock_settime (clockid_t clockid, const struct timespec *tp); - -#endif - diff --git a/components/libc/pthreads/pthread_internal.h b/components/libc/pthreads/pthread_internal.h index 0a21fccb1..ce7fb256a 100644 --- a/components/libc/pthreads/pthread_internal.h +++ b/components/libc/pthreads/pthread_internal.h @@ -83,7 +83,7 @@ rt_inline _pthread_data_t *_pthread_get_data(pthread_t thread) } int clock_time_to_tick(const struct timespec *time); -void clock_time_system_init(void); + void posix_mq_system_init(void); void posix_sem_system_init(void); void pthread_key_system_init(void); diff --git a/components/libc/timer/SConscript b/components/libc/time/SConscript similarity index 59% rename from components/libc/timer/SConscript rename to components/libc/time/SConscript index a01700aa8..4ecd5d24b 100644 --- a/components/libc/timer/SConscript +++ b/components/libc/time/SConscript @@ -6,7 +6,7 @@ cwd = GetCurrentDir() src = Glob('*.c') + Glob('*.cpp') CPPPATH = [cwd] -group = DefineGroup('libc', src, - depend = ['RT_USING_LIBC', 'RT_USING_POSIX_TIMER'], CPPPATH = CPPPATH) +group = DefineGroup('pthreads', src, + depend = ['RT_USING_PTHREADS'], CPPPATH = CPPPATH) Return('group') diff --git a/components/libc/pthreads/clock_time.c b/components/libc/time/clock_time.c similarity index 71% rename from components/libc/pthreads/clock_time.c rename to components/libc/time/clock_time.c index 072ab84f1..c2a0b8691 100644 --- a/components/libc/pthreads/clock_time.c +++ b/components/libc/time/clock_time.c @@ -24,10 +24,13 @@ */ #include +#include #include +#include "clock_time.h" + struct timeval _timevalue; -void clock_time_system_init() +int clock_time_system_init() { time_t time; rt_tick_t tick; @@ -46,7 +49,10 @@ void clock_time_system_init() _timevalue.tv_usec = (tick%RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK; _timevalue.tv_sec = time - tick/RT_TICK_PER_SECOND - 1; + + return 0; } +INIT_COMPONENT_EXPORT(clock_time_system_init); int clock_time_to_tick(const struct timespec *time) { @@ -83,38 +89,80 @@ RTM_EXPORT(clock_time_to_tick); int clock_getres(clockid_t clockid, struct timespec *res) { - if ((clockid != CLOCK_REALTIME) || (res == RT_NULL)) + int ret = 0; + + if (res == RT_NULL) { rt_set_errno(EINVAL); - return -1; } - res->tv_sec = 0; - res->tv_nsec = NANOSECOND_PER_SECOND/RT_TICK_PER_SECOND; + switch (clockid) + { + case CLOCK_REALTIME: + res->tv_sec = 0; + res->tv_nsec = NANOSECOND_PER_SECOND/RT_TICK_PER_SECOND; + break; + +#ifdef RT_USING_CPUTIME + case CLOCK_CPUTIME_ID: + res->tv_sec = 0; + res->tv_nsec = clock_cpu_getres(); + break; +#endif + + default: + ret = -1; + rt_set_errno(EINVAL); + break; + } - return 0; + return ret; } RTM_EXPORT(clock_getres); int clock_gettime(clockid_t clockid, struct timespec *tp) { - rt_tick_t tick; + int ret = 0; - if ((clockid != CLOCK_REALTIME) || (tp == RT_NULL)) + if (tp == RT_NULL) { rt_set_errno(EINVAL); - return -1; } - /* get tick */ - tick = rt_tick_get(); + switch (clockid) + { + case CLOCK_REALTIME: + { + /* get tick */ + int tick = rt_tick_get(); - tp->tv_sec = _timevalue.tv_sec + tick / RT_TICK_PER_SECOND; - tp->tv_nsec = (_timevalue.tv_usec + (tick % RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK) * 1000; + tp->tv_sec = _timevalue.tv_sec + tick / RT_TICK_PER_SECOND; + tp->tv_nsec = (_timevalue.tv_usec + (tick % RT_TICK_PER_SECOND) * MICROSECOND_PER_TICK) * 1000; + } + break; - return 0; +#ifdef RT_USING_CPUTIME + case CLOCK_CPUTIME_ID: + { + float unit = 0; + long long cpu_tick; + + unit = clock_cpu_getres(); + cpu_tick = clock_cpu_gettime(); + + tp->tv_sec = ((int)(cpu_tick * unit)) / NANOSECOND_PER_SECOND; + tp->tv_nsec = ((int)(cpu_tick * unit)) % NANOSECOND_PER_SECOND; + } + break; +#endif + default: + rt_set_errno(EINVAL); + ret = -1; + } + + return ret; } RTM_EXPORT(clock_gettime); diff --git a/components/libc/time/clock_time.h b/components/libc/time/clock_time.h new file mode 100644 index 000000000..e91e6c97f --- /dev/null +++ b/components/libc/time/clock_time.h @@ -0,0 +1,58 @@ +/* + * File : clock_time.h + * This file is part of RT-Thread RTOS + * COPYRIGHT (C) 2006 - 2017, RT-Thread Development Team + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Change Logs: + * Date Author Notes + * 2017-12-31 Bernard the first version + */ + +#ifndef CLOCK_TIME_H__ +#define CLOCK_TIME_H__ + +/* posix clock and timer */ +#define MILLISECOND_PER_SECOND 1000UL +#define MICROSECOND_PER_SECOND 1000000UL +#define NANOSECOND_PER_SECOND 1000000000UL + +#define MILLISECOND_PER_TICK (MILLISECOND_PER_SECOND / RT_TICK_PER_SECOND) +#define MICROSECOND_PER_TICK (MICROSECOND_PER_SECOND / RT_TICK_PER_SECOND) +#define NANOSECOND_PER_TICK (NANOSECOND_PER_SECOND / RT_TICK_PER_SECOND) + +#ifndef CLOCK_REALTIME +#define CLOCK_REALTIME 1 +#endif + +#define CLOCK_CPUTIME_ID 2 + +#ifndef CLOCK_PROCESS_CPUTIME_ID +#define CLOCK_PROCESS_CPUTIME_ID CLOCK_CPUTIME_ID +#endif +#ifndef CLOCK_THREAD_CPUTIME_ID +#define CLOCK_THREAD_CPUTIME_ID CLOCK_CPUTIME_ID +#endif + +#ifndef CLOCK_MONOTONIC +#define CLOCK_MONOTONIC 4 +#endif + +int clock_getres (clockid_t clockid, struct timespec *res); +int clock_gettime (clockid_t clockid, struct timespec *tp); +int clock_settime (clockid_t clockid, const struct timespec *tp); + +#endif diff --git a/components/libc/timer/posix_sleep.c b/components/libc/time/posix_sleep.c similarity index 100% rename from components/libc/timer/posix_sleep.c rename to components/libc/time/posix_sleep.c -- GitLab