4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-18 13:43:31 +08:00

[libc][win32] improve win32 support

This commit is contained in:
Meco Man 2021-10-13 12:57:32 -04:00
parent 0873b8163b
commit 8f6260146c
5 changed files with 30 additions and 5 deletions

View File

@ -11,6 +11,14 @@
#include <shell.h>
#ifdef RT_USING_POSIX
#error "simulator does not support RT_USING_POSIX"
#endif
#ifdef RT_USING_LIBC
#error "simulator does not support RT_USING_LIBC"
#endif
int platform_init(void)
{
#ifdef RT_USING_LWIP

View File

@ -110,4 +110,10 @@ int rt_hw_board_init(void)
#endif
return 0;
}
void rt_hw_us_delay(rt_uint32_t usec)
{
}
/*@}*/

View File

@ -15,6 +15,10 @@
#include <sys/types.h>
#include <sys/time.h>
#ifdef _WIN32
#include <winsock.h>
#endif
#ifndef FD_SETSIZE
#define FD_SETSIZE 32
#endif
@ -26,16 +30,17 @@
#define FD_SETSIZE DFS_FD_MAX
#endif /* SAL_USING_POSIX */
#define NBBY 8 /* number of bits in a byte */
typedef long fd_mask;
#ifndef _WIN32
#ifndef _SYS_TYPES_FD_SET /* MIPS */
#define NBBY 8 /* number of bits in a byte */
#define NFDBITS (sizeof (fd_mask) * NBBY) /* bits per mask */
#ifndef howmany
#define howmany(x,y) (((x)+((y)-1))/(y))
#endif
#ifndef _SYS_TYPES_FD_SET /* MIPS */
typedef struct _types_fd_set {
fd_mask fds_bits[howmany(FD_SETSIZE, NFDBITS)];
} _types_fd_set;
@ -48,5 +53,6 @@ typedef struct _types_fd_set {
#endif /* _SYS_TYPES_FD_SET */
int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);
#endif /* _WIN32 */
#endif /* __SYS_SELECT_H__ */

View File

@ -15,6 +15,10 @@
#include <dfs_posix.h>
#endif
#ifdef _WIN32
#include <winsock.h>
#endif
struct winsize {
unsigned short ws_row;
unsigned short ws_col;
@ -35,8 +39,8 @@ struct winsize {
#define FIONREAD _IOR('f', 127, int) /* get # bytes to read */
#define FIONBIO _IOW('f', 126, int) /* set/clear non-blocking i/o */
#define FIONWRITE _IOR('f', 121, int) /* get # bytes outstanding in send queue */
#endif
#define FIONWRITE _IOR('f', 121, int) /* get # bytes outstanding in send queue */
#define TCGETS 0x5401
#define TCSETS 0x5402

View File

@ -72,7 +72,8 @@ int libc_stdio_set_console(const char* device_name, int mode)
return -1;
}
int libc_stdio_get_console(void) {
int libc_stdio_get_console(void)
{
if (std_console)
return fileno(std_console);
else