2016-08-18 09:08:04 +02:00
|
|
|
/** @file
|
|
|
|
@brief TCP data handler
|
|
|
|
|
|
|
|
This is not to be included by the application.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2016 Intel Corporation
|
|
|
|
*
|
2017-01-19 02:01:01 +01:00
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
2016-08-18 09:08:04 +02:00
|
|
|
*/
|
|
|
|
|
2018-03-02 23:20:51 +01:00
|
|
|
#ifndef __TCP_INTERNAL_H
|
|
|
|
#define __TCP_INTERNAL_H
|
2016-08-18 09:08:04 +02:00
|
|
|
|
Introduce new sized integer typedefs
This is a start to move away from the C99 {u}int{8,16,32,64}_t types to
Zephyr defined u{8,16,32,64}_t and s{8,16,32,64}_t. This allows Zephyr
to define the sized types in a consistent manor across all the
architectures we support and not conflict with what various compilers
and libc might do with regards to the C99 types.
We introduce <zephyr/types.h> as part of this and have it include
<stdint.h> for now until we transition all the code away from the C99
types.
We go with u{8,16,32,64}_t and s{8,16,32,64}_t as there are some
existing variables defined u8 & u16 as well as to be consistent with
Zephyr naming conventions.
Jira: ZEP-2051
Change-Id: I451fed0623b029d65866622e478225dfab2c0ca8
Signed-off-by: Kumar Gala <kumar.gala@linaro.org>
2017-04-19 17:32:08 +02:00
|
|
|
#include <zephyr/types.h>
|
2023-10-07 00:38:53 +02:00
|
|
|
#include <zephyr/random/random.h>
|
2016-08-18 09:08:04 +02:00
|
|
|
|
2022-05-06 11:12:04 +02:00
|
|
|
#include <zephyr/net/net_core.h>
|
|
|
|
#include <zephyr/net/net_ip.h>
|
|
|
|
#include <zephyr/net/net_pkt.h>
|
|
|
|
#include <zephyr/net/net_context.h>
|
2016-08-18 09:08:04 +02:00
|
|
|
|
|
|
|
#include "connection.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-11-07 11:19:39 +01:00
|
|
|
|
2021-11-10 14:39:42 +01:00
|
|
|
#include "tcp_private.h"
|
2020-11-07 11:19:39 +01:00
|
|
|
|
2022-06-06 22:00:01 +02:00
|
|
|
enum tcp_conn_option {
|
|
|
|
TCP_OPT_NODELAY = 1,
|
2023-12-08 10:54:13 +01:00
|
|
|
TCP_OPT_KEEPALIVE = 2,
|
|
|
|
TCP_OPT_KEEPIDLE = 3,
|
|
|
|
TCP_OPT_KEEPINTVL = 4,
|
|
|
|
TCP_OPT_KEEPCNT = 5,
|
2022-06-06 22:00:01 +02:00
|
|
|
};
|
|
|
|
|
2018-03-20 14:06:45 +01:00
|
|
|
/**
|
2020-11-07 11:19:39 +01:00
|
|
|
* @brief Calculates and returns the MSS for a given TCP context
|
2018-03-20 14:06:45 +01:00
|
|
|
*
|
2020-11-07 11:19:39 +01:00
|
|
|
* @param tcp TCP context
|
2018-03-20 14:06:45 +01:00
|
|
|
*
|
2020-11-07 11:19:39 +01:00
|
|
|
* @return Maximum Segment Size
|
2018-03-20 14:06:45 +01:00
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2022-05-23 08:36:28 +02:00
|
|
|
uint16_t net_tcp_get_supported_mss(const struct tcp *conn);
|
2019-02-14 14:33:22 +01:00
|
|
|
#else
|
2022-05-23 08:36:28 +02:00
|
|
|
static inline uint16_t net_tcp_get_supported_mss(const struct tcp *conn)
|
2019-02-14 14:33:22 +01:00
|
|
|
{
|
2020-11-07 11:19:39 +01:00
|
|
|
ARG_UNUSED(conn);
|
|
|
|
return 0;
|
2019-02-14 14:33:22 +01:00
|
|
|
}
|
|
|
|
#endif
|
2018-03-20 14:06:48 +01:00
|
|
|
|
2020-11-07 11:19:39 +01:00
|
|
|
const char *net_tcp_state_str(enum tcp_state state);
|
|
|
|
|
2018-03-20 14:06:48 +01:00
|
|
|
/**
|
2020-11-07 11:19:39 +01:00
|
|
|
* @brief Obtains the state for a TCP context
|
2018-03-20 14:06:48 +01:00
|
|
|
*
|
2020-11-07 11:19:39 +01:00
|
|
|
* @param tcp TCP context
|
2018-03-20 14:06:48 +01:00
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2020-11-07 11:19:39 +01:00
|
|
|
static inline enum tcp_state net_tcp_get_state(const struct tcp *conn)
|
|
|
|
{
|
|
|
|
return conn->state;
|
|
|
|
}
|
2019-02-14 14:33:22 +01:00
|
|
|
#else
|
2020-11-07 11:19:39 +01:00
|
|
|
static inline enum tcp_state net_tcp_get_state(const struct tcp *conn)
|
2019-02-14 14:33:22 +01:00
|
|
|
{
|
2020-11-07 11:19:39 +01:00
|
|
|
ARG_UNUSED(conn);
|
|
|
|
return TCP_CLOSED;
|
|
|
|
}
|
|
|
|
#endif
|
2019-02-14 14:33:22 +01:00
|
|
|
|
2020-11-07 11:19:39 +01:00
|
|
|
/**
|
|
|
|
* @brief Go through all the TCP connections and call callback
|
|
|
|
* for each of them.
|
|
|
|
*
|
|
|
|
* @param cb User supplied callback function to call.
|
|
|
|
* @param user_data User specified data.
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
void net_tcp_foreach(net_tcp_cb_t cb, void *user_data);
|
|
|
|
#else
|
|
|
|
static inline void net_tcp_foreach(net_tcp_cb_t cb, void *user_data)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(cb);
|
|
|
|
ARG_UNUSED(user_data);
|
2019-02-14 14:33:22 +01:00
|
|
|
}
|
|
|
|
#endif
|
2018-03-20 14:06:48 +01:00
|
|
|
|
2018-03-20 14:06:49 +01:00
|
|
|
/**
|
2020-11-07 11:19:39 +01:00
|
|
|
* @brief Initialize TCP parts of a context
|
2018-03-20 14:06:49 +01:00
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
2020-11-07 11:19:39 +01:00
|
|
|
* @return 0 if successful, < 0 on error
|
2018-03-20 14:06:49 +01:00
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2020-11-07 11:19:39 +01:00
|
|
|
int net_tcp_get(struct net_context *context);
|
2019-02-14 14:33:22 +01:00
|
|
|
#else
|
2020-11-07 11:19:39 +01:00
|
|
|
static inline int net_tcp_get(struct net_context *context)
|
2019-02-14 14:33:22 +01:00
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
2018-03-20 14:06:49 +01:00
|
|
|
|
2018-03-21 11:14:07 +01:00
|
|
|
/**
|
2020-11-07 11:19:39 +01:00
|
|
|
* @brief Connect TCP connection
|
2018-03-21 11:14:07 +01:00
|
|
|
*
|
|
|
|
* @param context Network context
|
2020-11-07 11:19:39 +01:00
|
|
|
* @param addr Remote address
|
|
|
|
* @param laddr Local address
|
|
|
|
* @param rport Remote port
|
|
|
|
* @param lport Local port
|
|
|
|
* @param timeout Connect timeout
|
|
|
|
* @param cb Connect callback
|
|
|
|
* @param user_data Connect callback user data
|
2018-03-21 11:14:07 +01:00
|
|
|
*
|
2020-11-07 11:19:39 +01:00
|
|
|
* @return 0 on success, < 0 on error
|
2018-03-21 11:14:07 +01:00
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2020-11-07 11:19:39 +01:00
|
|
|
int net_tcp_connect(struct net_context *context,
|
|
|
|
const struct sockaddr *addr,
|
|
|
|
struct sockaddr *laddr,
|
|
|
|
uint16_t rport,
|
|
|
|
uint16_t lport,
|
|
|
|
k_timeout_t timeout,
|
|
|
|
net_context_connect_cb_t cb,
|
|
|
|
void *user_data);
|
2019-02-14 14:33:22 +01:00
|
|
|
#else
|
2020-11-07 11:19:39 +01:00
|
|
|
static inline int net_tcp_connect(struct net_context *context,
|
|
|
|
const struct sockaddr *addr,
|
|
|
|
struct sockaddr *laddr,
|
|
|
|
uint16_t rport, uint16_t lport,
|
|
|
|
k_timeout_t timeout,
|
|
|
|
net_context_connect_cb_t cb, void *user_data)
|
2019-02-14 14:33:22 +01:00
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
2020-11-07 11:19:39 +01:00
|
|
|
ARG_UNUSED(addr);
|
|
|
|
ARG_UNUSED(laddr);
|
|
|
|
ARG_UNUSED(rport);
|
|
|
|
ARG_UNUSED(lport);
|
|
|
|
ARG_UNUSED(cb);
|
|
|
|
ARG_UNUSED(user_data);
|
2019-02-14 14:33:22 +01:00
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
2018-03-21 11:14:07 +01:00
|
|
|
|
|
|
|
/**
|
2020-11-07 11:19:39 +01:00
|
|
|
* @brief Set TCP socket into listening state
|
2018-03-21 11:14:07 +01:00
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
2020-11-07 11:19:39 +01:00
|
|
|
* @return 0 if successful, -EOPNOTSUPP if the context was not for TCP,
|
|
|
|
* -EPROTONOSUPPORT if TCP is not supported
|
2018-03-21 11:14:07 +01:00
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2020-11-07 11:19:39 +01:00
|
|
|
int net_tcp_listen(struct net_context *context);
|
2019-02-14 14:33:22 +01:00
|
|
|
#else
|
2020-11-07 11:19:39 +01:00
|
|
|
static inline int net_tcp_listen(struct net_context *context)
|
2019-02-14 14:33:22 +01:00
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
2018-03-21 11:14:07 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Accept TCP connection
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
* @param cb Accept callback
|
|
|
|
* @param user_data Accept callback user data
|
|
|
|
*
|
|
|
|
* @return 0 on success, < 0 on error
|
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2018-03-21 11:14:07 +01:00
|
|
|
int net_tcp_accept(struct net_context *context, net_tcp_accept_cb_t cb,
|
|
|
|
void *user_data);
|
2019-02-14 14:33:22 +01:00
|
|
|
#else
|
|
|
|
static inline int net_tcp_accept(struct net_context *context,
|
|
|
|
net_tcp_accept_cb_t cb, void *user_data)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
ARG_UNUSED(cb);
|
|
|
|
ARG_UNUSED(user_data);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
2018-03-21 11:14:07 +01:00
|
|
|
|
|
|
|
/**
|
2020-11-07 11:19:39 +01:00
|
|
|
* @brief Send available queued data over TCP connection
|
|
|
|
*
|
|
|
|
* @param context TCP context
|
|
|
|
* @param cb TCP callback function
|
|
|
|
* @param user_data User specified data
|
|
|
|
*
|
|
|
|
* @return 0 if ok, < 0 if error
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
int net_tcp_send_data(struct net_context *context, net_context_send_cb_t cb,
|
|
|
|
void *user_data);
|
|
|
|
#else
|
|
|
|
static inline int net_tcp_send_data(struct net_context *context,
|
|
|
|
net_context_send_cb_t cb,
|
|
|
|
void *user_data)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
ARG_UNUSED(cb);
|
|
|
|
ARG_UNUSED(user_data);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief TCP receive function
|
2018-03-21 11:14:07 +01:00
|
|
|
*
|
|
|
|
* @param context Network context
|
2020-11-07 11:19:39 +01:00
|
|
|
* @param cb TCP receive callback function
|
|
|
|
* @param user_data TCP receive callback user data
|
2018-03-21 11:14:07 +01:00
|
|
|
*
|
2022-03-16 22:07:43 +01:00
|
|
|
* @return 0 if no error, < 0 in case of error
|
2018-03-21 11:14:07 +01:00
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2020-11-07 11:19:39 +01:00
|
|
|
int net_tcp_recv(struct net_context *context, net_context_recv_cb_t cb,
|
|
|
|
void *user_data);
|
2017-06-30 16:51:30 +02:00
|
|
|
#else
|
2020-11-07 11:19:39 +01:00
|
|
|
static inline int net_tcp_recv(struct net_context *context,
|
|
|
|
net_context_recv_cb_t cb, void *user_data)
|
2018-03-21 11:14:07 +01:00
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
ARG_UNUSED(cb);
|
|
|
|
ARG_UNUSED(user_data);
|
|
|
|
|
2020-11-07 11:19:39 +01:00
|
|
|
return -EPROTOTYPE;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Finalize TCP packet
|
|
|
|
*
|
|
|
|
* @param pkt Network packet
|
|
|
|
*
|
|
|
|
* @return 0 on success, negative errno otherwise.
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2023-10-12 15:49:00 +02:00
|
|
|
int net_tcp_finalize(struct net_pkt *pkt, bool force_chksum);
|
2020-11-07 11:19:39 +01:00
|
|
|
#else
|
2023-10-12 15:49:00 +02:00
|
|
|
static inline int net_tcp_finalize(struct net_pkt *pkt, bool force_chksum)
|
2020-11-07 11:19:39 +01:00
|
|
|
{
|
|
|
|
ARG_UNUSED(pkt);
|
2023-10-12 15:49:00 +02:00
|
|
|
ARG_UNUSED(force_chksum);
|
2020-11-07 11:19:39 +01:00
|
|
|
return 0;
|
2018-03-21 11:14:07 +01:00
|
|
|
}
|
2019-02-14 14:33:22 +01:00
|
|
|
#endif
|
2018-03-21 11:14:07 +01:00
|
|
|
|
2019-02-14 14:33:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Get pointer to TCP header in net_pkt
|
|
|
|
*
|
|
|
|
* @param pkt Network packet
|
|
|
|
* @param tcp_access Helper variable for accessing TCP header
|
|
|
|
*
|
|
|
|
* @return TCP header on success, NULL on error
|
|
|
|
*/
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2019-02-14 14:33:22 +01:00
|
|
|
struct net_tcp_hdr *net_tcp_input(struct net_pkt *pkt,
|
|
|
|
struct net_pkt_data_access *tcp_access);
|
|
|
|
#else
|
2018-12-13 21:38:07 +01:00
|
|
|
static inline
|
|
|
|
struct net_tcp_hdr *net_tcp_input(struct net_pkt *pkt,
|
|
|
|
struct net_pkt_data_access *tcp_access)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(pkt);
|
|
|
|
ARG_UNUSED(tcp_access);
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
2017-06-30 16:51:30 +02:00
|
|
|
#endif
|
|
|
|
|
2020-11-07 11:19:39 +01:00
|
|
|
/**
|
2023-11-14 12:40:49 +01:00
|
|
|
* @brief Enqueue data for transmission
|
2020-11-07 11:19:39 +01:00
|
|
|
*
|
2023-11-14 12:40:49 +01:00
|
|
|
* @param context Network context
|
|
|
|
* @param data Pointer to the data
|
|
|
|
* @param len Number of bytes
|
|
|
|
* @param msg Data for a vector array operation
|
2020-11-07 11:19:39 +01:00
|
|
|
*
|
|
|
|
* @return 0 if ok, < 0 if error
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2023-11-14 12:40:49 +01:00
|
|
|
int net_tcp_queue(struct net_context *context, const void *data, size_t len,
|
|
|
|
const struct msghdr *msg);
|
2020-11-07 11:19:39 +01:00
|
|
|
#else
|
2023-11-14 12:40:49 +01:00
|
|
|
static inline int net_tcp_queue(struct net_context *context, const void *data,
|
|
|
|
size_t len, const struct msghdr *msg)
|
2020-11-07 11:19:39 +01:00
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
2023-11-14 12:40:49 +01:00
|
|
|
ARG_UNUSED(data);
|
|
|
|
ARG_UNUSED(len);
|
|
|
|
ARG_UNUSED(msg);
|
|
|
|
|
2020-11-07 11:19:39 +01:00
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Update TCP receive window
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
* @param delta Receive window delta
|
|
|
|
*
|
|
|
|
* @return 0 on success, -EPROTOTYPE if there is no TCP context, -EINVAL
|
|
|
|
* if the receive window delta is out of bounds, -EPROTONOSUPPORT
|
|
|
|
* if TCP is not supported
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
int net_tcp_update_recv_wnd(struct net_context *context, int32_t delta);
|
|
|
|
#else
|
|
|
|
static inline int net_tcp_update_recv_wnd(struct net_context *context,
|
|
|
|
int32_t delta)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
ARG_UNUSED(delta);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Queue a TCP FIN packet if needed to close the socket
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
2022-03-16 22:07:43 +01:00
|
|
|
* @return 0 on success where a TCP FIN packet has been queued, -ENOTCONN
|
2020-11-07 11:19:39 +01:00
|
|
|
* in case the socket was not connected or listening, -EOPNOTSUPP
|
|
|
|
* in case it was not a TCP socket or -EPROTONOSUPPORT if TCP is not
|
|
|
|
* supported
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
int net_tcp_put(struct net_context *context);
|
|
|
|
#else
|
|
|
|
static inline int net_tcp_put(struct net_context *context)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define NET_TCP_MAX_OPT_SIZE 8
|
|
|
|
|
2019-08-09 13:49:35 +02:00
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
2016-08-18 09:08:04 +02:00
|
|
|
void net_tcp_init(void);
|
|
|
|
#else
|
|
|
|
#define net_tcp_init(...)
|
|
|
|
#endif
|
|
|
|
|
2022-06-06 22:00:01 +02:00
|
|
|
/**
|
|
|
|
* @brief Set tcp specific options of a socket
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
|
|
|
* @return 0 on success, -EINVAL if the value is not allowed
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
int net_tcp_set_option(struct net_context *context,
|
|
|
|
enum tcp_conn_option option,
|
|
|
|
const void *value, size_t len);
|
|
|
|
#else
|
|
|
|
static inline int net_tcp_set_option(struct net_context *context,
|
|
|
|
enum tcp_conn_option option,
|
|
|
|
const void *value, size_t len)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
ARG_UNUSED(option);
|
|
|
|
ARG_UNUSED(value);
|
|
|
|
ARG_UNUSED(len);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Obtain tcp specific options of a socket
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
int net_tcp_get_option(struct net_context *context,
|
|
|
|
enum tcp_conn_option option,
|
|
|
|
void *value, size_t *len);
|
|
|
|
#else
|
|
|
|
static inline int net_tcp_get_option(struct net_context *context,
|
|
|
|
enum tcp_conn_option option,
|
|
|
|
void *value, size_t *len)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(context);
|
|
|
|
ARG_UNUSED(option);
|
|
|
|
ARG_UNUSED(value);
|
|
|
|
ARG_UNUSED(len);
|
|
|
|
|
|
|
|
return -EPROTONOSUPPORT;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2022-05-10 10:17:36 +02:00
|
|
|
/**
|
|
|
|
* @brief Obtain a semaphore indicating if transfers are blocked (either due to
|
|
|
|
* filling TX window or entering retransmission mode).
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
|
|
|
* @return semaphore indicating if transfers are blocked
|
|
|
|
*/
|
|
|
|
struct k_sem *net_tcp_tx_sem_get(struct net_context *context);
|
|
|
|
|
2023-04-06 20:26:51 +02:00
|
|
|
/**
|
|
|
|
* @brief Obtain a semaphore indicating if connection is connected.
|
|
|
|
*
|
|
|
|
* @param context Network context
|
|
|
|
*
|
|
|
|
* @return semaphore indicating if connection is connected
|
|
|
|
*/
|
|
|
|
struct k_sem *net_tcp_conn_sem_get(struct net_context *context);
|
|
|
|
|
2023-10-16 16:11:32 +02:00
|
|
|
/**
|
|
|
|
* @brief Send a TCP RST reply for the received packet w/o associated connection.
|
|
|
|
*
|
|
|
|
* @param pkt TCP packet to reply for.
|
|
|
|
*/
|
|
|
|
#if defined(CONFIG_NET_NATIVE_TCP)
|
|
|
|
void net_tcp_reply_rst(struct net_pkt *pkt);
|
|
|
|
#else
|
|
|
|
static inline void net_tcp_reply_rst(struct net_pkt *pkt)
|
|
|
|
{
|
|
|
|
ARG_UNUSED(pkt);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2016-08-18 09:08:04 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-03-02 23:20:51 +01:00
|
|
|
#endif /* __TCP_INTERNAL_H */
|