improve libc time and MSVC simulator (#5775)

- [libc] 解决由于类unix操作系统发展历史原因fcntl.h定义的标志位在不同编译器中定义不同的问题
- [simulator] 部分宏定义转为全局宏定义以确保vs内置文件可以正确配置
- [simulator] 取消自欺欺人式的警告消除处理方式
- [libc][time] 优化time相关结构体在不同编译器下的包含
This commit is contained in:
Man, Jianting (Meco) 2022-04-07 02:24:11 -04:00 committed by GitHub
parent e68f934ff8
commit c318dfa964
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 73 additions and 25 deletions

View File

@ -1,12 +1,29 @@
import sys import sys
import os import os
from building import * from building import *
Import('rtconfig')
cwd = GetCurrentDir() cwd = GetCurrentDir()
src = Glob('*.c') src = Glob('*.c')
LIBS = [] LIBS = []
LIBPATH = [] LIBPATH = []
CPPPATH = [cwd] CPPPATH = [cwd]
CPPDEFINES = []
if rtconfig.CROSS_TOOL == 'msvc':
CPPDEFINES += \
[
# avoid to conflict with the inherent STDC in VS
'_CRT_DECLARE_NONSTDC_NAMES=0',
# errno macro redefinition
'_CRT_ERRNO_DEFINED',
# time.h conflicts
'_CRT_NO_TIME_T',
# disable deprecation of unsafe functions, such as strncpy
'_CRT_SECURE_NO_WARNINGS',
# RT_VESRION conflicts in winuser.h
'NORESOURCE',
]
# remove no need file. # remove no need file.
if GetDepend('PKG_USING_GUIENGINE') == False: if GetDepend('PKG_USING_GUIENGINE') == False:
@ -30,7 +47,8 @@ if GetDepend('RT_USING_DFS') == False or GetDepend('RT_USING_MODULE') == False:
if sys.platform[0:5]=="linux": #check whether under linux if sys.platform[0:5]=="linux": #check whether under linux
SrcRemove(src, ['module_win32.c', 'dfs_win32.c']) SrcRemove(src, ['module_win32.c', 'dfs_win32.c'])
group = DefineGroup('Drivers', src, depend = [''], CPPPATH = CPPPATH, LIBS=LIBS, LIBPATH=LIBPATH) group = DefineGroup('Drivers', src, depend = [''],
CPPPATH = CPPPATH, LIBS=LIBS, LIBPATH=LIBPATH, CPPDEFINES=CPPDEFINES)
list = os.listdir(cwd) list = os.listdir(cwd)
for item in list: for item in list:

View File

@ -12,21 +12,9 @@
#define RT_HEAP_SIZE (1024*1024*8) #define RT_HEAP_SIZE (1024*1024*8)
#if defined(_MSC_VER) #ifdef _MSC_VER
#define NORESOURCE /* RT_VESRION in winuser.h */
#define _CRT_ERRNO_DEFINED /* errno macro redefinition */
#define _INC_WTIME_INL /* dfs_elm.c time.h conflicts with wtime.inl */
#define _INC_TIME_INL /* dfs_elm.c time.h conflicts with wtime.inl */
#define _CRT_DECLARE_NONSTDC_NAMES 0 /* avoid to conflict with the inherent STDC in VS */
/* disable some warning in MSC */ /* disable some warning in MSC */
#pragma warning(disable:4273) /* to ignore: warning C4273: inconsistent dll linkage */ // #pragma warning(disable:4273) /* to ignore: warning C4273: inconsistent dll linkage */
#pragma warning(disable:4312) /* to ignore: warning C4312: 'type cast' : conversion from 'rt_uint32_t' to 'rt_uint32_t *' */ #endif /* _MSC_VER */
#pragma warning(disable:4311) /* to ignore: warning C4311: 'type cast' : pointer truncation from 'short *__w64 ' to 'long' */
#pragma warning(disable:4996) /* to ignore: warning C4996: The POSIX name for this item is deprecated. */
#pragma warning(disable:4267) /* to ignore: warning C4267: conversion from 'size_t' to 'rt_size_t', possible loss of data */
#pragma warning(disable:4244) /* to ignore: warning C4244: '=' : conversion from '__w64 int' to 'rt_size_t', possible loss of data */
#endif /* end of _MSC_VER */ #endif /* RTCONFIG_PROJECT_H__ */
#endif

View File

@ -1,5 +1,5 @@
import os
from building import * from building import *
Import('rtconfig') Import('rtconfig')
src = [] src = []
@ -9,6 +9,13 @@ group = []
src += Glob('*.c') src += Glob('*.c')
if rtconfig.PLATFORM != 'gcc' or rtconfig.ARCH == 'sim': if rtconfig.PLATFORM != 'gcc':
group = DefineGroup('Compiler', src, depend = [''], CPPPATH = CPPPATH) group = DefineGroup('Compiler', src, depend = [''], CPPPATH = CPPPATH)
list = os.listdir(cwd)
for d in list:
path = os.path.join(cwd, d)
if os.path.isfile(os.path.join(path, 'SConscript')):
group = group + SConscript(os.path.join(d, 'SConscript'))
Return('group') Return('group')

View File

@ -0,0 +1,4 @@
Because of the history issue, flags in fcntl.h, such as O_CREAT, have difference types of value. Some OS use hex flags and others use octal flags.
In terms of RT-Thread, Keil, IAR and MSVC use octal flags, which is located in the `tcntl/octal` folder; newlib uses hex flags; musl uses octal flags.

View File

@ -0,0 +1,15 @@
# RT-Thread building script for bridge
import os
from building import *
cwd = GetCurrentDir()
objs = []
list = os.listdir(cwd)
for d in list:
path = os.path.join(cwd, d)
if os.path.isfile(os.path.join(path, 'SConscript')):
objs = objs + SConscript(os.path.join(d, 'SConscript'))
Return('objs')

View File

@ -0,0 +1,14 @@
from building import *
Import('rtconfig')
src = []
cwd = GetCurrentDir()
CPPPATH = [cwd]
group = []
if rtconfig.PLATFORM == 'armcc' or\
rtconfig.PLATFORM == 'armclang' or\
rtconfig.PLATFORM == 'iar' or\
rtconfig.CROSS_TOOL == 'msvc':
group = DefineGroup('Compiler', src, depend = [''], CPPPATH = CPPPATH)
Return('group')

View File

@ -18,7 +18,9 @@
#include <time.h> #include <time.h>
#ifdef _WIN32 #ifdef _WIN32
#include <winsock.h> /* for struct timeval */ #include <winsock.h> /* for struct timeval */
#endif #include <corecrt.h> /* for __time64_t */
typedef __time64_t time_t;
#endif /* _WIN32 */
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -50,17 +52,17 @@ struct timeval
time_t tv_sec; /* seconds */ time_t tv_sec; /* seconds */
suseconds_t tv_usec; /* and microseconds */ suseconds_t tv_usec; /* and microseconds */
}; };
#endif #endif /* !defined(_TIMEVAL_DEFINED) && !defined(_WIN32) */
#if !(defined(__GNUC__) && !defined(__ARMCC_VERSION)/*GCC*/) && \ #if defined(__ARMCC_VERSION) || defined(_WIN32) || (defined(__ICCARM__) && (__VER__ >= 8010001))
!(defined(__ICCARM__) && (__VER__ >= 8010001)) && \
!defined(_WIN32)
struct timespec struct timespec
{ {
time_t tv_sec; /* seconds */ time_t tv_sec; /* seconds */
long tv_nsec; /* and nanoseconds */ long tv_nsec; /* and nanoseconds */
}; };
#endif /* defined(__ARMCC_VERSION) || defined(_WIN32) || (defined(__ICCARM__) && (__VER__ >= 8010001)) */
#if !(defined(__GNUC__) && !defined(__ARMCC_VERSION)/*GCC*/)
/* /*
* Structure defined by POSIX.1b to be like a itimerval, but with * Structure defined by POSIX.1b to be like a itimerval, but with
* timespecs. Used in the timer_*() system calls. * timespecs. Used in the timer_*() system calls.
@ -70,7 +72,7 @@ struct itimerspec
struct timespec it_interval; struct timespec it_interval;
struct timespec it_value; struct timespec it_value;
}; };
#endif #endif /* !(defined(__GNUC__) && !defined(__ARMCC_VERSION)) */
int stime(const time_t *t); int stime(const time_t *t);
time_t timegm(struct tm * const t); time_t timegm(struct tm * const t);