1*10465441SEvalZero /** 2*10465441SEvalZero * @file 3*10465441SEvalZero * pbuf API 4*10465441SEvalZero */ 5*10465441SEvalZero 6*10465441SEvalZero /* 7*10465441SEvalZero * Copyright (c) 2001-2004 Swedish Institute of Computer Science. 8*10465441SEvalZero * All rights reserved. 9*10465441SEvalZero * 10*10465441SEvalZero * Redistribution and use in source and binary forms, with or without modification, 11*10465441SEvalZero * are permitted provided that the following conditions are met: 12*10465441SEvalZero * 13*10465441SEvalZero * 1. Redistributions of source code must retain the above copyright notice, 14*10465441SEvalZero * this list of conditions and the following disclaimer. 15*10465441SEvalZero * 2. Redistributions in binary form must reproduce the above copyright notice, 16*10465441SEvalZero * this list of conditions and the following disclaimer in the documentation 17*10465441SEvalZero * and/or other materials provided with the distribution. 18*10465441SEvalZero * 3. The name of the author may not be used to endorse or promote products 19*10465441SEvalZero * derived from this software without specific prior written permission. 20*10465441SEvalZero * 21*10465441SEvalZero * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 22*10465441SEvalZero * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 23*10465441SEvalZero * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT 24*10465441SEvalZero * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 25*10465441SEvalZero * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT 26*10465441SEvalZero * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 27*10465441SEvalZero * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 28*10465441SEvalZero * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 29*10465441SEvalZero * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 30*10465441SEvalZero * OF SUCH DAMAGE. 31*10465441SEvalZero * 32*10465441SEvalZero * This file is part of the lwIP TCP/IP stack. 33*10465441SEvalZero * 34*10465441SEvalZero * Author: Adam Dunkels <[email protected]> 35*10465441SEvalZero * 36*10465441SEvalZero */ 37*10465441SEvalZero 38*10465441SEvalZero #ifndef LWIP_HDR_PBUF_H 39*10465441SEvalZero #define LWIP_HDR_PBUF_H 40*10465441SEvalZero 41*10465441SEvalZero #include "lwip/opt.h" 42*10465441SEvalZero #include "lwip/err.h" 43*10465441SEvalZero 44*10465441SEvalZero #ifdef __cplusplus 45*10465441SEvalZero extern "C" { 46*10465441SEvalZero #endif 47*10465441SEvalZero 48*10465441SEvalZero /** LWIP_SUPPORT_CUSTOM_PBUF==1: Custom pbufs behave much like their pbuf type 49*10465441SEvalZero * but they are allocated by external code (initialised by calling 50*10465441SEvalZero * pbuf_alloced_custom()) and when pbuf_free gives up their last reference, they 51*10465441SEvalZero * are freed by calling pbuf_custom->custom_free_function(). 52*10465441SEvalZero * Currently, the pbuf_custom code is only needed for one specific configuration 53*10465441SEvalZero * of IP_FRAG, unless required by external driver/application code. */ 54*10465441SEvalZero #ifndef LWIP_SUPPORT_CUSTOM_PBUF 55*10465441SEvalZero #define LWIP_SUPPORT_CUSTOM_PBUF ((IP_FRAG && !LWIP_NETIF_TX_SINGLE_PBUF) || (LWIP_IPV6 && LWIP_IPV6_FRAG)) 56*10465441SEvalZero #endif 57*10465441SEvalZero 58*10465441SEvalZero /* @todo: We need a mechanism to prevent wasting memory in every pbuf 59*10465441SEvalZero (TCP vs. UDP, IPv4 vs. IPv6: UDP/IPv4 packets may waste up to 28 bytes) */ 60*10465441SEvalZero 61*10465441SEvalZero #define PBUF_TRANSPORT_HLEN 20 62*10465441SEvalZero #if LWIP_IPV6 63*10465441SEvalZero #define PBUF_IP_HLEN 40 64*10465441SEvalZero #else 65*10465441SEvalZero #define PBUF_IP_HLEN 20 66*10465441SEvalZero #endif 67*10465441SEvalZero 68*10465441SEvalZero /** 69*10465441SEvalZero * @ingroup pbuf 70*10465441SEvalZero * Enumeration of pbuf layers 71*10465441SEvalZero */ 72*10465441SEvalZero typedef enum { 73*10465441SEvalZero /** Includes spare room for transport layer header, e.g. UDP header. 74*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like udp_send(). 75*10465441SEvalZero */ 76*10465441SEvalZero PBUF_TRANSPORT, 77*10465441SEvalZero /** Includes spare room for IP header. 78*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like raw_send(). 79*10465441SEvalZero */ 80*10465441SEvalZero PBUF_IP, 81*10465441SEvalZero /** Includes spare room for link layer header (ethernet header). 82*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like ethernet_output(). 83*10465441SEvalZero * @see PBUF_LINK_HLEN 84*10465441SEvalZero */ 85*10465441SEvalZero PBUF_LINK, 86*10465441SEvalZero /** Includes spare room for additional encapsulation header before ethernet 87*10465441SEvalZero * headers (e.g. 802.11). 88*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like netif->linkoutput(). 89*10465441SEvalZero * @see PBUF_LINK_ENCAPSULATION_HLEN 90*10465441SEvalZero */ 91*10465441SEvalZero PBUF_RAW_TX, 92*10465441SEvalZero /** Use this for input packets in a netif driver when calling netif->input() 93*10465441SEvalZero * in the most common case - ethernet-layer netif driver. */ 94*10465441SEvalZero PBUF_RAW 95*10465441SEvalZero } pbuf_layer; 96*10465441SEvalZero 97*10465441SEvalZero /** 98*10465441SEvalZero * @ingroup pbuf 99*10465441SEvalZero * Enumeration of pbuf types 100*10465441SEvalZero */ 101*10465441SEvalZero typedef enum { 102*10465441SEvalZero /** pbuf data is stored in RAM, used for TX mostly, struct pbuf and its payload 103*10465441SEvalZero are allocated in one piece of contiguous memory (so the first payload byte 104*10465441SEvalZero can be calculated from struct pbuf). 105*10465441SEvalZero pbuf_alloc() allocates PBUF_RAM pbufs as unchained pbufs (although that might 106*10465441SEvalZero change in future versions). 107*10465441SEvalZero This should be used for all OUTGOING packets (TX).*/ 108*10465441SEvalZero PBUF_RAM, 109*10465441SEvalZero /** pbuf data is stored in ROM, i.e. struct pbuf and its payload are located in 110*10465441SEvalZero totally different memory areas. Since it points to ROM, payload does not 111*10465441SEvalZero have to be copied when queued for transmission. */ 112*10465441SEvalZero PBUF_ROM, 113*10465441SEvalZero /** pbuf comes from the pbuf pool. Much like PBUF_ROM but payload might change 114*10465441SEvalZero so it has to be duplicated when queued before transmitting, depending on 115*10465441SEvalZero who has a 'ref' to it. */ 116*10465441SEvalZero PBUF_REF, 117*10465441SEvalZero /** pbuf payload refers to RAM. This one comes from a pool and should be used 118*10465441SEvalZero for RX. Payload can be chained (scatter-gather RX) but like PBUF_RAM, struct 119*10465441SEvalZero pbuf and its payload are allocated in one piece of contiguous memory (so 120*10465441SEvalZero the first payload byte can be calculated from struct pbuf). 121*10465441SEvalZero Don't use this for TX, if the pool becomes empty e.g. because of TCP queuing, 122*10465441SEvalZero you are unable to receive TCP acks! */ 123*10465441SEvalZero PBUF_POOL 124*10465441SEvalZero } pbuf_type; 125*10465441SEvalZero 126*10465441SEvalZero 127*10465441SEvalZero /** indicates this packet's data should be immediately passed to the application */ 128*10465441SEvalZero #define PBUF_FLAG_PUSH 0x01U 129*10465441SEvalZero /** indicates this is a custom pbuf: pbuf_free calls pbuf_custom->custom_free_function() 130*10465441SEvalZero when the last reference is released (plus custom PBUF_RAM cannot be trimmed) */ 131*10465441SEvalZero #define PBUF_FLAG_IS_CUSTOM 0x02U 132*10465441SEvalZero /** indicates this pbuf is UDP multicast to be looped back */ 133*10465441SEvalZero #define PBUF_FLAG_MCASTLOOP 0x04U 134*10465441SEvalZero /** indicates this pbuf was received as link-level broadcast */ 135*10465441SEvalZero #define PBUF_FLAG_LLBCAST 0x08U 136*10465441SEvalZero /** indicates this pbuf was received as link-level multicast */ 137*10465441SEvalZero #define PBUF_FLAG_LLMCAST 0x10U 138*10465441SEvalZero /** indicates this pbuf includes a TCP FIN flag */ 139*10465441SEvalZero #define PBUF_FLAG_TCP_FIN 0x20U 140*10465441SEvalZero 141*10465441SEvalZero /** Main packet buffer struct */ 142*10465441SEvalZero struct pbuf { 143*10465441SEvalZero /** next pbuf in singly linked pbuf chain */ 144*10465441SEvalZero struct pbuf *next; 145*10465441SEvalZero 146*10465441SEvalZero /** pointer to the actual data in the buffer */ 147*10465441SEvalZero void *payload; 148*10465441SEvalZero 149*10465441SEvalZero /** 150*10465441SEvalZero * total length of this buffer and all next buffers in chain 151*10465441SEvalZero * belonging to the same packet. 152*10465441SEvalZero * 153*10465441SEvalZero * For non-queue packet chains this is the invariant: 154*10465441SEvalZero * p->tot_len == p->len + (p->next? p->next->tot_len: 0) 155*10465441SEvalZero */ 156*10465441SEvalZero u16_t tot_len; 157*10465441SEvalZero 158*10465441SEvalZero /** length of this buffer */ 159*10465441SEvalZero u16_t len; 160*10465441SEvalZero 161*10465441SEvalZero /** pbuf_type as u8_t instead of enum to save space */ 162*10465441SEvalZero u8_t /*pbuf_type*/ type; 163*10465441SEvalZero 164*10465441SEvalZero /** misc flags */ 165*10465441SEvalZero u8_t flags; 166*10465441SEvalZero 167*10465441SEvalZero /** 168*10465441SEvalZero * the reference count always equals the number of pointers 169*10465441SEvalZero * that refer to this pbuf. This can be pointers from an application, 170*10465441SEvalZero * the stack itself, or pbuf->next pointers from a chain. 171*10465441SEvalZero */ 172*10465441SEvalZero u16_t ref; 173*10465441SEvalZero }; 174*10465441SEvalZero 175*10465441SEvalZero 176*10465441SEvalZero /** Helper struct for const-correctness only. 177*10465441SEvalZero * The only meaning of this one is to provide a const payload pointer 178*10465441SEvalZero * for PBUF_ROM type. 179*10465441SEvalZero */ 180*10465441SEvalZero struct pbuf_rom { 181*10465441SEvalZero /** next pbuf in singly linked pbuf chain */ 182*10465441SEvalZero struct pbuf *next; 183*10465441SEvalZero 184*10465441SEvalZero /** pointer to the actual data in the buffer */ 185*10465441SEvalZero const void *payload; 186*10465441SEvalZero }; 187*10465441SEvalZero 188*10465441SEvalZero #if LWIP_SUPPORT_CUSTOM_PBUF 189*10465441SEvalZero /** Prototype for a function to free a custom pbuf */ 190*10465441SEvalZero typedef void (*pbuf_free_custom_fn)(struct pbuf *p); 191*10465441SEvalZero 192*10465441SEvalZero /** A custom pbuf: like a pbuf, but following a function pointer to free it. */ 193*10465441SEvalZero struct pbuf_custom { 194*10465441SEvalZero /** The actual pbuf */ 195*10465441SEvalZero struct pbuf pbuf; 196*10465441SEvalZero /** This function is called when pbuf_free deallocates this pbuf(_custom) */ 197*10465441SEvalZero pbuf_free_custom_fn custom_free_function; 198*10465441SEvalZero }; 199*10465441SEvalZero #endif /* LWIP_SUPPORT_CUSTOM_PBUF */ 200*10465441SEvalZero 201*10465441SEvalZero /** Define this to 0 to prevent freeing ooseq pbufs when the PBUF_POOL is empty */ 202*10465441SEvalZero #ifndef PBUF_POOL_FREE_OOSEQ 203*10465441SEvalZero #define PBUF_POOL_FREE_OOSEQ 1 204*10465441SEvalZero #endif /* PBUF_POOL_FREE_OOSEQ */ 205*10465441SEvalZero #if LWIP_TCP && TCP_QUEUE_OOSEQ && NO_SYS && PBUF_POOL_FREE_OOSEQ 206*10465441SEvalZero extern volatile u8_t pbuf_free_ooseq_pending; 207*10465441SEvalZero void pbuf_free_ooseq(void); 208*10465441SEvalZero /** When not using sys_check_timeouts(), call PBUF_CHECK_FREE_OOSEQ() 209*10465441SEvalZero at regular intervals from main level to check if ooseq pbufs need to be 210*10465441SEvalZero freed! */ 211*10465441SEvalZero #define PBUF_CHECK_FREE_OOSEQ() do { if(pbuf_free_ooseq_pending) { \ 212*10465441SEvalZero /* pbuf_alloc() reported PBUF_POOL to be empty -> try to free some \ 213*10465441SEvalZero ooseq queued pbufs now */ \ 214*10465441SEvalZero pbuf_free_ooseq(); }}while(0) 215*10465441SEvalZero #else /* LWIP_TCP && TCP_QUEUE_OOSEQ && NO_SYS && PBUF_POOL_FREE_OOSEQ */ 216*10465441SEvalZero /* Otherwise declare an empty PBUF_CHECK_FREE_OOSEQ */ 217*10465441SEvalZero #define PBUF_CHECK_FREE_OOSEQ() 218*10465441SEvalZero #endif /* LWIP_TCP && TCP_QUEUE_OOSEQ && NO_SYS && PBUF_POOL_FREE_OOSEQ*/ 219*10465441SEvalZero 220*10465441SEvalZero /* Initializes the pbuf module. This call is empty for now, but may not be in future. */ 221*10465441SEvalZero #define pbuf_init() 222*10465441SEvalZero 223*10465441SEvalZero struct pbuf *pbuf_alloc(pbuf_layer l, u16_t length, pbuf_type type); 224*10465441SEvalZero #if LWIP_SUPPORT_CUSTOM_PBUF 225*10465441SEvalZero struct pbuf *pbuf_alloced_custom(pbuf_layer l, u16_t length, pbuf_type type, 226*10465441SEvalZero struct pbuf_custom *p, void *payload_mem, 227*10465441SEvalZero u16_t payload_mem_len); 228*10465441SEvalZero #endif /* LWIP_SUPPORT_CUSTOM_PBUF */ 229*10465441SEvalZero void pbuf_realloc(struct pbuf *p, u16_t size); 230*10465441SEvalZero u8_t pbuf_header(struct pbuf *p, s16_t header_size); 231*10465441SEvalZero u8_t pbuf_header_force(struct pbuf *p, s16_t header_size); 232*10465441SEvalZero void pbuf_ref(struct pbuf *p); 233*10465441SEvalZero u8_t pbuf_free(struct pbuf *p); 234*10465441SEvalZero u16_t pbuf_clen(const struct pbuf *p); 235*10465441SEvalZero void pbuf_cat(struct pbuf *head, struct pbuf *tail); 236*10465441SEvalZero void pbuf_chain(struct pbuf *head, struct pbuf *tail); 237*10465441SEvalZero struct pbuf *pbuf_dechain(struct pbuf *p); 238*10465441SEvalZero err_t pbuf_copy(struct pbuf *p_to, const struct pbuf *p_from); 239*10465441SEvalZero u16_t pbuf_copy_partial(const struct pbuf *p, void *dataptr, u16_t len, u16_t offset); 240*10465441SEvalZero err_t pbuf_take(struct pbuf *buf, const void *dataptr, u16_t len); 241*10465441SEvalZero err_t pbuf_take_at(struct pbuf *buf, const void *dataptr, u16_t len, u16_t offset); 242*10465441SEvalZero struct pbuf *pbuf_skip(struct pbuf* in, u16_t in_offset, u16_t* out_offset); 243*10465441SEvalZero struct pbuf *pbuf_coalesce(struct pbuf *p, pbuf_layer layer); 244*10465441SEvalZero #if LWIP_CHECKSUM_ON_COPY 245*10465441SEvalZero err_t pbuf_fill_chksum(struct pbuf *p, u16_t start_offset, const void *dataptr, 246*10465441SEvalZero u16_t len, u16_t *chksum); 247*10465441SEvalZero #endif /* LWIP_CHECKSUM_ON_COPY */ 248*10465441SEvalZero #if LWIP_TCP && TCP_QUEUE_OOSEQ && LWIP_WND_SCALE 249*10465441SEvalZero void pbuf_split_64k(struct pbuf *p, struct pbuf **rest); 250*10465441SEvalZero #endif /* LWIP_TCP && TCP_QUEUE_OOSEQ && LWIP_WND_SCALE */ 251*10465441SEvalZero 252*10465441SEvalZero u8_t pbuf_get_at(const struct pbuf* p, u16_t offset); 253*10465441SEvalZero int pbuf_try_get_at(const struct pbuf* p, u16_t offset); 254*10465441SEvalZero void pbuf_put_at(struct pbuf* p, u16_t offset, u8_t data); 255*10465441SEvalZero u16_t pbuf_memcmp(const struct pbuf* p, u16_t offset, const void* s2, u16_t n); 256*10465441SEvalZero u16_t pbuf_memfind(const struct pbuf* p, const void* mem, u16_t mem_len, u16_t start_offset); 257*10465441SEvalZero u16_t pbuf_strstr(const struct pbuf* p, const char* substr); 258*10465441SEvalZero 259*10465441SEvalZero #ifdef __cplusplus 260*10465441SEvalZero } 261*10465441SEvalZero #endif 262*10465441SEvalZero 263*10465441SEvalZero #endif /* LWIP_HDR_PBUF_H */ 264