Buffer
Functions | |
int | csp_buffer_init (int count, int size) |
void * | csp_buffer_get (size_t size) |
void * | csp_buffer_get_isr (size_t buf_size) |
void | csp_buffer_free (void *packet) |
void | csp_buffer_free_isr (void *packet) |
void * | csp_buffer_clone (void *buffer) |
int | csp_buffer_remaining (void) |
int | csp_buffer_size (void) |
Function Documentation
void* csp_buffer_clone | ( | void * | buffer | ) |
Clone an existing packet and increase/decrease cloned packet size.
- Parameters
-
buffer Existing buffer to clone.
void csp_buffer_free | ( | void * | packet | ) |
Free a buffer after use.
- Parameters
-
packet pointer to memory area, must be acquired by csp_buffer_get().
void csp_buffer_free_isr | ( | void * | packet | ) |
Free a buffer after use in ISR context.
- Parameters
-
packet pointer to memory area, must be acquired by csp_buffer_get().
void* csp_buffer_get | ( | size_t | size | ) |
Get a reference to a free buffer. This function can only be called from task context.
- Parameters
-
size Specify what data-size you will put in the buffer
- Returns
- pointer to a free csp_packet_t or NULL if out of memory
void* csp_buffer_get_isr | ( | size_t | buf_size | ) |
Get a reference to a free buffer. This function can only be called from interrupt context.
- Parameters
-
buf_size Specify what data-size you will put in the buffer
- Returns
- pointer to a free csp_packet_t or NULL if out of memory
int csp_buffer_init | ( | int | count, |
int | size | ||
) |
Start the buffer handling system You must specify the number for buffers and the size. All buffers are fixed size so you must specify the size of your largest buffer.
- Parameters
-
count Number of buffers to allocate size Buffer size in bytes.
- Returns
- CSP_ERR_NONE if malloc() succeeded, CSP_ERR message otherwise.
int csp_buffer_remaining | ( | void | ) |
Return how many buffers that are currently free.
- Returns
- number of free buffers
int csp_buffer_size | ( | void | ) |
Return the size of the CSP buffers
- Returns
- size of CSP buffers