| /* |
| * Copyright (c) 2019 Linaro Limited |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| |
| #ifndef ZEPHYR_INCLUDE_NET_SOCKET_SELECT_H_ |
| #define ZEPHYR_INCLUDE_NET_SOCKET_SELECT_H_ |
| |
| /** |
| * @brief BSD Sockets compatible API |
| * @defgroup bsd_sockets BSD Sockets compatible API |
| * @ingroup networking |
| * @{ |
| */ |
| |
| #include <toolchain.h> |
| #include <net/socket_types.h> |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| typedef struct zsock_fd_set { |
| uint32_t bitset[(CONFIG_POSIX_MAX_FDS + 31) / 32]; |
| } zsock_fd_set; |
| |
| |
| /** |
| * @brief Legacy function to poll multiple sockets for events |
| * |
| * @details |
| * @rst |
| * See `POSIX.1-2017 article |
| * <http://pubs.opengroup.org/onlinepubs/9699919799/functions/select.html>`__ |
| * for normative description. This function is provided to ease porting of |
| * existing code and not recommended for usage due to its inefficiency, |
| * use :c:func:`zsock_poll()` instead. In Zephyr this function works only with |
| * sockets, not arbitrary file descriptors. |
| * This function is also exposed as ``select()`` |
| * if :kconfig:`CONFIG_NET_SOCKETS_POSIX_NAMES` is defined (in which case |
| * it may conflict with generic POSIX ``select()`` function). |
| * @endrst |
| */ |
| __syscall int zsock_select(int nfds, zsock_fd_set *readfds, |
| zsock_fd_set *writefds, |
| zsock_fd_set *exceptfds, |
| struct zsock_timeval *timeout); |
| |
| /** Number of file descriptors which can be added to zsock_fd_set */ |
| #define ZSOCK_FD_SETSIZE (sizeof(((zsock_fd_set *)0)->bitset) * 8) |
| |
| /** |
| * @brief Initialize (clear) fd_set |
| * |
| * @details |
| * @rst |
| * See `POSIX.1-2017 article |
| * <http://pubs.opengroup.org/onlinepubs/9699919799/functions/select.html>`__ |
| * for normative description. |
| * This function is also exposed as ``FD_ZERO()`` |
| * if :kconfig:`CONFIG_NET_SOCKETS_POSIX_NAMES` is defined. |
| * @endrst |
| */ |
| void ZSOCK_FD_ZERO(zsock_fd_set *set); |
| |
| /** |
| * @brief Check whether socket is a member of fd_set |
| * |
| * @details |
| * @rst |
| * See `POSIX.1-2017 article |
| * <http://pubs.opengroup.org/onlinepubs/9699919799/functions/select.html>`__ |
| * for normative description. |
| * This function is also exposed as ``FD_ISSET()`` |
| * if :kconfig:`CONFIG_NET_SOCKETS_POSIX_NAMES` is defined. |
| * @endrst |
| */ |
| int ZSOCK_FD_ISSET(int fd, zsock_fd_set *set); |
| |
| /** |
| * @brief Remove socket from fd_set |
| * |
| * @details |
| * @rst |
| * See `POSIX.1-2017 article |
| * <http://pubs.opengroup.org/onlinepubs/9699919799/functions/select.html>`__ |
| * for normative description. |
| * This function is also exposed as ``FD_CLR()`` |
| * if :kconfig:`CONFIG_NET_SOCKETS_POSIX_NAMES` is defined. |
| * @endrst |
| */ |
| void ZSOCK_FD_CLR(int fd, zsock_fd_set *set); |
| |
| /** |
| * @brief Add socket to fd_set |
| * |
| * @details |
| * @rst |
| * See `POSIX.1-2017 article |
| * <http://pubs.opengroup.org/onlinepubs/9699919799/functions/select.html>`__ |
| * for normative description. |
| * This function is also exposed as ``FD_SET()`` |
| * if :kconfig:`CONFIG_NET_SOCKETS_POSIX_NAMES` is defined. |
| * @endrst |
| */ |
| void ZSOCK_FD_SET(int fd, zsock_fd_set *set); |
| |
| #ifdef CONFIG_NET_SOCKETS_POSIX_NAMES |
| |
| #define fd_set zsock_fd_set |
| #define timeval zsock_timeval |
| #define FD_SETSIZE ZSOCK_FD_SETSIZE |
| |
| static inline int select(int nfds, zsock_fd_set *readfds, |
| zsock_fd_set *writefds, zsock_fd_set *exceptfds, |
| struct timeval *timeout) |
| { |
| return zsock_select(nfds, readfds, writefds, exceptfds, timeout); |
| } |
| |
| static inline void FD_ZERO(zsock_fd_set *set) |
| { |
| ZSOCK_FD_ZERO(set); |
| } |
| |
| static inline int FD_ISSET(int fd, zsock_fd_set *set) |
| { |
| return ZSOCK_FD_ISSET(fd, set); |
| } |
| |
| static inline void FD_CLR(int fd, zsock_fd_set *set) |
| { |
| ZSOCK_FD_CLR(fd, set); |
| } |
| |
| static inline void FD_SET(int fd, zsock_fd_set *set) |
| { |
| ZSOCK_FD_SET(fd, set); |
| } |
| |
| #endif /* CONFIG_NET_SOCKETS_POSIX_NAMES */ |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #include <syscalls/socket_select.h> |
| |
| /** |
| * @} |
| */ |
| |
| #endif /* ZEPHYR_INCLUDE_NET_SOCKET_SELECT_H_ */ |