WIP: somethings wrong.. #19

Closed
muellerr wants to merge 808 commits from source/master into master
4 changed files with 66 additions and 3 deletions
Showing only changes of commit 16af33a7bb - Show all commits

View File

@ -21,7 +21,7 @@ public:
readIndex(0), writeIndex(0), currentSize(0) { readIndex(0), writeIndex(0), currentSize(0) {
} }
bool emtpy() { bool empty() {
return (currentSize == 0); return (currentSize == 0);
} }
@ -45,7 +45,7 @@ public:
} }
ReturnValue_t retrieve(T *value) { ReturnValue_t retrieve(T *value) {
if (emtpy()) { if (empty()) {
return EMPTY; return EMPTY;
} else { } else {
*value = data[readIndex]; *value = data[readIndex];

View File

@ -4,12 +4,40 @@
#include <framework/container/RingBufferBase.h> #include <framework/container/RingBufferBase.h>
#include <stddef.h> #include <stddef.h>
/**
* Circular buffer implementation, useful for buffering into data streams.
* Note that the deleteData() has to be called to increment the read pointer
*/
class SimpleRingBuffer: public RingBufferBase<> { class SimpleRingBuffer: public RingBufferBase<> {
public: public:
SimpleRingBuffer(uint32_t size, bool overwriteOld); SimpleRingBuffer(uint32_t size, bool overwriteOld);
virtual ~SimpleRingBuffer(); virtual ~SimpleRingBuffer();
/**
* Write to circular buffer and increment write pointer by amount
* @param data
* @param amount
* @return
*/
ReturnValue_t writeData(const uint8_t* data, uint32_t amount); ReturnValue_t writeData(const uint8_t* data, uint32_t amount);
/**
* Read from circular buffer at read pointer
* @param data
* @param amount
* @param readRemaining
* @param trueAmount
* @return
*/
ReturnValue_t readData(uint8_t* data, uint32_t amount, bool readRemaining = false, uint32_t* trueAmount = NULL); ReturnValue_t readData(uint8_t* data, uint32_t amount, bool readRemaining = false, uint32_t* trueAmount = NULL);
/**
* Delete data starting by incrementing read pointer
* @param amount
* @param deleteRemaining
* @param trueAmount
* @return
*/
ReturnValue_t deleteData(uint32_t amount, bool deleteRemaining = false, uint32_t* trueAmount = NULL); ReturnValue_t deleteData(uint32_t amount, bool deleteRemaining = false, uint32_t* trueAmount = NULL);
private: private:
// static const uint8_t TEMP_READ_PTR = 1; // static const uint8_t TEMP_READ_PTR = 1;

View File

@ -4,6 +4,22 @@
#include <framework/devicehandlers/Cookie.h> #include <framework/devicehandlers/Cookie.h>
#include <framework/returnvalues/HasReturnvaluesIF.h> #include <framework/returnvalues/HasReturnvaluesIF.h>
/**
* Documentation: Dissertation Baetz p.138
*
* This is an interface to decouple device communication from
* the device handler to allow reuse of these components.
* It works with the assumption that received data
* is polled by a component. There are four generic steps of device communication:
*
* 1. Send data to a device
* 2. Get acknowledgement for sending
* 3. Request reading data from a device
* 4. Read received data
*
* To identify different connection over a single interface can return so-called cookies to components.
*
*/
class DeviceCommunicationIF: public HasReturnvaluesIF { class DeviceCommunicationIF: public HasReturnvaluesIF {
public: public:
static const uint8_t INTERFACE_ID = CLASS_ID::DEVICE_COMMUNICATION_IF; static const uint8_t INTERFACE_ID = CLASS_ID::DEVICE_COMMUNICATION_IF;
@ -39,7 +55,15 @@ public:
virtual void close(Cookie *cookie) = 0; virtual void close(Cookie *cookie) = 0;
//SHOULDDO can data be const? /**
* Called by DHB in the SEND_WRITE doSendWrite().
* This function is used to send data to the physical device
* by implementing and calling related drivers or wrapper functions.
* @param cookie
* @param data
* @param len
* @return
*/
virtual ReturnValue_t sendMessage(Cookie *cookie,const uint8_t *data, virtual ReturnValue_t sendMessage(Cookie *cookie,const uint8_t *data,
uint32_t len) = 0; uint32_t len) = 0;
@ -47,6 +71,15 @@ public:
virtual ReturnValue_t requestReceiveMessage(Cookie *cookie) = 0; virtual ReturnValue_t requestReceiveMessage(Cookie *cookie) = 0;
/**
* Called by DHB in the GET_WIRTE doGetRead().
* This function is used to receive data from the physical device
* by implementing and calling related drivers or wrapper functions.
* @param cookie
* @param data
* @param len
* @return
*/
virtual ReturnValue_t readReceivedMessage(Cookie *cookie, uint8_t **buffer, virtual ReturnValue_t readReceivedMessage(Cookie *cookie, uint8_t **buffer,
uint32_t *size) = 0; uint32_t *size) = 0;

View File

@ -28,6 +28,8 @@
* This can also be applied to uint32_t and uint64_t: * This can also be applied to uint32_t and uint64_t:
* *
* 1. Use the AutoSerializeAdapter::deSerialize function with bool bigEndian = true: * 1. Use the AutoSerializeAdapter::deSerialize function with bool bigEndian = true:
* The pointer *buffer will be incremented automatically by the typeSize of data,
* so this function can be called on &buffer without adjusting pointer position
* *
* uint16_t data; * uint16_t data;
* int32_t dataLen = sizeof(data); * int32_t dataLen = sizeof(data);