Merge pull request #2100 from gbcwbz/vi

Fix stdio fd error when POSIX api is used
This commit is contained in:
Bernard Xiong 2018-12-30 18:31:18 +08:00 committed by GitHub
commit 56f1a8af4f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 13 additions and 1 deletions

View File

@ -18,6 +18,10 @@
#include <lwp.h>
#endif
#ifdef RT_USING_DFS_DEVFS
#include <libc.h>
#endif
/* Global variables */
const struct dfs_filesystem_ops *filesystem_operation_table[DFS_FILESYSTEM_TYPES_MAX];
struct dfs_filesystem filesystem_table[DFS_FILESYSTEMS_MAX];
@ -212,6 +216,11 @@ struct dfs_fd *fd_get(int fd)
struct dfs_fd *d;
struct dfs_fdtable *fdt;
#ifdef RT_USING_DFS_DEVFS
if ((0 <= fd) && (fd <= 2))
fd = libc_stdio_get_console();
#endif
fdt = dfs_fdtable_get();
fd = fd - DFS_FD_OFFSET;
if (fd < 0 || fd >= fdt->maxfd)

View File

@ -270,7 +270,10 @@ long _sys_flen(FILEHANDLE fh)
int _sys_istty(FILEHANDLE fh)
{
return 0;
if((STDIN <= fh) && (fh <= STDERR))
return 1;
else
return 0;
}
int remove(const char *filename)