Merge pull request #4879 from mysterywolf/signal

[rtlibc] remove libc_signal.h and libc_fdset.h
This commit is contained in:
Bernard Xiong 2021-07-30 23:30:49 +08:00 committed by GitHub
commit 56d3abe301
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
15 changed files with 137 additions and 139 deletions

View File

@ -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" {

View File

@ -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;

View File

@ -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. */

View File

@ -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)
/* /*

View File

@ -6,3 +6,8 @@
* Change Logs: * Change Logs:
* Date Author Notes * Date Author Notes
*/ */
#ifndef __SYS_STAT_H__
#define __SYS_STAT_H__
#endif

View File

@ -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>

View File

@ -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"

View File

@ -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__ */

View File

@ -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&LTOSTOP) */
#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

View File

@ -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"

View File

@ -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;

View File

@ -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{

View File

@ -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

View File

@ -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;

View File

@ -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__)