forked from nuttx/nuttx-update
Clean up all TCP-related naming
This commit is contained in:
parent
e2947c37a1
commit
04985d6d1e
41 changed files with 608 additions and 491 deletions
|
@ -104,7 +104,7 @@ struct socket
|
|||
#endif
|
||||
#endif
|
||||
|
||||
FAR void *s_conn; /* Connection: struct uip_conn or uip_udp_conn */
|
||||
FAR void *s_conn; /* Connection: struct tcp_conn_s or uip_udp_conn */
|
||||
|
||||
#ifdef CONFIG_NET_TCP_WRITE_BUFFERS
|
||||
/* Callback instance for TCP send */
|
||||
|
|
|
@ -387,7 +387,7 @@ uint16_t uip_ipchksum(struct uip_driver_s *dev);
|
|||
* to by d_appdata.
|
||||
*/
|
||||
|
||||
uint16_t uip_tcpchksum(struct uip_driver_s *dev);
|
||||
uint16_t tcp_chksum(struct uip_driver_s *dev);
|
||||
|
||||
uint16_t uip_udpchksum(struct uip_driver_s *dev);
|
||||
uint16_t uip_icmpchksum(struct uip_driver_s *dev, int len);
|
||||
|
|
|
@ -80,7 +80,7 @@
|
|||
|
||||
#define TCP_OPT_MSS_LEN 4 /* Length of TCP MSS option. */
|
||||
|
||||
/* The TCP states used in the struct uip_conn tcpstateflags field */
|
||||
/* The TCP states used in the struct tcp_conn_s tcpstateflags field */
|
||||
|
||||
#define UIP_TS_MASK 0x0f /* Bits 0-3: TCP state */
|
||||
#define UIP_CLOSED 0x00 /* The connection is not in use and available */
|
||||
|
@ -154,7 +154,7 @@
|
|||
|
||||
/* Representation of a uIP TCP connection.
|
||||
*
|
||||
* The uip_conn structure is used for identifying a connection. All
|
||||
* The tcp_conn_s structure is used for identifying a connection. All
|
||||
* but one field in the structure are to be considered read-only by an
|
||||
* application. The only exception is the 'private' fields whose purpose
|
||||
* is to let the application store application-specific state (e.g.,
|
||||
|
@ -163,9 +163,9 @@
|
|||
|
||||
struct uip_driver_s; /* Forward reference */
|
||||
struct uip_callback_s; /* Forward reference */
|
||||
struct uip_backlog_s; /* Forward reference */
|
||||
struct tcp_backlog_s; /* Forward reference */
|
||||
|
||||
struct uip_conn
|
||||
struct tcp_conn_s
|
||||
{
|
||||
dq_entry_t node; /* Implements a doubly linked list */
|
||||
uip_ipaddr_t ripaddr; /* The IP address of the remote host */
|
||||
|
@ -227,12 +227,12 @@ struct uip_conn
|
|||
* structure in which this connection is backlogged.
|
||||
* backlog - The pending connection backlog. If this connection is
|
||||
* configured as a listener with backlog, then this refers to the
|
||||
* struct uip_backlog_s tear-off structure that manages that backlog.
|
||||
* struct tcp_backlog_s tear-off structure that manages that backlog.
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_NET_TCPBACKLOG
|
||||
FAR struct uip_conn *blparent;
|
||||
FAR struct uip_backlog_s *backlog;
|
||||
FAR struct tcp_conn_s *blparent;
|
||||
FAR struct tcp_backlog_s *backlog;
|
||||
#endif
|
||||
|
||||
/* Application callbacks:
|
||||
|
@ -264,14 +264,14 @@ struct uip_conn
|
|||
/* accept() is called when the TCP logic has created a connection */
|
||||
|
||||
FAR void *accept_private;
|
||||
int (*accept)(FAR struct uip_conn *listener, struct uip_conn *conn);
|
||||
int (*accept)(FAR struct tcp_conn_s *listener, FAR struct tcp_conn_s *conn);
|
||||
|
||||
/* connection_event() is called on any of the subset of connection-related
|
||||
* events.
|
||||
*/
|
||||
|
||||
FAR void *connection_private;
|
||||
void (*connection_event)(FAR struct uip_conn *conn, uint16_t flags);
|
||||
void (*connection_event)(FAR struct tcp_conn_s *conn, uint16_t flags);
|
||||
};
|
||||
|
||||
/* This structure supports TCP write buffering */
|
||||
|
@ -290,22 +290,22 @@ struct tcp_wrbuffer_s
|
|||
|
||||
/* Support for listen backlog:
|
||||
*
|
||||
* struct uip_blcontainer_s describes one backlogged connection
|
||||
* struct uip_backlog_s is a "tear-off" describing all backlog for a
|
||||
* struct tcp_blcontainer_s describes one backlogged connection
|
||||
* struct tcp_backlog_s is a "tear-off" describing all backlog for a
|
||||
* listener connection
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_NET_TCPBACKLOG
|
||||
struct uip_blcontainer_s
|
||||
struct tcp_blcontainer_s
|
||||
{
|
||||
sq_entry_t bc_node; /* Implements a singly linked list */
|
||||
FAR struct uip_conn *bc_conn; /* Holds reference to the new connection structure */
|
||||
sq_entry_t bc_node; /* Implements a singly linked list */
|
||||
FAR struct tcp_conn_s *bc_conn; /* Holds reference to the new connection structure */
|
||||
};
|
||||
|
||||
struct uip_backlog_s
|
||||
struct tcp_backlog_s
|
||||
{
|
||||
sq_queue_t bl_free; /* Implements a singly-linked list of free containers */
|
||||
sq_queue_t bl_pending; /* Implements a singly-linked list of pending connections */
|
||||
sq_queue_t bl_free; /* Implements a singly-linked list of free containers */
|
||||
sq_queue_t bl_pending; /* Implements a singly-linked list of pending connections */
|
||||
};
|
||||
#endif
|
||||
|
||||
|
@ -314,7 +314,7 @@ struct uip_backlog_s
|
|||
*/
|
||||
|
||||
#ifdef CONFIG_NET_STATISTICS
|
||||
struct uip_tcp_stats_s
|
||||
struct tcp_stats_s
|
||||
{
|
||||
uip_stats_t drop; /* Number of dropped TCP segments */
|
||||
uip_stats_t recv; /* Number of received TCP segments */
|
||||
|
@ -331,7 +331,7 @@ struct uip_tcp_stats_s
|
|||
|
||||
/* The TCP and IP headers */
|
||||
|
||||
struct uip_tcpip_hdr
|
||||
struct tcp_iphdr_s
|
||||
{
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
|
||||
|
@ -395,25 +395,27 @@ struct uip_tcpip_hdr
|
|||
* normally something done by the implementation of the socket() API
|
||||
*/
|
||||
|
||||
struct uip_conn *uip_tcpalloc(void);
|
||||
struct tcp_conn_s *tcp_alloc(void);
|
||||
|
||||
/* Allocate a new TCP data callback */
|
||||
|
||||
#define uip_tcpcallbackalloc(conn) uip_callbackalloc(&conn->list)
|
||||
#define uip_tcpcallbackfree(conn,cb) uip_callbackfree(cb, &conn->list)
|
||||
#define tcp_callbackalloc(conn) uip_callbackalloc(&conn->list)
|
||||
#define tcp_callbackfree(conn,cb) uip_callbackfree(cb, &conn->list)
|
||||
|
||||
/* Free a connection structure that is no longer in use. This should
|
||||
* be done by the implementation of close()
|
||||
*/
|
||||
|
||||
void uip_tcpfree(struct uip_conn *conn);
|
||||
void tcp_free(FAR struct tcp_conn_s *conn);
|
||||
|
||||
/* Bind a TCP connection to a local address */
|
||||
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in6 *addr);
|
||||
int tcp_bind(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in6 *addr);
|
||||
#else
|
||||
int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in *addr);
|
||||
int tcp_bind(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in *addr);
|
||||
#endif
|
||||
|
||||
/* This function implements the UIP specific parts of the standard
|
||||
|
@ -425,50 +427,54 @@ int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in *addr);
|
|||
* the SYN_SENT state and sets the retransmission timer to 0. This will
|
||||
* cause a TCP SYN segment to be sent out the next time this connection
|
||||
* is periodically processed, which usually is done within 0.5 seconds
|
||||
* after the call to uip_tcpconnect().
|
||||
* after the call to tcp_connect().
|
||||
*
|
||||
* This function is called from normal user level code.
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
int uip_tcpconnect(struct uip_conn *conn, const struct sockaddr_in6 *addr);
|
||||
int tcp_connect(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in6 *addr);
|
||||
#else
|
||||
int uip_tcpconnect(struct uip_conn *conn, const struct sockaddr_in *addr);
|
||||
int tcp_connect(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in *addr);
|
||||
#endif
|
||||
|
||||
/* Start listening to the port bound to the specified TCP connection */
|
||||
|
||||
int uip_listen(struct uip_conn *conn);
|
||||
int tcp_listen(FAR struct tcp_conn_s *conn);
|
||||
|
||||
/* Stop listening to the port bound to the specified TCP connection */
|
||||
|
||||
int uip_unlisten(struct uip_conn *conn);
|
||||
int tcp_unlisten(FAR struct tcp_conn_s *conn);
|
||||
|
||||
/* Backlog support */
|
||||
|
||||
#ifdef CONFIG_NET_TCPBACKLOG
|
||||
/* APIs to create and terminate TCP backlog support */
|
||||
|
||||
int uip_backlogcreate(FAR struct uip_conn *conn, int nblg);
|
||||
int uip_backlogdestroy(FAR struct uip_conn *conn);
|
||||
int tcp_backlogcreate(FAR struct tcp_conn_s *conn, int nblg);
|
||||
int tcp_backlogdestroy(FAR struct tcp_conn_s *conn);
|
||||
|
||||
/* APIs to manage individual backlog actions */
|
||||
|
||||
int uip_backlogadd(FAR struct uip_conn *conn, FAR struct uip_conn *blconn);
|
||||
int tcp_backlogadd(FAR struct tcp_conn_s *conn,
|
||||
FAR struct tcp_conn_s *blconn);
|
||||
#ifndef CONFIG_DISABLE_POLL
|
||||
bool uip_backlogavailable(FAR struct uip_conn *conn);
|
||||
bool tcp_backlogavailable(FAR struct tcp_conn_s *conn);
|
||||
#else
|
||||
# define uip_backlogavailable(conn) (false);
|
||||
# define tcp_backlogavailable(conn) (false);
|
||||
#endif
|
||||
FAR struct uip_conn *uip_backlogremove(FAR struct uip_conn *conn);
|
||||
int uip_backlogdelete(FAR struct uip_conn *conn, FAR struct uip_conn *blconn);
|
||||
FAR struct tcp_conn_s *tcp_backlogremove(FAR struct tcp_conn_s *conn);
|
||||
int tcp_backlogdelete(FAR struct tcp_conn_s *conn,
|
||||
FAR struct tcp_conn_s *blconn);
|
||||
|
||||
#else
|
||||
# define uip_backlogcreate(conn,nblg) (-ENOSYS)
|
||||
# define uip_backlogdestroy(conn) (-ENOSYS)
|
||||
# define uip_backlogadd(conn,blconn) (-ENOSYS)
|
||||
# define uip_backlogavailable(conn) (false);
|
||||
# define uip_backlogremove(conn) (NULL)
|
||||
# define tcp_backlogcreate(conn,nblg) (-ENOSYS)
|
||||
# define tcp_backlogdestroy(conn) (-ENOSYS)
|
||||
# define tcp_backlogadd(conn,blconn) (-ENOSYS)
|
||||
# define tcp_backlogavailable(conn) (false);
|
||||
# define tcp_backlogremove(conn) (NULL)
|
||||
#endif
|
||||
|
||||
/* Tell the sending host to stop sending data.
|
||||
|
|
|
@ -209,7 +209,8 @@ struct uip_ip_hdr
|
|||
*
|
||||
* flink - Supports a singly linked list
|
||||
* event - Provides the address of the callback function entry point.
|
||||
* pvconn is a pointer to one of struct uip_conn or struct uip_udp_conn.
|
||||
* pvconn is a pointer to one of struct tcp_conn_s or struct
|
||||
* uip_udp_conn.
|
||||
* priv - Holds a reference to application specific data that will
|
||||
* provided
|
||||
* flags - Set by the application to inform the uIP layer which flags
|
||||
|
@ -280,7 +281,7 @@ struct uip_stats
|
|||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
struct uip_tcp_stats_s tcp; /* TCP statistics */
|
||||
struct tcp_stats_s tcp; /* TCP statistics */
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_UDP
|
||||
|
|
15
net/accept.c
15
net/accept.c
|
@ -69,7 +69,7 @@ struct accept_s
|
|||
#else
|
||||
FAR struct sockaddr_in *acpt_addr; /* Return connection adress */
|
||||
#endif
|
||||
FAR struct uip_conn *acpt_newconn; /* The accepted connection */
|
||||
FAR struct tcp_conn_s *acpt_newconn; /* The accepted connection */
|
||||
int acpt_result; /* The result of the wait */
|
||||
};
|
||||
|
||||
|
@ -101,7 +101,7 @@ struct accept_s
|
|||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
static inline void accept_tcpsender(FAR struct uip_conn *conn,
|
||||
static inline void accept_tcpsender(FAR struct tcp_conn_s *conn,
|
||||
FAR struct sockaddr_in6 *addr)
|
||||
{
|
||||
if (addr)
|
||||
|
@ -112,7 +112,7 @@ static inline void accept_tcpsender(FAR struct uip_conn *conn,
|
|||
}
|
||||
}
|
||||
#else
|
||||
static inline void accept_tcpsender(FAR struct uip_conn *conn,
|
||||
static inline void accept_tcpsender(FAR struct tcp_conn_s *conn,
|
||||
FAR struct sockaddr_in *addr)
|
||||
{
|
||||
if (addr)
|
||||
|
@ -143,7 +143,8 @@ static inline void accept_tcpsender(FAR struct uip_conn *conn,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static int accept_interrupt(struct uip_conn *listener, struct uip_conn *conn)
|
||||
static int accept_interrupt(FAR struct tcp_conn_s *listener,
|
||||
FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
struct accept_s *pstate = (struct accept_s *)listener->accept_private;
|
||||
int ret = -EINVAL;
|
||||
|
@ -255,7 +256,7 @@ int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
|||
{
|
||||
FAR struct socket *psock = sockfd_socket(sockfd);
|
||||
FAR struct socket *pnewsock;
|
||||
FAR struct uip_conn *conn;
|
||||
FAR struct tcp_conn_s *conn;
|
||||
struct accept_s state;
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
FAR struct sockaddr_in6 *inaddr = (struct sockaddr_in6 *)addr;
|
||||
|
@ -345,10 +346,10 @@ int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
|||
*/
|
||||
|
||||
save = uip_lock();
|
||||
conn = (struct uip_conn *)psock->s_conn;
|
||||
conn = (struct tcp_conn_s *)psock->s_conn;
|
||||
|
||||
#ifdef CONFIG_NET_TCPBACKLOG
|
||||
state.acpt_newconn = uip_backlogremove(conn);
|
||||
state.acpt_newconn = tcp_backlogremove(conn);
|
||||
if (state.acpt_newconn)
|
||||
{
|
||||
/* Yes... get the address of the connected client */
|
||||
|
|
10
net/bind.c
10
net/bind.c
|
@ -56,7 +56,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: pkt_rawbind
|
||||
* Function: pkt_bind
|
||||
*
|
||||
* Description:
|
||||
* Bind a raw socket to an network device.
|
||||
|
@ -71,8 +71,8 @@
|
|||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_PKT
|
||||
static int pkt_rawbind(FAR struct uip_pkt_conn *conn,
|
||||
FAR const struct sockaddr_ll *addr)
|
||||
static int pkt_bind(FAR struct uip_pkt_conn *conn,
|
||||
FAR const struct sockaddr_ll *addr)
|
||||
{
|
||||
int ifindex;
|
||||
#if 0
|
||||
|
@ -191,13 +191,13 @@ int psock_bind(FAR struct socket *psock, const struct sockaddr *addr,
|
|||
{
|
||||
#ifdef CONFIG_NET_PKT
|
||||
case SOCK_RAW:
|
||||
ret = pkt_rawbind(psock->s_conn, lladdr);
|
||||
ret = pkt_bind(psock->s_conn, lladdr);
|
||||
break;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
case SOCK_STREAM:
|
||||
ret = uip_tcpbind(psock->s_conn, inaddr);
|
||||
ret = tcp_bind(psock->s_conn, inaddr);
|
||||
psock->s_flags |= _SF_BOUND;
|
||||
break;
|
||||
#endif
|
||||
|
|
|
@ -60,7 +60,7 @@
|
|||
#ifdef CONFIG_NET_TCP
|
||||
struct tcp_connect_s
|
||||
{
|
||||
FAR struct uip_conn *tc_conn; /* Reference to TCP connection structure */
|
||||
FAR struct tcp_conn_s *tc_conn; /* Reference to TCP connection structure */
|
||||
FAR struct uip_callback_s *tc_cb; /* Reference to callback instance */
|
||||
sem_t tc_sem; /* Semaphore signals recv completion */
|
||||
int tc_result; /* OK on success, otherwise a negated errno. */
|
||||
|
@ -72,15 +72,18 @@ struct tcp_connect_s
|
|||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
static inline int tcp_setup_callbacks(FAR struct socket *psock,
|
||||
FAR struct tcp_connect_s *pstate);
|
||||
static inline void tcp_teardown_callbacks(struct tcp_connect_s *pstate, int status);
|
||||
static uint16_t tcp_connect_interrupt(struct uip_driver_s *dev, void *pvconn,
|
||||
void *pvpriv, uint16_t flags);
|
||||
static inline int psock_setup_callbacks(FAR struct socket *psock,
|
||||
FAR struct tcp_connect_s *pstate);
|
||||
static inline void psock_teardown_callbacks(FAR struct tcp_connect_s *pstate,
|
||||
int status);
|
||||
static uint16_t psock_connect_interrupt(FAR struct uip_driver_s *dev,
|
||||
FAR void *pvconn, FAR void *pvpriv,
|
||||
uint16_t flags);
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in6 *inaddr);
|
||||
static inline int psock_tcp_connect(FAR struct socket *psock,
|
||||
FAR const struct sockaddr_in6 *inaddr);
|
||||
#else
|
||||
static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in *inaddr);
|
||||
static inline int psock_tcp_connect(FAR struct socket *psock, const struct sockaddr_in *inaddr);
|
||||
#endif
|
||||
#endif /* CONFIG_NET_TCP */
|
||||
|
||||
|
@ -88,14 +91,14 @@ static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in
|
|||
* Private Functions
|
||||
****************************************************************************/
|
||||
/****************************************************************************
|
||||
* Name: tcp_setup_callbacks
|
||||
* Name: psock_setup_callbacks
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
static inline int tcp_setup_callbacks(FAR struct socket *psock,
|
||||
FAR struct tcp_connect_s *pstate)
|
||||
static inline int psock_setup_callbacks(FAR struct socket *psock,
|
||||
FAR struct tcp_connect_s *pstate)
|
||||
{
|
||||
FAR struct uip_conn *conn = psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = psock->s_conn;
|
||||
int ret = -EBUSY;
|
||||
|
||||
/* Initialize the TCP state structure */
|
||||
|
@ -106,14 +109,14 @@ static inline int tcp_setup_callbacks(FAR struct socket *psock,
|
|||
|
||||
/* Set up the callbacks in the connection */
|
||||
|
||||
pstate->tc_cb = uip_tcpcallbackalloc(conn);
|
||||
pstate->tc_cb = tcp_callbackalloc(conn);
|
||||
if (pstate->tc_cb)
|
||||
{
|
||||
/* Set up the connection "interrupt" handler */
|
||||
|
||||
pstate->tc_cb->flags = UIP_NEWDATA|UIP_CLOSE|UIP_ABORT|UIP_TIMEDOUT|UIP_CONNECTED;
|
||||
pstate->tc_cb->priv = (void*)pstate;
|
||||
pstate->tc_cb->event = tcp_connect_interrupt;
|
||||
pstate->tc_cb->event = psock_connect_interrupt;
|
||||
|
||||
/* Set up the connection event monitor */
|
||||
|
||||
|
@ -125,18 +128,18 @@ static inline int tcp_setup_callbacks(FAR struct socket *psock,
|
|||
#endif /* CONFIG_NET_TCP */
|
||||
|
||||
/****************************************************************************
|
||||
* Name: tcp_teardown_callbacks
|
||||
* Name: psock_teardown_callbacks
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
static inline void tcp_teardown_callbacks(struct tcp_connect_s *pstate,
|
||||
int status)
|
||||
static inline void psock_teardown_callbacks(FAR struct tcp_connect_s *pstate,
|
||||
int status)
|
||||
{
|
||||
FAR struct uip_conn *conn = pstate->tc_conn;
|
||||
FAR struct tcp_conn_s *conn = pstate->tc_conn;
|
||||
|
||||
/* Make sure that no further interrupts are processed */
|
||||
|
||||
uip_tcpcallbackfree(conn, pstate->tc_cb);
|
||||
tcp_callbackfree(conn, pstate->tc_cb);
|
||||
|
||||
pstate->tc_cb = NULL;
|
||||
|
||||
|
@ -154,7 +157,7 @@ static inline void tcp_teardown_callbacks(struct tcp_connect_s *pstate,
|
|||
#endif /* CONFIG_NET_TCP */
|
||||
|
||||
/****************************************************************************
|
||||
* Name: tcp_connect_interrupt
|
||||
* Name: psock_connect_interrupt
|
||||
*
|
||||
* Description:
|
||||
* This function is called from the interrupt level to perform the actual
|
||||
|
@ -174,8 +177,9 @@ static inline void tcp_teardown_callbacks(struct tcp_connect_s *pstate,
|
|||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
static uint16_t tcp_connect_interrupt(struct uip_driver_s *dev, void *pvconn,
|
||||
void *pvpriv, uint16_t flags)
|
||||
static uint16_t psock_connect_interrupt(FAR struct uip_driver_s *dev,
|
||||
FAR void *pvconn, FAR void *pvpriv,
|
||||
uint16_t flags)
|
||||
{
|
||||
struct tcp_connect_s *pstate = (struct tcp_connect_s *)pvpriv;
|
||||
|
||||
|
@ -239,7 +243,7 @@ static uint16_t tcp_connect_interrupt(struct uip_driver_s *dev, void *pvconn,
|
|||
|
||||
/* Stop further callbacks */
|
||||
|
||||
tcp_teardown_callbacks(pstate, pstate->tc_result);
|
||||
psock_teardown_callbacks(pstate, pstate->tc_result);
|
||||
|
||||
/* Wake up the waiting thread */
|
||||
|
||||
|
@ -251,7 +255,7 @@ static uint16_t tcp_connect_interrupt(struct uip_driver_s *dev, void *pvconn,
|
|||
#endif /* CONFIG_NET_TCP */
|
||||
|
||||
/****************************************************************************
|
||||
* Name: tcp_connect
|
||||
* Name: psock_tcp_connect
|
||||
*
|
||||
* Description:
|
||||
* Perform a TCP connection
|
||||
|
@ -270,9 +274,11 @@ static uint16_t tcp_connect_interrupt(struct uip_driver_s *dev, void *pvconn,
|
|||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in6 *inaddr)
|
||||
static inline int psock_tcp_connect(FAR struct socket *psock,
|
||||
FAR const struct sockaddr_in6 *inaddr)
|
||||
#else
|
||||
static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in *inaddr)
|
||||
static inline int psock_tcp_connect(FAR struct socket *psock,
|
||||
FAR const struct sockaddr_in *inaddr)
|
||||
#endif
|
||||
{
|
||||
struct tcp_connect_s state;
|
||||
|
@ -296,14 +302,14 @@ static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in
|
|||
{
|
||||
/* Perform the uIP connection operation */
|
||||
|
||||
ret = uip_tcpconnect(psock->s_conn, inaddr);
|
||||
ret = psock_tcp_connect(psock->s_conn, inaddr);
|
||||
}
|
||||
|
||||
if (ret >= 0)
|
||||
{
|
||||
/* Set up the callbacks in the connection */
|
||||
|
||||
ret = tcp_setup_callbacks(psock, &state);
|
||||
ret = psock_setup_callbacks(psock, &state);
|
||||
if (ret >= 0)
|
||||
{
|
||||
/* Wait for either the connect to complete or for an error/timeout
|
||||
|
@ -336,7 +342,7 @@ static inline int tcp_connect(FAR struct socket *psock, const struct sockaddr_in
|
|||
|
||||
/* Make sure that no further interrupts are processed */
|
||||
|
||||
tcp_teardown_callbacks(&state, ret);
|
||||
psock_teardown_callbacks(&state, ret);
|
||||
}
|
||||
|
||||
/* Mark the connection bound and connected */
|
||||
|
@ -475,7 +481,7 @@ int psock_connect(FAR struct socket *psock, FAR const struct sockaddr *addr,
|
|||
|
||||
/* Its not ... connect it */
|
||||
|
||||
ret = tcp_connect(psock, inaddr);
|
||||
ret = psock_tcp_connect(psock, inaddr);
|
||||
if (ret < 0)
|
||||
{
|
||||
err = -ret;
|
||||
|
|
|
@ -153,7 +153,7 @@ int getsockname(int sockfd, FAR struct sockaddr *addr, FAR socklen_t *addrlen)
|
|||
#ifdef CONFIG_NET_TCP
|
||||
case SOCK_STREAM:
|
||||
{
|
||||
struct uip_conn *tcp_conn = (struct uip_conn *)psock->s_conn;
|
||||
FAR struct tcp_conn_s *tcp_conn = (FAR struct tcp_conn_s *)psock->s_conn;
|
||||
outaddr->sin_port = tcp_conn->lport; /* Already in network byte order */
|
||||
}
|
||||
break;
|
||||
|
|
|
@ -88,7 +88,7 @@
|
|||
int listen(int sockfd, int backlog)
|
||||
{
|
||||
FAR struct socket *psock = sockfd_socket(sockfd);
|
||||
struct uip_conn *conn;
|
||||
struct tcp_conn_s *conn;
|
||||
int err;
|
||||
|
||||
/* Verify that the sockfd corresponds to valid, allocated socket */
|
||||
|
@ -115,7 +115,7 @@ int listen(int sockfd, int backlog)
|
|||
|
||||
/* Verify that the sockfd corresponds to a connected SOCK_STREAM */
|
||||
|
||||
conn = (struct uip_conn *)psock->s_conn;
|
||||
conn = (FAR struct tcp_conn_s *)psock->s_conn;
|
||||
if (psock->s_type != SOCK_STREAM || !psock->s_conn || conn->lport <= 0)
|
||||
{
|
||||
err = EOPNOTSUPP;
|
||||
|
@ -125,7 +125,7 @@ int listen(int sockfd, int backlog)
|
|||
/* Set up the backlog for this connection */
|
||||
|
||||
#ifdef CONFIG_NET_TCPBACKLOG
|
||||
err = uip_backlogcreate(conn, backlog);
|
||||
err = tcp_backlogcreate(conn, backlog);
|
||||
if (err < 0)
|
||||
{
|
||||
err = -err;
|
||||
|
@ -137,7 +137,7 @@ int listen(int sockfd, int backlog)
|
|||
* is called and enables poll()/select() logic.
|
||||
*/
|
||||
|
||||
uip_listen(conn);
|
||||
tcp_listen(conn);
|
||||
psock->s_flags |= _SF_LISTENING;
|
||||
return OK;
|
||||
|
||||
|
|
|
@ -169,7 +169,7 @@ FAR struct socket *sockfd_socket(int sockfd);
|
|||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
int net_startmonitor(FAR struct socket *psock);
|
||||
void net_stopmonitor(FAR struct uip_conn *conn);
|
||||
void net_stopmonitor(FAR struct tcp_conn_s *conn);
|
||||
void net_lostconnection(FAR struct socket *psock, uint16_t flags);
|
||||
#endif
|
||||
|
||||
|
|
|
@ -97,7 +97,7 @@ int net_clone(FAR struct socket *psock1, FAR struct socket *psock2)
|
|||
#ifdef CONFIG_NET_TCP
|
||||
if (psock2->s_type == SOCK_STREAM)
|
||||
{
|
||||
struct uip_conn *conn = psock2->s_conn;
|
||||
FAR struct tcp_conn_s *conn = psock2->s_conn;
|
||||
DEBUGASSERT(conn->crefs > 0 && conn->crefs < 255);
|
||||
conn->crefs++;
|
||||
}
|
||||
|
@ -106,7 +106,7 @@ int net_clone(FAR struct socket *psock1, FAR struct socket *psock2)
|
|||
#ifdef CONFIG_NET_UDP
|
||||
if (psock2->s_type == SOCK_DGRAM)
|
||||
{
|
||||
struct uip_udp_conn *conn = psock2->s_conn;
|
||||
FAR struct uip_udp_conn *conn = psock2->s_conn;
|
||||
DEBUGASSERT(conn->crefs > 0 && conn->crefs < 255);
|
||||
conn->crefs++;
|
||||
}
|
||||
|
|
|
@ -153,9 +153,9 @@ static uint16_t netclose_interrupt(FAR struct uip_driver_s *dev,
|
|||
uint16_t flags)
|
||||
{
|
||||
#ifdef CONFIG_NET_SOLINGER
|
||||
FAR struct tcp_close_s *pstate = (struct tcp_close_s *)pvpriv;
|
||||
FAR struct tcp_close_s *pstate = (FAR struct tcp_close_s *)pvpriv;
|
||||
#endif
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn *)pvconn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)pvconn;
|
||||
|
||||
DEBUGASSERT(conn != NULL);
|
||||
|
||||
|
@ -190,7 +190,7 @@ static uint16_t netclose_interrupt(FAR struct uip_driver_s *dev,
|
|||
{
|
||||
/* Free connection resources */
|
||||
|
||||
uip_tcpfree(conn);
|
||||
tcp_free(conn);
|
||||
|
||||
/* Stop further callbacks */
|
||||
|
||||
|
@ -273,7 +273,7 @@ end_wait:
|
|||
static inline int netclose_disconnect(FAR struct socket *psock)
|
||||
{
|
||||
struct tcp_close_s state;
|
||||
FAR struct uip_conn *conn;
|
||||
FAR struct tcp_conn_s *conn;
|
||||
uip_lock_t flags;
|
||||
#ifdef CONFIG_NET_SOLINGER
|
||||
bool linger;
|
||||
|
@ -283,7 +283,7 @@ static inline int netclose_disconnect(FAR struct socket *psock)
|
|||
/* Interrupts are disabled here to avoid race conditions */
|
||||
|
||||
flags = uip_lock();
|
||||
conn = (struct uip_conn*)psock->s_conn;
|
||||
conn = (FAR struct tcp_conn_s *)psock->s_conn;
|
||||
|
||||
/* If we have a semi-permanent write buffer callback in place, then
|
||||
* release it now.
|
||||
|
@ -292,7 +292,7 @@ static inline int netclose_disconnect(FAR struct socket *psock)
|
|||
#ifdef CONFIG_NET_TCP_WRITE_BUFFERS
|
||||
if (psock->s_sndcb)
|
||||
{
|
||||
uip_tcpcallbackfree(conn, psock->s_sndcb);
|
||||
tcp_callbackfree(conn, psock->s_sndcb);
|
||||
psock->s_sndcb = NULL;
|
||||
}
|
||||
#endif
|
||||
|
@ -304,7 +304,7 @@ static inline int netclose_disconnect(FAR struct socket *psock)
|
|||
/* Check for the case where the host beat us and disconnected first */
|
||||
|
||||
if (conn->tcpstateflags == UIP_ESTABLISHED &&
|
||||
(state.cl_cb = uip_tcpcallbackalloc(conn)) != NULL)
|
||||
(state.cl_cb = tcp_callbackalloc(conn)) != NULL)
|
||||
{
|
||||
/* Set up to receive TCP data event callbacks */
|
||||
|
||||
|
@ -368,12 +368,12 @@ static inline int netclose_disconnect(FAR struct socket *psock)
|
|||
/* We are now disconnected */
|
||||
|
||||
sem_destroy(&state.cl_sem);
|
||||
uip_tcpcallbackfree(conn, state.cl_cb);
|
||||
tcp_callbackfree(conn, state.cl_cb);
|
||||
|
||||
/* Free the connection */
|
||||
|
||||
conn->crefs = 0; /* No more references on the connection */
|
||||
uip_tcpfree(conn); /* Free uIP resources */
|
||||
conn->crefs = 0; /* No more references on the connection */
|
||||
tcp_free(conn); /* Free uIP resources */
|
||||
|
||||
/* Get the result of the close */
|
||||
|
||||
|
@ -383,7 +383,7 @@ static inline int netclose_disconnect(FAR struct socket *psock)
|
|||
}
|
||||
else
|
||||
{
|
||||
uip_tcpfree(conn);
|
||||
tcp_free(conn);
|
||||
}
|
||||
|
||||
uip_unlock(flags);
|
||||
|
@ -462,7 +462,7 @@ int psock_close(FAR struct socket *psock)
|
|||
#ifdef CONFIG_NET_TCP
|
||||
case SOCK_STREAM:
|
||||
{
|
||||
struct uip_conn *conn = psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = psock->s_conn;
|
||||
|
||||
/* Is this the last reference to the connection structure (there
|
||||
* could be more if the socket was dup'ed).
|
||||
|
@ -472,7 +472,7 @@ int psock_close(FAR struct socket *psock)
|
|||
{
|
||||
/* Yes... then perform the disconnection now */
|
||||
|
||||
uip_unlisten(conn); /* No longer accepting connections */
|
||||
tcp_unlisten(conn); /* No longer accepting connections */
|
||||
conn->crefs = 0; /* Discard our reference to the connection */
|
||||
err = netclose_disconnect(psock); /* Break any current connections */
|
||||
if (err < 0)
|
||||
|
|
|
@ -55,7 +55,7 @@
|
|||
* Private Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
static void connection_event(struct uip_conn *conn, uint16_t flags);
|
||||
static void connection_event(FAR struct tcp_conn_s *conn, uint16_t flags);
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
|
@ -78,7 +78,7 @@ static void connection_event(struct uip_conn *conn, uint16_t flags);
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void connection_event(FAR struct uip_conn *conn, uint16_t flags)
|
||||
static void connection_event(FAR struct tcp_conn_s *conn, uint16_t flags)
|
||||
{
|
||||
FAR struct socket *psock = (FAR struct socket *)conn->connection_private;
|
||||
|
||||
|
@ -124,7 +124,7 @@ static void connection_event(FAR struct uip_conn *conn, uint16_t flags)
|
|||
|
||||
int net_startmonitor(FAR struct socket *psock)
|
||||
{
|
||||
FAR struct uip_conn *conn = psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = psock->s_conn;
|
||||
|
||||
DEBUGASSERT(psock && conn);
|
||||
|
||||
|
@ -161,7 +161,7 @@ int net_startmonitor(FAR struct socket *psock)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void net_stopmonitor(FAR struct uip_conn *conn)
|
||||
void net_stopmonitor(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
DEBUGASSERT(conn);
|
||||
|
||||
|
|
|
@ -183,7 +183,7 @@ static uint16_t poll_interrupt(FAR struct uip_driver_s *dev, FAR void *conn,
|
|||
static inline int net_pollsetup(FAR struct socket *psock,
|
||||
FAR struct pollfd *fds)
|
||||
{
|
||||
FAR struct uip_conn *conn = psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = psock->s_conn;
|
||||
FAR struct net_poll_s *info;
|
||||
FAR struct uip_callback_s *cb;
|
||||
uip_lock_t flags;
|
||||
|
@ -212,7 +212,7 @@ static inline int net_pollsetup(FAR struct socket *psock,
|
|||
|
||||
/* Allocate a TCP/IP callback structure */
|
||||
|
||||
cb = uip_tcpcallbackalloc(conn);
|
||||
cb = tcp_callbackalloc(conn);
|
||||
if (!cb)
|
||||
{
|
||||
ret = -EBUSY;
|
||||
|
@ -243,7 +243,7 @@ static inline int net_pollsetup(FAR struct socket *psock,
|
|||
#ifdef CONFIG_NET_TCPBACKLOG
|
||||
/* Check for read data or backlogged connection availability now */
|
||||
|
||||
if (!IOB_QEMPTY(&conn->readahead) || uip_backlogavailable(conn))
|
||||
if (!IOB_QEMPTY(&conn->readahead) || tcp_backlogavailable(conn))
|
||||
#else
|
||||
/* Check for read data availability now */
|
||||
|
||||
|
@ -342,7 +342,7 @@ errout_with_lock:
|
|||
static inline int net_pollteardown(FAR struct socket *psock,
|
||||
FAR struct pollfd *fds)
|
||||
{
|
||||
FAR struct uip_conn *conn = psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = psock->s_conn;
|
||||
FAR struct net_poll_s *info;
|
||||
uip_lock_t flags;
|
||||
|
||||
|
@ -364,7 +364,7 @@ static inline int net_pollteardown(FAR struct socket *psock,
|
|||
/* Release the callback */
|
||||
|
||||
flags = uip_lock();
|
||||
uip_tcpcallbackfree(conn, info->cb);
|
||||
tcp_callbackfree(conn, info->cb);
|
||||
uip_unlock(flags);
|
||||
|
||||
/* Release the poll/select data slot */
|
||||
|
|
|
@ -72,7 +72,7 @@
|
|||
# define CONFIG_NET_TCP_SPLIT_SIZE 40
|
||||
#endif
|
||||
|
||||
#define TCPBUF ((struct uip_tcpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define TCPBUF ((struct tcp_iphdr_s *)&dev->d_buf[UIP_LLH_LEN])
|
||||
|
||||
/****************************************************************************
|
||||
* Private Types
|
||||
|
@ -164,7 +164,7 @@ static uint16_t ack_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
* is the number of bytes to be acknowledged.
|
||||
*/
|
||||
|
||||
pstate->snd_acked = uip_tcpgetsequence(TCPBUF->ackno) - pstate->snd_isn;
|
||||
pstate->snd_acked = tcp_getsequence(TCPBUF->ackno) - pstate->snd_isn;
|
||||
nllvdbg("ACK: acked=%d sent=%d flen=%d\n",
|
||||
pstate->snd_acked, pstate->snd_sent, pstate->snd_flen);
|
||||
|
||||
|
@ -225,7 +225,7 @@ static uint16_t ack_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
static uint16_t sendfile_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
||||
FAR void *pvpriv, uint16_t flags)
|
||||
{
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn*)pvconn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s*)pvconn;
|
||||
FAR struct sendfile_s *pstate = (FAR struct sendfile_s *)pvpriv;
|
||||
int ret;
|
||||
|
||||
|
@ -305,7 +305,7 @@ static uint16_t sendfile_interrupt(FAR struct uip_driver_s *dev, FAR void *pvcon
|
|||
seqno = pstate->snd_sent + pstate->snd_isn;
|
||||
nllvdbg("SEND: sndseq %08x->%08x len: %d\n", conn->sndseq, seqno, ret);
|
||||
|
||||
uip_tcpsetsequence(conn->sndseq, seqno);
|
||||
tcp_setsequence(conn->sndseq, seqno);
|
||||
|
||||
/* Check if the destination IP address is in the ARP table. If not,
|
||||
* then the send won't actually make it out... it will be replaced with
|
||||
|
@ -449,7 +449,7 @@ ssize_t net_sendfile(int outfd, struct file *infile, off_t *offset,
|
|||
size_t count)
|
||||
{
|
||||
FAR struct socket *psock = sockfd_socket(outfd);
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn*)psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s*)psock->s_conn;
|
||||
struct sendfile_s state;
|
||||
uip_lock_t save;
|
||||
int err;
|
||||
|
@ -490,7 +490,7 @@ ssize_t net_sendfile(int outfd, struct file *infile, off_t *offset,
|
|||
|
||||
/* Allocate resources to receive a callback */
|
||||
|
||||
state.snd_datacb = uip_tcpcallbackalloc(conn);
|
||||
state.snd_datacb = tcp_callbackalloc(conn);
|
||||
|
||||
if (state.snd_datacb == NULL)
|
||||
{
|
||||
|
@ -499,7 +499,7 @@ ssize_t net_sendfile(int outfd, struct file *infile, off_t *offset,
|
|||
goto errout_locked;
|
||||
}
|
||||
|
||||
state.snd_ackcb = uip_tcpcallbackalloc(conn);
|
||||
state.snd_ackcb = tcp_callbackalloc(conn);
|
||||
|
||||
if (state.snd_ackcb == NULL)
|
||||
{
|
||||
|
@ -510,7 +510,7 @@ ssize_t net_sendfile(int outfd, struct file *infile, off_t *offset,
|
|||
|
||||
/* Get the initial sequence number that will be used */
|
||||
|
||||
state.snd_isn = uip_tcpgetsequence(conn->sndseq);
|
||||
state.snd_isn = tcp_getsequence(conn->sndseq);
|
||||
|
||||
/* There is no outstanding, unacknowledged data after this
|
||||
* initial sequence number.
|
||||
|
@ -550,10 +550,10 @@ ssize_t net_sendfile(int outfd, struct file *infile, off_t *offset,
|
|||
|
||||
psock->s_flags = _SS_SETSTATE(psock->s_flags, _SF_IDLE);
|
||||
|
||||
uip_tcpcallbackfree(conn, state.snd_ackcb);
|
||||
tcp_callbackfree(conn, state.snd_ackcb);
|
||||
|
||||
errout_datacb:
|
||||
uip_tcpcallbackfree(conn, state.snd_datacb);
|
||||
tcp_callbackfree(conn, state.snd_datacb);
|
||||
|
||||
errout_locked:
|
||||
|
||||
|
|
|
@ -71,10 +71,10 @@ extern "C"
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: pkt_send
|
||||
* Function: psock_pkt_send
|
||||
*
|
||||
* Description:
|
||||
* The pkt_send() call may be used only when the packet socket is in a
|
||||
* The psock_pkt_send() call may be used only when the packet socket is in a
|
||||
* connected state (so that the intended recipient is known).
|
||||
*
|
||||
* Parameters:
|
||||
|
@ -128,7 +128,8 @@ extern "C"
|
|||
****************************************************************************/
|
||||
|
||||
struct socket;
|
||||
ssize_t pkt_send(FAR struct socket *psock, FAR const void *buf, size_t len);
|
||||
ssize_t psock_pkt_send(FAR struct socket *psock, FAR const void *buf,
|
||||
size_t len);
|
||||
|
||||
|
||||
#undef EXTERN
|
||||
|
|
|
@ -219,7 +219,7 @@ struct uip_pkt_conn *uip_pktactive(struct uip_eth_hdr *buf)
|
|||
|
||||
while (conn)
|
||||
{
|
||||
/* FIXME lmac in conn should have been set by pkt_rawbind() */
|
||||
/* FIXME lmac in conn should have been set by pkt_bind() */
|
||||
|
||||
if (uip_ethaddr_cmp(buf->dest, conn->lmac))
|
||||
{
|
||||
|
|
|
@ -85,12 +85,12 @@ struct send_s
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: pktsend_interrupt
|
||||
* Function: psock_send_interrupt
|
||||
****************************************************************************/
|
||||
|
||||
static uint16_t pktsend_interrupt(FAR struct uip_driver_s *dev,
|
||||
FAR void *pvconn,
|
||||
FAR void *pvpriv, uint16_t flags)
|
||||
static uint16_t psock_send_interrupt(FAR struct uip_driver_s *dev,
|
||||
FAR void *pvconn,
|
||||
FAR void *pvpriv, uint16_t flags)
|
||||
{
|
||||
FAR struct send_s *pstate = (FAR struct send_s *)pvpriv;
|
||||
|
||||
|
@ -145,10 +145,10 @@ static uint16_t pktsend_interrupt(FAR struct uip_driver_s *dev,
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: pkt_send
|
||||
* Function: psock_pkt_send
|
||||
*
|
||||
* Description:
|
||||
* The pkt_send() call may be used only when the packet socket is in a
|
||||
* The psock_pkt_send() call may be used only when the packet socket is in a
|
||||
* connected state (so that the intended recipient is known).
|
||||
*
|
||||
* Parameters:
|
||||
|
@ -201,7 +201,8 @@ static uint16_t pktsend_interrupt(FAR struct uip_driver_s *dev,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
ssize_t pkt_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
||||
ssize_t psock_pkt_send(FAR struct socket *psock, FAR const void *buf,
|
||||
size_t len)
|
||||
{
|
||||
struct send_s state;
|
||||
uip_lock_t save;
|
||||
|
@ -249,7 +250,7 @@ ssize_t pkt_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
|
||||
state.snd_cb->flags = UIP_POLL;
|
||||
state.snd_cb->priv = (void*)&state;
|
||||
state.snd_cb->event = pktsend_interrupt;
|
||||
state.snd_cb->event = psock_send_interrupt;
|
||||
|
||||
/* Notify the device driver of the availability of TX data */
|
||||
/* TODO better lookup network interface from *psock or *conn */
|
||||
|
|
|
@ -58,13 +58,14 @@
|
|||
|
||||
#include "net.h"
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#define UDPBUF ((struct uip_udpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define TCPBUF ((struct uip_tcpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define TCPBUF ((struct tcp_iphdr_s *)&dev->d_buf[UIP_LLH_LEN])
|
||||
|
||||
/****************************************************************************
|
||||
* Private Types
|
||||
|
@ -224,15 +225,15 @@ static inline void recvfrom_newtcpdata(FAR struct uip_driver_s *dev,
|
|||
if (recvlen < dev->d_len)
|
||||
{
|
||||
#ifdef CONFIG_NET_TCP_READAHEAD
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn *)pstate->rf_sock->s_conn;
|
||||
FAR uint8_t *buffer = (FAR uint8_t *)dev->d_appdata + recvlen;
|
||||
uint16_t buflen = dev->d_len - recvlen;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)pstate->rf_sock->s_conn;
|
||||
FAR uint8_t *buffer = (FAR uint8_t *)dev->d_appdata + recvlen;
|
||||
uint16_t buflen = dev->d_len - recvlen;
|
||||
#ifdef CONFIG_DEBUG_NET
|
||||
uint16_t nsaved;
|
||||
uint16_t nsaved;
|
||||
|
||||
nsaved = uip_datahandler(conn, buffer, buflen);
|
||||
nsaved = tcp_datahandler(conn, buffer, buflen);
|
||||
#else
|
||||
(void)uip_datahandler(conn, buffer, buflen);
|
||||
(void)tcp_datahandler(conn, buffer, buflen);
|
||||
#endif
|
||||
|
||||
/* There are complicated buffering issues that are not addressed fully
|
||||
|
@ -316,7 +317,7 @@ static inline void recvfrom_newudpdata(FAR struct uip_driver_s *dev,
|
|||
#if defined(CONFIG_NET_TCP) && defined(CONFIG_NET_TCP_READAHEAD)
|
||||
static inline void recvfrom_readahead(struct recvfrom_s *pstate)
|
||||
{
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn *)pstate->rf_sock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)pstate->rf_sock->s_conn;
|
||||
FAR struct iob_s *iob;
|
||||
int recvlen;
|
||||
|
||||
|
@ -1342,11 +1343,11 @@ static ssize_t tcp_recvfrom(FAR struct socket *psock, FAR void *buf, size_t len,
|
|||
if (state.rf_buflen > 0)
|
||||
#endif
|
||||
{
|
||||
struct uip_conn *conn = (struct uip_conn *)psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)psock->s_conn;
|
||||
|
||||
/* Set up the callback in the connection */
|
||||
|
||||
state.rf_cb = uip_tcpcallbackalloc(conn);
|
||||
state.rf_cb = tcp_callbackalloc(conn);
|
||||
if (state.rf_cb)
|
||||
{
|
||||
state.rf_cb->flags = UIP_NEWDATA|UIP_POLL|UIP_CLOSE|UIP_ABORT|UIP_TIMEDOUT;
|
||||
|
@ -1363,7 +1364,7 @@ static ssize_t tcp_recvfrom(FAR struct socket *psock, FAR void *buf, size_t len,
|
|||
|
||||
/* Make sure that no further interrupts are processed */
|
||||
|
||||
uip_tcpcallbackfree(conn, state.rf_cb);
|
||||
tcp_callbackfree(conn, state.rf_cb);
|
||||
ret = recvfrom_result(ret, &state);
|
||||
}
|
||||
else
|
||||
|
|
|
@ -43,6 +43,8 @@
|
|||
#include <sys/types.h>
|
||||
#include <sys/socket.h>
|
||||
|
||||
#include <nuttx/net/tcp.h>
|
||||
|
||||
#include "tcp/tcp.h"
|
||||
#include "pkt/pkt.h"
|
||||
#include "net.h"
|
||||
|
@ -137,7 +139,7 @@ ssize_t psock_send(FAR struct socket *psock, FAR const void *buf, size_t len,
|
|||
#if defined(CONFIG_NET_PKT)
|
||||
case SOCK_RAW:
|
||||
{
|
||||
ret = pkt_send(psock, buf, len);
|
||||
ret = psock_pkt_send(psock, buf, len);
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
|
@ -145,7 +147,7 @@ ssize_t psock_send(FAR struct socket *psock, FAR const void *buf, size_t len,
|
|||
#if defined(CONFIG_NET_TCP)
|
||||
case SOCK_STREAM:
|
||||
{
|
||||
ret = tcp_send(psock, buf, len);
|
||||
ret = psock_tcp_send(psock, buf, len);
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -195,7 +195,7 @@ int psock_socket(int domain, int type, int protocol, FAR struct socket *psock)
|
|||
* socket instance.
|
||||
*/
|
||||
|
||||
struct uip_conn *conn = uip_tcpalloc();
|
||||
FAR struct tcp_conn_s *conn = tcp_alloc();
|
||||
if (!conn)
|
||||
{
|
||||
/* Failed to reserve a connection structure */
|
||||
|
|
|
@ -70,11 +70,73 @@ extern "C"
|
|||
* Public Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
/* Defined in tcp_conn.c ****************************************************/
|
||||
|
||||
void tcp_initialize(void);
|
||||
struct tcp_conn_s *tcp_active(FAR struct tcp_iphdr_s *buf);
|
||||
struct tcp_conn_s *uip_nexttcpconn(FAR struct tcp_conn_s *conn);
|
||||
struct tcp_conn_s *tcp_listener(uint16_t portno);
|
||||
struct tcp_conn_s *tcp_alloc_accept(FAR struct tcp_iphdr_s *buf);
|
||||
|
||||
/* Defined in tcp_seqno.c ***************************************************/
|
||||
|
||||
void tcp_setsequence(FAR uint8_t *seqno, uint32_t value);
|
||||
uint32_t tcp_getsequence(FAR uint8_t *seqno);
|
||||
uint32_t tcp_addsequence(FAR uint8_t *seqno, uint16_t len);
|
||||
void tcp_initsequence(FAR uint8_t *seqno);
|
||||
void tcp_nextsequence(void);
|
||||
|
||||
/* Defined in tcp_poll.c ****************************************************/
|
||||
|
||||
void tcp_poll(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn);
|
||||
|
||||
/* Defined in tcp_timer.c ***************************************************/
|
||||
|
||||
void tcp_timer(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
int hsec);
|
||||
|
||||
/* Defined in tcp_listen.c **************************************************/
|
||||
|
||||
void tcp_listeninit(void);
|
||||
bool tcp_islistener(uint16_t port);
|
||||
int tcp_accept_connection(FAR struct uip_driver_s *dev,
|
||||
FAR struct tcp_conn_s *conn, uint16_t portno);
|
||||
|
||||
/* Defined in tcp_send.c ****************************************************/
|
||||
|
||||
void tcp_send(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t flags, uint16_t len);
|
||||
void tcp_reset(FAR struct uip_driver_s *dev);
|
||||
void tcp_ack(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint8_t ack);
|
||||
|
||||
/* Defined in tcp_appsend.c *************************************************/
|
||||
|
||||
void tcp_appsend(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t result);
|
||||
void tcp_rexmit(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t result);
|
||||
|
||||
/* Defined in tcp_input.c ***************************************************/
|
||||
|
||||
void tcp_input(FAR struct uip_driver_s *dev);
|
||||
|
||||
/* Defined in tcp_callback.c ************************************************/
|
||||
|
||||
uint16_t tcp_callback(FAR struct uip_driver_s *dev,
|
||||
FAR struct tcp_conn_s *conn, uint16_t flags);
|
||||
#ifdef CONFIG_NET_TCP_READAHEAD
|
||||
uint16_t tcp_datahandler(FAR struct tcp_conn_s *conn,
|
||||
FAR uint8_t *buffer, uint16_t nbytes);
|
||||
#endif
|
||||
#endif /* CONFIG_NET_TCP */
|
||||
|
||||
/****************************************************************************
|
||||
* Function: tcp_send
|
||||
* Function: psock_tcp_send
|
||||
*
|
||||
* Description:
|
||||
* The tcp_send() call may be used only when the TCP socket is in a
|
||||
* The psock_tcp_send() call may be used only when the TCP socket is in a
|
||||
* connected state (so that the intended recipient is known).
|
||||
*
|
||||
* Parameters:
|
||||
|
@ -128,7 +190,8 @@ extern "C"
|
|||
****************************************************************************/
|
||||
|
||||
struct socket;
|
||||
ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len);
|
||||
ssize_t psock_tcp_send(FAR struct socket *psock, FAR const void *buf,
|
||||
size_t len);
|
||||
|
||||
/****************************************************************************
|
||||
* Function: tcp_wrbuffer_initialize
|
||||
|
|
|
@ -53,6 +53,7 @@
|
|||
#include <nuttx/net/netdev.h>
|
||||
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
|
@ -75,7 +76,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpappsend
|
||||
* Name: tcp_appsend
|
||||
*
|
||||
* Description:
|
||||
* Handle application or TCP protocol response. If this function is called
|
||||
|
@ -95,8 +96,8 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpappsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t result)
|
||||
void tcp_appsend(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t result)
|
||||
{
|
||||
/* Handle the result based on the application response */
|
||||
|
||||
|
@ -111,7 +112,7 @@ void uip_tcpappsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
conn->tcpstateflags = UIP_CLOSED;
|
||||
nllvdbg("TCP state: UIP_CLOSED\n");
|
||||
|
||||
uip_tcpsend(dev, conn, TCP_RST | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_RST | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
}
|
||||
|
||||
/* Check for connection closed */
|
||||
|
@ -124,7 +125,7 @@ void uip_tcpappsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
nllvdbg("TCP state: UIP_FIN_WAIT_1\n");
|
||||
|
||||
dev->d_sndlen = 0;
|
||||
uip_tcpsend(dev, conn, TCP_FIN | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_FIN | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
}
|
||||
|
||||
/* None of the above */
|
||||
|
@ -158,12 +159,12 @@ void uip_tcpappsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
#endif
|
||||
/* Then handle the rest of the operation just as for the rexmit case */
|
||||
|
||||
uip_tcprexmit(dev, conn, result);
|
||||
tcp_rexmit(dev, conn, result);
|
||||
}
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcprexmit
|
||||
* Name: tcp_rexmit
|
||||
*
|
||||
* Description:
|
||||
* Handle application retransmission
|
||||
|
@ -181,8 +182,8 @@ void uip_tcpappsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcprexmit(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t result)
|
||||
void tcp_rexmit(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t result)
|
||||
{
|
||||
nllvdbg("result: %04x d_sndlen: %d conn->unacked: %d\n",
|
||||
result, dev->d_sndlen, conn->unacked);
|
||||
|
@ -203,14 +204,14 @@ void uip_tcprexmit(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
* the IP and TCP headers.
|
||||
*/
|
||||
|
||||
uip_tcpsend(dev, conn, TCP_ACK | TCP_PSH, dev->d_sndlen + UIP_TCPIP_HLEN);
|
||||
tcp_send(dev, conn, TCP_ACK | TCP_PSH, dev->d_sndlen + UIP_TCPIP_HLEN);
|
||||
}
|
||||
|
||||
/* If there is no data to send, just send out a pure ACK if one is requested`. */
|
||||
|
||||
else if ((result & UIP_SNDACK) != 0)
|
||||
{
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_TCPIP_HLEN);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_TCPIP_HLEN);
|
||||
}
|
||||
|
||||
/* There is nothing to do -- drop the packet */
|
||||
|
|
|
@ -65,7 +65,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_backlogcreate
|
||||
* Function: tcp_backlogcreate
|
||||
*
|
||||
* Description:
|
||||
* Called from the listen() logic to setup the backlog as specified in the
|
||||
|
@ -76,10 +76,10 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_backlogcreate(FAR struct uip_conn *conn, int nblg)
|
||||
int tcp_backlogcreate(FAR struct tcp_conn_s *conn, int nblg)
|
||||
{
|
||||
FAR struct uip_backlog_s *bls = NULL;
|
||||
FAR struct uip_blcontainer_s *blc;
|
||||
FAR struct tcp_backlog_s *bls = NULL;
|
||||
FAR struct tcp_blcontainer_s *blc;
|
||||
uip_lock_t flags;
|
||||
int size;
|
||||
int offset;
|
||||
|
@ -103,18 +103,18 @@ int uip_backlogcreate(FAR struct uip_conn *conn, int nblg)
|
|||
* on 64-bit address machines -- REVISIT
|
||||
*/
|
||||
|
||||
offset = (sizeof(struct uip_backlog_s) + 3) & ~3;
|
||||
offset = (sizeof(struct tcp_backlog_s) + 3) & ~3;
|
||||
|
||||
/* Then determine the full size of the allocation include the
|
||||
* uip_backlog_s, a pre-allocated array of struct uip_blcontainer_s
|
||||
* tcp_backlog_s, a pre-allocated array of struct tcp_blcontainer_s
|
||||
* and alignment padding
|
||||
*/
|
||||
|
||||
size = offset + nblg * sizeof(struct uip_blcontainer_s);
|
||||
size = offset + nblg * sizeof(struct tcp_blcontainer_s);
|
||||
|
||||
/* Then allocate that much */
|
||||
|
||||
bls = (FAR struct uip_backlog_s *)kzalloc(size);
|
||||
bls = (FAR struct tcp_backlog_s *)kzalloc(size);
|
||||
if (!bls)
|
||||
{
|
||||
nlldbg("Failed to allocate backlog\n");
|
||||
|
@ -123,7 +123,7 @@ int uip_backlogcreate(FAR struct uip_conn *conn, int nblg)
|
|||
|
||||
/* Then add all of the pre-allocated containers to the free list */
|
||||
|
||||
blc = (FAR struct uip_blcontainer_s*)(((FAR uint8_t*)bls) + offset);
|
||||
blc = (FAR struct tcp_blcontainer_s*)(((FAR uint8_t*)bls) + offset);
|
||||
for (i = 0; i < nblg; i++)
|
||||
{
|
||||
sq_addfirst(&blc->bc_node, &bls->bl_free);
|
||||
|
@ -134,7 +134,7 @@ int uip_backlogcreate(FAR struct uip_conn *conn, int nblg)
|
|||
/* Destroy any existing backlog (shouldn't be any) */
|
||||
|
||||
flags = uip_lock();
|
||||
uip_backlogdestroy(conn);
|
||||
tcp_backlogdestroy(conn);
|
||||
|
||||
/* Now install the backlog tear-off in the connection. NOTE that bls may
|
||||
* actually be NULL if nblg is <= 0; In that case, we are disabling backlog
|
||||
|
@ -148,13 +148,13 @@ int uip_backlogcreate(FAR struct uip_conn *conn, int nblg)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_backlogdestroy
|
||||
* Function: tcp_backlogdestroy
|
||||
*
|
||||
* Description:
|
||||
* (1) Called from uip_tcpfree() whenever a connection is freed.
|
||||
* (2) Called from uip_backlogcreate() to destroy any old backlog
|
||||
* (1) Called from tcp_free() whenever a connection is freed.
|
||||
* (2) Called from tcp_backlogcreate() to destroy any old backlog
|
||||
*
|
||||
* NOTE: This function may re-enter uip_tcpfree when a connection that
|
||||
* NOTE: This function may re-enter tcp_free when a connection that
|
||||
* is freed that has pending connections.
|
||||
*
|
||||
* Assumptions:
|
||||
|
@ -163,11 +163,11 @@ int uip_backlogcreate(FAR struct uip_conn *conn, int nblg)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_backlogdestroy(FAR struct uip_conn *conn)
|
||||
int tcp_backlogdestroy(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
FAR struct uip_backlog_s *blg;
|
||||
FAR struct uip_blcontainer_s *blc;
|
||||
FAR struct uip_conn *blconn;
|
||||
FAR struct tcp_backlog_s *blg;
|
||||
FAR struct tcp_blcontainer_s *blc;
|
||||
FAR struct tcp_conn_s *blconn;
|
||||
|
||||
nllvdbg("conn=%p\n", conn);
|
||||
|
||||
|
@ -189,7 +189,7 @@ int uip_backlogdestroy(FAR struct uip_conn *conn)
|
|||
|
||||
/* Handle any pending connections in the backlog */
|
||||
|
||||
while ((blc = (FAR struct uip_blcontainer_s*)sq_remfirst(&blg->bl_pending)) != NULL)
|
||||
while ((blc = (FAR struct tcp_blcontainer_s*)sq_remfirst(&blg->bl_pending)) != NULL)
|
||||
{
|
||||
blconn = blc->bc_conn;
|
||||
if (blconn)
|
||||
|
@ -199,7 +199,7 @@ int uip_backlogdestroy(FAR struct uip_conn *conn)
|
|||
blconn->blparent = NULL;
|
||||
blconn->backlog = NULL;
|
||||
blconn->crefs = 0;
|
||||
uip_tcpfree(blconn);
|
||||
tcp_free(blconn);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -212,10 +212,10 @@ int uip_backlogdestroy(FAR struct uip_conn *conn)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_backlogadd
|
||||
* Function: tcp_backlogadd
|
||||
*
|
||||
* Description:
|
||||
* Called uip_listen when a new connection is made with a listener socket
|
||||
* Called tcp_listen when a new connection is made with a listener socket
|
||||
* but when there is no accept() in place to receive the connection. This
|
||||
* function adds the new connection to the backlog.
|
||||
*
|
||||
|
@ -224,10 +224,10 @@ int uip_backlogdestroy(FAR struct uip_conn *conn)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_backlogadd(FAR struct uip_conn *conn, FAR struct uip_conn *blconn)
|
||||
int tcp_backlogadd(FAR struct tcp_conn_s *conn, FAR struct tcp_conn_s *blconn)
|
||||
{
|
||||
FAR struct uip_backlog_s *bls;
|
||||
FAR struct uip_blcontainer_s *blc;
|
||||
FAR struct tcp_backlog_s *bls;
|
||||
FAR struct tcp_blcontainer_s *blc;
|
||||
int ret = -EINVAL;
|
||||
|
||||
nllvdbg("conn=%p blconn=%p\n", conn, blconn);
|
||||
|
@ -244,7 +244,7 @@ int uip_backlogadd(FAR struct uip_conn *conn, FAR struct uip_conn *blconn)
|
|||
{
|
||||
/* Allocate a container for the connection from the free list */
|
||||
|
||||
blc = (FAR struct uip_blcontainer_s *)sq_remfirst(&bls->bl_free);
|
||||
blc = (FAR struct tcp_blcontainer_s *)sq_remfirst(&bls->bl_free);
|
||||
if (!blc)
|
||||
{
|
||||
nlldbg("Failed to allocate container\n");
|
||||
|
@ -265,7 +265,7 @@ int uip_backlogadd(FAR struct uip_conn *conn, FAR struct uip_conn *blconn)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_backlogremove
|
||||
* Function: tcp_backlogremove
|
||||
*
|
||||
* Description:
|
||||
* Called from poll(). Before waiting for a new connection, poll will
|
||||
|
@ -277,14 +277,14 @@ int uip_backlogadd(FAR struct uip_conn *conn, FAR struct uip_conn *blconn)
|
|||
****************************************************************************/
|
||||
|
||||
#ifndef CONFIG_DISABLE_POLL
|
||||
bool uip_backlogavailable(FAR struct uip_conn *conn)
|
||||
bool tcp_backlogavailable(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
return (conn && conn->backlog && !sq_empty(&conn->backlog->bl_pending));
|
||||
}
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_backlogremove
|
||||
* Function: tcp_backlogremove
|
||||
*
|
||||
* Description:
|
||||
* Called from accept(). Before waiting for a new connection, accept will
|
||||
|
@ -295,11 +295,11 @@ bool uip_backlogavailable(FAR struct uip_conn *conn)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_backlogremove(FAR struct uip_conn *conn)
|
||||
struct tcp_conn_s *tcp_backlogremove(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
FAR struct uip_backlog_s *bls;
|
||||
FAR struct uip_blcontainer_s *blc;
|
||||
FAR struct uip_conn *blconn = NULL;
|
||||
FAR struct tcp_backlog_s *bls;
|
||||
FAR struct tcp_blcontainer_s *blc;
|
||||
FAR struct tcp_conn_s *blconn = NULL;
|
||||
|
||||
#ifdef CONFIG_DEBUG
|
||||
if (!conn)
|
||||
|
@ -315,7 +315,7 @@ struct uip_conn *uip_backlogremove(FAR struct uip_conn *conn)
|
|||
* (FIFO)
|
||||
*/
|
||||
|
||||
blc = (FAR struct uip_blcontainer_s *)sq_remfirst(&bls->bl_pending);
|
||||
blc = (FAR struct tcp_blcontainer_s *)sq_remfirst(&bls->bl_pending);
|
||||
if (blc)
|
||||
{
|
||||
/* Extract the connection reference from the container and put
|
||||
|
@ -333,23 +333,23 @@ struct uip_conn *uip_backlogremove(FAR struct uip_conn *conn)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_backlogdelete
|
||||
* Function: tcp_backlogdelete
|
||||
*
|
||||
* Description:
|
||||
* Called from uip_tcpfree() when a connection is freed that this also
|
||||
* retained in the pending connectino list of a listener. We simply need
|
||||
* to remove the defunct connecton from the list.
|
||||
* Called from tcp_free() when a connection is freed that this also
|
||||
* retained in the pending connection list of a listener. We simply need
|
||||
* to remove the defunct connection from the list.
|
||||
*
|
||||
* Assumptions:
|
||||
* Called from the interrupt level with interrupts disabled
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_backlogdelete(FAR struct uip_conn *conn, FAR struct uip_conn *blconn)
|
||||
int tcp_backlogdelete(FAR struct tcp_conn_s *conn, FAR struct tcp_conn_s *blconn)
|
||||
{
|
||||
FAR struct uip_backlog_s *bls;
|
||||
FAR struct uip_blcontainer_s *blc;
|
||||
FAR struct uip_blcontainer_s *prev;
|
||||
FAR struct tcp_backlog_s *bls;
|
||||
FAR struct tcp_blcontainer_s *blc;
|
||||
FAR struct tcp_blcontainer_s *prev;
|
||||
|
||||
nllvdbg("conn=%p blconn=%p\n", conn, blconn);
|
||||
|
||||
|
@ -365,9 +365,9 @@ int uip_backlogdelete(FAR struct uip_conn *conn, FAR struct uip_conn *blconn)
|
|||
{
|
||||
/* Find the container hold the connection */
|
||||
|
||||
for (blc = (FAR struct uip_blcontainer_s *)sq_peek(&bls->bl_pending), prev = NULL;
|
||||
for (blc = (FAR struct tcp_blcontainer_s *)sq_peek(&bls->bl_pending), prev = NULL;
|
||||
blc;
|
||||
prev = blc, blc = (FAR struct uip_blcontainer_s *)sq_next(&blc->bc_node))
|
||||
prev = blc, blc = (FAR struct tcp_blcontainer_s *)sq_next(&blc->bc_node))
|
||||
{
|
||||
if (blc->bc_conn == blconn)
|
||||
{
|
||||
|
|
|
@ -50,6 +50,7 @@
|
|||
#include <nuttx/net/netdev.h>
|
||||
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Private Data
|
||||
|
@ -74,7 +75,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
static inline uint16_t
|
||||
uip_dataevent(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
||||
uip_dataevent(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t flags)
|
||||
{
|
||||
uint16_t ret;
|
||||
|
@ -104,7 +105,7 @@ uip_dataevent(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
* partial packets will not be buffered.
|
||||
*/
|
||||
|
||||
recvlen = uip_datahandler(conn, buffer, buflen);
|
||||
recvlen = tcp_datahandler(conn, buffer, buflen);
|
||||
if (recvlen < buflen)
|
||||
#endif
|
||||
{
|
||||
|
@ -135,7 +136,7 @@ uip_dataevent(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_tcpcallback
|
||||
* Function: tcp_callback
|
||||
*
|
||||
* Description:
|
||||
* Inform the application holding the TCP socket of a change in state.
|
||||
|
@ -145,8 +146,8 @@ uip_dataevent(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
uint16_t uip_tcpcallback(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t flags)
|
||||
uint16_t tcp_callback(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t flags)
|
||||
{
|
||||
/* Preserve the UIP_ACKDATA, UIP_CLOSE, and UIP_ABORT in the response.
|
||||
* These is needed by uIP to handle responses and buffer state. The
|
||||
|
@ -206,7 +207,7 @@ uint16_t uip_tcpcallback(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_datahandler
|
||||
* Function: tcp_datahandler
|
||||
*
|
||||
* Description:
|
||||
* Handle data that is not accepted by the application. This may be called
|
||||
|
@ -232,7 +233,7 @@ uint16_t uip_tcpcallback(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_TCP_READAHEAD
|
||||
uint16_t uip_datahandler(FAR struct uip_conn *conn, FAR uint8_t *buffer,
|
||||
uint16_t tcp_datahandler(FAR struct tcp_conn_s *conn, FAR uint8_t *buffer,
|
||||
uint16_t buflen)
|
||||
{
|
||||
FAR struct iob_s *iob;
|
||||
|
|
|
@ -68,7 +68,7 @@
|
|||
|
||||
/* The array containing all uIP TCP connections. */
|
||||
|
||||
static struct uip_conn g_tcp_connections[CONFIG_NET_TCP_CONNS];
|
||||
static struct tcp_conn_s g_tcp_connections[CONFIG_NET_TCP_CONNS];
|
||||
|
||||
/* A list of all free TCP connections */
|
||||
|
||||
|
@ -135,7 +135,7 @@ static int uip_selectport(uint16_t portno)
|
|||
g_last_tcp_port = 4096;
|
||||
}
|
||||
}
|
||||
while (uip_tcplistener(htons(g_last_tcp_port)));
|
||||
while (tcp_listener(htons(g_last_tcp_port)));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -143,7 +143,7 @@ static int uip_selectport(uint16_t portno)
|
|||
* connection is using this local port.
|
||||
*/
|
||||
|
||||
if (uip_tcplistener(portno))
|
||||
if (tcp_listener(portno))
|
||||
{
|
||||
/* It is in use... return EADDRINUSE */
|
||||
|
||||
|
@ -161,7 +161,7 @@ static int uip_selectport(uint16_t portno)
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpinit()
|
||||
* Name: tcp_initialize()
|
||||
*
|
||||
* Description:
|
||||
* Initialize the TCP/IP connection structures. Called only once and only
|
||||
|
@ -169,7 +169,7 @@ static int uip_selectport(uint16_t portno)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpinit(void)
|
||||
void tcp_initialize(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
|
@ -192,7 +192,7 @@ void uip_tcpinit(void)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpalloc()
|
||||
* Name: tcp_alloc()
|
||||
*
|
||||
* Description:
|
||||
* Find a free TCP/IP connection structure and allocate it
|
||||
|
@ -202,9 +202,9 @@ void uip_tcpinit(void)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_tcpalloc(void)
|
||||
FAR struct tcp_conn_s *tcp_alloc(void)
|
||||
{
|
||||
struct uip_conn *conn;
|
||||
FAR struct tcp_conn_s *conn;
|
||||
uip_lock_t flags;
|
||||
|
||||
/* Because this routine is called from both interrupt level and
|
||||
|
@ -216,7 +216,7 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
|
||||
/* Return the entry from the head of the free list */
|
||||
|
||||
conn = (struct uip_conn *)dq_remfirst(&g_free_tcp_connections);
|
||||
conn = (FAR struct tcp_conn_s *)dq_remfirst(&g_free_tcp_connections);
|
||||
|
||||
#ifndef CONFIG_NET_SOLINGER
|
||||
/* Is the free list empty? */
|
||||
|
@ -229,8 +229,8 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
* that is about to be closed anyway.
|
||||
*/
|
||||
|
||||
FAR struct uip_conn *tmp =
|
||||
(FAR struct uip_conn *)g_active_tcp_connections.head;
|
||||
FAR struct tcp_conn_s *tmp =
|
||||
(FAR struct tcp_conn_s *)g_active_tcp_connections.head;
|
||||
|
||||
while (tmp)
|
||||
{
|
||||
|
@ -260,7 +260,7 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
|
||||
/* Look at the next active connection */
|
||||
|
||||
tmp = (FAR struct uip_conn *)tmp->node.flink;
|
||||
tmp = (FAR struct tcp_conn_s *)tmp->node.flink;
|
||||
}
|
||||
|
||||
/* Did we find a connection that we can re-use? */
|
||||
|
@ -282,11 +282,11 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
* waiting for it.
|
||||
*/
|
||||
|
||||
uip_tcpfree(conn);
|
||||
tcp_free(conn);
|
||||
|
||||
/* Now there is guaranteed to be one free connection. Get it! */
|
||||
|
||||
conn = (struct uip_conn *)dq_remfirst(&g_free_tcp_connections);
|
||||
conn = (FAR struct tcp_conn_s *)dq_remfirst(&g_free_tcp_connections);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
@ -297,7 +297,7 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
|
||||
if (conn)
|
||||
{
|
||||
memset(conn, 0, sizeof(struct uip_conn));
|
||||
memset(conn, 0, sizeof(struct tcp_conn_s));
|
||||
conn->tcpstateflags = UIP_ALLOCATED;
|
||||
}
|
||||
|
||||
|
@ -305,7 +305,7 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpfree()
|
||||
* Name: tcp_free()
|
||||
*
|
||||
* Description:
|
||||
* Free a connection structure that is no longer in use. This should be
|
||||
|
@ -313,7 +313,7 @@ struct uip_conn *uip_tcpalloc(void)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpfree(struct uip_conn *conn)
|
||||
void tcp_free(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
FAR struct uip_callback_s *cb;
|
||||
FAR struct uip_callback_s *next;
|
||||
|
@ -337,7 +337,7 @@ void uip_tcpfree(struct uip_conn *conn)
|
|||
for (cb = conn->list; cb; cb = next)
|
||||
{
|
||||
next = cb->flink;
|
||||
uip_tcpcallbackfree(conn, cb);
|
||||
tcp_callbackfree(conn, cb);
|
||||
}
|
||||
|
||||
/* UIP_ALLOCATED means that that the connection is not in the active list
|
||||
|
@ -376,7 +376,7 @@ void uip_tcpfree(struct uip_conn *conn)
|
|||
|
||||
if (conn->backlog)
|
||||
{
|
||||
uip_backlogdestroy(conn);
|
||||
tcp_backlogdestroy(conn);
|
||||
}
|
||||
|
||||
/* If this connection is, itself, backlogged, then remove it from the
|
||||
|
@ -385,7 +385,7 @@ void uip_tcpfree(struct uip_conn *conn)
|
|||
|
||||
if (conn->blparent)
|
||||
{
|
||||
uip_backlogdelete(conn->blparent, conn);
|
||||
tcp_backlogdelete(conn->blparent, conn);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -397,7 +397,7 @@ void uip_tcpfree(struct uip_conn *conn)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpactive()
|
||||
* Name: tcp_active()
|
||||
*
|
||||
* Description:
|
||||
* Find a connection structure that is the appropriate
|
||||
|
@ -408,10 +408,10 @@ void uip_tcpfree(struct uip_conn *conn)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_tcpactive(struct uip_tcpip_hdr *buf)
|
||||
FAR struct tcp_conn_s *tcp_active(struct tcp_iphdr_s *buf)
|
||||
{
|
||||
struct uip_conn *conn = (struct uip_conn *)g_active_tcp_connections.head;
|
||||
in_addr_t srcipaddr = uip_ip4addr_conv(buf->srcipaddr);
|
||||
FAR struct tcp_conn_s *conn = (struct tcp_conn_s *)g_active_tcp_connections.head;
|
||||
in_addr_t srcipaddr = uip_ip4addr_conv(buf->srcipaddr);
|
||||
|
||||
while (conn)
|
||||
{
|
||||
|
@ -430,7 +430,7 @@ struct uip_conn *uip_tcpactive(struct uip_tcpip_hdr *buf)
|
|||
|
||||
/* Look at the next active connection */
|
||||
|
||||
conn = (struct uip_conn *)conn->node.flink;
|
||||
conn = (FAR struct tcp_conn_s *)conn->node.flink;
|
||||
}
|
||||
|
||||
return conn;
|
||||
|
@ -448,20 +448,20 @@ struct uip_conn *uip_tcpactive(struct uip_tcpip_hdr *buf)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_nexttcpconn(struct uip_conn *conn)
|
||||
FAR struct tcp_conn_s *uip_nexttcpconn(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
if (!conn)
|
||||
{
|
||||
return (struct uip_conn *)g_active_tcp_connections.head;
|
||||
return (FAR struct tcp_conn_s *)g_active_tcp_connections.head;
|
||||
}
|
||||
else
|
||||
{
|
||||
return (struct uip_conn *)conn->node.flink;
|
||||
return (FAR struct tcp_conn_s *)conn->node.flink;
|
||||
}
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcplistener()
|
||||
* Name: tcp_listener()
|
||||
*
|
||||
* Description:
|
||||
* Given a local port number (in network byte order), find the TCP
|
||||
|
@ -472,9 +472,9 @@ struct uip_conn *uip_nexttcpconn(struct uip_conn *conn)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_tcplistener(uint16_t portno)
|
||||
FAR struct tcp_conn_s *tcp_listener(uint16_t portno)
|
||||
{
|
||||
struct uip_conn *conn;
|
||||
FAR struct tcp_conn_s *conn;
|
||||
int i;
|
||||
|
||||
/* Check if this port number is in use by any active UIP TCP connection */
|
||||
|
@ -494,10 +494,10 @@ struct uip_conn *uip_tcplistener(uint16_t portno)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpaccept()
|
||||
* Name: tcp_alloc_accept()
|
||||
*
|
||||
* Description:
|
||||
* Called when uip_interupt matches the incoming packet with a connection
|
||||
* Called when uip_interrupt matches the incoming packet with a connection
|
||||
* in LISTEN. In that case, this function will create a new connection and
|
||||
* initialize it to send a SYNACK in return.
|
||||
*
|
||||
|
@ -506,9 +506,9 @@ struct uip_conn *uip_tcplistener(uint16_t portno)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_tcpaccept(struct uip_tcpip_hdr *buf)
|
||||
FAR struct tcp_conn_s *tcp_alloc_accept(FAR struct tcp_iphdr_s *buf)
|
||||
{
|
||||
struct uip_conn *conn = uip_tcpalloc();
|
||||
FAR struct tcp_conn_s *conn = tcp_alloc();
|
||||
if (conn)
|
||||
{
|
||||
/* Fill in the necessary fields for the new connection. */
|
||||
|
@ -524,7 +524,7 @@ struct uip_conn *uip_tcpaccept(struct uip_tcpip_hdr *buf)
|
|||
uip_ipaddr_copy(conn->ripaddr, uip_ip4addr_conv(buf->srcipaddr));
|
||||
conn->tcpstateflags = UIP_SYN_RCVD;
|
||||
|
||||
uip_tcpinitsequence(conn->sndseq);
|
||||
tcp_initsequence(conn->sndseq);
|
||||
conn->unacked = 1;
|
||||
#ifdef CONFIG_NET_TCP_WRITE_BUFFERS
|
||||
conn->expired = 0;
|
||||
|
@ -560,7 +560,7 @@ struct uip_conn *uip_tcpaccept(struct uip_tcpip_hdr *buf)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpbind()
|
||||
* Name: tcp_bind()
|
||||
*
|
||||
* Description:
|
||||
* This function implements the UIP specific parts of the standard TCP
|
||||
|
@ -575,9 +575,11 @@ struct uip_conn *uip_tcpaccept(struct uip_tcpip_hdr *buf)
|
|||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in6 *addr)
|
||||
int tcp_bind(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in6 *addr)
|
||||
#else
|
||||
int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in *addr)
|
||||
int tcp_bind(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in *addr)
|
||||
#endif
|
||||
{
|
||||
uip_lock_t flags;
|
||||
|
@ -613,7 +615,7 @@ int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in *addr)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpconnect()
|
||||
* Name: tcp_connect
|
||||
*
|
||||
* Description:
|
||||
* This function implements the UIP specific parts of the standard
|
||||
|
@ -625,7 +627,7 @@ int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in *addr)
|
|||
* the SYN_SENT state and sets the retransmission timer to 0. This will
|
||||
* cause a TCP SYN segment to be sent out the next time this connection
|
||||
* is periodically processed, which usually is done within 0.5 seconds
|
||||
* after the call to uip_tcpconnect().
|
||||
* after the call to tcp_connect().
|
||||
*
|
||||
* Assumptions:
|
||||
* This function is called from normal user level code.
|
||||
|
@ -633,9 +635,11 @@ int uip_tcpbind(struct uip_conn *conn, const struct sockaddr_in *addr)
|
|||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
int uip_tcpconnect(struct uip_conn *conn, const struct sockaddr_in6 *addr)
|
||||
int tcp_connect(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in6 *addr)
|
||||
#else
|
||||
int uip_tcpconnect(struct uip_conn *conn, const struct sockaddr_in *addr)
|
||||
int tcp_connect(FAR struct tcp_conn_s *conn,
|
||||
FAR const struct sockaddr_in *addr)
|
||||
#endif
|
||||
{
|
||||
uip_lock_t flags;
|
||||
|
@ -667,7 +671,7 @@ int uip_tcpconnect(struct uip_conn *conn, const struct sockaddr_in *addr)
|
|||
/* Initialize and return the connection structure, bind it to the port number */
|
||||
|
||||
conn->tcpstateflags = UIP_SYN_SENT;
|
||||
uip_tcpinitsequence(conn->sndseq);
|
||||
tcp_initsequence(conn->sndseq);
|
||||
|
||||
conn->mss = UIP_TCP_INITIAL_MSS;
|
||||
conn->unacked = 1; /* TCP length of the SYN is one. */
|
||||
|
|
|
@ -55,12 +55,13 @@
|
|||
#include <nuttx/net/netdev.h>
|
||||
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#define BUF ((struct uip_tcpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define BUF ((struct tcp_iphdr_s *)&dev->d_buf[UIP_LLH_LEN])
|
||||
|
||||
/****************************************************************************
|
||||
* Public Variables
|
||||
|
@ -79,7 +80,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpinput
|
||||
* Name: tcp_input
|
||||
*
|
||||
* Description:
|
||||
* Handle incoming TCP input
|
||||
|
@ -95,10 +96,10 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpinput(struct uip_driver_s *dev)
|
||||
void tcp_input(struct uip_driver_s *dev)
|
||||
{
|
||||
struct uip_conn *conn = NULL;
|
||||
struct uip_tcpip_hdr *pbuf = BUF;
|
||||
struct tcp_conn_s *conn = NULL;
|
||||
struct tcp_iphdr_s *pbuf = BUF;
|
||||
uint16_t tmp16;
|
||||
uint16_t flags;
|
||||
uint8_t opt;
|
||||
|
@ -115,7 +116,7 @@ void uip_tcpinput(struct uip_driver_s *dev)
|
|||
|
||||
/* Start of TCP input header processing code. */
|
||||
|
||||
if (uip_tcpchksum(dev) != 0xffff)
|
||||
if (tcp_chksum(dev) != 0xffff)
|
||||
{
|
||||
/* Compute and check the TCP checksum. */
|
||||
|
||||
|
@ -129,7 +130,7 @@ void uip_tcpinput(struct uip_driver_s *dev)
|
|||
|
||||
/* Demultiplex this segment. First check any active connections. */
|
||||
|
||||
conn = uip_tcpactive(pbuf);
|
||||
conn = tcp_active(pbuf);
|
||||
if (conn)
|
||||
{
|
||||
/* We found an active connection.. Check for the subsequent SYN
|
||||
|
@ -162,7 +163,7 @@ void uip_tcpinput(struct uip_driver_s *dev)
|
|||
*/
|
||||
|
||||
tmp16 = pbuf->destport;
|
||||
if (uip_islistener(tmp16))
|
||||
if (tcp_islistener(tmp16))
|
||||
{
|
||||
/* We matched the incoming packet with a connection in LISTEN.
|
||||
* We now need to create a new connection and send a SYNACK in
|
||||
|
@ -173,7 +174,7 @@ void uip_tcpinput(struct uip_driver_s *dev)
|
|||
* user application to accept it.
|
||||
*/
|
||||
|
||||
conn = uip_tcpaccept(pbuf);
|
||||
conn = tcp_alloc_accept(pbuf);
|
||||
if (conn)
|
||||
{
|
||||
/* The connection structure was successfully allocated. Now see if
|
||||
|
@ -182,12 +183,12 @@ void uip_tcpinput(struct uip_driver_s *dev)
|
|||
*/
|
||||
|
||||
conn->crefs = 1;
|
||||
if (uip_accept(dev, conn, tmp16) != OK)
|
||||
if (tcp_accept_connection(dev, conn, tmp16) != OK)
|
||||
{
|
||||
/* No, then we have to give the connection back and drop the packet */
|
||||
|
||||
conn->crefs = 0;
|
||||
uip_tcpfree(conn);
|
||||
tcp_free(conn);
|
||||
conn = NULL;
|
||||
}
|
||||
}
|
||||
|
@ -262,7 +263,7 @@ void uip_tcpinput(struct uip_driver_s *dev)
|
|||
|
||||
/* Our response will be a SYNACK. */
|
||||
|
||||
uip_tcpack(dev, conn, TCP_ACK | TCP_SYN);
|
||||
tcp_ack(dev, conn, TCP_ACK | TCP_SYN);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -283,7 +284,7 @@ reset:
|
|||
#ifdef CONFIG_NET_STATISTICS
|
||||
uip_stat.tcp.synrst++;
|
||||
#endif
|
||||
uip_tcpreset(dev);
|
||||
tcp_reset(dev);
|
||||
return;
|
||||
|
||||
found:
|
||||
|
@ -305,7 +306,7 @@ found:
|
|||
conn->tcpstateflags = UIP_CLOSED;
|
||||
nlldbg("RESET - TCP state: UIP_CLOSED\n");
|
||||
|
||||
(void)uip_tcpcallback(dev, conn, UIP_ABORT);
|
||||
(void)tcp_callback(dev, conn, UIP_ABORT);
|
||||
goto drop;
|
||||
}
|
||||
|
||||
|
@ -337,7 +338,7 @@ found:
|
|||
if ((dev->d_len > 0 || ((pbuf->flags & (TCP_SYN | TCP_FIN)) != 0)) &&
|
||||
memcmp(pbuf->seqno, conn->rcvseq, 4) != 0)
|
||||
{
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -361,14 +362,14 @@ found:
|
|||
#ifdef CONFIG_NET_TCP_WRITE_BUFFERS
|
||||
unackseq = conn->isn + conn->sent;
|
||||
#else
|
||||
unackseq = uip_tcpaddsequence(conn->sndseq, conn->unacked);
|
||||
unackseq = tcp_addsequence(conn->sndseq, conn->unacked);
|
||||
#endif
|
||||
|
||||
/* Get the sequence number of that has just been acknowledged by this
|
||||
* incoming packet.
|
||||
*/
|
||||
|
||||
ackseq = uip_tcpgetsequence(pbuf->ackno);
|
||||
ackseq = tcp_getsequence(pbuf->ackno);
|
||||
|
||||
/* Check how many of the outstanding bytes have been acknowledged. For
|
||||
* a most uIP send operation, this should always be true. However,
|
||||
|
@ -394,7 +395,7 @@ found:
|
|||
if ((conn->tcpstateflags & UIP_TS_MASK) == UIP_ESTABLISHED)
|
||||
{
|
||||
nlldbg("ERROR: conn->sndseq %d, conn->unacked %d\n",
|
||||
uip_tcpgetsequence(conn->sndseq), conn->unacked);
|
||||
tcp_getsequence(conn->sndseq), conn->unacked);
|
||||
goto reset;
|
||||
}
|
||||
}
|
||||
|
@ -406,7 +407,7 @@ found:
|
|||
|
||||
nllvdbg("sndseq: %08x->%08x unackseq: %08x new unacked: %d\n",
|
||||
conn->sndseq, ackseq, unackseq, conn->unacked);
|
||||
uip_tcpsetsequence(conn->sndseq, ackseq);
|
||||
tcp_setsequence(conn->sndseq, ackseq);
|
||||
|
||||
/* Do RTT estimation, unless we have done retransmissions. */
|
||||
|
||||
|
@ -460,8 +461,8 @@ found:
|
|||
conn->tcpstateflags = UIP_ESTABLISHED;
|
||||
|
||||
#ifdef CONFIG_NET_TCP_WRITE_BUFFERS
|
||||
conn->isn = uip_tcpgetsequence(pbuf->ackno);
|
||||
uip_tcpsetsequence(conn->sndseq, conn->isn);
|
||||
conn->isn = tcp_getsequence(pbuf->ackno);
|
||||
tcp_setsequence(conn->sndseq, conn->isn);
|
||||
conn->sent = 0;
|
||||
#endif
|
||||
conn->unacked = 0;
|
||||
|
@ -475,8 +476,8 @@ found:
|
|||
}
|
||||
|
||||
dev->d_sndlen = 0;
|
||||
result = uip_tcpcallback(dev, conn, flags);
|
||||
uip_tcpappsend(dev, conn, result);
|
||||
result = tcp_callback(dev, conn, flags);
|
||||
tcp_appsend(dev, conn, result);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -484,7 +485,7 @@ found:
|
|||
|
||||
if ((pbuf->flags & TCP_CTL) == TCP_SYN)
|
||||
{
|
||||
uip_tcpack(dev, conn, TCP_ACK | TCP_SYN);
|
||||
tcp_ack(dev, conn, TCP_ACK | TCP_SYN);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -558,21 +559,21 @@ found:
|
|||
conn->unacked = 0;
|
||||
|
||||
#ifdef CONFIG_NET_TCP_WRITE_BUFFERS
|
||||
conn->isn = uip_tcpgetsequence(pbuf->ackno);
|
||||
uip_tcpsetsequence(conn->sndseq, conn->isn);
|
||||
conn->isn = tcp_getsequence(pbuf->ackno);
|
||||
tcp_setsequence(conn->sndseq, conn->isn);
|
||||
#endif
|
||||
dev->d_len = 0;
|
||||
dev->d_sndlen = 0;
|
||||
|
||||
nllvdbg("TCP state: UIP_ESTABLISHED\n");
|
||||
result = uip_tcpcallback(dev, conn, UIP_CONNECTED | UIP_NEWDATA);
|
||||
uip_tcpappsend(dev, conn, result);
|
||||
result = tcp_callback(dev, conn, UIP_CONNECTED | UIP_NEWDATA);
|
||||
tcp_appsend(dev, conn, result);
|
||||
return;
|
||||
}
|
||||
|
||||
/* Inform the application that the connection failed */
|
||||
|
||||
(void)uip_tcpcallback(dev, conn, UIP_ABORT);
|
||||
(void)tcp_callback(dev, conn, UIP_ABORT);
|
||||
|
||||
/* The connection is closed after we send the RST */
|
||||
|
||||
|
@ -586,7 +587,7 @@ found:
|
|||
goto drop;
|
||||
}
|
||||
|
||||
uip_tcpreset(dev);
|
||||
tcp_reset(dev);
|
||||
return;
|
||||
|
||||
case UIP_ESTABLISHED:
|
||||
|
@ -628,14 +629,14 @@ found:
|
|||
flags |= UIP_NEWDATA;
|
||||
}
|
||||
|
||||
(void)uip_tcpcallback(dev, conn, flags);
|
||||
(void)tcp_callback(dev, conn, flags);
|
||||
|
||||
conn->tcpstateflags = UIP_LAST_ACK;
|
||||
conn->unacked = 1;
|
||||
conn->nrtx = 0;
|
||||
nllvdbg("TCP state: UIP_LAST_ACK\n");
|
||||
|
||||
uip_tcpsend(dev, conn, TCP_FIN | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_FIN | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -709,12 +710,12 @@ found:
|
|||
|
||||
/* Provide the packet to the application */
|
||||
|
||||
result = uip_tcpcallback(dev, conn, flags);
|
||||
result = tcp_callback(dev, conn, flags);
|
||||
|
||||
/* If the application successfully handled the incoming data,
|
||||
* then UIP_SNDACK will be set in the result. In this case,
|
||||
* we need to update the sequence number. The ACK will be
|
||||
* send by uip_tcpappsend().
|
||||
* send by tcp_appsend().
|
||||
*/
|
||||
|
||||
if ((result & UIP_SNDACK) != 0)
|
||||
|
@ -726,7 +727,7 @@ found:
|
|||
|
||||
/* Send the response, ACKing the data or not, as appropriate */
|
||||
|
||||
uip_tcpappsend(dev, conn, result);
|
||||
tcp_appsend(dev, conn, result);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -742,7 +743,7 @@ found:
|
|||
conn->tcpstateflags = UIP_CLOSED;
|
||||
nllvdbg("UIP_LAST_ACK TCP state: UIP_CLOSED\n");
|
||||
|
||||
(void)uip_tcpcallback(dev, conn, UIP_CLOSE);
|
||||
(void)tcp_callback(dev, conn, UIP_CLOSE);
|
||||
}
|
||||
break;
|
||||
|
||||
|
@ -773,8 +774,8 @@ found:
|
|||
}
|
||||
|
||||
uip_incr32(conn->rcvseq, 1);
|
||||
(void)uip_tcpcallback(dev, conn, UIP_CLOSE);
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
(void)tcp_callback(dev, conn, UIP_CLOSE);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
}
|
||||
else if ((flags & UIP_ACKDATA) != 0)
|
||||
|
@ -787,7 +788,7 @@ found:
|
|||
|
||||
if (dev->d_len > 0)
|
||||
{
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -806,21 +807,21 @@ found:
|
|||
nllvdbg("TCP state: UIP_TIME_WAIT\n");
|
||||
|
||||
uip_incr32(conn->rcvseq, 1);
|
||||
(void)uip_tcpcallback(dev, conn, UIP_CLOSE);
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
(void)tcp_callback(dev, conn, UIP_CLOSE);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
}
|
||||
|
||||
if (dev->d_len > 0)
|
||||
{
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
}
|
||||
|
||||
goto drop;
|
||||
|
||||
case UIP_TIME_WAIT:
|
||||
uip_tcpsend(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_ACK, UIP_IPTCPH_LEN);
|
||||
return;
|
||||
|
||||
case UIP_CLOSING:
|
||||
|
|
|
@ -51,21 +51,22 @@
|
|||
#include <nuttx/net/netconfig.h>
|
||||
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Private Data
|
||||
****************************************************************************/
|
||||
|
||||
/* The uip_listenports list all currently listening ports. */
|
||||
/* The tcp_listenports list all currently listening ports. */
|
||||
|
||||
static struct uip_conn *uip_listenports[CONFIG_NET_MAX_LISTENPORTS];
|
||||
static FAR struct tcp_conn_s *tcp_listenports[CONFIG_NET_MAX_LISTENPORTS];
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_findlistener
|
||||
* Function: tcp_findlistener
|
||||
*
|
||||
* Description:
|
||||
* Return the connection listener for connections on this port (if any)
|
||||
|
@ -75,7 +76,7 @@ static struct uip_conn *uip_listenports[CONFIG_NET_MAX_LISTENPORTS];
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
struct uip_conn *uip_findlistener(uint16_t portno)
|
||||
FAR struct tcp_conn_s *tcp_findlistener(uint16_t portno)
|
||||
{
|
||||
int ndx;
|
||||
|
||||
|
@ -87,7 +88,7 @@ struct uip_conn *uip_findlistener(uint16_t portno)
|
|||
* local port number?
|
||||
*/
|
||||
|
||||
struct uip_conn *conn = uip_listenports[ndx];
|
||||
FAR struct tcp_conn_s *conn = tcp_listenports[ndx];
|
||||
if (conn && conn->lport == portno)
|
||||
{
|
||||
/* Yes.. we found a listener on this port */
|
||||
|
@ -106,7 +107,7 @@ struct uip_conn *uip_findlistener(uint16_t portno)
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_listeninit
|
||||
* Function: tcp_listeninit
|
||||
*
|
||||
* Description:
|
||||
* Setup the listening data structures
|
||||
|
@ -117,17 +118,17 @@ struct uip_conn *uip_findlistener(uint16_t portno)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_listeninit(void)
|
||||
void tcp_listeninit(void)
|
||||
{
|
||||
int ndx;
|
||||
for (ndx = 0; ndx < CONFIG_NET_MAX_LISTENPORTS; ndx++)
|
||||
{
|
||||
uip_listenports[ndx] = NULL;
|
||||
tcp_listenports[ndx] = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_unlisten
|
||||
* Function: tcp_unlisten
|
||||
*
|
||||
* Description:
|
||||
* Stop listening to the port bound to the specified TCP connection
|
||||
|
@ -137,7 +138,7 @@ void uip_listeninit(void)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_unlisten(struct uip_conn *conn)
|
||||
int tcp_unlisten(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
uip_lock_t flags;
|
||||
int ndx;
|
||||
|
@ -146,9 +147,9 @@ int uip_unlisten(struct uip_conn *conn)
|
|||
flags = uip_lock();
|
||||
for (ndx = 0; ndx < CONFIG_NET_MAX_LISTENPORTS; ndx++)
|
||||
{
|
||||
if (uip_listenports[ndx] == conn)
|
||||
if (tcp_listenports[ndx] == conn)
|
||||
{
|
||||
uip_listenports[ndx] = NULL;
|
||||
tcp_listenports[ndx] = NULL;
|
||||
ret = OK;
|
||||
break;
|
||||
}
|
||||
|
@ -159,7 +160,7 @@ int uip_unlisten(struct uip_conn *conn)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_listen
|
||||
* Function: tcp_listen
|
||||
*
|
||||
* Description:
|
||||
* Start listening to the port bound to the specified TCP connection
|
||||
|
@ -169,7 +170,7 @@ int uip_unlisten(struct uip_conn *conn)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_listen(struct uip_conn *conn)
|
||||
int tcp_listen(FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
uip_lock_t flags;
|
||||
int ndx;
|
||||
|
@ -183,7 +184,7 @@ int uip_listen(struct uip_conn *conn)
|
|||
|
||||
/* First, check if there is already a socket listening on this port */
|
||||
|
||||
if (uip_islistener(conn->lport))
|
||||
if (tcp_islistener(conn->lport))
|
||||
{
|
||||
/* Yes, then we must refuse this request */
|
||||
|
||||
|
@ -203,11 +204,11 @@ int uip_listen(struct uip_conn *conn)
|
|||
{
|
||||
/* Is the next slot available? */
|
||||
|
||||
if (!uip_listenports[ndx])
|
||||
if (!tcp_listenports[ndx])
|
||||
{
|
||||
/* Yes.. we found it */
|
||||
|
||||
uip_listenports[ndx] = conn;
|
||||
tcp_listenports[ndx] = conn;
|
||||
ret = OK;
|
||||
break;
|
||||
}
|
||||
|
@ -219,7 +220,7 @@ int uip_listen(struct uip_conn *conn)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_islistener
|
||||
* Function: tcp_islistener
|
||||
*
|
||||
* Description:
|
||||
* Return true is there is a listener for the specified port
|
||||
|
@ -229,13 +230,13 @@ int uip_listen(struct uip_conn *conn)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
bool uip_islistener(uint16_t portno)
|
||||
bool tcp_islistener(uint16_t portno)
|
||||
{
|
||||
return uip_findlistener(portno) != NULL;
|
||||
return tcp_findlistener(portno) != NULL;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: uip_accept
|
||||
* Function: tcp_accept_connection
|
||||
*
|
||||
* Description:
|
||||
* Accept the new connection for the specified listening port.
|
||||
|
@ -245,10 +246,10 @@ bool uip_islistener(uint16_t portno)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
int uip_accept(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t portno)
|
||||
int tcp_accept_connection(FAR struct uip_driver_s *dev,
|
||||
FAR struct tcp_conn_s *conn, uint16_t portno)
|
||||
{
|
||||
struct uip_conn *listener;
|
||||
FAR struct tcp_conn_s *listener;
|
||||
int ret = ERROR;
|
||||
|
||||
/* The interrupt logic has already allocated and initialized a TCP
|
||||
|
@ -256,7 +257,7 @@ int uip_accept(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
* connection.
|
||||
*/
|
||||
|
||||
listener = uip_findlistener(portno);
|
||||
listener = tcp_findlistener(portno);
|
||||
if (listener)
|
||||
{
|
||||
/* Yes, there is a listener. Is it accepting connections now? */
|
||||
|
@ -274,10 +275,10 @@ int uip_accept(struct uip_driver_s *dev, struct uip_conn *conn,
|
|||
* may be waiting on poll()/select() that the connection is available.
|
||||
*/
|
||||
|
||||
ret = uip_backlogadd(listener, conn);
|
||||
ret = tcp_backlogadd(listener, conn);
|
||||
if (ret == OK)
|
||||
{
|
||||
(void)uip_tcpcallback(dev, listener, UIP_BACKLOG);
|
||||
(void)tcp_callback(dev, listener, UIP_BACKLOG);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -53,6 +53,7 @@
|
|||
#include <nuttx/net/netdev.h>
|
||||
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
|
@ -75,7 +76,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcppoll
|
||||
* Name: tcp_poll
|
||||
*
|
||||
* Description:
|
||||
* Poll a TCP connection structure for availability of TX data
|
||||
|
@ -92,7 +93,7 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcppoll(struct uip_driver_s *dev, struct uip_conn *conn)
|
||||
void tcp_poll(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
uint8_t result;
|
||||
|
||||
|
@ -110,11 +111,11 @@ void uip_tcppoll(struct uip_driver_s *dev, struct uip_conn *conn)
|
|||
|
||||
/* Perform the callback */
|
||||
|
||||
result = uip_tcpcallback(dev, conn, UIP_POLL);
|
||||
result = tcp_callback(dev, conn, UIP_POLL);
|
||||
|
||||
/* Handle the callback response */
|
||||
|
||||
uip_tcpappsend(dev, conn, result);
|
||||
tcp_appsend(dev, conn, result);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
@ -58,7 +58,7 @@
|
|||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#define BUF ((struct uip_tcpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define BUF ((struct tcp_iphdr_s *)&dev->d_buf[UIP_LLH_LEN])
|
||||
|
||||
/****************************************************************************
|
||||
* Public Variables
|
||||
|
@ -73,7 +73,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpsendcomplete
|
||||
* Name: tcp_sendcomplete
|
||||
*
|
||||
* Description:
|
||||
* Complete the final portions of the send operation. This function sets
|
||||
|
@ -90,9 +90,9 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void uip_tcpsendcomplete(FAR struct uip_driver_s *dev)
|
||||
static void tcp_sendcomplete(FAR struct uip_driver_s *dev)
|
||||
{
|
||||
FAR struct uip_tcpip_hdr *pbuf = BUF;
|
||||
FAR struct tcp_iphdr_s *pbuf = BUF;
|
||||
|
||||
pbuf->ttl = UIP_TTL;
|
||||
|
||||
|
@ -117,7 +117,7 @@ static void uip_tcpsendcomplete(FAR struct uip_driver_s *dev)
|
|||
/* Calculate TCP checksum. */
|
||||
|
||||
pbuf->tcpchksum = 0;
|
||||
pbuf->tcpchksum = ~(uip_tcpchksum(dev));
|
||||
pbuf->tcpchksum = ~(tcp_chksum(dev));
|
||||
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
|
||||
|
@ -152,7 +152,7 @@ static void uip_tcpsendcomplete(FAR struct uip_driver_s *dev)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpsendcommon
|
||||
* Name: tcp_sendcommon
|
||||
*
|
||||
* Description:
|
||||
* We're done with the input processing. We are now ready to send a reply
|
||||
|
@ -171,10 +171,10 @@ static void uip_tcpsendcomplete(FAR struct uip_driver_s *dev)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void uip_tcpsendcommon(FAR struct uip_driver_s *dev,
|
||||
FAR struct uip_conn *conn)
|
||||
static void tcp_sendcommon(FAR struct uip_driver_s *dev,
|
||||
FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
FAR struct uip_tcpip_hdr *pbuf = BUF;
|
||||
FAR struct tcp_iphdr_s *pbuf = BUF;
|
||||
|
||||
memcpy(pbuf->ackno, conn->rcvseq, 4);
|
||||
memcpy(pbuf->seqno, conn->sndseq, 4);
|
||||
|
@ -205,7 +205,7 @@ static void uip_tcpsendcommon(FAR struct uip_driver_s *dev,
|
|||
* the message.
|
||||
*/
|
||||
|
||||
uip_tcpsendcomplete(dev);
|
||||
tcp_sendcomplete(dev);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
|
@ -213,7 +213,7 @@ static void uip_tcpsendcommon(FAR struct uip_driver_s *dev,
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpsend
|
||||
* Name: tcp_send
|
||||
*
|
||||
* Description:
|
||||
* Setup to send a TCP packet
|
||||
|
@ -232,19 +232,19 @@ static void uip_tcpsendcommon(FAR struct uip_driver_s *dev,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpsend(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
||||
uint16_t flags, uint16_t len)
|
||||
void tcp_send(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint16_t flags, uint16_t len)
|
||||
{
|
||||
FAR struct uip_tcpip_hdr *pbuf = BUF;
|
||||
FAR struct tcp_iphdr_s *pbuf = BUF;
|
||||
|
||||
pbuf->flags = flags;
|
||||
dev->d_len = len;
|
||||
pbuf->tcpoffset = (UIP_TCPH_LEN / 4) << 4;
|
||||
uip_tcpsendcommon(dev, conn);
|
||||
tcp_sendcommon(dev, conn);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpreset
|
||||
* Name: tcp_reset
|
||||
*
|
||||
* Description:
|
||||
* Send a TCP reset (no-data) message
|
||||
|
@ -260,9 +260,9 @@ void uip_tcpsend(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpreset(FAR struct uip_driver_s *dev)
|
||||
void tcp_reset(FAR struct uip_driver_s *dev)
|
||||
{
|
||||
FAR struct uip_tcpip_hdr *pbuf = BUF;
|
||||
FAR struct tcp_iphdr_s *pbuf = BUF;
|
||||
uint16_t tmp16;
|
||||
uint8_t seqbyte;
|
||||
|
||||
|
@ -321,11 +321,11 @@ void uip_tcpreset(FAR struct uip_driver_s *dev)
|
|||
|
||||
/* And send out the RST packet */
|
||||
|
||||
uip_tcpsendcomplete(dev);
|
||||
tcp_sendcomplete(dev);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpack
|
||||
* Name: tcp_ack
|
||||
*
|
||||
* Description:
|
||||
* Send the SYN or SYNACK response.
|
||||
|
@ -343,10 +343,10 @@ void uip_tcpreset(FAR struct uip_driver_s *dev)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpack(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
||||
uint8_t ack)
|
||||
void tcp_ack(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
uint8_t ack)
|
||||
{
|
||||
struct uip_tcpip_hdr *pbuf = BUF;
|
||||
struct tcp_iphdr_s *pbuf = BUF;
|
||||
|
||||
/* Save the ACK bits */
|
||||
|
||||
|
@ -363,7 +363,7 @@ void uip_tcpack(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
|
||||
/* Complete the common portions of the TCP message */
|
||||
|
||||
uip_tcpsendcommon(dev, conn);
|
||||
tcp_sendcommon(dev, conn);
|
||||
}
|
||||
|
||||
#endif /* CONFIG_NET && CONFIG_NET_TCP */
|
||||
|
|
|
@ -75,7 +75,7 @@
|
|||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#define TCPBUF ((struct uip_tcpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define TCPBUF ((struct tcp_iphdr_s *)&dev->d_buf[UIP_LLH_LEN])
|
||||
|
||||
/* Debug */
|
||||
|
||||
|
@ -96,7 +96,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: send_insert_seqment
|
||||
* Function: psock_insert_segment
|
||||
*
|
||||
* Description:
|
||||
* Insert a new segment in a write buffer queue, keep the segment queue in
|
||||
|
@ -114,8 +114,8 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void send_insert_seqment(FAR struct tcp_wrbuffer_s *wrb,
|
||||
FAR sq_queue_t *q)
|
||||
static void psock_insert_segment(FAR struct tcp_wrbuffer_s *wrb,
|
||||
FAR sq_queue_t *q)
|
||||
{
|
||||
sq_entry_t *entry = (sq_entry_t*)wrb;
|
||||
sq_entry_t *insert = NULL;
|
||||
|
@ -145,7 +145,7 @@ static void send_insert_seqment(FAR struct tcp_wrbuffer_s *wrb,
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: lost_connection
|
||||
* Function: psock_lost_connection
|
||||
*
|
||||
* Description:
|
||||
* The TCP connection has been lost. Free all write buffers.
|
||||
|
@ -159,8 +159,8 @@ static void send_insert_seqment(FAR struct tcp_wrbuffer_s *wrb,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static inline void lost_connection(FAR struct socket *psock,
|
||||
FAR struct uip_conn *conn)
|
||||
static inline void psock_lost_connection(FAR struct socket *psock,
|
||||
FAR struct tcp_conn_s *conn)
|
||||
{
|
||||
FAR sq_entry_t *entry;
|
||||
FAR sq_entry_t *next;
|
||||
|
@ -192,7 +192,7 @@ static inline void lost_connection(FAR struct socket *psock,
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Function: send_interrupt
|
||||
* Function: psock_send_interrupt
|
||||
*
|
||||
* Description:
|
||||
* This function is called from the interrupt level to perform the actual
|
||||
|
@ -211,10 +211,11 @@ static inline void lost_connection(FAR struct socket *psock,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
||||
FAR void *pvpriv, uint16_t flags)
|
||||
static uint16_t psock_send_interrupt(FAR struct uip_driver_s *dev,
|
||||
FAR void *pvconn, FAR void *pvpriv,
|
||||
uint16_t flags)
|
||||
{
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn *)pvconn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)pvconn;
|
||||
FAR struct socket *psock = (FAR struct socket *)pvpriv;
|
||||
|
||||
nllvdbg("flags: %04x\n", flags);
|
||||
|
@ -230,7 +231,7 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
FAR sq_entry_t *next;
|
||||
uint32_t ackno;
|
||||
|
||||
ackno = uip_tcpgetsequence(TCPBUF->ackno);
|
||||
ackno = tcp_getsequence(TCPBUF->ackno);
|
||||
nllvdbg("ACK: ackno=%u flags=%04x\n", ackno, flags);
|
||||
|
||||
/* Look at every write buffer in the unacked_q. The unacked_q
|
||||
|
@ -352,7 +353,7 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
|
||||
/* Free write buffers and terminate polling */
|
||||
|
||||
lost_connection(psock, conn);
|
||||
psock_lost_connection(psock, conn);
|
||||
return flags;
|
||||
}
|
||||
|
||||
|
@ -498,7 +499,7 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
|
||||
nllvdbg("REXMIT: Moving wrb=%p nrtx=%u\n", wrb, WRB_NRTX(wrb));
|
||||
|
||||
send_insert_seqment(wrb, &conn->write_q);
|
||||
psock_insert_segment(wrb, &conn->write_q);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -590,7 +591,7 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
* before the packet is sent.
|
||||
*/
|
||||
|
||||
uip_tcpsetsequence(conn->sndseq, WRB_SEQNO(wrb) + WRB_SENT(wrb));
|
||||
tcp_setsequence(conn->sndseq, WRB_SEQNO(wrb) + WRB_SENT(wrb));
|
||||
|
||||
/* Then set-up to send that amount of data with the offset
|
||||
* corresponding to the amount of data already sent. (this
|
||||
|
@ -637,7 +638,7 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
* segment is waiting for ACK again
|
||||
*/
|
||||
|
||||
send_insert_seqment(wrb, &conn->unacked_q);
|
||||
psock_insert_segment(wrb, &conn->unacked_q);
|
||||
}
|
||||
|
||||
/* Only one data can be sent by low level driver at once,
|
||||
|
@ -658,10 +659,10 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Function: tcp_send
|
||||
* Function: psock_tcp_send
|
||||
*
|
||||
* Description:
|
||||
* The tcp_send() call may be used only when the TCP socket is in a
|
||||
* The psock_tcp_send() call may be used only when the TCP socket is in a
|
||||
* connected state (so that the intended recipient is known).
|
||||
*
|
||||
* Parameters:
|
||||
|
@ -714,7 +715,8 @@ static uint16_t send_interrupt(FAR struct uip_driver_s *dev, FAR void *pvconn,
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
||||
ssize_t psock_tcp_send(FAR struct socket *psock, FAR const void *buf,
|
||||
size_t len)
|
||||
{
|
||||
uip_lock_t save;
|
||||
ssize_t result = 0;
|
||||
|
@ -735,7 +737,7 @@ ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
|
||||
/* Dump the incoming buffer */
|
||||
|
||||
BUF_DUMP("tcp_send", buf, len);
|
||||
BUF_DUMP("psock_tcp_send", buf, len);
|
||||
|
||||
/* Set the socket state to sending */
|
||||
|
||||
|
@ -745,13 +747,13 @@ ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
|
||||
if (len > 0)
|
||||
{
|
||||
struct uip_conn *conn = (struct uip_conn*)psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)psock->s_conn;
|
||||
|
||||
/* Allocate resources to receive a callback */
|
||||
|
||||
if (!psock->s_sndcb)
|
||||
{
|
||||
psock->s_sndcb = uip_tcpcallbackalloc(conn);
|
||||
psock->s_sndcb = tcp_callbackalloc(conn);
|
||||
}
|
||||
|
||||
/* Test if the callback has been allocated */
|
||||
|
@ -772,7 +774,7 @@ ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
psock->s_sndcb->flags = (UIP_ACKDATA | UIP_REXMIT |UIP_POLL | \
|
||||
UIP_CLOSE | UIP_ABORT | UIP_TIMEDOUT);
|
||||
psock->s_sndcb->priv = (void*)psock;
|
||||
psock->s_sndcb->event = send_interrupt;
|
||||
psock->s_sndcb->event = psock_send_interrupt;
|
||||
|
||||
/* Allocate an write buffer */
|
||||
|
||||
|
@ -789,7 +791,7 @@ ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
|
||||
WRB_DUMP("I/O buffer chain", wrb, WRB_PKTLEN(wrb), 0);
|
||||
|
||||
/* send_interrupt() will send data in FIFO order from the
|
||||
/* psock_send_interrupt() will send data in FIFO order from the
|
||||
* conn->write_q
|
||||
*/
|
||||
|
||||
|
|
|
@ -66,7 +66,7 @@
|
|||
# define CONFIG_NET_TCP_SPLIT_SIZE 40
|
||||
#endif
|
||||
|
||||
#define TCPBUF ((struct uip_tcpip_hdr *)&dev->d_buf[UIP_LLH_LEN])
|
||||
#define TCPBUF ((struct tcp_iphdr_s *)&dev->d_buf[UIP_LLH_LEN])
|
||||
|
||||
/****************************************************************************
|
||||
* Private Types
|
||||
|
@ -163,7 +163,7 @@ static uint16_t tcpsend_interrupt(FAR struct uip_driver_s *dev,
|
|||
FAR void *pvconn,
|
||||
FAR void *pvpriv, uint16_t flags)
|
||||
{
|
||||
FAR struct uip_conn *conn = (FAR struct uip_conn*)pvconn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)pvconn;
|
||||
FAR struct send_s *pstate = (FAR struct send_s *)pvpriv;
|
||||
|
||||
nllvdbg("flags: %04x acked: %d sent: %d\n",
|
||||
|
@ -187,7 +187,7 @@ static uint16_t tcpsend_interrupt(FAR struct uip_driver_s *dev,
|
|||
* is the number of bytes to be acknowledged.
|
||||
*/
|
||||
|
||||
pstate->snd_acked = uip_tcpgetsequence(TCPBUF->ackno) - pstate->snd_isn;
|
||||
pstate->snd_acked = tcp_getsequence(TCPBUF->ackno) - pstate->snd_isn;
|
||||
nllvdbg("ACK: acked=%d sent=%d buflen=%d\n",
|
||||
pstate->snd_acked, pstate->snd_sent, pstate->snd_buflen);
|
||||
|
||||
|
@ -367,7 +367,7 @@ static uint16_t tcpsend_interrupt(FAR struct uip_driver_s *dev,
|
|||
|
||||
seqno = pstate->snd_sent + pstate->snd_isn;
|
||||
nllvdbg("SEND: sndseq %08x->%08x\n", conn->sndseq, seqno);
|
||||
uip_tcpsetsequence(conn->sndseq, seqno);
|
||||
tcp_setsequence(conn->sndseq, seqno);
|
||||
|
||||
/* Then set-up to send that amount of data. (this won't actually
|
||||
* happen until the polling cycle completes).
|
||||
|
@ -542,16 +542,16 @@ ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
|
||||
if (len > 0)
|
||||
{
|
||||
struct uip_conn *conn = (struct uip_conn*)psock->s_conn;
|
||||
FAR struct tcp_conn_s *conn = (FAR struct tcp_conn_s *)psock->s_conn;
|
||||
|
||||
/* Allocate resources to receive a callback */
|
||||
|
||||
state.snd_cb = uip_tcpcallbackalloc(conn);
|
||||
state.snd_cb = tcp_callbackalloc(conn);
|
||||
if (state.snd_cb)
|
||||
{
|
||||
/* Get the initial sequence number that will be used */
|
||||
|
||||
state.snd_isn = uip_tcpgetsequence(conn->sndseq);
|
||||
state.snd_isn = tcp_getsequence(conn->sndseq);
|
||||
|
||||
/* There is no outstanding, unacknowledged data after this
|
||||
* initial sequence number.
|
||||
|
@ -584,7 +584,7 @@ ssize_t tcp_send(FAR struct socket *psock, FAR const void *buf, size_t len)
|
|||
|
||||
/* Make sure that no further interrupts are processed */
|
||||
|
||||
uip_tcpcallbackfree(conn, state.snd_cb);
|
||||
tcp_callbackfree(conn, state.snd_cb);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -77,7 +77,7 @@ static uint32_t g_tcpsequence;
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpsetsequence
|
||||
* Name: tcp_setsequence
|
||||
*
|
||||
* Description:
|
||||
* Set the TCP/IP sequence number
|
||||
|
@ -87,7 +87,7 @@ static uint32_t g_tcpsequence;
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpsetsequence(FAR uint8_t *seqno, uint32_t value)
|
||||
void tcp_setsequence(FAR uint8_t *seqno, uint32_t value)
|
||||
{
|
||||
/* Copy the sequence number in network (big-endian) order */
|
||||
|
||||
|
@ -98,7 +98,7 @@ void uip_tcpsetsequence(FAR uint8_t *seqno, uint32_t value)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpgetsequence
|
||||
* Name: tcp_getsequence
|
||||
*
|
||||
* Description:
|
||||
* Get the TCP/IP sequence number
|
||||
|
@ -108,7 +108,7 @@ void uip_tcpsetsequence(FAR uint8_t *seqno, uint32_t value)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
uint32_t uip_tcpgetsequence(FAR uint8_t *seqno)
|
||||
uint32_t tcp_getsequence(FAR uint8_t *seqno)
|
||||
{
|
||||
uint32_t value;
|
||||
|
||||
|
@ -122,7 +122,7 @@ uint32_t uip_tcpgetsequence(FAR uint8_t *seqno)
|
|||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpaddsequence
|
||||
* Name: tcp_addsequence
|
||||
*
|
||||
* Description:
|
||||
* Add the length to get the next TCP sequence number.
|
||||
|
@ -132,13 +132,13 @@ uint32_t uip_tcpgetsequence(FAR uint8_t *seqno)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
uint32_t uip_tcpaddsequence(FAR uint8_t *seqno, uint16_t len)
|
||||
uint32_t tcp_addsequence(FAR uint8_t *seqno, uint16_t len)
|
||||
{
|
||||
return uip_tcpgetsequence(seqno) + (uint32_t)len;
|
||||
return tcp_getsequence(seqno) + (uint32_t)len;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpinitsequence
|
||||
* Name: tcp_initsequence
|
||||
*
|
||||
* Description:
|
||||
* Set the (initial) the TCP/IP sequence number when a TCP connection is
|
||||
|
@ -149,13 +149,13 @@ uint32_t uip_tcpaddsequence(FAR uint8_t *seqno, uint16_t len)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpinitsequence(FAR uint8_t *seqno)
|
||||
void tcp_initsequence(FAR uint8_t *seqno)
|
||||
{
|
||||
uip_tcpsetsequence(seqno, g_tcpsequence);
|
||||
tcp_setsequence(seqno, g_tcpsequence);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcpnextsequence
|
||||
* Name: tcp_nextsequence
|
||||
*
|
||||
* Description:
|
||||
* Increment the TCP/IP sequence number
|
||||
|
@ -165,7 +165,7 @@ void uip_tcpinitsequence(FAR uint8_t *seqno)
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcpnextsequence(void)
|
||||
void tcp_nextsequence(void)
|
||||
{
|
||||
g_tcpsequence++;
|
||||
}
|
||||
|
|
|
@ -53,6 +53,7 @@
|
|||
#include <nuttx/net/netdev.h>
|
||||
|
||||
#include "uip/uip.h"
|
||||
#include "tcp/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
|
@ -75,7 +76,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: uip_tcptimer
|
||||
* Name: tcp_timer
|
||||
*
|
||||
* Description:
|
||||
* Handle a TCP timer expiration for the provided TCP connection
|
||||
|
@ -93,8 +94,8 @@
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
||||
int hsec)
|
||||
void tcp_timer(FAR struct uip_driver_s *dev, FAR struct tcp_conn_s *conn,
|
||||
int hsec)
|
||||
{
|
||||
uint8_t result;
|
||||
|
||||
|
@ -103,7 +104,7 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
|
||||
/* Increase the TCP sequence number */
|
||||
|
||||
uip_tcpnextsequence();
|
||||
tcp_nextsequence();
|
||||
|
||||
/* Reset the length variables. */
|
||||
|
||||
|
@ -128,7 +129,7 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
|
||||
/* Notify upper layers about the timeout */
|
||||
|
||||
result = uip_tcpcallback(dev, conn, UIP_TIMEDOUT);
|
||||
result = tcp_callback(dev, conn, UIP_TIMEDOUT);
|
||||
|
||||
nllvdbg("TCP state: UIP_CLOSED\n");
|
||||
}
|
||||
|
@ -172,16 +173,16 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
conn->tcpstateflags = UIP_CLOSED;
|
||||
nllvdbg("TCP state: UIP_CLOSED\n");
|
||||
|
||||
/* We call uip_tcpcallback() with UIP_TIMEDOUT to
|
||||
/* We call tcp_callback() with UIP_TIMEDOUT to
|
||||
* inform the application that the connection has
|
||||
* timed out.
|
||||
*/
|
||||
|
||||
result = uip_tcpcallback(dev, conn, UIP_TIMEDOUT);
|
||||
result = tcp_callback(dev, conn, UIP_TIMEDOUT);
|
||||
|
||||
/* We also send a reset packet to the remote host. */
|
||||
|
||||
uip_tcpsend(dev, conn, TCP_RST | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_RST | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
goto done;
|
||||
}
|
||||
|
||||
|
@ -208,13 +209,13 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
* SYNACK.
|
||||
*/
|
||||
|
||||
uip_tcpack(dev, conn, TCP_ACK | TCP_SYN);
|
||||
tcp_ack(dev, conn, TCP_ACK | TCP_SYN);
|
||||
goto done;
|
||||
|
||||
case UIP_SYN_SENT:
|
||||
/* In the SYN_SENT state, we retransmit out SYN. */
|
||||
|
||||
uip_tcpack(dev, conn, TCP_SYN);
|
||||
tcp_ack(dev, conn, TCP_SYN);
|
||||
goto done;
|
||||
|
||||
case UIP_ESTABLISHED:
|
||||
|
@ -223,8 +224,8 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
* the code for sending out the packet.
|
||||
*/
|
||||
|
||||
result = uip_tcpcallback(dev, conn, UIP_REXMIT);
|
||||
uip_tcprexmit(dev, conn, result);
|
||||
result = tcp_callback(dev, conn, UIP_REXMIT);
|
||||
tcp_rexmit(dev, conn, result);
|
||||
goto done;
|
||||
|
||||
case UIP_FIN_WAIT_1:
|
||||
|
@ -232,7 +233,7 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
case UIP_LAST_ACK:
|
||||
/* In all these states we should retransmit a FINACK. */
|
||||
|
||||
uip_tcpsend(dev, conn, TCP_FIN | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
tcp_send(dev, conn, TCP_FIN | TCP_ACK, UIP_IPTCPH_LEN);
|
||||
goto done;
|
||||
}
|
||||
}
|
||||
|
@ -246,8 +247,8 @@ void uip_tcptimer(FAR struct uip_driver_s *dev, FAR struct uip_conn *conn,
|
|||
* application for new data.
|
||||
*/
|
||||
|
||||
result = uip_tcpcallback(dev, conn, UIP_POLL);
|
||||
uip_tcpappsend(dev, conn, result);
|
||||
result = tcp_callback(dev, conn, UIP_POLL);
|
||||
tcp_appsend(dev, conn, result);
|
||||
goto done;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -54,9 +54,10 @@
|
|||
#include <assert.h>
|
||||
#include <debug.h>
|
||||
|
||||
#include <nuttx/net/iob.h>
|
||||
#include <nuttx/net/tcp.h>
|
||||
|
||||
#include "tcp/tcp.h"
|
||||
#include "nuttx/net/iob.h"
|
||||
#include "nuttx/net/tcp.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Private Types
|
||||
|
|
79
net/udp/udp.h
Normal file
79
net/udp/udp.h
Normal file
|
@ -0,0 +1,79 @@
|
|||
/****************************************************************************
|
||||
* net/udp/udp.h
|
||||
*
|
||||
* Copyright (C) 2014 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __NET_UDP_UDP_H
|
||||
#define __NET_UDP_UDP_H
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
#include <sys/types.h>
|
||||
|
||||
#ifdef CONFIG_NET_UDP
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Type Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Data
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef __cplusplus
|
||||
# define EXTERN extern "C"
|
||||
extern "C"
|
||||
{
|
||||
#else
|
||||
# define EXTERN extern
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Public Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
#undef EXTERN
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* CONFIG_NET_UDP */
|
||||
#endif /* __NET_UDP_UDP_H */
|
|
@ -125,66 +125,6 @@ void uip_pktpoll(struct uip_driver_s *dev, struct uip_pkt_conn *conn);
|
|||
|
||||
#endif /* CONFIG_NET_PKT */
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
/* Defined in tcp_conn.c ****************************************************/
|
||||
|
||||
void uip_tcpinit(void);
|
||||
struct uip_conn *uip_tcpactive(struct uip_tcpip_hdr *buf);
|
||||
struct uip_conn *uip_nexttcpconn(struct uip_conn *conn);
|
||||
struct uip_conn *uip_tcplistener(uint16_t portno);
|
||||
struct uip_conn *uip_tcpaccept(struct uip_tcpip_hdr *buf);
|
||||
|
||||
/* Defined in tcp_seqno.c ***************************************************/
|
||||
|
||||
void uip_tcpsetsequence(FAR uint8_t *seqno, uint32_t value);
|
||||
uint32_t uip_tcpgetsequence(FAR uint8_t *seqno);
|
||||
uint32_t uip_tcpaddsequence(FAR uint8_t *seqno, uint16_t len);
|
||||
void uip_tcpinitsequence(FAR uint8_t *seqno);
|
||||
void uip_tcpnextsequence(void);
|
||||
|
||||
/* Defined in tcp_poll.c ****************************************************/
|
||||
|
||||
void uip_tcppoll(struct uip_driver_s *dev, struct uip_conn *conn);
|
||||
|
||||
/* Defined in tcp_timer.c ***************************************************/
|
||||
|
||||
void uip_tcptimer(struct uip_driver_s *dev, struct uip_conn *conn, int hsec);
|
||||
|
||||
/* Defined in tcp_listen.c **************************************************/
|
||||
|
||||
void uip_listeninit(void);
|
||||
bool uip_islistener(uint16_t port);
|
||||
int uip_accept(struct uip_driver_s *dev, struct uip_conn *conn, uint16_t portno);
|
||||
|
||||
/* Defined in tcp_send.c ****************************************************/
|
||||
|
||||
void uip_tcpsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t flags, uint16_t len);
|
||||
void uip_tcpreset(struct uip_driver_s *dev);
|
||||
void uip_tcpack(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint8_t ack);
|
||||
|
||||
/* Defined in tcp_appsend.c *************************************************/
|
||||
|
||||
void uip_tcpappsend(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t result);
|
||||
void uip_tcprexmit(struct uip_driver_s *dev, struct uip_conn *conn,
|
||||
uint16_t result);
|
||||
|
||||
/* Defined in tcp_input.c ***************************************************/
|
||||
|
||||
void uip_tcpinput(struct uip_driver_s *dev);
|
||||
|
||||
/* Defined in tcp_callback.c ************************************************/
|
||||
|
||||
uint16_t uip_tcpcallback(FAR struct uip_driver_s *dev,
|
||||
FAR struct uip_conn *conn, uint16_t flags);
|
||||
#ifdef CONFIG_NET_TCP_READAHEAD
|
||||
uint16_t uip_datahandler(FAR struct uip_conn *conn,
|
||||
FAR uint8_t *buffer, uint16_t nbytes);
|
||||
#endif
|
||||
#endif /* CONFIG_NET_TCP */
|
||||
|
||||
#ifdef CONFIG_NET_UDP
|
||||
/* Defined in udp_conn.c ****************************************************/
|
||||
|
||||
|
|
|
@ -202,7 +202,7 @@ uint16_t uip_ipchksum(struct uip_driver_s *dev)
|
|||
|
||||
/* Calculate the TCP checksum of the packet in d_buf and d_appdata. */
|
||||
|
||||
uint16_t uip_tcpchksum(struct uip_driver_s *dev)
|
||||
uint16_t tcp_chksum(struct uip_driver_s *dev)
|
||||
{
|
||||
return upper_layer_chksum(dev, UIP_PROTO_TCP);
|
||||
}
|
||||
|
|
|
@ -133,11 +133,11 @@ void uip_initialize(void)
|
|||
/* Initialize the listening port structures */
|
||||
|
||||
#ifdef CONFIG_NET_TCP
|
||||
uip_listeninit();
|
||||
tcp_listeninit();
|
||||
|
||||
/* Initialize the TCP/IP connection structures */
|
||||
|
||||
uip_tcpinit();
|
||||
tcp_initialize();
|
||||
|
||||
/* Initialize the TCP/IP write buffering */
|
||||
|
||||
|
|
|
@ -54,7 +54,7 @@
|
|||
* statement. While it would be possible to break the uip_input()
|
||||
* function into many smaller functions, this would increase the code
|
||||
* size because of the overhead of parameter passing and the fact that
|
||||
* the optimier would not be as efficient.
|
||||
* the optimizer would not be as efficient.
|
||||
*
|
||||
* The principle is that we have a small buffer, called the d_buf,
|
||||
* in which the device driver puts an incoming packet. The TCP/IP
|
||||
|
@ -93,6 +93,8 @@
|
|||
# include "uip_neighbor.h"
|
||||
#endif /* CONFIG_NET_IPv6 */
|
||||
|
||||
#include "tcp/tcp.h"
|
||||
#include "udp/udp.h"
|
||||
#include "uip.h"
|
||||
|
||||
/****************************************************************************
|
||||
|
@ -506,7 +508,7 @@ int uip_input(struct uip_driver_s *dev)
|
|||
{
|
||||
#ifdef CONFIG_NET_TCP
|
||||
case UIP_PROTO_TCP: /* TCP input */
|
||||
uip_tcpinput(dev);
|
||||
tcp_input(dev);
|
||||
break;
|
||||
#endif
|
||||
|
||||
|
|
|
@ -46,6 +46,7 @@
|
|||
#include <nuttx/net/uip.h>
|
||||
#include <nuttx/net/netdev.h>
|
||||
|
||||
#include "tcp/tcp.h"
|
||||
#include "uip.h"
|
||||
|
||||
/****************************************************************************
|
||||
|
@ -196,7 +197,7 @@ static int uip_polludpconnections(FAR struct uip_driver_s *dev,
|
|||
static inline int uip_polltcpconnections(FAR struct uip_driver_s *dev,
|
||||
uip_poll_callback_t callback)
|
||||
{
|
||||
FAR struct uip_conn *conn = NULL;
|
||||
FAR struct tcp_conn_s *conn = NULL;
|
||||
int bstop = 0;
|
||||
|
||||
/* Traverse all of the active TCP connections and perform the poll action */
|
||||
|
@ -205,7 +206,7 @@ static inline int uip_polltcpconnections(FAR struct uip_driver_s *dev,
|
|||
{
|
||||
/* Perform the TCP TX poll */
|
||||
|
||||
uip_tcppoll(dev, conn);
|
||||
tcp_poll(dev, conn);
|
||||
|
||||
/* Call back into the driver */
|
||||
|
||||
|
@ -235,7 +236,7 @@ static inline int uip_polltcpconnections(FAR struct uip_driver_s *dev,
|
|||
static inline int uip_polltcptimer(FAR struct uip_driver_s *dev,
|
||||
uip_poll_callback_t callback, int hsec)
|
||||
{
|
||||
FAR struct uip_conn *conn = NULL;
|
||||
FAR struct tcp_conn_s *conn = NULL;
|
||||
int bstop = 0;
|
||||
|
||||
/* Traverse all of the active TCP connections and perform the poll action */
|
||||
|
@ -244,7 +245,7 @@ static inline int uip_polltcptimer(FAR struct uip_driver_s *dev,
|
|||
{
|
||||
/* Perform the TCP timer poll */
|
||||
|
||||
uip_tcptimer(dev, conn, hsec);
|
||||
tcp_timer(dev, conn, hsec);
|
||||
|
||||
/* Call back into the driver */
|
||||
|
||||
|
|
Loading…
Reference in a new issue