Merge pull request #5239 from mysterywolf/POSIX

[libc] 消除代码中将RT_LIBC_USING_FILEIO的预编译判断条件
This commit is contained in:
guo 2021-10-28 10:30:20 +08:00 committed by GitHub
commit e0f45a6ca4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 61 additions and 90 deletions

View File

@ -54,7 +54,7 @@ const char __stderr_name[] = "STDERR";
*/ */
FILEHANDLE _sys_open(const char *name, int openmode) FILEHANDLE _sys_open(const char *name, int openmode)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int fd; int fd;
int mode = O_RDONLY; int mode = O_RDONLY;
#endif #endif
@ -67,7 +67,7 @@ FILEHANDLE _sys_open(const char *name, int openmode)
if (strcmp(name, __stderr_name) == 0) if (strcmp(name, __stderr_name) == 0)
return (STDERR); return (STDERR);
#ifndef RT_LIBC_USING_FILEIO #ifndef RT_USING_POSIX
return 0; /* error */ return 0; /* error */
#else #else
/* Correct openmode from fopen to open */ /* Correct openmode from fopen to open */
@ -101,19 +101,19 @@ FILEHANDLE _sys_open(const char *name, int openmode)
return 0; /* error */ return 0; /* error */
else else
return fd; return fd;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _sys_close(FILEHANDLE fh) int _sys_close(FILEHANDLE fh)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
if (fh <= STDERR) if (fh <= STDERR)
return 0; /* error */ return 0; /* error */
return close(fh); return close(fh);
#else #else
return 0; return 0;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
/* /*
@ -143,7 +143,7 @@ int _sys_close(FILEHANDLE fh)
*/ */
int _sys_read(FILEHANDLE fh, unsigned char *buf, unsigned len, int mode) int _sys_read(FILEHANDLE fh, unsigned char *buf, unsigned len, int mode)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int size; int size;
if (fh == STDIN) if (fh == STDIN)
@ -168,7 +168,7 @@ int _sys_read(FILEHANDLE fh, unsigned char *buf, unsigned len, int mode)
return 0; /* error */ return 0; /* error */
#else #else
return 0; /* error */ return 0; /* error */
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
/* /*
@ -178,13 +178,13 @@ int _sys_read(FILEHANDLE fh, unsigned char *buf, unsigned len, int mode)
*/ */
int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode) int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int size; int size;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
if ((fh == STDOUT) || (fh == STDERR)) if ((fh == STDOUT) || (fh == STDERR))
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
if (libc_stdio_get_console() < 0) if (libc_stdio_get_console() < 0)
{ {
LOG_W("Do not invoke standard input before initializing libc"); LOG_W("Do not invoke standard input before initializing libc");
@ -199,14 +199,14 @@ int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode)
} }
return 0; /* error */ return 0; /* error */
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
else if (fh == STDIN) else if (fh == STDIN)
{ {
return 0; /* error */ return 0; /* error */
} }
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
size = write(fh, buf, len); size = write(fh, buf, len);
if (size >= 0) if (size >= 0)
return len - size; return len - size;
@ -214,7 +214,7 @@ int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode)
return 0; /* error */ return 0; /* error */
#else #else
return 0; return 0;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
/* /*
@ -223,7 +223,7 @@ int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode)
*/ */
int _sys_seek(FILEHANDLE fh, long pos) int _sys_seek(FILEHANDLE fh, long pos)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
if (fh < STDERR) if (fh < STDERR)
return 0; /* error */ return 0; /* error */
@ -231,7 +231,7 @@ int _sys_seek(FILEHANDLE fh, long pos)
return lseek(fh, pos, 0); return lseek(fh, pos, 0);
#else #else
return 0; /* error */ return 0; /* error */
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
/** /**
@ -276,7 +276,7 @@ RT_WEAK void _sys_exit(int return_code)
*/ */
long _sys_flen(FILEHANDLE fh) long _sys_flen(FILEHANDLE fh)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
struct stat stat; struct stat stat;
if (fh < STDERR) if (fh < STDERR)
@ -286,7 +286,7 @@ long _sys_flen(FILEHANDLE fh)
return stat.st_size; return stat.st_size;
#else #else
return 0; return 0;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _sys_istty(FILEHANDLE fh) int _sys_istty(FILEHANDLE fh)
@ -299,11 +299,11 @@ int _sys_istty(FILEHANDLE fh)
int remove(const char *filename) int remove(const char *filename)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
return unlink(filename); return unlink(filename);
#else #else
return 0; /* error */ return 0; /* error */
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
#ifdef __MICROLIB #ifdef __MICROLIB
@ -324,7 +324,7 @@ int fputc(int c, FILE *f)
int fgetc(FILE *f) int fgetc(FILE *f)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
char ch; char ch;
if (libc_stdio_get_console() < 0) if (libc_stdio_get_console() < 0)
@ -335,7 +335,7 @@ int fgetc(FILE *f)
if(read(STDIN_FILENO, &ch, 1) == 1) if(read(STDIN_FILENO, &ch, 1) == 1)
return ch; return ch;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
return 0; /* error */ return 0; /* error */
} }

