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`.
This commit is contained in:
parent
421d174f60
commit
43b1c5c74c
@ -23,63 +23,14 @@
|
|||||||
#ifndef NET_SOCK_ASYNC_H
|
#ifndef NET_SOCK_ASYNC_H
|
||||||
#define NET_SOCK_ASYNC_H
|
#define NET_SOCK_ASYNC_H
|
||||||
|
|
||||||
#ifdef MODULE_SOCK_DTLS
|
#include "net/sock/async/types.h"
|
||||||
#include "net/sock/dtls.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef MODULE_SOCK_IP
|
|
||||||
#include "net/sock/ip.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef MODULE_SOCK_TCP
|
|
||||||
#include "net/sock/tcp.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef MODULE_SOCK_UDP
|
|
||||||
#include "net/sock/udp.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOCK_HAS_ASYNC) || defined(DOXYGEN)
|
#if defined(SOCK_HAS_ASYNC) || defined(DOXYGEN)
|
||||||
#ifdef SOCK_HAS_ASYNC_CTX
|
|
||||||
#include "sock_async_ctx.h" /* defines sock_async_ctx_t */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Flag types to signify asynchronous sock events
|
|
||||||
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
SOCK_ASYNC_CONN_RDY = 0x0001, /**< Connection ready event */
|
|
||||||
SOCK_ASYNC_CONN_FIN = 0x0002, /**< Connection finished event */
|
|
||||||
SOCK_ASYNC_CONN_RECV = 0x0004, /**< Listener received connection event */
|
|
||||||
SOCK_ASYNC_MSG_RECV = 0x0010, /**< Message received event */
|
|
||||||
SOCK_ASYNC_MSG_SENT = 0x0020, /**< Message sent event */
|
|
||||||
SOCK_ASYNC_PATH_PROP = 0x0040, /**< Path property changed event */
|
|
||||||
} sock_async_flags_t;
|
|
||||||
|
|
||||||
#if defined(MODULE_SOCK_DTLS) || defined(DOXYGEN)
|
#if defined(MODULE_SOCK_DTLS) || defined(DOXYGEN)
|
||||||
/**
|
|
||||||
* @brief Event callback for @ref sock_dtls_t
|
|
||||||
*
|
|
||||||
* @pre `(sock != NULL)`
|
|
||||||
*
|
|
||||||
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
|
||||||
*
|
|
||||||
* @param[in] sock The sock the event happened on
|
|
||||||
* @param[in] flags The event flags. Expected values are
|
|
||||||
* - @ref SOCK_ASYNC_CONN_RDY (if a session you created becomes ready),
|
|
||||||
* - @ref SOCK_ASYNC_CONN_FIN (if a created session was destroyed),
|
|
||||||
* - @ref SOCK_ASYNC_CONN_RECV (if a peer tries to create a session),
|
|
||||||
* - @ref SOCK_ASYNC_MSG_RECV,
|
|
||||||
* - @ref SOCK_ASYNC_MSG_SENT,
|
|
||||||
* - @ref SOCK_ASYNC_PATH_PROP, or
|
|
||||||
* - a combination of them.
|
|
||||||
*/
|
|
||||||
typedef void (*sock_dtls_cb_t)(sock_dtls_t *sock, sock_async_flags_t flags);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Gets the asynchronous event context from sock object
|
* @brief Gets the asynchronous event context from sock object
|
||||||
@ -98,22 +49,6 @@ void sock_dtls_set_cb(sock_dtls_t *sock, sock_dtls_cb_t cb);
|
|||||||
#endif /* defined(MODULE_SOCK_DTLS) || defined(DOXYGEN) */
|
#endif /* defined(MODULE_SOCK_DTLS) || defined(DOXYGEN) */
|
||||||
|
|
||||||
#if defined(MODULE_SOCK_IP) || defined(DOXYGEN)
|
#if defined(MODULE_SOCK_IP) || defined(DOXYGEN)
|
||||||
/**
|
|
||||||
* @brief Event callback for @ref sock_ip_t
|
|
||||||
*
|
|
||||||
* @pre `(sock != NULL)`
|
|
||||||
*
|
|
||||||
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
|
||||||
*
|
|
||||||
* @param[in] sock The sock the event happened on
|
|
||||||
* @param[in] flags The event flags. Expected values are
|
|
||||||
* - @ref SOCK_ASYNC_MSG_RECV,
|
|
||||||
* - @ref SOCK_ASYNC_MSG_SENT,
|
|
||||||
* - @ref SOCK_ASYNC_PATH_PROP, or
|
|
||||||
* - a combination of them.
|
|
||||||
*/
|
|
||||||
typedef void (*sock_ip_cb_t)(sock_ip_t *sock, sock_async_flags_t flags);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Sets event callback for @ref sock_ip_t
|
* @brief Sets event callback for @ref sock_ip_t
|
||||||
*
|
*
|
||||||
@ -131,38 +66,6 @@ void sock_ip_set_cb(sock_ip_t *sock, sock_ip_cb_t cb);
|
|||||||
#endif /* defined(MODULE_SOCK_IP) || defined(DOXYGEN) */
|
#endif /* defined(MODULE_SOCK_IP) || defined(DOXYGEN) */
|
||||||
|
|
||||||
#if defined(MODULE_SOCK_TCP) || defined(DOXYGEN)
|
#if defined(MODULE_SOCK_TCP) || defined(DOXYGEN)
|
||||||
/**
|
|
||||||
* @brief Event callback for @ref sock_tcp_t
|
|
||||||
*
|
|
||||||
* @pre `(sock != NULL)`
|
|
||||||
*
|
|
||||||
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
|
||||||
*
|
|
||||||
* @param[in] sock The sock the event happened on
|
|
||||||
* @param[in] flags The event flags. Expected values are
|
|
||||||
* - @ref SOCK_ASYNC_CONN_RDY,
|
|
||||||
* - @ref SOCK_ASYNC_CONN_FIN,
|
|
||||||
* - @ref SOCK_ASYNC_MSG_RECV,
|
|
||||||
* - @ref SOCK_ASYNC_MSG_SENT,
|
|
||||||
* - @ref SOCK_ASYNC_PATH_PROP, or
|
|
||||||
* - a combination of them.
|
|
||||||
*/
|
|
||||||
typedef void (*sock_tcp_cb_t)(sock_tcp_t *sock, sock_async_flags_t flags);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Event callback for @ref sock_tcp_queue_t
|
|
||||||
*
|
|
||||||
* @pre `(queue != NULL)`
|
|
||||||
*
|
|
||||||
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
|
||||||
*
|
|
||||||
* @param[in] queue The TCP listening queue the event happened on
|
|
||||||
* @param[in] flags The event flags. The only expected value is @ref
|
|
||||||
* SOCK_ASYNC_CONN_RECV.
|
|
||||||
*/
|
|
||||||
typedef void (*sock_tcp_queue_cb_t)(sock_tcp_queue_t *queue,
|
|
||||||
sock_async_flags_t flags);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Sets event callback for @ref sock_tcp_t
|
* @brief Sets event callback for @ref sock_tcp_t
|
||||||
*
|
*
|
||||||
@ -195,22 +98,6 @@ void sock_tcp_queue_set_cb(sock_tcp_queue_t *queue, sock_tcp_queue_cb_t cb);
|
|||||||
#endif /* defined(MODULE_SOCK_TCP) || defined(DOXYGEN) */
|
#endif /* defined(MODULE_SOCK_TCP) || defined(DOXYGEN) */
|
||||||
|
|
||||||
#if defined(MODULE_SOCK_UDP) || defined(DOXYGEN)
|
#if defined(MODULE_SOCK_UDP) || defined(DOXYGEN)
|
||||||
/**
|
|
||||||
* @brief Event callback for @ref sock_udp_t
|
|
||||||
*
|
|
||||||
* @pre `(sock != NULL)`
|
|
||||||
*
|
|
||||||
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
|
||||||
*
|
|
||||||
* @param[in] sock The sock the event happened on
|
|
||||||
* @param[in] flags The event flags. Expected values are
|
|
||||||
* - @ref SOCK_ASYNC_MSG_RECV,
|
|
||||||
* - @ref SOCK_ASYNC_MSG_SENT,
|
|
||||||
* - @ref SOCK_ASYNC_PATH_PROP, or
|
|
||||||
* - a combination of them.
|
|
||||||
*/
|
|
||||||
typedef void (*sock_udp_cb_t)(sock_udp_t *sock, sock_async_flags_t type);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Gets the asynchronous event context from sock object
|
* @brief Gets the asynchronous event context from sock object
|
||||||
*
|
*
|
||||||
@ -228,6 +115,8 @@ void sock_udp_set_cb(sock_udp_t *sock, sock_udp_cb_t cb);
|
|||||||
#endif /* defined(MODULE_SOCK_UDP) || defined(DOXYGEN) */
|
#endif /* defined(MODULE_SOCK_UDP) || defined(DOXYGEN) */
|
||||||
|
|
||||||
#if defined(SOCK_HAS_ASYNC_CTX) || 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)
|
#if defined(MODULE_SOCK_DTLS) || defined(DOXYGEN)
|
||||||
/**
|
/**
|
||||||
* @brief Gets the asynchronous event context from sock object
|
* @brief Gets the asynchronous event context from sock object
|
||||||
|
|||||||
146
sys/include/net/sock/async/types.h
Normal file
146
sys/include/net/sock/async/types.h
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
/**
|
||||||
|
* @addtogroup net_sock_async Sock extension for asynchronous access
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @brief Definitions for sock extension for asynchronous access
|
||||||
|
*
|
||||||
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
||||||
|
*/
|
||||||
|
#ifndef NET_SOCK_ASYNC_TYPES_H
|
||||||
|
#define NET_SOCK_ASYNC_TYPES_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(SOCK_HAS_ASYNC) || defined(DOXYGEN)
|
||||||
|
/**
|
||||||
|
* @brief Flag types to signify asynchronous sock events
|
||||||
|
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
SOCK_ASYNC_CONN_RDY = 0x0001, /**< Connection ready event */
|
||||||
|
SOCK_ASYNC_CONN_FIN = 0x0002, /**< Connection finished event */
|
||||||
|
SOCK_ASYNC_CONN_RECV = 0x0004, /**< Listener received connection event */
|
||||||
|
SOCK_ASYNC_MSG_RECV = 0x0010, /**< Message received event */
|
||||||
|
SOCK_ASYNC_MSG_SENT = 0x0020, /**< Message sent event */
|
||||||
|
SOCK_ASYNC_PATH_PROP = 0x0040, /**< Path property changed event */
|
||||||
|
} sock_async_flags_t;
|
||||||
|
|
||||||
|
#if defined(MODULE_SOCK_DTLS) || defined(DOXYGEN)
|
||||||
|
typedef struct sock_dtls sock_dtls_t; /**< forward declare for async */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Event callback for @ref sock_dtls_t
|
||||||
|
*
|
||||||
|
* @pre `(sock != NULL)`
|
||||||
|
*
|
||||||
|
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
||||||
|
*
|
||||||
|
* @param[in] sock The sock the event happened on
|
||||||
|
* @param[in] flags The event flags. Expected values are
|
||||||
|
* - @ref SOCK_ASYNC_CONN_RDY (if a session you created becomes ready),
|
||||||
|
* - @ref SOCK_ASYNC_CONN_FIN (if a created session was destroyed),
|
||||||
|
* - @ref SOCK_ASYNC_CONN_RECV (if a peer tries to create a session),
|
||||||
|
* - @ref SOCK_ASYNC_MSG_RECV,
|
||||||
|
* - @ref SOCK_ASYNC_MSG_SENT,
|
||||||
|
* - @ref SOCK_ASYNC_PATH_PROP, or
|
||||||
|
* - a combination of them.
|
||||||
|
*/
|
||||||
|
typedef void (*sock_dtls_cb_t)(sock_dtls_t *sock, sock_async_flags_t flags);
|
||||||
|
#endif /* defined(MODULE_SOCK_DTLS) || defined(DOXYGEN) */
|
||||||
|
|
||||||
|
#if defined(MODULE_SOCK_IP) || defined(DOXYGEN)
|
||||||
|
typedef struct sock_ip sock_ip_t; /**< forward declare for async */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Event callback for @ref sock_ip_t
|
||||||
|
*
|
||||||
|
* @pre `(sock != NULL)`
|
||||||
|
*
|
||||||
|
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
||||||
|
*
|
||||||
|
* @param[in] sock The sock the event happened on
|
||||||
|
* @param[in] flags The event flags. Expected values are
|
||||||
|
* - @ref SOCK_ASYNC_MSG_RECV,
|
||||||
|
* - @ref SOCK_ASYNC_MSG_SENT,
|
||||||
|
* - @ref SOCK_ASYNC_PATH_PROP, or
|
||||||
|
* - a combination of them.
|
||||||
|
*/
|
||||||
|
typedef void (*sock_ip_cb_t)(sock_ip_t *sock, sock_async_flags_t flags);
|
||||||
|
#endif /* defined(MODULE_SOCK_IP) || defined(DOXYGEN) */
|
||||||
|
|
||||||
|
#if defined(MODULE_SOCK_TCP) || defined(DOXYGEN)
|
||||||
|
typedef struct sock_tcp sock_tcp_t; /**< forward declare for async */
|
||||||
|
typedef struct sock_tcp sock_tcp_quee_t; /**< forward declare for async */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Event callback for @ref sock_tcp_t
|
||||||
|
*
|
||||||
|
* @pre `(sock != NULL)`
|
||||||
|
*
|
||||||
|
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
||||||
|
*
|
||||||
|
* @param[in] sock The sock the event happened on
|
||||||
|
* @param[in] flags The event flags. Expected values are
|
||||||
|
* - @ref SOCK_ASYNC_CONN_RDY,
|
||||||
|
* - @ref SOCK_ASYNC_CONN_FIN,
|
||||||
|
* - @ref SOCK_ASYNC_MSG_RECV,
|
||||||
|
* - @ref SOCK_ASYNC_MSG_SENT,
|
||||||
|
* - @ref SOCK_ASYNC_PATH_PROP, or
|
||||||
|
* - a combination of them.
|
||||||
|
*/
|
||||||
|
typedef void (*sock_tcp_cb_t)(sock_tcp_t *sock, sock_async_flags_t flags);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Event callback for @ref sock_tcp_queue_t
|
||||||
|
*
|
||||||
|
* @pre `(queue != NULL)`
|
||||||
|
*
|
||||||
|
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
||||||
|
*
|
||||||
|
* @param[in] queue The TCP listening queue the event happened on
|
||||||
|
* @param[in] flags The event flags. The only expected value is @ref
|
||||||
|
* SOCK_ASYNC_CONN_RECV.
|
||||||
|
*/
|
||||||
|
typedef void (*sock_tcp_queue_cb_t)(sock_tcp_queue_t *queue,
|
||||||
|
sock_async_flags_t flags);
|
||||||
|
#endif /* defined(MODULE_SOCK_TCP) || defined(DOXYGEN) */
|
||||||
|
|
||||||
|
#if defined(MODULE_SOCK_UDP) || defined(DOXYGEN)
|
||||||
|
typedef struct sock_udp sock_udp_t; /**< forward declare for async */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Event callback for @ref sock_udp_t
|
||||||
|
*
|
||||||
|
* @pre `(sock != NULL)`
|
||||||
|
*
|
||||||
|
* @note Only applicable with @ref SOCK_HAS_ASYNC defined.
|
||||||
|
*
|
||||||
|
* @param[in] sock The sock the event happened on
|
||||||
|
* @param[in] flags The event flags. Expected values are
|
||||||
|
* - @ref SOCK_ASYNC_MSG_RECV,
|
||||||
|
* - @ref SOCK_ASYNC_MSG_SENT,
|
||||||
|
* - @ref SOCK_ASYNC_PATH_PROP, or
|
||||||
|
* - a combination of them.
|
||||||
|
*/
|
||||||
|
typedef void (*sock_udp_cb_t)(sock_udp_t *sock, sock_async_flags_t type);
|
||||||
|
#endif /* defined(MODULE_SOCK_UDP) || defined(DOXYGEN) */
|
||||||
|
|
||||||
|
#include "sock_types.h"
|
||||||
|
#ifdef MODULE_SOCK_DTLS
|
||||||
|
#include "sock_dtls_types.h"
|
||||||
|
#endif /* MODULE_SOCK_DTLS */
|
||||||
|
#ifdef SOCK_HAS_ASYNC_CTX
|
||||||
|
#include "sock_async_ctx.h"
|
||||||
|
#endif
|
||||||
|
#endif /* defined(SOCK_HAS_ASYNC) || defined(DOXYGEN) */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* NET_SOCK_ASYNC_TYPES_H */
|
||||||
|
/** @} */
|
||||||
Loading…
x
Reference in New Issue
Block a user