ReactOS 0.4.15-dev-8614-gbc76250
|
#include "lwip/opt.h"
#include "lwip/stats.h"
#include "lwip/def.h"
#include "lwip/mem.h"
#include "lwip/memp.h"
#include "lwip/pbuf.h"
#include "lwip/sys.h"
#include "arch/perf.h"
#include <string.h>
Go to the source code of this file.
Macros | |
#define | SIZEOF_STRUCT_PBUF LWIP_MEM_ALIGN_SIZE(sizeof(struct pbuf)) |
#define | PBUF_POOL_BUFSIZE_ALIGNED LWIP_MEM_ALIGN_SIZE(PBUF_POOL_BUFSIZE) |
#define | PBUF_POOL_IS_EMPTY() |
Functions | |
struct pbuf * | pbuf_alloc (pbuf_layer layer, u16_t length, pbuf_type type) |
void | pbuf_realloc (struct pbuf *p, u16_t new_len) |
u8_t | pbuf_header (struct pbuf *p, s16_t header_size_increment) |
u8_t | pbuf_free (struct pbuf *p) |
u8_t | pbuf_clen (struct pbuf *p) |
void | pbuf_ref (struct pbuf *p) |
void | pbuf_cat (struct pbuf *h, struct pbuf *t) |
void | pbuf_chain (struct pbuf *h, struct pbuf *t) |
struct pbuf * | pbuf_dechain (struct pbuf *p) |
err_t | pbuf_copy (struct pbuf *p_to, struct pbuf *p_from) |
u16_t | pbuf_copy_partial (struct pbuf *buf, void *dataptr, u16_t len, u16_t offset) |
err_t | pbuf_take (struct pbuf *buf, const void *dataptr, u16_t len) |
struct pbuf * | pbuf_coalesce (struct pbuf *p, pbuf_layer layer) |
u8_t | pbuf_get_at (struct pbuf *p, u16_t offset) |
u16_t | pbuf_memcmp (struct pbuf *p, u16_t offset, const void *s2, u16_t n) |
u16_t | pbuf_memfind (struct pbuf *p, const void *mem, u16_t mem_len, u16_t start_offset) |
u16_t | pbuf_strstr (struct pbuf *p, const char *substr) |
Packet buffer management
Packets are built from the pbuf data structure. It supports dynamic memory allocation for packet contents or can reference externally managed packet contents both in RAM and ROM. Quick allocation for incoming packets is provided through pools with fixed sized pbufs.
A packet may span over multiple pbufs, chained as a singly linked list. This is called a "pbuf chain".
Multiple packets may be queued, also using this singly linked list. This is called a "packet queue".
So, a packet queue consists of one or more pbuf chains, each of which consist of one or more pbufs. CURRENTLY, PACKET QUEUES ARE NOT SUPPORTED!!! Use helper structs to queue multiple packets.
The differences between a pbuf chain and a packet queue are very precise but subtle.
The last pbuf of a packet has a ->tot_len field that equals the ->len field. It can be found by traversing the list. If the last pbuf of a packet has a ->next field other than NULL, more packets are on the queue.
Therefore, looping through a pbuf of a single packet, has an loop end condition (tot_len == p->len), NOT (next == NULL).
Definition in file pbuf.c.
#define PBUF_POOL_BUFSIZE_ALIGNED LWIP_MEM_ALIGN_SIZE(PBUF_POOL_BUFSIZE) |
#define SIZEOF_STRUCT_PBUF LWIP_MEM_ALIGN_SIZE(sizeof(struct pbuf)) |
struct pbuf * pbuf_alloc | ( | pbuf_layer | layer, |
u16_t | length, | ||
pbuf_type | type | ||
) |
Allocates a pbuf of the given type (possibly a chain for PBUF_POOL type).
The actual memory allocated for the pbuf is determined by the layer at which the pbuf is allocated and the requested size (from the size parameter).
layer | flag to define header size |
length | size of the pbuf's payload |
type | this parameter decides how and where the pbuf should be allocated as follows: |
Definition at line 207 of file pbuf.c.
Referenced by create_arp_response(), LibIPInsertPacket(), pbuf_coalesce(), START_TEST(), tcp_create_segment_wnd(), and test_tcp_netif_output().
Concatenate two pbufs (each may be a pbuf chain) and take over the caller's reference of the tail pbuf.
Definition at line 745 of file pbuf.c.
Referenced by pbuf_chain(), and test_tcp_netif_output().
Chain two pbufs (or pbuf chains) together.
The caller MUST call pbuf_free(t) once it has stopped using it. Use pbuf_cat() instead if you no longer use t.
h | head pbuf (chain) |
t | tail pbuf (chain) |
The ->tot_len fields of all pbufs of the head chain are adjusted. The ->next field of the last pbuf of the head chain is adjusted. The ->ref field of the first pbuf of the tail chain is adjusted.
Definition at line 786 of file pbuf.c.
Count number of pbufs in a chain
p | first pbuf of chain |
Definition at line 704 of file pbuf.c.
Referenced by tcp_oos_pbuf_count().
struct pbuf * pbuf_coalesce | ( | struct pbuf * | p, |
pbuf_layer | layer | ||
) |
Creates a single pbuf out of a queue of pbufs.
p | the source pbuf |
layer | pbuf_layer of the new pbuf |
Definition at line 1010 of file pbuf.c.
Create PBUF_RAM copies of pbufs.
Used to queue packets on behalf of the lwIP stack, such as ARP based queueing.
p_to | pbuf destination of the copy |
p_from | pbuf source of the copy |
Definition at line 852 of file pbuf.c.
Referenced by pbuf_coalesce(), and test_tcp_netif_output().
Copy (part of) the contents of a packet buffer to an application supplied buffer.
buf | the pbuf from which to copy data |
dataptr | the application supplied buffer |
len | length of data to copy (dataptr must be big enough). No more than buf->tot_len will be copied, irrespective of len |
offset | offset into the packet buffer from where to begin copying len bytes |
Definition at line 918 of file pbuf.c.
Referenced by LibTCPGetDataFromConnectionQueue(), and test_tcp_tx_full_window_lost().
Dechains the first pbuf from its succeeding pbufs in the chain.
Makes p->tot_len field equal to p->len.
p | pbuf to dechain |
Definition at line 803 of file pbuf.c.
Dereference a pbuf chain or queue and deallocate any no-longer-used pbufs at the head of this chain or queue.
Decrements the pbuf reference count. If it reaches zero, the pbuf is deallocated.
For a pbuf chain, this is repeated for each pbuf in the chain, up to the first pbuf which has a non-zero reference count after decrementing. So, when all reference counts are one, the whole chain is free'd.
p | The pbuf (chain) to be dereferenced. |
Definition at line 618 of file pbuf.c.
Referenced by InternalRecvEventHandler(), ip_forward(), ip_input(), LibTCPEmptyQueue(), pbuf_alloc(), pbuf_coalesce(), pbuf_dechain(), pbuf_free_int(), pbuf_realloc(), START_TEST(), test_tcp_counters_recv(), and test_tcp_tx_full_window_lost().
Get one byte from the specified position in a pbuf WARNING: returns zero for offset >= p->tot_len
p | pbuf to parse |
offset | offset into p of the byte to return |
Definition at line 1077 of file pbuf.c.
Referenced by pbuf_memcmp().
Adjusts the payload pointer to hide or reveal headers in the payload.
Adjusts the ->payload pointer so that space for a header (dis)appears in the pbuf payload.
The ->payload, ->tot_len and ->len fields are adjusted.
p | pbuf to change the header size. |
header_size_increment | Number of bytes to increment header size which increases the size of the pbuf. New space is on the front. (Using a negative value decreases the header size.) If hdr_size_inc is 0, this function does nothing and returns succesful. |
PBUF_ROM and PBUF_REF type buffers cannot have their sizes increased, so the call will fail. A check is made that the increase in header size does not move the payload pointer in front of the start of the buffer.
Definition at line 511 of file pbuf.c.
Referenced by ip_input(), ip_output_if(), and tcp_create_segment_wnd().
Compare pbuf contents at specified offset with memory s2, both of length n
p | pbuf to compare |
offset | offset into p at wich to start comparing |
s2 | buffer to compare |
n | length of buffer to compare |
Definition at line 1104 of file pbuf.c.
Referenced by pbuf_memfind().
Find occurrence of mem (with length mem_len) in pbuf p, starting at offset start_offset.
p | pbuf to search, maximum length is 0xFFFE since 0xFFFF is used as return value 'not found' |
mem | search for the contents of this buffer |
mem_len | length of 'mem' |
start_offset | offset into p at which to start searching |
Definition at line 1140 of file pbuf.c.
Referenced by pbuf_strstr().
Shrink a pbuf chain to a desired length.
p | pbuf to shrink. |
new_len | desired new length of pbuf chain |
Depending on the desired length, the first few pbufs in a chain might be skipped and left unchanged. The new last pbuf in the chain will be resized, and any remaining pbufs will be freed.
Definition at line 430 of file pbuf.c.
Referenced by ip_input().
Increment the reference count of the pbuf.
p | pbuf to increase reference counter of |
Definition at line 723 of file pbuf.c.
Referenced by pbuf_chain().
Find occurrence of substr with length substr_len in pbuf p, start at offset start_offset WARNING: in contrast to strstr(), this one does not stop at the first \0 in the pbuf/source string!
p | pbuf to search, maximum length is 0xFFFE since 0xFFFF is used as return value 'not found' |
substr | string to search for in p, maximum length is 0xFFFE |
Definition at line 1168 of file pbuf.c.
Copy application supplied data into a pbuf. This function can only be used to copy the equivalent of buf->tot_len data.
buf | pbuf to fill with data |
dataptr | application supplied data buffer |
len | length of the application supplied data buffer |
Definition at line 966 of file pbuf.c.
Referenced by tcp_create_segment_wnd().