View File

@ -11,7 +11,7 @@ CPPDEFINES = ['RT_USING_DLIBC']
if rtconfig.PLATFORM == 'iar': if rtconfig.PLATFORM == 'iar':
if GetDepend('RT_LIBC_USING_FILEIO'): if GetDepend('RT_USING_POSIX'):
from distutils.version import LooseVersion from distutils.version import LooseVersion
from iar import IARVersion from iar import IARVersion

View File

@ -18,9 +18,9 @@ int __close(int handle)
handle == _LLIO_STDERR || handle == _LLIO_STDERR ||
handle == _LLIO_STDIN) handle == _LLIO_STDIN)
return _LLIO_ERROR; return _LLIO_ERROR;
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
return close(handle); return close(handle);
#else #else
return _LLIO_ERROR; return _LLIO_ERROR;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }

View File

@ -18,9 +18,9 @@ long __lseek(int handle, long offset, int whence)
handle == _LLIO_STDERR || handle == _LLIO_STDERR ||
handle == _LLIO_STDIN) handle == _LLIO_STDIN)
return _LLIO_ERROR; return _LLIO_ERROR;
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
return lseek(handle, offset, whence); return lseek(handle, offset, whence);
#else #else
return _LLIO_ERROR; return _LLIO_ERROR;
#endif #endif /* RT_USING_POSIX */
} }

View File

@ -16,7 +16,7 @@
int __open(const char *filename, int mode) int __open(const char *filename, int mode)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int handle; int handle;
int open_mode = O_RDONLY; int open_mode = O_RDONLY;
@ -68,5 +68,5 @@ int __open(const char *filename, int mode)
return handle; return handle;
#else #else
return _LLIO_ERROR; return _LLIO_ERROR;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }

View File

@ -20,7 +20,7 @@
#pragma module_name = "?__read" #pragma module_name = "?__read"
size_t __read(int handle, unsigned char *buf, size_t len) size_t __read(int handle, unsigned char *buf, size_t len)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int size; int size;
if (handle == _LLIO_STDIN) if (handle == _LLIO_STDIN)
@ -41,5 +41,5 @@ size_t __read(int handle, unsigned char *buf, size_t len)
return size; return size;
#else #else
return _LLIO_ERROR; return _LLIO_ERROR;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }

View File

@ -21,13 +21,13 @@
size_t __write(int handle, const unsigned char *buf, size_t len) size_t __write(int handle, const unsigned char *buf, size_t len)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int size; int size;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
if ((handle == _LLIO_STDOUT) || (handle == _LLIO_STDERR)) if ((handle == _LLIO_STDOUT) || (handle == _LLIO_STDERR))
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
if (libc_stdio_get_console() < 0) if (libc_stdio_get_console() < 0)
{ {
LOG_W("Do not invoke standard output before initializing libc"); LOG_W("Do not invoke standard output before initializing libc");
@ -46,17 +46,17 @@ size_t __write(int handle, const unsigned char *buf, size_t len)
return len; return len;
#else #else
return _LLIO_ERROR; return _LLIO_ERROR;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
else if (handle == _LLIO_STDIN) else if (handle == _LLIO_STDIN)
{ {
return _LLIO_ERROR; return _LLIO_ERROR;
} }
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
size = write(handle, buf, len); size = write(handle, buf, len);
return size; return size;
#else #else
return _LLIO_ERROR; return _LLIO_ERROR;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }

View File

@ -15,11 +15,13 @@ extern "C" {
#endif #endif
int libc_system_init(void); int libc_system_init(void);
#ifdef RT_USING_POSIX #ifdef RT_USING_POSIX
int libc_stdio_get_console(void); int libc_stdio_get_console(void);
int libc_stdio_set_console(const char* device_name, int mode); int libc_stdio_set_console(const char* device_name, int mode);
#endif /* RT_USING_POSIX */ #endif /* RT_USING_POSIX */
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -7,16 +7,14 @@
* Date Author Notes * Date Author Notes
* 2017/10/15 bernard the first version * 2017/10/15 bernard the first version
*/ */
#include <rtthread.h> #include <rtconfig.h>
#ifdef RT_USING_POSIX
#include <stdio.h> #include <stdio.h>
#include <stdlib.h>
#include <fcntl.h> #include <fcntl.h>
#include "libc.h" #include "libc.h"
#define STDIO_DEVICE_NAME_MAX 32 #define STDIO_DEVICE_NAME_MAX 32
#ifdef RT_LIBC_USING_FILEIO
#include <stdlib.h>
static FILE* std_console = NULL; static FILE* std_console = NULL;
int libc_stdio_set_console(const char* device_name, int mode) int libc_stdio_set_console(const char* device_name, int mode)
@ -76,7 +74,8 @@ int libc_stdio_set_console(const char* device_name, int mode)
_GLOBAL_REENT->__sdidinit = 1; _GLOBAL_REENT->__sdidinit = 1;
} }
if (std_console) return fileno(std_console); if (std_console)
return fileno(std_console);
return -1; return -1;
} }
@ -89,34 +88,4 @@ int libc_stdio_get_console(void)
return -1; return -1;
} }
#elif defined(RT_USING_POSIX) #endif /* RT_USING_POSIX */
#include <unistd.h>
static int std_fd = -1;
int libc_stdio_set_console(const char* device_name, int mode)
{
int fd;
char name[STDIO_DEVICE_NAME_MAX];
snprintf(name, sizeof(name) - 1, "/dev/%s", device_name);
name[STDIO_DEVICE_NAME_MAX - 1] = '\0';
fd = open(name, mode, 0);
if (fd >= 0)
{
if (std_fd >= 0)
{
close(std_fd);
}
std_fd = fd;
}
return std_fd;
}
int libc_stdio_get_console(void)
{
return std_fd;
}
#endif /* RT_LIBC_USING_FILEIO */

