📄 uip-udp.h
字号:
/**************************************************************************** * net/uip/uip-udp.h * Header file for the uIP UDP stack. * * The uIP UDP stack header file contains definitions for a number * of C macros that are used by uIP programs as well as internal uIP * structures, UDP header structures and function declarations. * * Copyright (C) 2007 Gregory Nutt. All rights reserved. * Author: Gregory Nutt <spudmonkey@racsa.co.cr> * * This logic was leveraged from uIP which also has a BSD-style license: * * Author Adam Dunkels <adam@dunkels.com> * Copyright (c) 2001-2003, Adam Dunkels. * All rights reserved. * * 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. The name of the author may not be used to endorse or promote * products derived from this software without specific prior * written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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_UIP_UIP_UDP_H#define __NET_UIP_UIP_UDP_H/**************************************************************************** * Included Files ****************************************************************************/#include <nuttx/config.h>#include <sys/types.h>#include <net/uip/uipopt.h>/**************************************************************************** * Definitions ****************************************************************************//* Header sizes */#define UIP_UDPH_LEN 8 /* Size of UDP header */#define UIP_IPUDPH_LEN (UIP_UDPH_LEN + UIP_IPH_LEN) /* Size of IP + UDP header *//**************************************************************************** * Public Type Definitions ****************************************************************************//* Representation of a uIP UDP connection */struct uip_driver_s; /* Forward reference */struct uip_udp_conn{ dq_entry_t node; /* Supports a doubly linked list */ uip_ipaddr_t ripaddr; /* The IP address of the remote peer */ uint16 lport; /* The local port number in network byte order */ uint16 rport; /* The remote port number in network byte order */ uint8 ttl; /* Default time-to-live */ /* Defines the UDP callback */ void *private; void (*event)(struct uip_driver_s *dev, struct uip_udp_conn *conn, uint8 flags);};/* The UDP and IP headers */struct uip_udpip_hdr{#ifdef CONFIG_NET_IPv6 /* IPv6 Ip header */ uint8 vtc; /* Bits 0-3: version, bits 4-7: traffic class (MS) */ uint8 tcf; /* Bits 0-3: traffic class (LS), 4-bits: flow label (MS) */ uint16 flow; /* 16-bit flow label (LS) */ uint8 len[2]; /* 16-bit Payload length */ uint8 proto; /* 8-bit Next header (same as IPv4 protocol field) */ uint8 ttl; /* 8-bit Hop limit (like IPv4 TTL field) */ uip_ip6addr_t srcipaddr; /* 128-bit Source address */ uip_ip6addr_t destipaddr; /* 128-bit Destination address */#else /* CONFIG_NET_IPv6 */ /* IPv4 header */ uint8 vhl; /* 8-bit Version (4) and header length (5 or 6) */ uint8 tos; /* 8-bit Type of service (e.g., 6=TCP) */ uint8 len[2]; /* 16-bit Total length */ uint8 ipid[2]; /* 16-bit Identification */ uint8 ipoffset[2]; /* 16-bit IP flags + fragment offset */ uint8 ttl; /* 8-bit Time to Live */ uint8 proto; /* 8-bit Protocol */ uint16 ipchksum; /* 16-bit Header checksum */ uint16 srcipaddr[2]; /* 32-bit Source IP address */ uint16 destipaddr[2]; /* 32-bit Destination IP address */#endif /* CONFIG_NET_IPv6 */ /* UDP header */ uint16 srcport; uint16 destport; uint16 udplen; uint16 udpchksum;};/* The structure holding the UDP statistics that are gathered if * CONFIG_NET_STATISTICS is defined. */#ifdef CONFIG_NET_STATISTICSstruct uip_udp_stats_s{ uip_stats_t drop; /* Number of dropped UDP segments */ uip_stats_t recv; /* Number of recived UDP segments */ uip_stats_t sent; /* Number of sent UDP segments */ uip_stats_t chkerr; /* Number of UDP segments with a bad checksum */};#endif/**************************************************************************** * Public Data ****************************************************************************//**************************************************************************** * Public Function Prototypes ****************************************************************************//* uIP application functions * * Functions used by an application running of top of uIP. This includes * functions for opening and closing connections, sending and receiving * data, etc. * * Find a free connection structure and allocate it for use. This is * normally something done by the implementation of the socket() API */extern struct uip_udp_conn *uip_udpalloc(void);/* Free a connection structure that is no longer in use. This should * be done by the implementation of close() */extern void uip_udpfree(struct uip_udp_conn *conn);/* Bind a UDP connection to a local address */#ifdef CONFIG_NET_IPv6extern int uip_udpbind(struct uip_udp_conn *conn, const struct sockaddr_in6 *addr);#elseextern int uip_udpbind(struct uip_udp_conn *conn, const struct sockaddr_in *addr);#endif/* This function sets up a new UDP connection. The function will * automatically allocate an unused local port for the new * connection. However, another port can be chosen by using the * uip_udpbind() call, after the uip_udpconnect() function has been * called. * * This function is called as part of the implementation of sendto * and recvfrom. * * addr The address of the remote host. */#ifdef CONFIG_NET_IPv6extern int uip_udpconnect(struct uip_udp_conn *conn, const struct sockaddr_in6 *addr);#elseextern int uip_udpconnect(struct uip_udp_conn *conn, const struct sockaddr_in *addr);#endif/* Enable/disable UDP callbacks on a connection */extern void uip_udpenable(struct uip_udp_conn *conn);extern void uip_udpdisable(struct uip_udp_conn *conn);#endif /* __NET_UIP_UIP_UDP_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -