EDGESEC
0.1.0-alpha.0+sha.ca29a8277b72f80785649ea9ef9cd7edf642d939
Secure router - reference implementation
|
Dynamic data buffer. More...
#include "wpabuf.h"
#include "common.h"
#include "utils/allocs.h"
#include "utils/log.h"
#include "utils/os.h"
Functions | |
int | wpabuf_resize (struct wpabuf **_buf, size_t add_len) |
struct wpabuf * | wpabuf_alloc (size_t len) |
struct wpabuf * | wpabuf_alloc_ext_data (u8 *data, size_t len) |
struct wpabuf * | wpabuf_alloc_copy (const void *data, size_t len) |
struct wpabuf * | wpabuf_dup (const struct wpabuf *src) |
void | wpabuf_free (struct wpabuf *buf) |
void | wpabuf_clear_free (struct wpabuf *buf) |
void * | wpabuf_put (struct wpabuf *buf, size_t len) |
struct wpabuf * | wpabuf_concat (struct wpabuf *a, struct wpabuf *b) |
struct wpabuf * | wpabuf_zeropad (struct wpabuf *buf, size_t len) |
void | wpabuf_printf (struct wpabuf *buf, char *fmt,...) |
struct wpabuf * | wpabuf_parse_bin (const char *buf) |
Dynamic data buffer.
src/utils/wpabuf.c
struct wpabuf* wpabuf_alloc | ( | size_t | len | ) |
wpabuf_alloc - Allocate a wpabuf of the given size @len: Length for the allocated buffer Returns: Buffer to the allocated wpabuf or NULL on failure
struct wpabuf* wpabuf_alloc_copy | ( | const void * | data, |
size_t | len | ||
) |
void wpabuf_clear_free | ( | struct wpabuf * | buf | ) |
wpabuf_concat - Concatenate two buffers into a newly allocated one : First buffer : Second buffer Returns: wpabuf with concatenated a + b data or NULL on failure
Both buffers a and b will be freed regardless of the return value. Input buffers can be NULL which is interpreted as an empty buffer.
void wpabuf_free | ( | struct wpabuf * | buf | ) |
wpabuf_free - Free a wpabuf @buf: wpabuf buffer
struct wpabuf* wpabuf_parse_bin | ( | const char * | buf | ) |
wpabuf_parse_bin - Parse a null terminated string of binary data to a wpabuf @buf: Buffer with null terminated string (hexdump) of binary data Returns: wpabuf or NULL on failure
The string len must be a multiple of two and contain only hexadecimal digits.
void wpabuf_printf | ( | struct wpabuf * | buf, |
char * | fmt, | ||
... | |||
) |
void* wpabuf_put | ( | struct wpabuf * | buf, |
size_t | len | ||
) |
int wpabuf_resize | ( | struct wpabuf ** | _buf, |
size_t | add_len | ||
) |
wpabuf_zeropad - Pad buffer with 0x00 octets (prefix) to specified length @buf: Buffer to be padded @len: Length for the padded buffer Returns: wpabuf padded to len octets or NULL on failure
If buf is longer than len octets or of same size, it will be returned as-is. Otherwise a new buffer is allocated and prefixed with 0x00 octets followed by the source data. The source buffer will be freed on error, i.e., caller will only be responsible on freeing the returned buffer. If buf is NULL, NULL will be returned.