2016-06-04 12:18:13 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Alexander Aring <aar@pengutronix.de>
|
|
|
|
* Freie Universität Berlin
|
|
|
|
* HAW Hamburg
|
|
|
|
* Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* 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_udp UDP sock API
|
|
|
|
* @ingroup net_sock
|
|
|
|
* @brief Sock submodule for UDP
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief UDP sock definitions
|
|
|
|
*
|
|
|
|
* @author Alexander Aring <aar@pengutronix.de>
|
|
|
|
* @author Simon Brummer <simon.brummer@haw-hamburg.de>
|
|
|
|
* @author Cenk Gündoğan <mail@cgundogan.de>
|
|
|
|
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
|
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
|
|
|
#ifndef NET_SOCK_UDP_H_
|
|
|
|
#define NET_SOCK_UDP_H_
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdlib.h>
|
2016-08-19 16:17:35 +02:00
|
|
|
#include <sys/types.h>
|
2016-06-04 12:18:13 +02:00
|
|
|
|
2016-08-19 17:36:58 +02:00
|
|
|
#include "net/sock.h"
|
2016-06-04 12:18:13 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2016-08-20 02:33:22 +02:00
|
|
|
typedef struct _sock_tl_ep sock_udp_ep_t; /**< An end point for a UDP sock object */
|
2016-06-04 12:18:13 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Implementation-specific type of a UDP sock object
|
|
|
|
*
|
2016-08-19 16:17:35 +02:00
|
|
|
* `struct sock_udp` needs to be defined by stack-specific `sock_types.h`.
|
2016-06-04 12:18:13 +02:00
|
|
|
*/
|
|
|
|
typedef struct sock_udp sock_udp_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Creates a new UDP sock object
|
|
|
|
*
|
|
|
|
* @pre `(sock != NULL)`
|
|
|
|
* @pre `(local == NULL) || (local->port != 0)`
|
|
|
|
* @pre `(remote == NULL) || (remote->port != 0)`
|
|
|
|
*
|
2016-08-20 02:39:51 +02:00
|
|
|
* @param[out] sock The resulting sock object.
|
2016-06-04 12:18:13 +02:00
|
|
|
* @param[in] local Local end point for the sock object.
|
|
|
|
* May be `NULL` to solicit implicit bind on
|
|
|
|
* @ref sock_udp_send().
|
|
|
|
* sock_udp_ep_t::port may not be 0 if `local != NULL`.
|
|
|
|
* sock_udp_ep_t::netif must either be
|
|
|
|
* @ref SOCK_ADDR_ANY_NETIF or equal to sock_udp_ep_t::netif
|
|
|
|
* of @p remote if `remote != NULL`.
|
|
|
|
* @param[in] remote Remote end point for the sock object.
|
|
|
|
* May be `NULL` but then the `remote` parameter of
|
|
|
|
* @ref sock_udp_send() may not be `NULL` and or it will
|
|
|
|
* always error with return value -ENOTCONN.
|
|
|
|
* sock_udp_ep_t::port may not be 0 if `remote != NULL`.
|
|
|
|
* sock_udp_ep_t::netif must either be
|
|
|
|
* @ref SOCK_ADDR_ANY_NETIF or equal to sock_udp_ep_t::netif
|
|
|
|
* of @p local if `local != NULL`.
|
|
|
|
* @param[in] flags Flags for the sock object. See also @ref net_sock_flags.
|
2016-08-19 15:27:15 +02:00
|
|
|
* May be 0.
|
2016-06-04 12:18:13 +02:00
|
|
|
*
|
|
|
|
* @return 0 on success.
|
2016-08-25 17:55:08 +02:00
|
|
|
* @return -EADDRINUSE, if `local != NULL` and the stack reports that @p local
|
|
|
|
* is already used elsewhere
|
2016-06-04 12:18:13 +02:00
|
|
|
* @return -EAFNOSUPPORT, if `local != NULL` or `remote != NULL` and
|
|
|
|
* sock_udp_ep_t::family of @p local or @p remote is not supported.
|
|
|
|
* @return -EINVAL, if sock_udp_ep_t::netif of @p local or @p remote is not a
|
|
|
|
* valid interface or contradict each other (i.e.
|
|
|
|
* `(local->netif != remote->netif) &&
|
|
|
|
* ((local->netif != SOCK_ADDR_ANY_NETIF) ||
|
|
|
|
* (remote->netif != SOCK_ADDR_ANY_NETIF))` if neither is `NULL`).
|
|
|
|
* `
|
|
|
|
*/
|
|
|
|
int sock_udp_create(sock_udp_t *sock, const sock_udp_ep_t *local,
|
2016-08-19 17:36:58 +02:00
|
|
|
const sock_udp_ep_t *remote, uint16_t flags);
|
2016-06-04 12:18:13 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Closes a UDP sock object
|
|
|
|
*
|
|
|
|
* @pre `(sock != NULL)`
|
|
|
|
*
|
|
|
|
* @param[in] sock A UDP sock object.
|
|
|
|
*/
|
|
|
|
void sock_udp_close(sock_udp_t *sock);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the local end point of a UDP sock object
|
|
|
|
*
|
|
|
|
* @pre `(sock != NULL) && (ep != NULL)`
|
|
|
|
*
|
|
|
|
* @param[in] sock A UDP sock object.
|
|
|
|
* @param[out] ep The local end point.
|
|
|
|
*
|
|
|
|
* @return 0 on success.
|
|
|
|
* @return -EADDRNOTAVAIL, when @p sock has no local end point.
|
|
|
|
*/
|
|
|
|
int sock_udp_get_local(sock_udp_t *sock, sock_udp_ep_t *ep);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the remote end point of a UDP sock object
|
|
|
|
*
|
|
|
|
* @pre `(sock != NULL) && (ep != NULL)`
|
|
|
|
*
|
|
|
|
* @param[in] sock A UDP sock object.
|
|
|
|
* @param[out] ep The remote end point.
|
|
|
|
*
|
|
|
|
* @return 0 on success.
|
|
|
|
* @return -ENOTCONN, when @p sock has no remote end point bound to it.
|
|
|
|
*/
|
|
|
|
int sock_udp_get_remote(sock_udp_t *sock, sock_udp_ep_t *ep);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Receives a UDP message from a remote end point
|
|
|
|
*
|
|
|
|
* @pre `(sock != NULL) && (data != NULL) && (max_len > 0)`
|
|
|
|
*
|
|
|
|
* @param[in] sock A raw IPv4/IPv6 sock object.
|
|
|
|
* @param[out] data Pointer where the received data should be stored.
|
|
|
|
* @param[in] max_len Maximum space available at @p data.
|
|
|
|
* If received data exceeds @p max_len the data is
|
|
|
|
* truncated and the remaining data can be retrieved
|
|
|
|
* later on.
|
|
|
|
* @param[in] timeout Timeout for receive in microseconds.
|
|
|
|
* This value can be ignored (no timeout) if the
|
|
|
|
* @ref sys_xtimer module is not present and the stack does
|
|
|
|
* not support timeouts on its own.
|
|
|
|
* May be 0 for no timeout.
|
|
|
|
* Must be 0 if @ref sys_xtimer module is not present.
|
|
|
|
* @param[out] remote Remote end point of the received data.
|
|
|
|
* May be `NULL`, if it is not required by the application.
|
|
|
|
*
|
|
|
|
* @note Function blocks if no packet is currently waiting.
|
|
|
|
*
|
|
|
|
* @return The number of bytes received on success.
|
|
|
|
* @return 0, if no received data is available, but everything is in order.
|
|
|
|
* @return -EADDRNOTAVAIL, if local of @p sock is not given.
|
|
|
|
* @return -ENOBUFS, if buffer space is not large enough to store received
|
|
|
|
* data.
|
|
|
|
* @return -EPROTO, if source address of received packet did not equal
|
|
|
|
* the remote of @p sock.
|
|
|
|
* @return -ETIMEDOUT, if @p timeout expired.
|
|
|
|
*/
|
2016-08-19 16:17:35 +02:00
|
|
|
ssize_t sock_udp_recv(sock_udp_t *sock, void *data, size_t max_len,
|
|
|
|
uint32_t timeout, sock_udp_ep_t *remote);
|
2016-06-04 12:18:13 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sends a UDP message to remote end point
|
|
|
|
*
|
|
|
|
* @pre `((sock != NULL || remote != NULL)) && (if (len != 0): (data != NULL))`
|
|
|
|
*
|
|
|
|
* @param[in] sock A raw IPv4/IPv6 sock object. May be `NULL`.
|
|
|
|
* A sensible local end point should be selected by the
|
|
|
|
* stack in that case.
|
|
|
|
* @param[in] data Pointer where the received data should be stored.
|
|
|
|
* May be `NULL` if `len == 0`.
|
|
|
|
* @param[in] len Maximum space available at @p data.
|
|
|
|
* @param[in] remote Remote end point for the send data.
|
|
|
|
* May be `NULL`, if @p sock has a remote end point.
|
|
|
|
* sock_udp_ep_t::family may be AF_UNSPEC, if local
|
|
|
|
* end point of @p sock provides this information.
|
|
|
|
* sock_udp_ep_t::port may not be 0.
|
|
|
|
*
|
|
|
|
* @note Function blocks until packet is handed to the stack.
|
|
|
|
*
|
|
|
|
* @return The number of bytes sent on success.
|
|
|
|
* @return -EAFNOSUPPORT, if `remote != NULL` and sock_udp_ep_t::family of
|
|
|
|
* @p remote is != AF_UNSPEC and not supported.
|
|
|
|
* @return -EINVAL, if sock_udp_ep_t::netif of @p remote is not a valid
|
|
|
|
* interface or contradicts the given local interface (i.e.
|
|
|
|
* neither the local end point of `sock` nor remote are assigned to
|
|
|
|
* `SOCK_ADDR_ANY_NETIF` but are nevertheless different.
|
|
|
|
* @return -EINVAL, if sock_udp_ep_t::port of @p remote is 0.
|
|
|
|
* @return -ENOMEM, if no memory was available to send @p data.
|
|
|
|
* @return -ENOTCONN, if `remote == NULL`, but @p sock has no remote end point.
|
|
|
|
*/
|
2016-08-19 16:17:35 +02:00
|
|
|
ssize_t sock_udp_send(sock_udp_t *sock, const void *data, size_t len,
|
|
|
|
const sock_udp_ep_t *remote);
|
2016-06-04 12:18:13 +02:00
|
|
|
|
2016-08-19 16:17:35 +02:00
|
|
|
#include "sock_types.h"
|
2016-06-04 12:18:13 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* NET_SOCK_UDP_H_ */
|
|
|
|
/** @} */
|