⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 uip-udp.h

📁 這是一個實時嵌入式作業系統 實作了MCS51 ARM等MCU
💻 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 + -