View File

@ -14,6 +14,7 @@
#include <reent.h> #include <reent.h>
#include <rtthread.h> #include <rtthread.h>
#include <stdio.h> #include <stdio.h>
#include <string.h>
#include <stddef.h> #include <stddef.h>
#include <fcntl.h> #include <fcntl.h>
#include <unistd.h> #include <unistd.h>
@ -175,7 +176,7 @@ int flock(int fd, int operation)
_off_t _lseek_r(struct _reent *ptr, int fd, _off_t pos, int whence) _off_t _lseek_r(struct _reent *ptr, int fd, _off_t pos, int whence)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
_off_t rc; _off_t rc;
rc = lseek(fd, pos, whence); rc = lseek(fd, pos, whence);
@ -183,12 +184,12 @@ _off_t _lseek_r(struct _reent *ptr, int fd, _off_t pos, int whence)
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _mkdir_r(struct _reent *ptr, const char *name, int mode) int _mkdir_r(struct _reent *ptr, const char *name, int mode)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int rc; int rc;
rc = mkdir(name, mode); rc = mkdir(name, mode);
@ -196,25 +197,24 @@ int _mkdir_r(struct _reent *ptr, const char *name, int mode)
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _open_r(struct _reent *ptr, const char *file, int flags, int mode) int _open_r(struct _reent *ptr, const char *file, int flags, int mode)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int rc; int rc;
rc = open(file, flags, mode); rc = open(file, flags, mode);
return rc; return rc;
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
_ssize_t _read_r(struct _reent *ptr, int fd, void *buf, size_t nbytes) _ssize_t _read_r(struct _reent *ptr, int fd, void *buf, size_t nbytes)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
_ssize_t rc; _ssize_t rc;
if (libc_stdio_get_console() < 0 && fd == STDIN_FILENO) if (libc_stdio_get_console() < 0 && fd == STDIN_FILENO)
{ {
@ -226,12 +226,12 @@ _ssize_t _read_r(struct _reent *ptr, int fd, void *buf, size_t nbytes)
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _rename_r(struct _reent *ptr, const char *old, const char *new) int _rename_r(struct _reent *ptr, const char *old, const char *new)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int rc; int rc;
rc = rename(old, new); rc = rename(old, new);
@ -239,12 +239,12 @@ int _rename_r(struct _reent *ptr, const char *old, const char *new)
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _stat_r(struct _reent *ptr, const char *file, struct stat *pstat) int _stat_r(struct _reent *ptr, const char *file, struct stat *pstat)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
int rc; int rc;
rc = stat(file, pstat); rc = stat(file, pstat);
@ -252,22 +252,22 @@ int _stat_r(struct _reent *ptr, const char *file, struct stat *pstat)
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
int _unlink_r(struct _reent *ptr, const char *file) int _unlink_r(struct _reent *ptr, const char *file)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
return unlink(file); return unlink(file);
#else #else
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
} }
_ssize_t _write_r(struct _reent *ptr, int fd, const void *buf, size_t nbytes) _ssize_t _write_r(struct _reent *ptr, int fd, const void *buf, size_t nbytes)
{ {
#ifdef RT_LIBC_USING_FILEIO #ifdef RT_USING_POSIX
_ssize_t rc; _ssize_t rc;
if (libc_stdio_get_console() < 0 && fd == STDOUT_FILENO) if (libc_stdio_get_console() < 0 && fd == STDOUT_FILENO)
{ {
@ -285,7 +285,7 @@ _ssize_t _write_r(struct _reent *ptr, int fd, const void *buf, size_t nbytes)
if (console) if (console)
return rt_device_write(console, -1, buf, nbytes); return rt_device_write(console, -1, buf, nbytes);
} }
#endif /* RT_LIBC_USING_FILEIO */ #endif /* RT_USING_POSIX */
ptr->_errno = ENOTSUP; ptr->_errno = ENOTSUP;
return -1; return -1;
} }