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 /** @ingroup pbuf 59*10465441SEvalZero * PBUF_NEEDS_COPY(p): return a boolean value indicating whether the given 60*10465441SEvalZero * pbuf needs to be copied in order to be kept around beyond the current call 61*10465441SEvalZero * stack without risking being corrupted. The default setting provides safety: 62*10465441SEvalZero * it will make a copy iof any pbuf chain that does not consist entirely of 63*10465441SEvalZero * PBUF_ROM type pbufs. For setups with zero-copy support, it may be redefined 64*10465441SEvalZero * to evaluate to true in all cases, for example. However, doing so also has an 65*10465441SEvalZero * effect on the application side: any buffers that are *not* copied must also 66*10465441SEvalZero * *not* be reused by the application after passing them to lwIP. For example, 67*10465441SEvalZero * when setting PBUF_NEEDS_COPY to (0), after using udp_send() with a PBUF_RAM 68*10465441SEvalZero * pbuf, the application must free the pbuf immediately, rather than reusing it 69*10465441SEvalZero * for other purposes. For more background information on this, see tasks #6735 70*10465441SEvalZero * and #7896, and bugs #11400 and #49914. */ 71*10465441SEvalZero #ifndef PBUF_NEEDS_COPY 72*10465441SEvalZero #define PBUF_NEEDS_COPY(p) ((p)->type_internal & PBUF_TYPE_FLAG_DATA_VOLATILE) 73*10465441SEvalZero #endif /* PBUF_NEEDS_COPY */ 74*10465441SEvalZero 75*10465441SEvalZero /* @todo: We need a mechanism to prevent wasting memory in every pbuf 76*10465441SEvalZero (TCP vs. UDP, IPv4 vs. IPv6: UDP/IPv4 packets may waste up to 28 bytes) */ 77*10465441SEvalZero 78*10465441SEvalZero #define PBUF_TRANSPORT_HLEN 20 79*10465441SEvalZero #if LWIP_IPV6 80*10465441SEvalZero #define PBUF_IP_HLEN 40 81*10465441SEvalZero #else 82*10465441SEvalZero #define PBUF_IP_HLEN 20 83*10465441SEvalZero #endif 84*10465441SEvalZero 85*10465441SEvalZero /** 86*10465441SEvalZero * @ingroup pbuf 87*10465441SEvalZero * Enumeration of pbuf layers 88*10465441SEvalZero */ 89*10465441SEvalZero typedef enum { 90*10465441SEvalZero /** Includes spare room for transport layer header, e.g. UDP header. 91*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like udp_send(). 92*10465441SEvalZero */ 93*10465441SEvalZero PBUF_TRANSPORT = PBUF_LINK_ENCAPSULATION_HLEN + PBUF_LINK_HLEN + PBUF_IP_HLEN + PBUF_TRANSPORT_HLEN, 94*10465441SEvalZero /** Includes spare room for IP header. 95*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like raw_send(). 96*10465441SEvalZero */ 97*10465441SEvalZero PBUF_IP = PBUF_LINK_ENCAPSULATION_HLEN + PBUF_LINK_HLEN + PBUF_IP_HLEN, 98*10465441SEvalZero /** Includes spare room for link layer header (ethernet header). 99*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like ethernet_output(). 100*10465441SEvalZero * @see PBUF_LINK_HLEN 101*10465441SEvalZero */ 102*10465441SEvalZero PBUF_LINK = PBUF_LINK_ENCAPSULATION_HLEN + PBUF_LINK_HLEN, 103*10465441SEvalZero /** Includes spare room for additional encapsulation header before ethernet 104*10465441SEvalZero * headers (e.g. 802.11). 105*10465441SEvalZero * Use this if you intend to pass the pbuf to functions like netif->linkoutput(). 106*10465441SEvalZero * @see PBUF_LINK_ENCAPSULATION_HLEN 107*10465441SEvalZero */ 108*10465441SEvalZero PBUF_RAW_TX = PBUF_LINK_ENCAPSULATION_HLEN, 109*10465441SEvalZero /** Use this for input packets in a netif driver when calling netif->input() 110*10465441SEvalZero * in the most common case - ethernet-layer netif driver. */ 111*10465441SEvalZero PBUF_RAW = 0 112*10465441SEvalZero } pbuf_layer; 113*10465441SEvalZero 114*10465441SEvalZero 115*10465441SEvalZero /* Base flags for pbuf_type definitions: */ 116*10465441SEvalZero 117*10465441SEvalZero /** Indicates that the payload directly follows the struct pbuf. 118*10465441SEvalZero * This makes @ref pbuf_header work in both directions. */ 119*10465441SEvalZero #define PBUF_TYPE_FLAG_STRUCT_DATA_CONTIGUOUS 0x80 120*10465441SEvalZero /** Indicates the data stored in this pbuf can change. If this pbuf needs 121*10465441SEvalZero * to be queued, it must be copied/duplicated. */ 122*10465441SEvalZero #define PBUF_TYPE_FLAG_DATA_VOLATILE 0x40 123*10465441SEvalZero /** 4 bits are reserved for 16 allocation sources (e.g. heap, pool1, pool2, etc) 124*10465441SEvalZero * Internally, we use: 0=heap, 1=MEMP_PBUF, 2=MEMP_PBUF_POOL -> 13 types free*/ 125*10465441SEvalZero #define PBUF_TYPE_ALLOC_SRC_MASK 0x0F 126*10465441SEvalZero /** Indicates this pbuf is used for RX (if not set, indicates use for TX). 127*10465441SEvalZero * This information can be used to keep some spare RX buffers e.g. for 128*10465441SEvalZero * receiving TCP ACKs to unblock a connection) */ 129*10465441SEvalZero #define PBUF_ALLOC_FLAG_RX 0x0100 130*10465441SEvalZero /** Indicates the application needs the pbuf payload to be in one piece */ 131*10465441SEvalZero #define PBUF_ALLOC_FLAG_DATA_CONTIGUOUS 0x0200 132*10465441SEvalZero 133*10465441SEvalZero #define PBUF_TYPE_ALLOC_SRC_MASK_STD_HEAP 0x00 134*10465441SEvalZero #define PBUF_TYPE_ALLOC_SRC_MASK_STD_MEMP_PBUF 0x01 135*10465441SEvalZero #define PBUF_TYPE_ALLOC_SRC_MASK_STD_MEMP_PBUF_POOL 0x02 136*10465441SEvalZero /** First pbuf allocation type for applications */ 137*10465441SEvalZero #define PBUF_TYPE_ALLOC_SRC_MASK_APP_MIN 0x03 138*10465441SEvalZero /** Last pbuf allocation type for applications */ 139*10465441SEvalZero #define PBUF_TYPE_ALLOC_SRC_MASK_APP_MAX PBUF_TYPE_ALLOC_SRC_MASK 140*10465441SEvalZero 141*10465441SEvalZero /** 142*10465441SEvalZero * @ingroup pbuf 143*10465441SEvalZero * Enumeration of pbuf types 144*10465441SEvalZero */ 145*10465441SEvalZero typedef enum { 146*10465441SEvalZero /** pbuf data is stored in RAM, used for TX mostly, struct pbuf and its payload 147*10465441SEvalZero are allocated in one piece of contiguous memory (so the first payload byte 148*10465441SEvalZero can be calculated from struct pbuf). 149*10465441SEvalZero pbuf_alloc() allocates PBUF_RAM pbufs as unchained pbufs (although that might 150*10465441SEvalZero change in future versions). 151*10465441SEvalZero This should be used for all OUTGOING packets (TX).*/ 152*10465441SEvalZero PBUF_RAM = (PBUF_ALLOC_FLAG_DATA_CONTIGUOUS | PBUF_TYPE_FLAG_STRUCT_DATA_CONTIGUOUS | PBUF_TYPE_ALLOC_SRC_MASK_STD_HEAP), 153*10465441SEvalZero /** pbuf data is stored in ROM, i.e. struct pbuf and its payload are located in 154*10465441SEvalZero totally different memory areas. Since it points to ROM, payload does not 155*10465441SEvalZero have to be copied when queued for transmission. */ 156*10465441SEvalZero PBUF_ROM = PBUF_TYPE_ALLOC_SRC_MASK_STD_MEMP_PBUF, 157*10465441SEvalZero /** pbuf comes from the pbuf pool. Much like PBUF_ROM but payload might change 158*10465441SEvalZero so it has to be duplicated when queued before transmitting, depending on 159*10465441SEvalZero who has a 'ref' to it. */ 160*10465441SEvalZero PBUF_REF = (PBUF_TYPE_FLAG_DATA_VOLATILE | PBUF_TYPE_ALLOC_SRC_MASK_STD_MEMP_PBUF), 161*10465441SEvalZero /** pbuf payload refers to RAM. This one comes from a pool and should be used 162*10465441SEvalZero for RX. Payload can be chained (scatter-gather RX) but like PBUF_RAM, struct 163*10465441SEvalZero pbuf and its payload are allocated in one piece of contiguous memory (so 164*10465441SEvalZero the first payload byte can be calculated from struct pbuf). 165*10465441SEvalZero Don't use this for TX, if the pool becomes empty e.g. because of TCP queuing, 166*10465441SEvalZero you are unable to receive TCP acks! */ 167*10465441SEvalZero PBUF_POOL = (PBUF_ALLOC_FLAG_RX | PBUF_TYPE_FLAG_STRUCT_DATA_CONTIGUOUS | PBUF_TYPE_ALLOC_SRC_MASK_STD_MEMP_PBUF_POOL) 168*10465441SEvalZero } pbuf_type; 169*10465441SEvalZero 170*10465441SEvalZero 171*10465441SEvalZero /** indicates this packet's data should be immediately passed to the application */ 172*10465441SEvalZero #define PBUF_FLAG_PUSH 0x01U 173*10465441SEvalZero /** indicates this is a custom pbuf: pbuf_free calls pbuf_custom->custom_free_function() 174*10465441SEvalZero when the last reference is released (plus custom PBUF_RAM cannot be trimmed) */ 175*10465441SEvalZero #define PBUF_FLAG_IS_CUSTOM 0x02U 176*10465441SEvalZero /** indicates this pbuf is UDP multicast to be looped back */ 177*10465441SEvalZero #define PBUF_FLAG_MCASTLOOP 0x04U 178*10465441SEvalZero /** indicates this pbuf was received as link-level broadcast */ 179*10465441SEvalZero #define PBUF_FLAG_LLBCAST 0x08U 180*10465441SEvalZero /** indicates this pbuf was received as link-level multicast */ 181*10465441SEvalZero #define PBUF_FLAG_LLMCAST 0x10U 182*10465441SEvalZero /** indicates this pbuf includes a TCP FIN flag */ 183*10465441SEvalZero #define PBUF_FLAG_TCP_FIN 0x20U 184*10465441SEvalZero 185*10465441SEvalZero /** Main packet buffer struct */ 186*10465441SEvalZero struct pbuf { 187*10465441SEvalZero /** next pbuf in singly linked pbuf chain */ 188*10465441SEvalZero struct pbuf *next; 189*10465441SEvalZero 190*10465441SEvalZero /** pointer to the actual data in the buffer */ 191*10465441SEvalZero void *payload; 192*10465441SEvalZero 193*10465441SEvalZero /** 194*10465441SEvalZero * total length of this buffer and all next buffers in chain 195*10465441SEvalZero * belonging to the same packet. 196*10465441SEvalZero * 197*10465441SEvalZero * For non-queue packet chains this is the invariant: 198*10465441SEvalZero * p->tot_len == p->len + (p->next? p->next->tot_len: 0) 199*10465441SEvalZero */ 200*10465441SEvalZero u16_t tot_len; 201*10465441SEvalZero 202*10465441SEvalZero /** length of this buffer */ 203*10465441SEvalZero u16_t len; 204*10465441SEvalZero 205*10465441SEvalZero /** a bit field indicating pbuf type and allocation sources 206*10465441SEvalZero (see PBUF_TYPE_FLAG_*, PBUF_ALLOC_FLAG_* and PBUF_TYPE_ALLOC_SRC_MASK) 207*10465441SEvalZero */ 208*10465441SEvalZero u8_t type_internal; 209*10465441SEvalZero 210*10465441SEvalZero /** misc flags */ 211*10465441SEvalZero u8_t flags; 212*10465441SEvalZero 213*10465441SEvalZero /** 214*10465441SEvalZero * the reference count always equals the number of pointers 215*10465441SEvalZero * that refer to this pbuf. This can be pointers from an application, 216*10465441SEvalZero * the stack itself, or pbuf->next pointers from a chain. 217*10465441SEvalZero */ 218*10465441SEvalZero LWIP_PBUF_REF_T ref; 219*10465441SEvalZero 220*10465441SEvalZero /** For incoming packets, this contains the input netif's index */ 221*10465441SEvalZero u8_t if_idx; 222*10465441SEvalZero }; 223*10465441SEvalZero 224*10465441SEvalZero 225*10465441SEvalZero /** Helper struct for const-correctness only. 226*10465441SEvalZero * The only meaning of this one is to provide a const payload pointer 227*10465441SEvalZero * for PBUF_ROM type. 228*10465441SEvalZero */ 229*10465441SEvalZero struct pbuf_rom { 230*10465441SEvalZero /** next pbuf in singly linked pbuf chain */ 231*10465441SEvalZero struct pbuf *next; 232*10465441SEvalZero 233*10465441SEvalZero /** pointer to the actual data in the buffer */ 234*10465441SEvalZero const void *payload; 235*10465441SEvalZero }; 236*10465441SEvalZero 237*10465441SEvalZero #if LWIP_SUPPORT_CUSTOM_PBUF 238*10465441SEvalZero /** Prototype for a function to free a custom pbuf */ 239*10465441SEvalZero typedef void (*pbuf_free_custom_fn)(struct pbuf *p); 240*10465441SEvalZero 241*10465441SEvalZero /** A custom pbuf: like a pbuf, but following a function pointer to free it. */ 242*10465441SEvalZero struct pbuf_custom { 243*10465441SEvalZero /** The actual pbuf */ 244*10465441SEvalZero struct pbuf pbuf; 245*10465441SEvalZero /** This function is called when pbuf_free deallocates this pbuf(_custom) */ 246*10465441SEvalZero pbuf_free_custom_fn custom_free_function; 247*10465441SEvalZero }; 248*10465441SEvalZero #endif /* LWIP_SUPPORT_CUSTOM_PBUF */ 249*10465441SEvalZero 250*10465441SEvalZero /** Define this to 0 to prevent freeing ooseq pbufs when the PBUF_POOL is empty */ 251*10465441SEvalZero #ifndef PBUF_POOL_FREE_OOSEQ 252*10465441SEvalZero #define PBUF_POOL_FREE_OOSEQ 1 253*10465441SEvalZero #endif /* PBUF_POOL_FREE_OOSEQ */ 254*10465441SEvalZero #if LWIP_TCP && TCP_QUEUE_OOSEQ && NO_SYS && PBUF_POOL_FREE_OOSEQ 255*10465441SEvalZero extern volatile u8_t pbuf_free_ooseq_pending; 256*10465441SEvalZero void pbuf_free_ooseq(void); 257*10465441SEvalZero /** When not using sys_check_timeouts(), call PBUF_CHECK_FREE_OOSEQ() 258*10465441SEvalZero at regular intervals from main level to check if ooseq pbufs need to be 259*10465441SEvalZero freed! */ 260*10465441SEvalZero #define PBUF_CHECK_FREE_OOSEQ() do { if(pbuf_free_ooseq_pending) { \ 261*10465441SEvalZero /* pbuf_alloc() reported PBUF_POOL to be empty -> try to free some \ 262*10465441SEvalZero ooseq queued pbufs now */ \ 263*10465441SEvalZero pbuf_free_ooseq(); }}while(0) 264*10465441SEvalZero #else /* LWIP_TCP && TCP_QUEUE_OOSEQ && NO_SYS && PBUF_POOL_FREE_OOSEQ */ 265*10465441SEvalZero /* Otherwise declare an empty PBUF_CHECK_FREE_OOSEQ */ 266*10465441SEvalZero #define PBUF_CHECK_FREE_OOSEQ() 267*10465441SEvalZero #endif /* LWIP_TCP && TCP_QUEUE_OOSEQ && NO_SYS && PBUF_POOL_FREE_OOSEQ*/ 268*10465441SEvalZero 269*10465441SEvalZero /* Initializes the pbuf module. This call is empty for now, but may not be in future. */ 270*10465441SEvalZero #define pbuf_init() 271*10465441SEvalZero 272*10465441SEvalZero struct pbuf *pbuf_alloc(pbuf_layer l, u16_t length, pbuf_type type); 273*10465441SEvalZero struct pbuf *pbuf_alloc_reference(void *payload, u16_t length, pbuf_type type); 274*10465441SEvalZero #if LWIP_SUPPORT_CUSTOM_PBUF 275*10465441SEvalZero struct pbuf *pbuf_alloced_custom(pbuf_layer l, u16_t length, pbuf_type type, 276*10465441SEvalZero struct pbuf_custom *p, void *payload_mem, 277*10465441SEvalZero u16_t payload_mem_len); 278*10465441SEvalZero #endif /* LWIP_SUPPORT_CUSTOM_PBUF */ 279*10465441SEvalZero void pbuf_realloc(struct pbuf *p, u16_t size); 280*10465441SEvalZero #define pbuf_get_allocsrc(p) ((p)->type_internal & PBUF_TYPE_ALLOC_SRC_MASK) 281*10465441SEvalZero #define pbuf_match_allocsrc(p, type) (pbuf_get_allocsrc(p) == ((type) & PBUF_TYPE_ALLOC_SRC_MASK)) 282*10465441SEvalZero #define pbuf_match_type(p, type) pbuf_match_allocsrc(p, type) 283*10465441SEvalZero u8_t pbuf_header(struct pbuf *p, s16_t header_size); 284*10465441SEvalZero u8_t pbuf_header_force(struct pbuf *p, s16_t header_size); 285*10465441SEvalZero u8_t pbuf_add_header(struct pbuf *p, size_t header_size_increment); 286*10465441SEvalZero u8_t pbuf_add_header_force(struct pbuf *p, size_t header_size_increment); 287*10465441SEvalZero u8_t pbuf_remove_header(struct pbuf *p, size_t header_size); 288*10465441SEvalZero struct pbuf *pbuf_free_header(struct pbuf *q, u16_t size); 289*10465441SEvalZero void pbuf_ref(struct pbuf *p); 290*10465441SEvalZero u8_t pbuf_free(struct pbuf *p); 291*10465441SEvalZero u16_t pbuf_clen(const struct pbuf *p); 292*10465441SEvalZero void pbuf_cat(struct pbuf *head, struct pbuf *tail); 293*10465441SEvalZero void pbuf_chain(struct pbuf *head, struct pbuf *tail); 294*10465441SEvalZero struct pbuf *pbuf_dechain(struct pbuf *p); 295*10465441SEvalZero err_t pbuf_copy(struct pbuf *p_to, const struct pbuf *p_from); 296*10465441SEvalZero u16_t pbuf_copy_partial(const struct pbuf *p, void *dataptr, u16_t len, u16_t offset); 297*10465441SEvalZero void *pbuf_get_contiguous(const struct pbuf *p, void *buffer, size_t bufsize, u16_t len, u16_t offset); 298*10465441SEvalZero err_t pbuf_take(struct pbuf *buf, const void *dataptr, u16_t len); 299*10465441SEvalZero err_t pbuf_take_at(struct pbuf *buf, const void *dataptr, u16_t len, u16_t offset); 300*10465441SEvalZero struct pbuf *pbuf_skip(struct pbuf* in, u16_t in_offset, u16_t* out_offset); 301*10465441SEvalZero struct pbuf *pbuf_coalesce(struct pbuf *p, pbuf_layer layer); 302*10465441SEvalZero struct pbuf *pbuf_clone(pbuf_layer l, pbuf_type type, struct pbuf *p); 303*10465441SEvalZero #if LWIP_CHECKSUM_ON_COPY 304*10465441SEvalZero err_t pbuf_fill_chksum(struct pbuf *p, u16_t start_offset, const void *dataptr, 305*10465441SEvalZero u16_t len, u16_t *chksum); 306*10465441SEvalZero #endif /* LWIP_CHECKSUM_ON_COPY */ 307*10465441SEvalZero #if LWIP_TCP && TCP_QUEUE_OOSEQ && LWIP_WND_SCALE 308*10465441SEvalZero void pbuf_split_64k(struct pbuf *p, struct pbuf **rest); 309*10465441SEvalZero #endif /* LWIP_TCP && TCP_QUEUE_OOSEQ && LWIP_WND_SCALE */ 310*10465441SEvalZero 311*10465441SEvalZero u8_t pbuf_get_at(const struct pbuf* p, u16_t offset); 312*10465441SEvalZero int pbuf_try_get_at(const struct pbuf* p, u16_t offset); 313*10465441SEvalZero void pbuf_put_at(struct pbuf* p, u16_t offset, u8_t data); 314*10465441SEvalZero u16_t pbuf_memcmp(const struct pbuf* p, u16_t offset, const void* s2, u16_t n); 315*10465441SEvalZero u16_t pbuf_memfind(const struct pbuf* p, const void* mem, u16_t mem_len, u16_t start_offset); 316*10465441SEvalZero u16_t pbuf_strstr(const struct pbuf* p, const char* substr); 317*10465441SEvalZero 318*10465441SEvalZero #ifdef __cplusplus 319*10465441SEvalZero } 320*10465441SEvalZero #endif 321*10465441SEvalZero 322*10465441SEvalZero #endif /* LWIP_HDR_PBUF_H */ 323