WIP: somethings wrong.. #19
@ -2,7 +2,13 @@
|
|||||||
#define COOKIE_H_
|
#define COOKIE_H_
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This datatype is used to identify different connection over a single interface (like RMAP or I2C)
|
* @brief This datatype is used to identify different connection over a single interface
|
||||||
|
* (like RMAP or I2C)
|
||||||
|
* @details
|
||||||
|
* To use this class, implement a communication specific child cookie. This cookie
|
||||||
|
* can be used in the device communication interface by performing
|
||||||
|
* a C++ dynamic cast. The cookie can be used to store all kinds of information
|
||||||
|
* about the communication between read and send calls.
|
||||||
*/
|
*/
|
||||||
class Cookie{
|
class Cookie{
|
||||||
public:
|
public:
|
||||||
|
@ -8,6 +8,11 @@
|
|||||||
* @brief Communication interfaces for flight software objects
|
* @brief Communication interfaces for flight software objects
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Physical address type
|
||||||
|
*/
|
||||||
|
typedef uint32_t address_t;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This is an interface to decouple device communication from
|
* @brief This is an interface to decouple device communication from
|
||||||
* the device handler to allow reuse of these components.
|
* the device handler to allow reuse of these components.
|
||||||
@ -39,23 +44,36 @@ public:
|
|||||||
|
|
||||||
virtual ~DeviceCommunicationIF() {}
|
virtual ~DeviceCommunicationIF() {}
|
||||||
|
|
||||||
virtual ReturnValue_t open(Cookie **cookie, uint32_t address,
|
/**
|
||||||
|
* Open a connection. Define a communication specific cookie which can
|
||||||
|
* be used to store information about the communication.
|
||||||
|
*
|
||||||
|
* @param cookie [in/out] This data class stores information about the communication.
|
||||||
|
* @param address Logical device address
|
||||||
|
* @param maxReplyLen Maximum length of expected reply
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
virtual ReturnValue_t open(Cookie **cookie, address_t address,
|
||||||
uint32_t maxReplyLen) = 0;
|
uint32_t maxReplyLen) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Use an existing cookie to open a connection to a new DeviceCommunication.
|
* Use an existing cookie to open a connection to a new DeviceCommunication.
|
||||||
* The previous connection must not be closed.
|
* The previous connection must not be closed.
|
||||||
* If the returnvalue is not RETURN_OK, the cookie is unchanged and
|
|
||||||
* can be used with the previous connection.
|
|
||||||
*
|
*
|
||||||
* @param cookie
|
* @param cookie
|
||||||
* @param address
|
* @param address
|
||||||
* @param maxReplyLen
|
* @param maxReplyLen
|
||||||
* @return
|
* @return -@c RETURN_OK New communication set up successfully
|
||||||
|
* - Everything else: Cookie is unchanged and can be used with
|
||||||
|
* previous connection
|
||||||
*/
|
*/
|
||||||
virtual ReturnValue_t reOpen(Cookie *cookie, uint32_t address,
|
virtual ReturnValue_t reOpen(Cookie *cookie, address_t address,
|
||||||
uint32_t maxReplyLen) = 0;
|
uint32_t maxReplyLen) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Closing call of connection. Don't forget to free memory of cookie.
|
||||||
|
* @param cookie
|
||||||
|
*/
|
||||||
virtual void close(Cookie *cookie) = 0;
|
virtual void close(Cookie *cookie) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -65,16 +83,18 @@ public:
|
|||||||
* @param cookie
|
* @param cookie
|
||||||
* @param data
|
* @param data
|
||||||
* @param len
|
* @param len
|
||||||
* @return @c RETURN_OK for successfull send
|
* @return -@c RETURN_OK for successfull send
|
||||||
* Everything else triggers sending failed event with returnvalue as parameter 1
|
* -Everything else triggers sending failed event with
|
||||||
|
* returnvalue as parameter 1
|
||||||
*/
|
*/
|
||||||
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;
|
||||||
|
|
||||||
virtual ReturnValue_t getSendSuccess(Cookie *cookie) = 0;
|
virtual ReturnValue_t getSendSuccess(Cookie *cookie) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called by DHB in the SEND_WRITE doSendRead().
|
* Called by DHB in the SEND_WRITE doSendRead().
|
||||||
|
* Instructs the Communication Interface to prepare
|
||||||
* @param cookie
|
* @param cookie
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@ -93,9 +113,9 @@ public:
|
|||||||
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;
|
||||||
|
|
||||||
virtual ReturnValue_t setAddress(Cookie *cookie, uint32_t address) = 0;
|
virtual ReturnValue_t setAddress(Cookie *cookie, address_t address) = 0;
|
||||||
|
|
||||||
virtual uint32_t getAddress(Cookie *cookie) = 0;
|
virtual address_t getAddress(Cookie *cookie) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Can be used by DeviceHandlerBase getParameter() call to set DeviceComIF parameters
|
* Can be used by DeviceHandlerBase getParameter() call to set DeviceComIF parameters
|
||||||
@ -112,7 +132,6 @@ public:
|
|||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
virtual uint32_t getParameter(Cookie *cookie) = 0;
|
virtual uint32_t getParameter(Cookie *cookie) = 0;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* DEVICECOMMUNICATIONIF_H_ */
|
#endif /* DEVICECOMMUNICATIONIF_H_ */
|
||||||
|
@ -33,28 +33,25 @@ class StorageManagerIF;
|
|||||||
* Contains all devices and the DeviceHandlerBase class.
|
* Contains all devices and the DeviceHandlerBase class.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
|
||||||
* Physical address type
|
|
||||||
*/
|
|
||||||
typedef uint32_t address_t;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This is the abstract base class for device handlers.
|
* @brief This is the abstract base class for device handlers.
|
||||||
* @details
|
* @details
|
||||||
* Documentation: Dissertation Baetz p.138,139, p.141-149
|
* Documentation: Dissertation Baetz p.138,139, p.141-149
|
||||||
*
|
*
|
||||||
* It features handling of @link DeviceHandlerIF::Mode_t Modes @endlink, communication with
|
* It features handling of @link DeviceHandlerIF::Mode_t Modes @endlink,
|
||||||
* physical devices, using the @link DeviceCommunicationIF @endlink, and communication with commanding objects.
|
* communication with physical devices, using the @link DeviceCommunicationIF @endlink,
|
||||||
|
* and communication with commanding objects.
|
||||||
* It inherits SystemObject and thus can be created by the ObjectManagerIF.
|
* It inherits SystemObject and thus can be created by the ObjectManagerIF.
|
||||||
*
|
*
|
||||||
* This class uses the opcode of ExecutableObjectIF to perform a step-wise execution.
|
* This class uses the opcode of ExecutableObjectIF to perform a step-wise execution.
|
||||||
* For each step an RMAP action is selected and executed.
|
* For each step an RMAP action is selected and executed.
|
||||||
* If data has been received (GET_READ), the data will be interpreted.
|
* If data has been received (GET_READ), the data will be interpreted.
|
||||||
* The action for each step can be defined by the child class but as most device handlers share a 4-call
|
* The action for each step can be defined by the child class but as most
|
||||||
* (sendRead-getRead-sendWrite-getWrite) structure, a default implementation is provided.
|
* device handlers share a 4-call (sendRead-getRead-sendWrite-getWrite) structure,
|
||||||
* NOTE: RMAP is a standard which is used for FLP.
|
* a default implementation is provided. NOTE: RMAP is a standard which is used for FLP.
|
||||||
* RMAP communication is not mandatory for projects implementing the FSFW.
|
* RMAP communication is not mandatory for projects implementing the FSFW.
|
||||||
* However, the communication principles are similar to RMAP as there are two write and two send calls involved.
|
* However, the communication principles are similar to RMAP as there are
|
||||||
|
* two write and two send calls involved.
|
||||||
*
|
*
|
||||||
* Device handler instances should extend this class and implement the abstract functions.
|
* Device handler instances should extend this class and implement the abstract functions.
|
||||||
* Components and drivers can send so called cookies which are used for communication
|
* Components and drivers can send so called cookies which are used for communication
|
||||||
@ -495,7 +492,8 @@ protected:
|
|||||||
DeviceCommunicationIF *communicationInterface;
|
DeviceCommunicationIF *communicationInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Cookie used for communication
|
* Cookie used for communication. This is passed to the communication
|
||||||
|
* interface.
|
||||||
*/
|
*/
|
||||||
Cookie *cookie;
|
Cookie *cookie;
|
||||||
|
|
||||||
@ -910,7 +908,7 @@ private:
|
|||||||
/**
|
/**
|
||||||
* State a cookie is in.
|
* State a cookie is in.
|
||||||
*
|
*
|
||||||
* Used to keep track of the state of the RMAP communication.
|
* Used to keep track of the state of the communication.
|
||||||
*/
|
*/
|
||||||
enum CookieState_t {
|
enum CookieState_t {
|
||||||
COOKIE_UNUSED, //!< The Cookie is unused
|
COOKIE_UNUSED, //!< The Cookie is unused
|
||||||
|
@ -4,7 +4,8 @@
|
|||||||
#include <framework/devicehandlers/DeviceCommunicationIF.h>
|
#include <framework/devicehandlers/DeviceCommunicationIF.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This class is a implementation of a DeviceCommunicationIF for RMAP calls. It expects RMAPCookies or a derived class of RMAPCookies
|
* @brief This class is a implementation of a DeviceCommunicationIF for RMAP calls.
|
||||||
|
* It expects RMAPCookies or a derived class of RMAPCookies
|
||||||
*
|
*
|
||||||
* @details The open, close and reOpen calls are mission specific
|
* @details The open, close and reOpen calls are mission specific
|
||||||
* The open call might return any child of RMAPCookies
|
* The open call might return any child of RMAPCookies
|
||||||
@ -44,7 +45,8 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Closing call of connection and memory free of cookie. Mission dependent call
|
* Closing call of connection and free memory of cookie.
|
||||||
|
* Mission dependent call
|
||||||
* @param cookie
|
* @param cookie
|
||||||
*/
|
*/
|
||||||
virtual void close(Cookie *cookie) = 0;
|
virtual void close(Cookie *cookie) = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user