Merge pull request #4649 from mysterywolf/libc2

[libc][time] remove _TIMESPEC_DEFINED in common/sys/time.h and complete time.c
This commit is contained in:
Bernard Xiong 2021-05-01 10:58:10 +08:00 committed by GitHub
commit beb2f046c4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 11 additions and 20 deletions

View File

@ -18,14 +18,6 @@
extern "C" {
#endif
/*
* Skip define timespec for IAR version over 8.10.1 where __VER__ is 8010001.
*/
#if defined ( __ICCARM__ ) && (__VER__ >= 8010001)
#define _TIMESPEC_DEFINED
#endif
#ifndef _TIMEVAL_DEFINED
#define _TIMEVAL_DEFINED
/*
@ -40,7 +32,7 @@ struct timeval {
#endif
#endif /* _TIMEVAL_DEFINED */
#if !(defined(__GNUC__) && !defined(__ARMCC_VERSION)/*GCC*/) && !defined (__ICCARM__) && !defined (_WIN32)
#if !(defined(__GNUC__) && !defined(__ARMCC_VERSION)/*GCC*/) && !(defined(__ICCARM__) && (__VER__ >= 8010001)) && !defined(_WIN32)
struct timespec {
time_t tv_sec; /* seconds */
long tv_nsec; /* and nanoseconds */

View File

@ -16,7 +16,7 @@
* 2012-12-08 Bernard <clock_time.c> fix the issue of _timevalue.tv_usec initialization,
* which found by Rob <rdent@iinet.net.au>
* 2021-02-12 Meco Man move all of the functions located in <clock_time.c> to this file
* 2021-03-15 Meco Man fixed bug: https://club.rt-thread.org/ask/question/423650.html
* 2021-03-15 Meco Man fixed a bug of leaking memory in asctime()
*/
#include <sys/time.h>
@ -104,7 +104,7 @@ static int get_timeval(struct timeval *tv)
}
else
{
/* LOG_W will cause a recursive printing if ulog timestamp function is turned on */
/* LOG_W will cause a recursive printing if ulog timestamp function is enabled */
rt_kprintf("Cannot find a RTC device to provide time!\r\n");
return -1;
}
@ -112,7 +112,7 @@ static int get_timeval(struct timeval *tv)
return (rst < 0) ? -1 : 1;
#else
/* LOG_W will cause a recursive printing if ulog timestamp function is turned on */
/* LOG_W will cause a recursive printing if ulog timestamp function is enabled */
rt_kprintf("Cannot find a RTC device to provide time!\r\n");
return -1;
#endif /* RT_USING_RTC */
@ -270,16 +270,16 @@ char* asctime(const struct tm *timeptr)
}
RTM_EXPORT(asctime);
char *ctime_r (const time_t * tim_p, char * result)
char *ctime_r(const time_t * tim_p, char * result)
{
struct tm tm;
return asctime_r (localtime_r (tim_p, &tm), result);
return asctime_r(localtime_r(tim_p, &tm), result);
}
RTM_EXPORT(ctime_r);
char* ctime(const time_t *tim_p)
{
return asctime (localtime (tim_p));
return asctime(localtime(tim_p));
}
RTM_EXPORT(ctime);

View File

@ -4,17 +4,18 @@ Import('rtconfig')
src = []
cwd = GetCurrentDir()
group = []
LIBS = []
CPPDEFINES = []
CPPPATH = [cwd]
if rtconfig.PLATFORM == 'gcc':
if GetDepend('RT_USING_LIBC'):
CPPDEFINES = ['RT_USING_NEWLIB']
CPPDEFINES += ['RT_USING_NEWLIB']
# link with libc and libm:
# libm is a frequently used lib. Newlib is compiled with -ffunction-sections in
# recent GCC tool chains. The linker would just link in the functions that have
# been referenced. So setting this won't result in bigger text size.
LIBS = ['c', 'm']
LIBS += ['c', 'm']
src += Glob('*.c')
SrcRemove(src, ['minilib.c'])
@ -22,8 +23,6 @@ if rtconfig.PLATFORM == 'gcc':
SrcRemove(src, ['libc_syms.c'])
else:
src += ['minilib.c']
CPPDEFINES = []
LIBS = []
group = DefineGroup('libc', src, depend = [], CPPPATH = CPPPATH, CPPDEFINES = CPPDEFINES, LIBS = LIBS)