Circular integer buffer interface.
More...
Circular integer buffer interface.
This structure provides an organizational interface and combined with an memory array forms a circular buffer.
- Author
- Kaspar Schleiser kaspa.nosp@m.r@sc.nosp@m.hleis.nosp@m.er.d.nosp@m.e
Definition in file cib.h.
Go to the source code of this file.
|
struct | cib_t |
| circular integer buffer structure More...
|
|
#define | CIB_INIT(SIZE) { 0, 0, (SIZE)-1 } |
| Initialize cib_t to a given size.
|
|
static void | cib_init (cib_t *__restrict cib, unsigned int size) |
| Initialize cib to 0 and set buffer size to size .
|
|
static unsigned int | cib_size (const cib_t *cib) |
| Returns the total capacity (size parameter of cib_init()) of a cib_t.
|
|
static unsigned int | cib_avail (const cib_t *cib) |
| Calculates difference between cib_put() and cib_get() accesses.
|
|
static unsigned int | cib_full (const cib_t *cib) |
| Check if cib is full.
|
|
static int | cib_get (cib_t *__restrict cib) |
| Get the index of the next item in buffer.
|
|
static int | cib_peek_at_unsafe (const cib_t *__restrict cib, unsigned offset) |
| Get the index of an item in the buffer without removing anything.
|
|
static int | cib_peek_at (const cib_t *__restrict cib, unsigned offset) |
| Get the index of an item in the buffer without removing anything.
|
|
static int | cib_peek_unsafe (const cib_t *__restrict cib) |
| Get the index of the next item in buffer without removing it.
|
|
static int | cib_peek (const cib_t *__restrict cib) |
| Get the index of the next item in buffer without removing it.
|
|
static int | cib_get_unsafe (cib_t *cib) |
| Get the index of the next item in buffer.
|
|
static int | cib_put (cib_t *__restrict cib) |
| Get index for item in buffer to put to.
|
|
static int | cib_put_unsafe (cib_t *cib) |
| Get index for item in buffer to put to.
|
|
◆ CIB_INIT
#define CIB_INIT |
( |
|
SIZE | ) |
{ 0, 0, (SIZE)-1 } |
Initialize cib_t to a given size.
- Parameters
-
[in] | SIZE | Size of the buffer, must not exceed (UINT_MAX + 1) / 2. Should be equal to 0 or power of 2. |
Definition at line 47 of file cib.h.
◆ cib_avail()
static unsigned int cib_avail |
( |
const cib_t * |
cib | ) |
|
|
inlinestatic |
Calculates difference between cib_put() and cib_get() accesses.
- Parameters
-
[in] | cib | the cib_t to check. Must not be NULL. |
- Returns
- How often cib_get() can be called before
cib
is empty.
Definition at line 88 of file cib.h.
◆ cib_full()
static unsigned int cib_full |
( |
const cib_t * |
cib | ) |
|
|
inlinestatic |
Check if cib is full.
- Parameters
-
[in] | cib | the cib_t to check. Must not be NULL. |
- Returns
- 1 if cib_put() would return "-1", 0 otherwise
Definition at line 100 of file cib.h.
◆ cib_get()
static int cib_get |
( |
cib_t *__restrict |
cib | ) |
|
|
inlinestatic |
Get the index of the next item in buffer.
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
- Returns
- index of next item
- Return values
-
Definition at line 113 of file cib.h.
◆ cib_get_unsafe()
static int cib_get_unsafe |
( |
cib_t * |
cib | ) |
|
|
inlinestatic |
Get the index of the next item in buffer.
Unsafe version, must not be called if buffer is empty!
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
- Returns
- index of next item
Definition at line 202 of file cib.h.
◆ cib_init()
static void cib_init |
( |
cib_t *__restrict |
cib, |
|
|
unsigned int |
size |
|
) |
| |
|
inlinestatic |
Initialize cib
to 0 and set buffer size to size
.
- Parameters
-
[out] | cib | Buffer to initialize. Must not be NULL. |
[in] | size | Size of the buffer, must not exceed (UINT_MAX + 1) / 2. Should be equal to 0 or power of 2. |
Definition at line 58 of file cib.h.
◆ cib_peek()
static int cib_peek |
( |
const cib_t *__restrict |
cib | ) |
|
|
inlinestatic |
Get the index of the next item in buffer without removing it.
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
- Returns
- index of next item
- Return values
-
Definition at line 188 of file cib.h.
◆ cib_peek_at()
static int cib_peek_at |
( |
const cib_t *__restrict |
cib, |
|
|
unsigned |
offset |
|
) |
| |
|
inlinestatic |
Get the index of an item in the buffer without removing anything.
Offset 0 is the next item in the buffer that would be returned by cip_get()
, offset 1 would be the following, and so on.
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
[in] | offset | offset from front of buffer |
- Returns
- index of item
- Return values
-
-1 | if no item at offset exists in the buffer |
Definition at line 156 of file cib.h.
◆ cib_peek_at_unsafe()
static int cib_peek_at_unsafe |
( |
const cib_t *__restrict |
cib, |
|
|
unsigned |
offset |
|
) |
| |
|
inlinestatic |
Get the index of an item in the buffer without removing anything.
Offset 0 is the next item in the buffer that would be returned by cip_get()
, offset 1 would be the following, and so on.
Unsafe version, must not pass an offset that is larger than the number of items currently in the buffer!
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
[in] | offset | offset from front of buffer |
- Returns
- index of item
- Return values
-
-1 | if no item at offset exists in the buffer |
Definition at line 138 of file cib.h.
◆ cib_peek_unsafe()
static int cib_peek_unsafe |
( |
const cib_t *__restrict |
cib | ) |
|
|
inlinestatic |
Get the index of the next item in buffer without removing it.
Unsafe version, must not be called if buffer is empty!
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
- Returns
- index of next item
- Return values
-
Definition at line 175 of file cib.h.
◆ cib_put()
static int cib_put |
( |
cib_t *__restrict |
cib | ) |
|
|
inlinestatic |
Get index for item in buffer to put to.
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
- Returns
- index of item to put to
- Return values
-
Definition at line 215 of file cib.h.
◆ cib_put_unsafe()
static int cib_put_unsafe |
( |
cib_t * |
cib | ) |
|
|
inlinestatic |
Get index for item in buffer to put to.
Unsafe version, must not be called if buffer is full!
- Parameters
-
[in,out] | cib | corresponding cib to buffer. Must not be NULL. |
- Returns
- index of item to put to
Definition at line 236 of file cib.h.
◆ cib_size()
static unsigned int cib_size |
( |
const cib_t * |
cib | ) |
|
|
inlinestatic |
Returns the total capacity (size
parameter of cib_init()) of a cib_t.
- Parameters
-
[in] | cib | the cib_t to check. Must not be NULL. |
- Returns
- The total size of
cib
.
Definition at line 76 of file cib.h.