The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
|
BIO abstractions for memory buffers. More...
#include <freeradius-devel/bio/bio_priv.h>
#include <freeradius-devel/bio/null.h>
#include <freeradius-devel/bio/buf.h>
#include <freeradius-devel/bio/mem.h>
Go to the source code of this file.
Data Structures | |
struct | fr_bio_mem_s |
The memory buffer bio. More... | |
Typedefs | |
typedef struct fr_bio_mem_s | fr_bio_mem_t |
The memory buffer bio. | |
Functions | |
fr_bio_t * | fr_bio_mem_alloc (TALLOC_CTX *ctx, size_t read_size, size_t write_size, fr_bio_t *next) |
Allocate a memory buffer bio. | |
static bool | fr_bio_mem_buf_alloc (fr_bio_mem_t *my, fr_bio_buf_t *buf, size_t size) |
Allocate a memory buffer bio for either reading or writing. | |
static int | fr_bio_mem_call_verify (fr_bio_t *bio, void *packet_ctx, size_t *size) |
Verify that a packet is OK. | |
static int | fr_bio_mem_eof (fr_bio_t *bio) |
static ssize_t | fr_bio_mem_read (fr_bio_t *bio, void *packet_ctx, void *buffer, size_t size) |
Read from a memory BIO. | |
static ssize_t | fr_bio_mem_read_buffer (fr_bio_t *bio, UNUSED void *packet_ctx, void *buffer, size_t size) |
Read from a buffer which a previous bio has filled. | |
void | fr_bio_mem_read_discard (fr_bio_t *bio, size_t size) |
Discard data from the read buffer. | |
static ssize_t | fr_bio_mem_read_eof (fr_bio_t *bio, UNUSED void *packet_ctx, void *buffer, size_t size) |
At EOF, read data from the buffer until it is empty. | |
uint8_t const * | fr_bio_mem_read_peek (fr_bio_t *bio, size_t *size) |
Peek at the data in the read buffer. | |
static ssize_t | fr_bio_mem_read_verify (fr_bio_t *bio, void *packet_ctx, void *buffer, size_t size) |
Return data only if we have a complete packet. | |
static ssize_t | fr_bio_mem_read_verify_datagram (fr_bio_t *bio, void *packet_ctx, void *buffer, size_t size) |
Return data only if we have a complete packet. | |
int | fr_bio_mem_set_verify (fr_bio_t *bio, fr_bio_verify_t verify, void *verify_ctx, bool datagram) |
Set the verification function for memory bios. | |
static void | fr_bio_mem_shutdown (fr_bio_t *bio) |
fr_bio_t * | fr_bio_mem_sink_alloc (TALLOC_CTX *ctx, size_t read_size) |
Allocate a memory buffer which sinks data from a bio system into the callers application. | |
fr_bio_t * | fr_bio_mem_source_alloc (TALLOC_CTX *ctx, size_t write_size, fr_bio_t *next) |
Allocate a memory buffer which sources data from the callers application into the bio system. | |
static ssize_t | fr_bio_mem_write_buffer (fr_bio_t *bio, UNUSED void *packet_ctx, void const *buffer, size_t size) |
Write to the memory buffer. | |
static ssize_t | fr_bio_mem_write_buffer (fr_bio_t *bio, void *packet_ctx, void const *buffer, size_t size) |
static ssize_t | fr_bio_mem_write_flush (fr_bio_mem_t *my, size_t size) |
Flush the memory buffer. | |
static ssize_t | fr_bio_mem_write_next (fr_bio_t *bio, void *packet_ctx, void const *buffer, size_t size) |
Pass writes to the next BIO. | |
int | fr_bio_mem_write_pause (fr_bio_t *bio) |
Pause writes. | |
static ssize_t | fr_bio_mem_write_read_buffer (fr_bio_t *bio, UNUSED void *packet_ctx, void const *buffer, size_t size) |
Write to the read buffer. | |
int | fr_bio_mem_write_resume (fr_bio_t *bio) |
See if we can resume writes to the memory bio. | |
BIO abstractions for memory buffers.
Definition in file mem.c.
struct fr_bio_mem_s |
The memory buffer bio.
It is used to buffer reads / writes to a streaming socket.
Data Fields | ||
---|---|---|
FR_BIO_COMMON | ||
fr_bio_buf_t | read_buffer | buffering for reads |
fr_bio_verify_t | verify | verify data to see if we have a packet. |
void * | verify_ctx | verify context |
fr_bio_buf_t | write_buffer | buffering for writes |
typedef struct fr_bio_mem_s fr_bio_mem_t |
The memory buffer bio.
It is used to buffer reads / writes to a streaming socket.
fr_bio_t * fr_bio_mem_alloc | ( | TALLOC_CTX * | ctx, |
size_t | read_size, | ||
size_t | write_size, | ||
fr_bio_t * | next | ||
) |
Allocate a memory buffer bio.
The "read buffer" will cache reads from the next bio in the chain. If the next bio returns more data than the caller asked for, the extra data is cached in the read buffer.
The "write buffer" will buffer writes to the next bio in the chain. If the caller writes more data than the next bio can process, the extra data is cached in the write buffer.
When the bio is closed (or freed) any pending data in the buffers is lost. The same happens if the next bio returns a fatal error.
At some point during a read, the next bio may return EOF. When that happens, the caller should not rely on the next FD being readable or writable. Instead, it should keep reading from the memory bio until it returns EOF. See fr_bio_fd_eof() for details.
ctx | the talloc ctx |
read_size | size of the read buffer. Must be 1024..1^20 |
write_size | size of the write buffer. Can be zero. If non-zero, must be 1024..1^20 |
next | the next bio which will perform the underlying reads and writes.
|
Definition at line 727 of file mem.c.
|
static |
Verify that a packet is OK.
bio | the fr_bio_mem_t | |
packet_ctx | the packet ctx | |
[out] | size | how big the verified packet is |
Definition at line 623 of file mem.c.
|
static |
|
static |
Read from a memory BIO.
This bio reads as much data as possible into the memory buffer. On the theory that a few memcpy() or memmove() calls are much cheaper than a system call.
If the read buffer has enough data to satisfy the read, then it is returned.
Otherwise the next bio is called to re-fill the buffer. The next read call will try to get as much data as possible into the buffer, even if that results in reading more than "size" bytes.
Once the next read has been done, then the data from the buffer is returned, even if it is less than "size".
Definition at line 106 of file mem.c.
|
static |
At EOF, read data from the buffer until it is empty.
When "next" bio returns EOF, there may still be pending data in the memory buffer. Return that until it's empty, and then EOF from then on.
Definition at line 54 of file mem.c.
int fr_bio_mem_set_verify | ( | fr_bio_t * | bio, |
fr_bio_verify_t | verify, | ||
void * | verify_ctx, | ||
bool | datagram | ||
) |
Set the verification function for memory bios.
It is possible to add a verification function. It is not currently possible to remove one.
bio | the binary IO handler |
verify | the verification function |
datagram | whether or not this bio is a datagram one. |
Definition at line 880 of file mem.c.
|
static |
Allocate a memory buffer which sinks data from a bio system into the callers application.
The caller reads data from this bio, but never writes to it. Upstream BIOs will source the data.
Definition at line 845 of file mem.c.
|
static |
|
static |
|
static |
Pass writes to the next BIO.
For speed, we try to bypass the memory buffer and write directly to the next bio. However, if the next bio returns EWOULDBLOCK, we write the data to the memory buffer, even if it is partial data.
Definition at line 370 of file mem.c.
int fr_bio_mem_write_pause | ( | fr_bio_t * | bio | ) |
Pause writes.
Calls to fr_bio_write() will write to the memory buffer, and not to the next bio. You MUST call fr_bio_mem_write_resume() after this to flush any data.
Definition at line 952 of file mem.c.
int fr_bio_mem_write_resume | ( | fr_bio_t * | bio | ) |
See if we can resume writes to the memory bio.
Note that there is no equivalent fr_bio_mem_write_blocked(), as that function wouldn't do anything. Perhaps it could swap the write function to fr_bio_mem_write_buffer(), but the fr_bio_mem_write_next() function should automatically do that when the write to the next bio only writes part of the data, or if it returns fr_bio_error(IO_WOULD_BLOCK)
Definition at line 926 of file mem.c.