123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- /*
- * 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_ */
|