Merge pull request #4879 from mysterywolf/signal
[rtlibc] remove libc_signal.h and libc_fdset.h
This commit is contained in:
commit
56d3abe301
|
@ -10,7 +10,7 @@
|
||||||
#ifndef DFS_SELECT_H__
|
#ifndef DFS_SELECT_H__
|
||||||
#define DFS_SELECT_H__
|
#define DFS_SELECT_H__
|
||||||
|
|
||||||
#include <libc/libc_fdset.h>
|
#include <sys/select.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
|
|
@ -9,14 +9,8 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include <rthw.h>
|
#include <rthw.h>
|
||||||
#include <rtdevice.h>
|
|
||||||
#include <rtthread.h>
|
|
||||||
|
|
||||||
#include <dfs_posix.h>
|
#include <dfs_posix.h>
|
||||||
|
|
||||||
#include "posix_aio.h"
|
#include "posix_aio.h"
|
||||||
|
|
||||||
struct rt_workqueue* aio_queue = NULL;
|
struct rt_workqueue* aio_queue = NULL;
|
||||||
|
|
|
@ -11,6 +11,10 @@
|
||||||
#ifndef POSIX_AIO_H__
|
#ifndef POSIX_AIO_H__
|
||||||
#define POSIX_AIO_H__
|
#define POSIX_AIO_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/signal.h>
|
||||||
|
#include <rtdevice.h>
|
||||||
|
|
||||||
struct aiocb
|
struct aiocb
|
||||||
{
|
{
|
||||||
int aio_fildes; /* File descriptor. */
|
int aio_fildes; /* File descriptor. */
|
||||||
|
|
|
@ -7,8 +7,8 @@
|
||||||
* Date Author Notes
|
* Date Author Notes
|
||||||
* 2021-05-22 Meco Man The first version.
|
* 2021-05-22 Meco Man The first version.
|
||||||
*/
|
*/
|
||||||
#ifndef _SYS_ERRNO_H
|
#ifndef __SYS_ERRNO_H__
|
||||||
#define _SYS_ERRNO_H
|
#define __SYS_ERRNO_H__
|
||||||
|
|
||||||
#if defined(__ARMCC_VERSION)
|
#if defined(__ARMCC_VERSION)
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -6,3 +6,8 @@
|
||||||
* Change Logs:
|
* Change Logs:
|
||||||
* Date Author Notes
|
* Date Author Notes
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef __SYS_STAT_H__
|
||||||
|
#define __SYS_STAT_H__
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
* 2020-09-05 Meco Man fix bugs
|
* 2020-09-05 Meco Man fix bugs
|
||||||
* 2020-12-16 Meco Man add useconds_t
|
* 2020-12-16 Meco Man add useconds_t
|
||||||
*/
|
*/
|
||||||
#ifndef __TYPES_H__
|
#ifndef __SYS_TYPES_H__
|
||||||
#define __TYPES_H__
|
#define __SYS_TYPES_H__
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
|
|
@ -7,8 +7,8 @@
|
||||||
* Date Author Notes
|
* Date Author Notes
|
||||||
* 2020-12-16 Meco Man add usleep
|
* 2020-12-16 Meco Man add usleep
|
||||||
*/
|
*/
|
||||||
#ifndef _SYS_UNISTD_H
|
#ifndef __SYS_UNISTD_H__
|
||||||
#define _SYS_UNISTD_H
|
#define __SYS_UNISTD_H__
|
||||||
|
|
||||||
#include <rtconfig.h>
|
#include <rtconfig.h>
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2006-2021, RT-Thread Development Team
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Change Logs:
|
||||||
|
* Date Author Notes
|
||||||
|
* 2021-07-21 Meco Man The first version
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __SYS_SELECT_H__
|
||||||
|
#define __SYS_SELECT_H__
|
||||||
|
|
||||||
|
#include <rtconfig.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#ifndef FD_SETSIZE
|
||||||
|
#define FD_SETSIZE 32
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SAL_USING_POSIX
|
||||||
|
#ifdef FD_SETSIZE
|
||||||
|
#undef FD_SETSIZE
|
||||||
|
#endif
|
||||||
|
#define FD_SETSIZE DFS_FD_MAX
|
||||||
|
#endif /* SAL_USING_POSIX */
|
||||||
|
|
||||||
|
#define NBBY 8 /* number of bits in a byte */
|
||||||
|
|
||||||
|
typedef long fd_mask;
|
||||||
|
|
||||||
|
#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;
|
||||||
|
#define fd_set _types_fd_set
|
||||||
|
|
||||||
|
#define FD_SET(n, p) ((p)->fds_bits[(n)/NFDBITS] |= (1L << ((n) % NFDBITS)))
|
||||||
|
#define FD_CLR(n, p) ((p)->fds_bits[(n)/NFDBITS] &= ~(1L << ((n) % NFDBITS)))
|
||||||
|
#define FD_ISSET(n, p) ((p)->fds_bits[(n)/NFDBITS] & (1L << ((n) % NFDBITS)))
|
||||||
|
#define FD_ZERO(p) memset((void*)(p), 0, sizeof(*(p)))
|
||||||
|
#endif /* _SYS_TYPES_FD_SET */
|
||||||
|
|
||||||
|
#endif /* __SYS_SELECT_H__ */
|
|
@ -6,33 +6,27 @@
|
||||||
* Change Logs:
|
* Change Logs:
|
||||||
* Date Author Notes
|
* Date Author Notes
|
||||||
* 2017-09-12 Bernard The first version
|
* 2017-09-12 Bernard The first version
|
||||||
|
* 2021-07-21 Meco Man move to libc/common
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBC_SIGNAL_H__
|
#ifndef __SYS_SIGNAL_H__
|
||||||
#define LIBC_SIGNAL_H__
|
#define __SYS_SIGNAL_H__
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#ifdef HAVE_CCONFIG_H
|
|
||||||
#include <cconfig.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef HAVE_SIGVAL
|
|
||||||
/* Signal Generation and Delivery, P1003.1b-1993, p. 63
|
/* Signal Generation and Delivery, P1003.1b-1993, p. 63
|
||||||
NOTE: P1003.1c/D10, p. 34 adds sigev_notify_function and
|
NOTE: P1003.1c/D10, p. 34 adds sigev_notify_function and
|
||||||
sigev_notify_attributes to the sigevent structure. */
|
sigev_notify_attributes to the sigevent structure. */
|
||||||
|
|
||||||
union sigval
|
union sigval
|
||||||
{
|
{
|
||||||
int sival_int; /* Integer signal value */
|
int sival_int; /* Integer signal value */
|
||||||
void *sival_ptr; /* Pointer signal value */
|
void *sival_ptr; /* Pointer signal value */
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef HAVE_SIGEVENT
|
|
||||||
struct sigevent
|
struct sigevent
|
||||||
{
|
{
|
||||||
int sigev_notify; /* Notification type */
|
int sigev_notify; /* Notification type */
|
||||||
|
@ -42,9 +36,7 @@ struct sigevent
|
||||||
/* Notification function */
|
/* Notification function */
|
||||||
void *sigev_notify_attributes; /* Notification Attributes, really pthread_attr_t */
|
void *sigev_notify_attributes; /* Notification Attributes, really pthread_attr_t */
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef HAVE_SIGINFO
|
|
||||||
struct siginfo
|
struct siginfo
|
||||||
{
|
{
|
||||||
uint16_t si_signo;
|
uint16_t si_signo;
|
||||||
|
@ -53,26 +45,37 @@ struct siginfo
|
||||||
union sigval si_value;
|
union sigval si_value;
|
||||||
};
|
};
|
||||||
typedef struct siginfo siginfo_t;
|
typedef struct siginfo siginfo_t;
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SI_USER 0x01 /* Signal sent by kill(). */
|
#define SI_USER 0x01 /* Signal sent by kill(). */
|
||||||
#define SI_QUEUE 0x02 /* Signal sent by sigqueue(). */
|
#define SI_QUEUE 0x02 /* Signal sent by sigqueue(). */
|
||||||
#define SI_TIMER 0x03 /* Signal generated by expiration of a
|
#define SI_TIMER 0x03 /* Signal generated by expiration of a timer set by timer_settime(). */
|
||||||
timer set by timer_settime(). */
|
#define SI_ASYNCIO 0x04 /* Signal generated by completion of an asynchronous I/O request. */
|
||||||
#define SI_ASYNCIO 0x04 /* Signal generated by completion of an
|
#define SI_MESGQ 0x05 /* Signal generated by arrival of a message on an empty message queue. */
|
||||||
asynchronous I/O request. */
|
|
||||||
#define SI_MESGQ 0x05 /* Signal generated by arrival of a
|
|
||||||
message on an empty message queue. */
|
|
||||||
|
|
||||||
#if !defined(RT_USING_NEWLIB)
|
|
||||||
typedef void (*_sig_func_ptr)(int);
|
typedef void (*_sig_func_ptr)(int);
|
||||||
typedef unsigned long sigset_t;
|
typedef unsigned long sigset_t;
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <signal.h>
|
struct sigaction
|
||||||
|
{
|
||||||
|
_sig_func_ptr sa_handler;
|
||||||
|
sigset_t sa_mask;
|
||||||
|
int sa_flags;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define SIG_SETMASK 0 /* set mask with sigprocmask() */
|
||||||
|
#define SIG_BLOCK 1 /* set of signals to block */
|
||||||
|
#define SIG_UNBLOCK 2 /* set of signals to, well, unblock */
|
||||||
|
|
||||||
|
#define sigaddset(what,sig) (*(what) |= (1<<(sig)), 0)
|
||||||
|
#define sigdelset(what,sig) (*(what) &= ~(1<<(sig)), 0)
|
||||||
|
#define sigemptyset(what) (*(what) = 0, 0)
|
||||||
|
#define sigfillset(what) (*(what) = ~(0), 0)
|
||||||
|
#define sigismember(what,sig) (((*(what)) & (1<<(sig))) != 0)
|
||||||
|
|
||||||
|
int sigprocmask (int how, const sigset_t *set, sigset_t *oset);
|
||||||
|
int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
|
||||||
|
|
||||||
#ifdef __ARMCC_VERSION
|
#ifdef __ARMCC_VERSION
|
||||||
|
|
||||||
#define SIGHUP 1
|
#define SIGHUP 1
|
||||||
/* #define SIGINT 2 */
|
/* #define SIGINT 2 */
|
||||||
#define SIGQUIT 3
|
#define SIGQUIT 3
|
||||||
|
@ -103,28 +106,9 @@ typedef unsigned long sigset_t;
|
||||||
#define SIGRTMAX 31
|
#define SIGRTMAX 31
|
||||||
#define NSIG 32
|
#define NSIG 32
|
||||||
|
|
||||||
#define SIG_SETMASK 0 /* set mask with sigprocmask() */
|
#include <signal.h>
|
||||||
#define SIG_BLOCK 1 /* set of signals to block */
|
|
||||||
#define SIG_UNBLOCK 2 /* set of signals to, well, unblock */
|
|
||||||
|
|
||||||
struct sigaction
|
|
||||||
{
|
|
||||||
_sig_func_ptr sa_handler;
|
|
||||||
sigset_t sa_mask;
|
|
||||||
int sa_flags;
|
|
||||||
};
|
|
||||||
|
|
||||||
#define sigaddset(what,sig) (*(what) |= (1<<(sig)), 0)
|
|
||||||
#define sigdelset(what,sig) (*(what) &= ~(1<<(sig)), 0)
|
|
||||||
#define sigemptyset(what) (*(what) = 0, 0)
|
|
||||||
#define sigfillset(what) (*(what) = ~(0), 0)
|
|
||||||
#define sigismember(what,sig) (((*(what)) & (1<<(sig))) != 0)
|
|
||||||
|
|
||||||
int sigprocmask (int how, const sigset_t *set, sigset_t *oset);
|
|
||||||
int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
|
|
||||||
|
|
||||||
#elif defined(__IAR_SYSTEMS_ICC__)
|
#elif defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
|
||||||
#define SIGHUP 1
|
#define SIGHUP 1
|
||||||
#define SIGINT 2
|
#define SIGINT 2
|
||||||
#define SIGQUIT 3
|
#define SIGQUIT 3
|
||||||
|
@ -155,25 +139,51 @@ int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact)
|
||||||
#define SIGRTMAX 31
|
#define SIGRTMAX 31
|
||||||
#define NSIG 32
|
#define NSIG 32
|
||||||
|
|
||||||
#define SIG_SETMASK 0 /* set mask with sigprocmask() */
|
#include <signal.h>
|
||||||
#define SIG_BLOCK 1 /* set of signals to block */
|
|
||||||
#define SIG_UNBLOCK 2 /* set of signals to, well, unblock */
|
|
||||||
|
|
||||||
struct sigaction
|
#elif defined(__GNUC__)
|
||||||
{
|
#define SIGHUP 1 /* hangup */
|
||||||
_sig_func_ptr sa_handler;
|
#define SIGINT 2 /* interrupt */
|
||||||
sigset_t sa_mask;
|
#define SIGQUIT 3 /* quit */
|
||||||
int sa_flags;
|
#define SIGILL 4 /* illegal instruction (not reset when caught) */
|
||||||
};
|
#define SIGTRAP 5 /* trace trap (not reset when caught) */
|
||||||
|
#define SIGIOT 6 /* IOT instruction */
|
||||||
|
#define SIGABRT 6 /* used by abort, replace SIGIOT in the future */
|
||||||
|
#define SIGEMT 7 /* EMT instruction */
|
||||||
|
#define SIGFPE 8 /* floating point exception */
|
||||||
|
#define SIGKILL 9 /* kill (cannot be caught or ignored) */
|
||||||
|
#define SIGBUS 10 /* bus error */
|
||||||
|
#define SIGSEGV 11 /* segmentation violation */
|
||||||
|
#define SIGSYS 12 /* bad argument to system call */
|
||||||
|
#define SIGPIPE 13 /* write on a pipe with no one to read it */
|
||||||
|
#define SIGALRM 14 /* alarm clock */
|
||||||
|
#define SIGTERM 15 /* software termination signal from kill */
|
||||||
|
#define SIGURG 16 /* urgent condition on IO channel */
|
||||||
|
#define SIGSTOP 17 /* sendable stop signal not from tty */
|
||||||
|
#define SIGTSTP 18 /* stop signal from tty */
|
||||||
|
#define SIGCONT 19 /* continue a stopped process */
|
||||||
|
#define SIGCHLD 20 /* to parent on child stop or exit */
|
||||||
|
#define SIGCLD 20 /* System V name for SIGCHLD */
|
||||||
|
#define SIGTTIN 21 /* to readers pgrp upon background tty read */
|
||||||
|
#define SIGTTOU 22 /* like TTIN for output if (tp->t_local<OSTOP) */
|
||||||
|
#define SIGIO 23 /* input/output possible signal */
|
||||||
|
#define SIGPOLL SIGIO /* System V name for SIGIO */
|
||||||
|
#define SIGXCPU 24 /* exceeded CPU time limit */
|
||||||
|
#define SIGXFSZ 25 /* exceeded file size limit */
|
||||||
|
#define SIGVTALRM 26 /* virtual time alarm */
|
||||||
|
#define SIGPROF 27 /* profiling time alarm */
|
||||||
|
#define SIGWINCH 28 /* window changed */
|
||||||
|
#define SIGLOST 29 /* resource lost (eg, record-lock lost) */
|
||||||
|
#define SIGUSR1 30 /* user defined signal 1 */
|
||||||
|
#define SIGUSR2 31 /* user defined signal 2 */
|
||||||
|
#define NSIG 32 /* signal 0 implied */
|
||||||
|
|
||||||
#define sigaddset(what,sig) (*(what) |= (1<<(sig)), 0)
|
#ifndef _SIGNAL_H_
|
||||||
#define sigdelset(what,sig) (*(what) &= ~(1<<(sig)), 0)
|
/* Some applications take advantage of the fact that <sys/signal.h>
|
||||||
#define sigemptyset(what) (*(what) = 0, 0)
|
* and <signal.h> are equivalent in glibc. Allow for that here. */
|
||||||
#define sigfillset(what) (*(what) = ~(0), 0)
|
#include <signal.h>
|
||||||
#define sigismember(what,sig) (((*(what)) & (1<<(sig))) != 0)
|
#endif
|
||||||
|
|
||||||
int sigprocmask (int how, const sigset_t *set, sigset_t *oset);
|
|
||||||
int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
|
@ -8,6 +8,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <sys/signal.h>
|
||||||
#include "mqueue.h"
|
#include "mqueue.h"
|
||||||
#include "pthread_internal.h"
|
#include "pthread_internal.h"
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
* Date Author Notes
|
* Date Author Notes
|
||||||
* 2017/10/1 Bernard The first version
|
* 2017/10/1 Bernard The first version
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <rthw.h>
|
#include <rthw.h>
|
||||||
#include <rtthread.h>
|
#include <rtthread.h>
|
||||||
|
|
||||||
|
@ -14,6 +15,7 @@
|
||||||
#include <sys/errno.h>
|
#include <sys/errno.h>
|
||||||
|
|
||||||
#include "posix_signal.h"
|
#include "posix_signal.h"
|
||||||
|
|
||||||
#define sig_valid(sig_no) (sig_no >= 0 && sig_no < RT_SIG_MAX)
|
#define sig_valid(sig_no) (sig_no >= 0 && sig_no < RT_SIG_MAX)
|
||||||
|
|
||||||
void (*signal(int sig, void (*func)(int))) (int)
|
void (*signal(int sig, void (*func)(int))) (int)
|
||||||
|
@ -79,13 +81,10 @@ int sigtimedwait(const sigset_t *set, siginfo_t *info,
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
int tick = RT_WAITING_FOREVER;
|
int tick = RT_WAITING_FOREVER;
|
||||||
|
|
||||||
#ifdef RT_USING_PTHREADS
|
|
||||||
if (timeout)
|
if (timeout)
|
||||||
{
|
{
|
||||||
extern int clock_time_to_tick(const struct timespec *time);
|
|
||||||
tick = clock_time_to_tick(timeout);
|
tick = clock_time_to_tick(timeout);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = rt_signal_wait(set, info, tick);
|
ret = rt_signal_wait(set, info, tick);
|
||||||
if (ret == 0) return 0;
|
if (ret == 0) return 0;
|
||||||
|
|
|
@ -15,7 +15,6 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <rtthread.h>
|
|
||||||
#include <sys/signal.h>
|
#include <sys/signal.h>
|
||||||
|
|
||||||
enum rt_signal_value{
|
enum rt_signal_value{
|
||||||
|
|
|
@ -1,60 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2006-2021, RT-Thread Development Team
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
|
||||||
*
|
|
||||||
* Change Logs:
|
|
||||||
* Date Author Notes
|
|
||||||
* 2017-10-30 Bernard The first version
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef LIBC_FDSET_H__
|
|
||||||
#define LIBC_FDSET_H__
|
|
||||||
|
|
||||||
#include <rtconfig.h>
|
|
||||||
|
|
||||||
#if defined(RT_USING_NEWLIB) || defined(_WIN32) || (defined( __GNUC__ ) && !defined(__ARMCC_VERSION))
|
|
||||||
#include <sys/types.h>
|
|
||||||
#if defined(HAVE_SYS_SELECT_H)
|
|
||||||
#include <sys/select.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#ifdef SAL_USING_POSIX
|
|
||||||
|
|
||||||
#ifdef FD_SETSIZE
|
|
||||||
#undef FD_SETSIZE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define FD_SETSIZE DFS_FD_MAX
|
|
||||||
#endif
|
|
||||||
|
|
||||||
# ifndef FD_SETSIZE
|
|
||||||
# define FD_SETSIZE 32
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# define NBBY 8 /* number of bits in a byte */
|
|
||||||
|
|
||||||
typedef long fd_mask;
|
|
||||||
# define NFDBITS (sizeof (fd_mask) * NBBY) /* bits per mask */
|
|
||||||
# ifndef howmany
|
|
||||||
# define howmany(x,y) (((x)+((y)-1))/(y))
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* We use a macro for fd_set so that including Sockets.h afterwards
|
|
||||||
can work. */
|
|
||||||
typedef struct _types_fd_set {
|
|
||||||
fd_mask fds_bits[howmany(FD_SETSIZE, NFDBITS)];
|
|
||||||
} _types_fd_set;
|
|
||||||
|
|
||||||
#define fd_set _types_fd_set
|
|
||||||
|
|
||||||
# define FD_SET(n, p) ((p)->fds_bits[(n)/NFDBITS] |= (1L << ((n) % NFDBITS)))
|
|
||||||
# define FD_CLR(n, p) ((p)->fds_bits[(n)/NFDBITS] &= ~(1L << ((n) % NFDBITS)))
|
|
||||||
# define FD_ISSET(n, p) ((p)->fds_bits[(n)/NFDBITS] & (1L << ((n) % NFDBITS)))
|
|
||||||
# define FD_ZERO(p) memset((void*)(p), 0, sizeof(*(p)))
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -510,7 +510,7 @@ typedef struct rt_timer *rt_timer_t;
|
||||||
* @addtogroup Signal
|
* @addtogroup Signal
|
||||||
*/
|
*/
|
||||||
#ifdef RT_USING_SIGNALS
|
#ifdef RT_USING_SIGNALS
|
||||||
#include <libc/libc_signal.h>
|
#include <sys/signal.h>
|
||||||
typedef unsigned long rt_sigset_t;
|
typedef unsigned long rt_sigset_t;
|
||||||
typedef void (*rt_sighandler_t)(int signo);
|
typedef void (*rt_sighandler_t)(int signo);
|
||||||
typedef siginfo_t rt_siginfo_t;
|
typedef siginfo_t rt_siginfo_t;
|
||||||
|
|
|
@ -13,11 +13,8 @@
|
||||||
|
|
||||||
/* definitions for libc if toolchain has no these definitions */
|
/* definitions for libc if toolchain has no these definitions */
|
||||||
#include "libc/libc_stat.h"
|
#include "libc/libc_stat.h"
|
||||||
|
|
||||||
#include "libc/libc_fcntl.h"
|
#include "libc/libc_fcntl.h"
|
||||||
#include "libc/libc_dirent.h"
|
#include "libc/libc_dirent.h"
|
||||||
#include "libc/libc_signal.h"
|
|
||||||
#include "libc/libc_fdset.h"
|
|
||||||
|
|
||||||
#ifndef RT_USING_LIBC
|
#ifndef RT_USING_LIBC
|
||||||
#if defined(__ARMCC_VERSION) || defined(__IAR_SYSTEMS_ICC__)
|
#if defined(__ARMCC_VERSION) || defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
|
Loading…
Reference in New Issue