1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/include/net/sock/async.h
Martine S. Lenders 43b1c5c74c
sock_async: fix cyclic dependency with sock_types.h
Typically a stack needs to add the callback for a sock as a member of
its respective `sock` type so `sock_types.h` needs to include
`net/sock/async.h` at the moment. As those however include
`net/sock/<prot>.h`, which in turn include `sock_types.h`, we create a
cyclic dependency.

This fix resolves this cyclic dependency, by putting the callback
definitions in its own header that then in turn can be also included
by `sock_types.h`.
2020-01-07 10:13:01 +01:00

216 lines
6.3 KiB
C

/*
* Copyright (C) 2019 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup net_sock_async Sock extension for asynchronous access
* @ingroup net_sock
* @brief Provides backend functionality for asynchronous sock access.
* @experimental This API extension is still under development and should
* not be used in production yet.
*
* @{
*
* @file
* @brief Definitions for sock extension for asynchronous access
*
* @author Martine Lenders <m.lenders@fu-berlin.de>
*/
#ifndef NET_SOCK_ASYNC_H
#define NET_SOCK_ASYNC_H
#include "net/sock/async/types.h"
#ifdef __cplusplus
extern "C" {
#endif
#if defined(SOCK_HAS_ASYNC) || defined(DOXYGEN)
#if defined(MODULE_SOCK_DTLS) || defined(DOXYGEN)
/**
* @brief Gets the asynchronous event context from sock object
*
* @pre `(sock != NULL)`
*
* @warning Never handle the callback in the caller's context! You might block
* the operation of the network stack or the DTLS library with that.
*
* @note Only available with @ref SOCK_HAS_ASYNC defined.
*
* @param[in] sock A DTLS sock object.
* @param[in] cb An event callback. May be NULL to unset event callback.
*/
void sock_dtls_set_cb(sock_dtls_t *sock, sock_dtls_cb_t cb);
#endif /* defined(MODULE_SOCK_DTLS) || defined(DOXYGEN) */
#if defined(MODULE_SOCK_IP) || defined(DOXYGEN)
/**
* @brief Sets event callback for @ref sock_ip_t
*
* @pre `(sock != NULL)`
*
* @warning Never handle the callback in the caller's context! You might block
* the operation of the network stack with that.
*
* @note Only available with @ref SOCK_HAS_ASYNC defined.
*
* @param[in] sock A raw IPv4/IPv6 sock object.
* @param[in] cb An event callback. May be NULL to unset event callback.
*/
void sock_ip_set_cb(sock_ip_t *sock, sock_ip_cb_t cb);
#endif /* defined(MODULE_SOCK_IP) || defined(DOXYGEN) */
#if defined(MODULE_SOCK_TCP) || defined(DOXYGEN)
/**
* @brief Sets event callback for @ref sock_tcp_t
*
* @pre `(sock != NULL)`
*
* @warning Never handle the callback in the caller's context! You might block
* the operation of the network stack with that.
*
* @note Only available with @ref SOCK_HAS_ASYNC defined.
*
* @param[in] sock A TCP sock object.
* @param[in] cb An event callback. May be NULL to unset event callback.
*/
void sock_tcp_set_cb(sock_tcp_t *sock, sock_tcp_cb_t cb);
/**
* @brief Sets event callback for @ref sock_tcp_queue_t
*
* @pre `(sock != NULL)`
*
* @warning Never handle the callback in the caller's context! You might block
* the operation of the network stack with that.
*
* @note Only available with @ref SOCK_HAS_ASYNC defined.
*
* @param[in] queue A TCP listening queue.
* @param[in] cb An event callback. May be NULL to unset event callback.
*/
void sock_tcp_queue_set_cb(sock_tcp_queue_t *queue, sock_tcp_queue_cb_t cb);
#endif /* defined(MODULE_SOCK_TCP) || defined(DOXYGEN) */
#if defined(MODULE_SOCK_UDP) || defined(DOXYGEN)
/**
* @brief Gets the asynchronous event context from sock object
*
* @pre `(sock != NULL)`
*
* @warning Never handle the callback in the caller's context! You might block
* the operation of the network stack with that.
*
* @note Only available with @ref SOCK_HAS_ASYNC defined.
*
* @param[in] sock A UDP sock object.
* @param[in] cb An event callback. May be NULL to unset event callback.
*/
void sock_udp_set_cb(sock_udp_t *sock, sock_udp_cb_t cb);
#endif /* defined(MODULE_SOCK_UDP) || defined(DOXYGEN) */
#if defined(SOCK_HAS_ASYNC_CTX) || defined(DOXYGEN)
#include "sock_async_ctx.h" /* defines sock_async_ctx_t */
#if defined(MODULE_SOCK_DTLS) || defined(DOXYGEN)
/**
* @brief Gets the asynchronous event context from sock object
*
* @pre `(sock != NULL)`
*
* @note Only available with @ref SOCK_HAS_ASYNC and @ref SOCK_HAS_ASYNC_CTX
* defined.
*
* @see @ref SOCK_HAS_ASYNC_CTX
*
* @param[in] sock A DTLS sock object.
*
* @return The asynchronous event context
*/
sock_async_ctx_t *sock_dtls_get_async_ctx(sock_dtls_t *sock);
#endif /* defined(MODULE_SOCK_DTLS) || defined(DOXYGEN) */
#if defined(MODULE_SOCK_IP) || defined(DOXYGEN)
/**
* @brief Gets the asynchronous event context from sock object
*
* @pre `(sock != NULL)`
*
* @note Only available with @ref SOCK_HAS_ASYNC and @ref SOCK_HAS_ASYNC_CTX
* defined.
*
* @see @ref SOCK_HAS_ASYNC_CTX
*
* @param[in] sock A raw IPv4/IPv6 sock object.
*
* @return The asynchronous event context
*/
sock_async_ctx_t *sock_ip_get_async_ctx(sock_ip_t *sock);
#endif /* defined(MODULE_SOCK_IP) || defined(DOXYGEN) */
#if defined(MODULE_SOCK_TCP) || defined(DOXYGEN)
/**
* @brief Gets the asynchronous event context from sock object
*
* @pre `(sock != NULL)`
*
* @note Only available with @ref SOCK_HAS_ASYNC and @ref SOCK_HAS_ASYNC_CTX
* defined.
*
* @see @ref SOCK_HAS_ASYNC_CTX
*
* @param[in] sock A TCP sock object.
*
* @return The asynchronous event context
*/
sock_async_ctx_t *sock_tcp_get_async_ctx(sock_tcp_t *sock);
/**
* @brief Gets the asynchronous event context from TCP listening queue
*
* @pre `(queue != NULL)`
*
* @note Only available with @ref SOCK_HAS_ASYNC and @ref SOCK_HAS_ASYNC_CTX
* defined.
*
* @see @ref SOCK_HAS_ASYNC_CTX
*
* @param[in] queue A TCP listening queue.
*
* @return The asynchronous event context
*/
sock_async_ctx_t *sock_tcp_queue_get_async_ctx(sock_tcp_queue_t *queue);
#endif /* defined(MODULE_SOCK_TCP) || defined(DOXYGEN) */
#if defined(MODULE_SOCK_UDP) || defined(DOXYGEN)
/**
* @brief Gets the asynchronous event context from sock object
*
* @pre `(sock != NULL)`
*
* @note Only available with @ref SOCK_HAS_ASYNC and @ref SOCK_HAS_ASYNC_CTX
* defined.
*
* @see @ref SOCK_HAS_ASYNC_CTX
*
* @param[in] sock A UDP sock object.
*
* @return The asynchronous event context
*/
sock_async_ctx_t *sock_udp_get_async_ctx(sock_udp_t *sock);
#endif /* defined(MODULE_SOCK_UDP) || defined(DOXYGEN) */
#endif /* defined(SOCK_HAS_ASYNC_CTX) || defined(DOXYGEN) */
#endif /* defined(SOCK_HAS_ASYNC) || defined(DOXYGEN) */
#ifdef __cplusplus
}
#endif
#endif /* NET_SOCK_ASYNC_H */
/** @} */