Neonode zForce(TM) SDK
Transport.h
Go to the documentation of this file.
1 
12 #ifndef TRANSPORT_TRANSPORT_H
13 #define TRANSPORT_TRANSPORT_H
14 
15 #ifndef ZFORCECOMMON_H
16  #error Please include "zForceCommon.h" before this file.
17 #endif // ZFORCECOMMON_H
18 
23 {
28 };
29 
30 /*
31  * Forward declaration required in order to break the cycle where
32  * Transport needs TransportEntry, and
33  * TransportEntry needs Transport.
34  */
37 
41 typedef struct Transport Transport;
47 struct Transport
48 {
68  char ConnectionString
69  [TRANSPORTPROTOCOL_MaxOptionParameterLength + 1];
74  bool Terminate;
82  bool IsOpen;
83  bool Opening;
88 
109  bool ( * Open)(Transport * self);
122  bool ( * Close)(Transport * self);
137  DataFrame * ( * Read)(Transport * self);
151  bool ( * Write)(Transport * self, DataFrame * payload);
159  uint64_t ( * GetTimeOutValue)(Transport * self);
174  bool ( * EnqueueDataFrame)(Transport * self, DataFrame * dataFrame);
175 
180  void ( * Destructor )(Transport * self);
181 };
182 
183 // Exported Functions (prefixed with module name and underscore)
184 
217 DLLEXTERNAL Transport * Transport_GetInstance (Connection * connection,
218  char * connectionString,
219  char * dataFrameType);
220 
245 DLLEXTERNAL bool Transport_AddTransport(TransportEntry * transportEntry);
246 
267 DLLINTERNAL bool Transport_Initialize (void);
268 
282 DLLINTERNAL void Transport_Uninitialize (void);
283 
284 #ifdef USE_SERIALTRANSPORT
285  DLLINTERNAL bool SerialTransport_AddSerialTransportEntry (void);
286 #endif //USE_SERIALTRANSPORT
287 
288 #ifdef USE_HIDPIPETRANSPORT
289  DLLINTERNAL bool HidPipeTransport_AddHidPipeTransportEntry (void);
290 #endif //USE_HIDPIPETRANSPORT
291 
292 #endif // TRANSPORT_TRANSPORT_H
293 
DLLINTERNAL void Transport_Uninitialize(void)
Uninitialize the Transport module.
bool(* Write)(Transport *self, DataFrame *payload)
Function pointer to Transport's Write.
Definition: Transport.h:151
The main Connection struct.
Definition: Connection.h:56
bool(* Open)(Transport *self)
Open the generic Transport.
Definition: Transport.h:109
volatile ReadWriteThreadStatus ReadThreadStatus
Thread is active.
Definition: Transport.h:87
DLLINTERNAL bool SerialTransport_AddSerialTransportEntry(void)
Internal call to add a SerialTransport to the list of available transports.
Transport struct. This structure represents the base class of all Transport definitions.
Definition: Transport.h:47
bool Terminate
A flag indicating if the Transport Read and Write threads should terminate (true) or not (false)...
Definition: Transport.h:74
zForce * zForce
A pointer to the global zForce instance.
Definition: Transport.h:61
bool IsOpen
A flag indicating if the Transport is open (true) or not (false).
Definition: Transport.h:82
Thread is Initializing.
Definition: Transport.h:25
void(* Destructor)(Transport *self)
Destructor frees all the resources that have been allocated.
Definition: Transport.h:180
volatile ReadWriteThreadStatus WriteThreadStatus
Thread is active.
Definition: Transport.h:86
DLLEXTERNAL bool Transport_AddTransport(TransportEntry *transportEntry)
Add a new Transport to the list of those available.
Thread is Terminating.
Definition: Transport.h:27
Thread is not running.
Definition: Transport.h:24
Transport * Base
Base pointer to the immediate base Transport class. The inheritance is nested so for example WinSerTr...
Definition: Transport.h:55
The Queue struct.
Definition: Queue.h:26
bool Opening
Transport is in Opening phase.
Definition: Transport.h:83
Struct containing the DataFrame information.
Definition: DataFrame.h:27
DLLINTERNAL bool HidPipeTransport_AddHidPipeTransportEntry(void)
Internal call to add a HidPipeTransport to the list of available transports.
struct TransportEntry TransportEntry
Definition: Transport.h:36
uint64_t(* GetTimeOutValue)(Transport *self)
Function pointer to Transport's GetTimeOutValue.
Definition: Transport.h:159
void zForceThread
Typecast to underlying (system) type.
Definition: OsAbstractionLayer.h:21
DLLINTERNAL bool Transport_Initialize(void)
Initialize the Transport module.
Main struct.
Definition: zForce.h:29
DLLEXTERNAL Transport * Transport_GetInstance(Connection *connection, char *connectionString, char *dataFrameType)
This is the Transport factory function.
zForceThread * WriteThread
Write Thread pointer.
Definition: Transport.h:84
char ConnectionString[TRANSPORTPROTOCOL_MaxOptionParameterLength+1]
Connection string. This string contain the type of transport and the option parameters on the followi...
Definition: Transport.h:69
Queue * WriteQueue
A pointer to the Write queue used by EnqueueDataFrame.
Definition: Transport.h:78
bool(* Close)(Transport *self)
Close the generic Transport.
Definition: Transport.h:122
Connection * Connection
Each Transport is linked to one Connection.
Definition: Transport.h:59
Thread is Running.
Definition: Transport.h:26
ReadWriteThreadStatus
Enum describing the current status of a Read or Write thread.
Definition: Transport.h:22
zForceThread * ReadThread
Read Thread pointer.
Definition: Transport.h:85
bool(* EnqueueDataFrame)(Transport *self, DataFrame *dataFrame)
Enqueue given dataframe.
Definition: Transport.h:174