Loading...
Searching...
No Matches
tcp.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2015-2017 Simon Brummer
3 *
4 * This file is subject to the terms and conditions of the GNU Lesser
5 * General Public License v2.1. See the file LICENSE in the top level
6 * directory for more details.
7 */
8
9#pragma once
10
23
24#include <stdint.h>
25
26#include "compiler_hints.h"
27#include "net/gnrc/pkt.h"
28#include "net/gnrc/tcp/tcb.h"
29
30#ifdef SOCK_HAS_IPV6
31# include "net/sock.h"
32#else
33# ifdef MODULE_GNRC_IPV6
34# include "net/gnrc/ipv6.h"
35# endif
36#endif
37
38#ifdef __cplusplus
39extern "C" {
40#endif
41
42/* Note: This value if configurable for test purposes. Do not override it.
43 * Changing this value may lead to errors that are hard to track down.
44 */
45#ifndef GNRC_TCP_NO_TIMEOUT
49#define GNRC_TCP_NO_TIMEOUT (UINT32_MAX)
50#endif
51
52#ifdef SOCK_HAS_IPV6
53/* Reuse sock endpoint if sock is available and supporting IPv6. */
54typedef struct _sock_tl_ep gnrc_tcp_ep_t;
55
56#else
61typedef struct {
62 int family;
63 union {
64#ifdef MODULE_GNRC_IPV6
65 uint8_t ipv6[sizeof(ipv6_addr_t)];
66#endif
67 uint8_t dummy;
68 } addr;
69 uint16_t netif;
70 uint16_t port;
72#endif
73
88ACCESS(read_only, 3, 4)
89int gnrc_tcp_ep_init(gnrc_tcp_ep_t *ep, int family, const uint8_t *addr, size_t addr_size,
90 uint16_t port, uint16_t netif);
91
106int gnrc_tcp_ep_from_str(gnrc_tcp_ep_t *ep, const char *str);
107
117
125
133
160int gnrc_tcp_open(gnrc_tcp_tcb_t *tcb, const gnrc_tcp_ep_t *remote, uint16_t local_port);
161
184int gnrc_tcp_listen(gnrc_tcp_tcb_queue_t *queue, gnrc_tcp_tcb_t *tcbs, size_t tcbs_len,
185 const gnrc_tcp_ep_t *local);
186
209 const uint32_t user_timeout_duration_ms);
210
236ACCESS(read_only, 2, 3)
237ssize_t gnrc_tcp_send(gnrc_tcp_tcb_t *tcb, const void *data, const size_t len,
238 const uint32_t user_timeout_duration_ms);
239
271ACCESS(write_only, 2, 3)
272ssize_t gnrc_tcp_recv(gnrc_tcp_tcb_t *tcb, void *data, size_t max_len,
273 uint32_t user_timeout_duration_ms);
274
284
294
306
320
334
348
360int gnrc_tcp_calc_csum(const gnrc_pktsnip_t *hdr, const gnrc_pktsnip_t *pseudo_hdr);
361
372gnrc_pktsnip_t *gnrc_tcp_hdr_build(gnrc_pktsnip_t *payload, uint16_t src, uint16_t dst);
373
374#ifdef __cplusplus
375}
376#endif
377
Common macros and compiler attributes/pragmas configuration.
#define ACCESS(mode, ptr_idx, size_idx)
Emit an attribute (if supported by the compiler) that declares how a function will access its paramet...
Definitions for GNRC's IPv6 implementation.
struct gnrc_pktsnip gnrc_pktsnip_t
Type to represent parts (either headers or payload) of a packet, called snips.
void gnrc_tcp_close(gnrc_tcp_tcb_t *tcb)
Close a TCP connection.
void gnrc_tcp_tcb_queue_init(gnrc_tcp_tcb_queue_t *queue)
Initialize Transmission Control Block (TCB) queue.
void gnrc_tcp_stop_listen(gnrc_tcp_tcb_queue_t *queue)
Close connections and stop listening on TCB queue.
int gnrc_tcp_init(void)
Initialize TCP.
int gnrc_tcp_queue_get_local(gnrc_tcp_tcb_queue_t *queue, gnrc_tcp_ep_t *ep)
Gets the local end point of a TCB queue.
int gnrc_tcp_calc_csum(const gnrc_pktsnip_t *hdr, const gnrc_pktsnip_t *pseudo_hdr)
Calculate and set checksum in TCP header.
int gnrc_tcp_get_local(gnrc_tcp_tcb_t *tcb, gnrc_tcp_ep_t *ep)
Get the local end point of a connected TCB.
int gnrc_tcp_accept(gnrc_tcp_tcb_queue_t *queue, gnrc_tcp_tcb_t **tcb, const uint32_t user_timeout_duration_ms)
Accept TCP connection from listening queue.
int gnrc_tcp_ep_init(gnrc_tcp_ep_t *ep, int family, const uint8_t *addr, size_t addr_size, uint16_t port, uint16_t netif)
Initialize TCP connection endpoint.
int gnrc_tcp_ep_from_str(gnrc_tcp_ep_t *ep, const char *str)
Construct TCP connection endpoint from string.
int gnrc_tcp_get_remote(gnrc_tcp_tcb_t *tcb, gnrc_tcp_ep_t *ep)
Get the remote end point of a connected TCB.
int gnrc_tcp_listen(gnrc_tcp_tcb_queue_t *queue, gnrc_tcp_tcb_t *tcbs, size_t tcbs_len, const gnrc_tcp_ep_t *local)
Configures a sequence of TCBs to wait for incoming connections.
void gnrc_tcp_abort(gnrc_tcp_tcb_t *tcb)
Abort a TCP connection.
gnrc_pktsnip_t * gnrc_tcp_hdr_build(gnrc_pktsnip_t *payload, uint16_t src, uint16_t dst)
Adds a TCP header to a given payload.
ssize_t gnrc_tcp_recv(gnrc_tcp_tcb_t *tcb, void *data, size_t max_len, uint32_t user_timeout_duration_ms)
Receive Data from the peer.
int gnrc_tcp_open(gnrc_tcp_tcb_t *tcb, const gnrc_tcp_ep_t *remote, uint16_t local_port)
Opens a connection.
void gnrc_tcp_tcb_init(gnrc_tcp_tcb_t *tcb)
Initialize Transmission Control Block (TCB)
ssize_t gnrc_tcp_send(gnrc_tcp_tcb_t *tcb, const void *data, const size_t len, const uint32_t user_timeout_duration_ms)
Transmit data to connected peer.
General definitions for network packets and their helper functions.
Common sock API definitions.
Common IP-based transport layer end point.
Definition sock.h:214
union _sock_tl_ep::@145104007015077003173063335316042002054250273140 addr
address
Address information for a single TCP connection endpoint.
Definition tcp.h:61
uint16_t netif
Network interface ID.
Definition tcp.h:69
uint8_t ipv6[sizeof(ipv6_addr_t)]
IPv6 address storage.
Definition tcp.h:65
int family
IP address family.
Definition tcp.h:62
uint16_t port
Port number (in host byte order)
Definition tcp.h:70
uint8_t dummy
Enable build without network module.
Definition tcp.h:67
GNRC TCP transmission control block (TCB)
struct sock_tcp_queue gnrc_tcp_tcb_queue_t
Transmission control block queue.
struct sock_tcp gnrc_tcp_tcb_t
Transmission control block of GNRC TCP.
Data type to represent an IPv6 address.
Definition addr.h:67