![]() |
GM6000 Digital Heater Controller Branch: main
SDX-1330
|
This template class implements a THREAD SAFE Ring Buffer. More...
This template class implements a THREAD SAFE Ring Buffer.
The size of the ring buffer is limited by number of bits in platform's 'unsigned' data type.
Template Args: ITEM:= Type of the data stored in the Ring Buffer
#include <RingBufferMT.h>
Public Member Functions | |
RingBufferMT (unsigned maxElements, ITEM memoryForElements[]) noexcept | |
Constructor. | |
bool | remove (ITEM &dst) noexcept |
See Cpl::Container::RingBuffer. | |
bool | add (const ITEM &item) noexcept |
See Cpl::Container::RingBuffer. | |
ITEM * | peekHead (void) const noexcept |
See Cpl::Container::RingBuffer. | |
ITEM * | peekTail (void) const noexcept |
See Cpl::Container::RingBuffer. | |
ITEM * | peekNextAddItems (unsigned &dstNumFlatElements) noexcept |
This method returns a pointer to the next item to be added. | |
void | addElements (unsigned numElementsAdded) noexcept |
This method 'adds' N elements - that were populated using the pointer returned from peekNextAddItems - to the ring buffer. | |
ITEM * | peekNextRemoveItems (unsigned &dstNumFlatElements) noexcept |
This method returns a pointer to the next item to be removed. | |
void | removeElements (unsigned numElementsToRemove) noexcept |
This method 'removes' N elements - that were removed using the pointer returned from peekNextRemoveItems - from the ring buffer. | |
bool | isEmpty (void) const noexcept |
See Cpl::Container::RingBuffer. | |
bool | isFull (void) const noexcept |
See Cpl::Container::RingBuffer. | |
unsigned | getNumItems (void) const noexcept |
See Cpl::Container::RingBuffer. | |
unsigned | getMaxItems (void) const noexcept |
See Cpl::Container::RingBuffer. | |
void | clearTheBuffer () noexcept |
See Cpl::Container::RingBuffer. | |
![]() | |
RingBuffer (unsigned numElements, ITEM memoryForElements[]) noexcept | |
Constructor. | |
bool | remove (ITEM &dst) noexcept |
Removes the first item in the Buffer. | |
bool | add (const ITEM &item) noexcept |
The contents of 'item' will be copied into the Ring Buffer as the 'last' item in the buffer. | |
ITEM * | peekHead (void) const noexcept |
Returns a pointer to the first item in the Buffer. | |
ITEM * | peekTail (void) const noexcept |
Returns a pointer to the last item in the Buffer. | |
bool | isEmpty (void) const noexcept |
This method returns true if the Ring Buffer is empty. | |
bool | isFull (void) const noexcept |
This method returns true if the Ring Buffer is full. | |
unsigned | getNumItems (void) const noexcept |
This method returns the current number of items in the Ring Buffer. | |
unsigned | getMaxItems (void) const noexcept |
This method returns the maximum number of items that can be stored in the Ring buffer. | |
void | clearTheBuffer () noexcept |
Empties the Ring Buffer. | |
ITEM * | peekNextRemoveItems (unsigned &dstNumFlatElements) noexcept |
This method returns a pointer to the next item to be removed. | |
void | removeElements (unsigned numElementsToRemove) noexcept |
This method 'removes' N elements - that were removed using the pointer returned from peekNextRemoveItems - from the ring buffer. | |
ITEM * | peekNextAddItems (unsigned &dstNumFlatElements) noexcept |
This method returns a pointer to the next item to be added. | |
void | addElements (unsigned numElementsAdded) noexcept |
This method 'adds' N elements - that were populated using the pointer returned from peekNextAddItems - to the ring buffer. | |
Protected Attributes | |
Cpl::System::Mutex | m_lock |
Mutex for critical sections. | |
|
inlinenoexcept |
Constructor.
The application is responsible for providing the memory for the Ring Buffer. The argument ''maxElements' is the number of items that will fit in the memory allocated by 'memoryForElements' - it is NOT the number of bytes of 'memoryForElements'.
|
inlinenoexcept |
|
inlinenoexcept |
This method 'adds' N elements - that were populated using the pointer returned from peekNextAddItems - to the ring buffer.
Basically its updates the tail pointer to reflect items added using direct memory access.
'numElementsAdded' be less than or equal to the 'dstNumFlatElements' returned from peekNextAddItems(). If the call to peekNextAddTiems, THEN 'numElementsAdded' MUST BE SET to zero.
CAUTION:
|
inlinenoexcept |
|
inlinenoexcept |
|
inlinenoexcept |
|
inlinenoexcept |
|
inlinenoexcept |
|
inlinenoexcept |
|
inlinenoexcept |
This method returns a pointer to the next item to be added.
In addition it returns the number of elements that can be added as linear/flat buffer (i.e. without wrapping around raw buffer memory)
If the Ring buffer is full, a null pointer is returned (and 'dstNumFlatElements' is set to zero).
This method with addElements() method provide an ATOMIC update of the ring buffer. This means that addElements() MUST ALWAYS be called after calling peekNextAddItems().
|
inlinenoexcept |
This method returns a pointer to the next item to be removed.
In addition it returns the number of elements that can be removed as linear/flat buffer (i.e. without wrapping around raw buffer memory)
If the Ring buffer is empty, a null pointer is returned (and 'dstNumFlatElements' is set to zero).
This method with removeElements() method provide an ATOMIC update of the ring buffer. This means that removeElements() MUST ALWAYS be called after calling peekNextRemoveItems().
|
inlinenoexcept |
|
inlinenoexcept |
|
inlinenoexcept |
This method 'removes' N elements - that were removed using the pointer returned from peekNextRemoveItems - from the ring buffer.
Basically it updates the head pointer to reflect items removed using direct memory access.
'numElementsToRemove' be less than or equal to the 'dstNumFlatElements' returned from peekNextRemoveItems().
CAUTION:
|
protected |
Mutex for critical sections.