diff --git a/Makefile.dep b/Makefile.dep index 60e251a279bbec3b815edab5dbfe005a21355e41..28af0d23198ddf2544acbd6b14b8752ce8e75b2b 100644 --- a/Makefile.dep +++ b/Makefile.dep @@ -302,6 +302,22 @@ ifneq (,$(filter oonf_common,$(USEMODULE))) USEMODULE += socket_base endif +ifneq (,$(filter %_conn_ip,$(USEMODULE))) + USEMODULE += conn_ip +endif + +ifneq (,$(filter %_conn_tcp,$(USEMODULE))) + USEMODULE += conn_tcp +endif + +ifneq (,$(filter %_conn_udp,$(USEMODULE))) + USEMODULE += conn_udp +endif + +ifneq (,$(filter conn_%,$(USEMODULE))) + USEMODULE += conn +endif + # if any log_* is used, also use LOG pseudomodule ifneq (,$(filter log_%,$(USEMODULE))) USEMODULE += log diff --git a/Makefile.pseudomodules b/Makefile.pseudomodules index 1efad80a02344bce2fd17bcc6f8d88dce4b3cde0..86aca801eb73ae249b07af49bbc342fd647acc2a 100644 --- a/Makefile.pseudomodules +++ b/Makefile.pseudomodules @@ -1,3 +1,7 @@ +PSEUDOMODULES += conn +PSEUDOMODULES += conn_ip +PSEUDOMODULES += conn_tcp +PSEUDOMODULES += conn_udp PSEUDOMODULES += gnrc_netif_default PSEUDOMODULES += gnrc_ipv6_default PSEUDOMODULES += gnrc_ipv6_router diff --git a/sys/include/net/conn.h b/sys/include/net/conn.h new file mode 100644 index 0000000000000000000000000000000000000000..bd03991973dbf4e1f43ac9a00068936f85b3c079 --- /dev/null +++ b/sys/include/net/conn.h @@ -0,0 +1,51 @@ +/* + * Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.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_conn Application connection API + * @ingroup net + * @brief Provides a minimal common API for applications to connect to the + * different network stacks. + * + * This module provides a minimal common API for applications to connect over different network + * stacks. For each network stack there is supposed to be at least one connection type + * implementation. Note that this definition gives no restriction on how a connection type should be + * structured for simplicity and modularity. As a result, it can't give any guarantee that an + * implementation keeps them compatible to each other. For example, an implementation might allow, + * that a UDP receive function is called on a raw IPv6 connection object and even choose to do so + * for valid reasons (e.g. code size), but this definition does not impose this on the + * implementation. Currently there are the following option types defined: + * + * * @ref conn_ip_t (net/conn/ip.h): raw IP connections + * * @ref conn_tcp_t (net/conn/tcp.h): TCP connections + * * @ref conn_udp_t (net/conn/udp.h): UDP connections + * + * @{ + * + * @file + * @brief Application connection API definitions + * + * @author Martine Lenders <mlenders@inf.fu-berlin.de> + */ +#ifndef NET_CONN_H_ +#define NET_CONN_H_ + +#include "net/conn/ip.h" +#include "net/conn/tcp.h" +#include "net/conn/udp.h" + +#ifdef __cplusplus +extern "C" { +#endif + +#ifdef __cplusplus +} +#endif + +#endif /* NET_CONN_H_ */ +/** @} */ diff --git a/sys/include/net/conn/ip.h b/sys/include/net/conn/ip.h new file mode 100644 index 0000000000000000000000000000000000000000..061ed967edfd7c507340c4a191f7149f89544218 --- /dev/null +++ b/sys/include/net/conn/ip.h @@ -0,0 +1,124 @@ +/* + * Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.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_conn_ip Raw IPv4/IPv6 connections + * @ingroup net_conn + * @brief Connection submodule for raw IPv4/IPv6 connections + * @{ + * + * @file + * @brief Raw IPv4/IPv6 connection definitions + * + * @author Martine Lenders <mlenders@inf.fu-berlin.de> + */ +#ifndef NET_CONN_IP_H_ +#define NET_CONN_IP_H_ + +#include <stdint.h> +#include <stdlib.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Forward declaration of @ref conn_ip_t to allow for external definition. + */ +struct conn_ip; + +/** + * @brief Implementation-specific type of a raw IPv4/IPv6 connection object + */ +typedef struct conn_ip conn_ip_t; + +/** + * @brief Creates a new raw IPv4/IPv6 connection object + * + * @param[out] conn Preallocated connection object. Must fill the size of the stack-specific + * connection desriptor. + * @param[in] addr The local IP address for @p conn. + * @param[in] addr_len Length of @p addr. Must be fitting for the @p family. + * @param[in] family The family of @p addr (see @ref net_af). + * @param[in] proto @ref net_protnum for the IPv6 packets to receive. + * + * @return 0 on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' bind() function specification. + */ +int conn_ip_create(conn_ip_t *conn, const void *addr, size_t addr_len, int family, int proto); + +/** + * @brief Closes a raw IPv4/IPv6 connection + * + * @param[in,out] conn A raw IPv4/IPv6 connection object. + */ +void conn_ip_close(conn_ip_t *conn); + +/** + * @brief Gets the local address of a raw IPv4/IPv6 connection + * + * @param[in] conn A raw IPv4/IPv6 connection object. + * @param[out] addr The local IP address. Must have space for any address of the connection's + * family. + * + * @return length of @p addr on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' getsockname() function + * specification. + */ +int conn_ip_getlocaladdr(conn_ip_t *conn, void *addr); + +/** + * @brief Receives a message over IPv4/IPv6 + * + * @param[in] conn A raw IPv4/IPv6 connection object. + * @param[out] data Pointer where the received data should be stored. + * @param[in] max_len Maximum space available at @p data. + * @param[out] addr NULL pointer or the sender's IP address. Must have space for any address + * of the connection's family. + * @param[out] addr_len Length of @p addr. Can be NULL if @p addr is NULL. + * + * @note Function may block. + * + * @return The number of bytes received on success. + * @return 0, if no received data is available, but everything is in order. + * @return any other negative number in case of an error. For portability, implementations should + * draw inspiration of the errno values from the POSIX' recv(), recvfrom(), or recvmsg() + * function specification. + */ +int conn_ip_recvfrom(conn_ip_t *conn, void *data, size_t max_len, void *addr, size_t *addr_len); + +/** + * @brief Sends a message over IPv4/IPv6 + * + * @param[in] data Pointer where the received data should be stored. + * @param[in] len Maximum space available at @p data. + * @param[in] src The source address. May be NULL for all any interface address. + * @param[in] src_len Length of @p src. + * @param[in] dst The receiver's network address. + * @param[in] dst_len Length of @p dst. + * @param[in] family The family of @p src and @p dst (see @ref net_af). + * @param[in] proto @ref net_protnum for the IPv6 packets to set. + * + * @note Function may block. + * + * @return The number of bytes send on success. + * @return any other negative number in case of an error. For portability, implementations should + * draw inspiration of the errno values from the POSIX' send(), sendfrom(), or sendmsg() + * function specification. + */ +int conn_ip_sendto(const void *data, size_t len, const void *src, size_t src_len, + void *dst, size_t dst_len, int family, int proto); + +#ifdef __cplusplus +} +#endif + +#endif /* NET_CONN_IP_H_ */ +/** @} */ diff --git a/sys/include/net/conn/tcp.h b/sys/include/net/conn/tcp.h new file mode 100644 index 0000000000000000000000000000000000000000..508e9e74785cad99c739e07849b4281a482548f6 --- /dev/null +++ b/sys/include/net/conn/tcp.h @@ -0,0 +1,173 @@ +/* + * Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.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_conn_tcp TCP connections + * @ingroup net_conn + * @brief Connection submodule for TCP connections + * @{ + * + * @file + * @brief TCP connection definitions + * + * @author Martine Lenders <mlenders@inf.fu-berlin.de> + */ +#ifndef NET_CONN_TCP_H_ +#define NET_CONN_TCP_H_ + +#include <stdint.h> +#include <stdlib.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Forward declaration of @ref conn_tcp_t to allow for external definition. + */ +struct conn_tcp; + +/** + * @brief Implementation-specific type of a TCP connection object + */ +typedef struct conn_tcp conn_tcp_t; + +/** + * @brief Creates a new TCP connection object + * + * @param[out] conn Preallocated connection object. Must fill the size of the stack-specific + * connection desriptor. + * @param[in] addr The local network layer address for @p conn. + * @param[in] addr_len The length of @p addr. Must be fitting for the @p family. + * @param[in] family The family of @p addr (see @ref net_af). + * @param[in] port The local TCP port for @p conn. + * + * @return 0 on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' bind() function specification. + */ +int conn_tcp_create(conn_tcp_t *conn, const void *addr, size_t addr_len, int family, + uint16_t port); + +/** + * @brief Closes a TCP connection + * + * @param[in,out] conn A TCP connection object. + */ +void conn_tcp_close(conn_tcp_t *conn); + +/** + * @brief Gets the local address of a TCP connection + * + * @param[in] conn A TCP connection object. + * @param[out] addr The local network layer address. Must have space for any address of + * the connection's family. + * @param[out] port The local TCP port. + * + * @return length of @p addr on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' getsockname() function + * specification. + */ +int conn_tcp_getlocaladdr(conn_tcp_t *conn, void *addr, uint16_t *port); + +/** + * @brief Gets the address of the connected peer of a TCP connection + * + * @param[in] conn A TCP connection object. + * @param[out] addr The network layer address of the connected peer. Must have space for any + * address of the connection's family. + * @param[out] port The TCP port of the connected peer. + * + * @return length of @p addr on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' getpeername() function + * specification. + */ +int conn_tcp_getpeeraddr(conn_tcp_t *conn, void *addr, uint16_t *port); + +/** + * @brief Connects to a remote TCP peer + * + * @param[in] conn A TCP connection object. + * @param[in] addr The remote network layer address for @p conn. + * @param[in] addr_len Length of @p addr. + * @param[in] port The remote TCP port for @p conn. + * + * @return 0 on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' connect() function specification. + */ +int conn_tcp_connect(conn_tcp_t *conn, const void *addr, size_t addr_len, uint16_t port); + +/** + * @brief Marks connection to listen for a connection request by a remote TCP peer + * + * @param[in] conn A TCP connection object. + * @param[in] queue_len Maximum length of the queue for connection requests. + * An implementation may choose to silently adapt this value to its needs + * (setting it to a minimum or maximum value). Any negative number must be + * set at least to 0. + * + * @return 0 on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' listen() function specification. + */ +int conn_tcp_listen(conn_tcp_t *conn, int queue_len); + +/** + * @brief Receives and handles TCP connection requests from other peers + * + * @param[in] conn A TCP connection object. + * @param[out] out_conn A new TCP connection object for the established connection. + * + * @return 0 on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' accept() function specification. + */ +int conn_tcp_accept(conn_tcp_t *conn, conn_tcp_t *out_conn); + +/** + * @brief Receives a TCP message + * + * @param[in] conn A TCP connection object. + * @param[out] data Pointer where the received data should be stored. + * @param[in] max_len Maximum space available at @p data. + * + * @note Function may block. + * + * @return The number of bytes received on success. + * @return 0, if no received data is available, but everything is in order. + * @return any other negative number in case of an error. For portability, implementations should + * draw inspiration of the errno values from the POSIX' recv(), recvfrom(), or recvmsg() + * function specification. + */ +int conn_tcp_recv(conn_tcp_t *conn, void *data, size_t max_len); + +/** + * @brief Sends a TCP message + * + * @param[in] conn A TCP connection object. + * @param[in] data Pointer where the received data should be stored. + * @param[in] len Maximum space available at @p data. + * + * @note Function may block. + * + * @return The number of bytes send on success. + * @return any other negative number in case of an error. For portability, implementations should + * draw inspiration of the errno values from the POSIX' send(), sendfrom(), or sendmsg() + * function specification. + */ +int conn_tcp_send(conn_tcp_t *conn, const void *data, size_t len); + +#ifdef __cplusplus +} +#endif + +#endif /* NET_CONN_TCP_H_ */ +/** @} */ diff --git a/sys/include/net/conn/udp.h b/sys/include/net/conn/udp.h new file mode 100644 index 0000000000000000000000000000000000000000..a91c9f434617f0598d6a57fae145427f2d435b6d --- /dev/null +++ b/sys/include/net/conn/udp.h @@ -0,0 +1,130 @@ +/* + * Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.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_conn_udp UDP connections + * @ingroup net_conn + * @brief Connection submodule for UDP connections + * @{ + * + * @file + * @brief UDP connection definitions + * + * @author Martine Lenders <mlenders@inf.fu-berlin.de> + */ +#ifndef NET_CONN_UDP_H_ +#define NET_CONN_UDP_H_ + +#include <stdint.h> +#include <stdlib.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Forward declaration of @ref conn_udp_t to allow for external definition. + */ +struct conn_udp; + +/** + * @brief Implementation-specific type of a UDP connection object + */ +typedef struct conn_udp conn_udp_t; + +/** + * @brief Creates a new UDP connection object + * + * @param[out] conn Preallocated connection object. Must fill the size of the stack-specific + * connection desriptor. + * @param[in] addr The local network layer address for @p conn. + * @param[in] addr_len The length of @p addr. Must be fitting for the @p family. + * @param[in] family The family of @p addr (see @ref net_af). + * @param[in] port The local UDP port for @p conn. + * + * @return 0 on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' bind() function specification. + */ +int conn_udp_create(conn_udp_t *conn, const void *addr, size_t addr_len, int family, + uint16_t port); + +/** + * @brief Closes a UDP connection + * + * @param[in,out] conn A UDP connection object. + */ +void conn_udp_close(conn_udp_t *conn); + +/** + * @brief Gets the local address of a UDP connection + * + * @param[in] conn A UDP connection object. + * @param[out] addr The local network layer address. Must have space for any address of + * the connection's family. + * @param[out] port The local UDP port. + * + * @return length of @p addr on success. + * @return any other negative number in case of an error. For portability implementations should + * draw inspiration of the errno values from the POSIX' getsockname() function + * specification. + */ +int conn_udp_getlocaladdr(conn_udp_t *conn, void *addr, uint16_t *port); + +/** + * @brief Receives a UDP message + * + * @param[in] conn A UDP connection object. + * @param[out] data Pointer where the received data should be stored. + * @param[in] max_len Maximum space available at @p data. + * @param[out] addr NULL pointer or the sender's network layer address. Must have space + * for any address of the connection's family. + * @param[out] addr_len Length of @p addr. Can be NULL if @p addr is NULL. + * @param[out] port NULL pointer or the sender's UDP port. + * + * @note Function may block. + * + * @return The number of bytes received on success. + * @return 0, if no received data is available, but everything is in order. + * @return any other negative number in case of an error. For portability, implementations should + * draw inspiration of the errno values from the POSIX' recv(), recvfrom(), or recvmsg() + * function specification. + */ +int conn_udp_recvfrom(conn_udp_t *conn, void *data, size_t max_len, void *addr, size_t *addr_len, + uint16_t *port); + +/** + * @brief Sends a UDP message + * + * @param[in] data Pointer where the received data should be stored. + * @param[in] len Maximum space available at @p data. + * @param[in] src The source address. May be NULL for all any interface address. + * @param[in] src_len Length of @p src. May be 0 if @p src is NULL + * @param[in] dst The receiver's network address. + * @param[in] dst_len Length of @p dst. + * @param[in] family The family of @p src and @p dst (see @ref net_af). + * @param[in] sport The source UDP port. + * @param[in] dport The receiver's UDP port. + * + * @note Function may block. + * + * @return The number of bytes send on success. + * @return any other negative number in case of an error. For portability, implementations should + * draw inspiration of the errno values from the POSIX' send(), sendfrom(), or sendmsg() + * function specification. + */ +int conn_udp_sendto(const void *data, size_t len, const void *src, size_t src_len, + const void *dst, size_t dst_len, int family, uint16_t sport, + uint16_t dport); + +#ifdef __cplusplus +} +#endif + +#endif /* NET_CONN_UDP4_H_ */ +/** @} */