opcua_basictypes.h 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. /*
  2. * opcua_basictypes.h
  3. *
  4. * Created on: 13.03.2014
  5. * Author: mrt
  6. */
  7. #ifndef OPCUA_BASICTYPES_H_
  8. #define OPCUA_BASICTYPES_H_
  9. #include <stdint.h>
  10. /* Basic types */
  11. typedef _Bool UA_Boolean;
  12. typedef uint8_t UA_Byte;
  13. typedef int8_t UA_SByte;
  14. typedef int16_t UA_Int16;
  15. typedef uint16_t UA_UInt16;
  16. typedef int32_t UA_Int32;
  17. typedef uint32_t UA_UInt32;
  18. typedef int64_t UA_Int64;
  19. typedef uint64_t UA_UInt64;
  20. typedef float UA_Float;
  21. typedef double UA_Double;
  22. /* Function return values */
  23. #define UA_SUCCESS 0
  24. #define UA_NO_ERROR UA_SUCCESS
  25. #define UA_ERROR (0x01)
  26. #define UA_ERR_INCONSISTENT (UA_ERROR | (0x01 << 1))
  27. #define UA_ERR_INVALID_VALUE (UA_ERROR | (0x01 << 2))
  28. #define UA_ERR_NO_MEMORY (UA_ERROR | (0x01 << 3))
  29. #define UA_ERR_NOT_IMPLEMENTED (UA_ERROR | (0x01 << 4))
  30. /* Boolean values and null */
  31. #define UA_TRUE (42==42)
  32. #define TRUE UA_TRUE
  33. #define UA_FALSE (!UA_TRUE)
  34. #define FALSE UA_FALSE
  35. /* Compare values */
  36. #define UA_EQUAL 0
  37. #define UA_NOT_EQUAL (!UA_EQUAL)
  38. /* heap memory functions */
  39. #define UA_NULL ((void*)0)
  40. extern void const * UA_alloc_lastptr;
  41. UA_Int32 UA_free(void * ptr);
  42. UA_Int32 UA_memcpy(void *dst, void const *src, int size);
  43. UA_Int32 UA_alloc(void ** dst, int size);
  44. /* Array operations */
  45. UA_Int32 UA_Array_calcSize(UA_Int32 noElements, UA_Int32 type, void const ** ptr);
  46. UA_Int32 UA_Array_encode(void const **src, UA_Int32 noElements, UA_Int32 type, UA_Int32* pos, char * dst);
  47. UA_Int32 UA_Array_decode(char const * src,UA_Int32 noElements, UA_Int32 type, UA_Int32* pos, void const **dst);
  48. #define UA_TYPE_METHOD_PROTOTYPES(TYPE) \
  49. UA_Int32 TYPE##_calcSize(TYPE const * ptr);\
  50. UA_Int32 TYPE##_encode(TYPE const * src, UA_Int32* pos, char * dst);\
  51. UA_Int32 TYPE##_decode(char const * src, UA_Int32* pos, TYPE * dst);\
  52. UA_Int32 TYPE##_delete(TYPE * p);\
  53. UA_Int32 TYPE##_deleteMembers(TYPE * p); \
  54. #define UA_TYPE_METHOD_CALCSIZE_SIZEOF(TYPE) \
  55. UA_Int32 TYPE##_calcSize(TYPE const * p) { return sizeof(TYPE); }
  56. #define UA_TYPE_METHOD_CALCSIZE_AS(TYPE, TYPE_AS) \
  57. UA_Int32 TYPE##_calcSize(TYPE const * p) { return TYPE_AS##_calcSize((TYPE_AS*) p); }
  58. #define UA_TYPE_METHOD_DELETE_FREE(TYPE) \
  59. UA_Int32 TYPE##_delete(TYPE * p) { return UA_free(p); }
  60. #define UA_TYPE_METHOD_DELETE_AS(TYPE, TYPE_AS) \
  61. UA_Int32 TYPE##_delete(TYPE * p) { return TYPE_AS##_delete((TYPE_AS*) p);}
  62. #define UA_TYPE_METHOD_DELETE_STRUCT(TYPE) \
  63. UA_Int32 TYPE##_delete(TYPE *p) { \
  64. UA_Int32 retval = UA_SUCCESS; \
  65. retval |= TYPE##_deleteMembers(p); \
  66. retval |= UA_free(p); \
  67. return retval; \
  68. }
  69. #define UA_TYPE_METHOD_DELETEMEMBERS_NOACTION(TYPE) \
  70. UA_Int32 TYPE##_deleteMembers(TYPE * p) { return UA_SUCCESS; }
  71. #define UA_TYPE_METHOD_DELETEMEMBERS_AS(TYPE, TYPE_AS) \
  72. UA_Int32 TYPE##_deleteMembers(TYPE * p) { return TYPE_AS##_deleteMembers((TYPE_AS*) p);}
  73. #define UA_TYPE_METHOD_DECODE_AS(TYPE,TYPE_AS) \
  74. UA_Int32 TYPE##_decode(char const * src, UA_Int32* pos, TYPE *dst) { \
  75. return TYPE_AS##_decode(src,pos,(TYPE_AS*) dst); \
  76. }
  77. #define UA_TYPE_METHOD_ENCODE_AS(TYPE,TYPE_AS) \
  78. UA_Int32 TYPE##_encode(TYPE const * src, UA_Int32* pos, char *dst) { \
  79. return TYPE_AS##_encode((TYPE_AS*) src,pos,dst); \
  80. }
  81. /*** Prototypes for basic types **/
  82. UA_TYPE_METHOD_PROTOTYPES (UA_Boolean)
  83. UA_TYPE_METHOD_PROTOTYPES (UA_Byte)
  84. UA_TYPE_METHOD_PROTOTYPES (UA_SByte)
  85. UA_TYPE_METHOD_PROTOTYPES (UA_Int16)
  86. UA_TYPE_METHOD_PROTOTYPES (UA_UInt16)
  87. UA_TYPE_METHOD_PROTOTYPES (UA_Int32)
  88. UA_TYPE_METHOD_PROTOTYPES (UA_UInt32)
  89. UA_TYPE_METHOD_PROTOTYPES (UA_Int64)
  90. UA_TYPE_METHOD_PROTOTYPES (UA_UInt64)
  91. UA_TYPE_METHOD_PROTOTYPES (UA_Float)
  92. UA_TYPE_METHOD_PROTOTYPES (UA_Double)
  93. /**
  94. * StatusCodeBinaryEncoding
  95. * Part: 6
  96. * Chapter: 5.2.2.11
  97. * Page: 20
  98. */
  99. typedef UA_Int32 UA_StatusCode;
  100. enum UA_StatusCode_enum
  101. {
  102. // Some Values are called the same as previous Enumerations so we need
  103. //names that are unique
  104. SC_Good = 0x00
  105. };
  106. UA_TYPE_METHOD_PROTOTYPES (UA_StatusCode)
  107. /** IntegerId - Part: 4, Chapter: 7.13, Page: 118 */
  108. typedef float UA_IntegerId;
  109. UA_TYPE_METHOD_PROTOTYPES (UA_IntegerId)
  110. typedef struct T_UA_VTable {
  111. UA_UInt32 Id;
  112. UA_Int32 (*calcSize)(void const * ptr);
  113. UA_Int32 (*decode)(char const * src, UA_Int32* pos, void* dst);
  114. UA_Int32 (*encode)(void const * src, UA_Int32* pos, char* dst);
  115. } UA_VTable;
  116. /* VariantBinaryEncoding - Part: 6, Chapter: 5.2.2.16, Page: 22 */
  117. typedef struct T_UA_Variant {
  118. UA_VTable* vt; // internal entry into vTable
  119. UA_Byte encodingMask; // Type of UA_Variant_EncodingMaskType_enum
  120. UA_Int32 arrayLength; // total number of elements
  121. void** data;
  122. } UA_Variant;
  123. UA_TYPE_METHOD_PROTOTYPES (UA_Variant)
  124. /* String - Part: 6, Chapter: 5.2.2.4, Page: 16 */
  125. typedef struct T_UA_String
  126. {
  127. UA_Int32 length;
  128. UA_Byte* data;
  129. }
  130. UA_String;
  131. UA_TYPE_METHOD_PROTOTYPES (UA_String)
  132. UA_Int32 UA_String_compare(UA_String *string1, UA_String *string2);
  133. void UA_String_printf(char* label, UA_String* string);
  134. void UA_String_printx(char* label, UA_String* string);
  135. void UA_String_printx_hex(char* label, UA_String* string);
  136. /* ByteString - Part: 6, Chapter: 5.2.2.7, Page: 17 */
  137. typedef struct T_UA_ByteString
  138. {
  139. UA_Int32 length;
  140. UA_Byte* data;
  141. }
  142. UA_ByteString;
  143. UA_TYPE_METHOD_PROTOTYPES (UA_ByteString)
  144. UA_Int32 UA_ByteString_compare(UA_ByteString *string1, UA_ByteString *string2);
  145. /** LocalizedTextBinaryEncoding - Part: 6, Chapter: 5.2.2.14, Page: 21 */
  146. typedef struct T_UA_LocalizedText
  147. {
  148. UA_Byte encodingMask;
  149. UA_String locale;
  150. UA_String text;
  151. }
  152. UA_LocalizedText;
  153. UA_TYPE_METHOD_PROTOTYPES (UA_LocalizedText)
  154. /* GuidType - Part: 6, Chapter: 5.2.2.6 Page: 17 */
  155. typedef struct T_UA_Guid
  156. {
  157. UA_UInt32 data1;
  158. UA_UInt16 data2;
  159. UA_UInt16 data3;
  160. UA_ByteString data4;
  161. } UA_Guid;
  162. UA_TYPE_METHOD_PROTOTYPES (UA_Guid)
  163. UA_Int32 UA_Guid_compare(UA_Guid *g1, UA_Guid *g2);
  164. /* DateTime - Part: 6, Chapter: 5.2.2.5, Page: 16 */
  165. typedef UA_Int64 UA_DateTime; //100 nanosecond resolution
  166. UA_TYPE_METHOD_PROTOTYPES (UA_DateTime)
  167. typedef struct T_UA_NodeId
  168. {
  169. UA_Byte encodingByte; //enum BID_NodeIdEncodingValuesType
  170. UA_UInt16 namespace;
  171. union
  172. {
  173. UA_UInt32 numeric;
  174. UA_String string;
  175. UA_Guid guid;
  176. UA_ByteString byteString;
  177. }
  178. identifier;
  179. } UA_NodeId;
  180. UA_TYPE_METHOD_PROTOTYPES (UA_NodeId)
  181. UA_Int32 UA_NodeId_compare(UA_NodeId *n1, UA_NodeId *n2);
  182. /** XmlElement - Part: 6, Chapter: 5.2.2.8, Page: 17 */
  183. typedef struct T_UA_XmlElement
  184. {
  185. //TODO Überlegung ob man es direkt als ByteString speichert oder als String
  186. UA_ByteString data;
  187. } UA_XmlElement;
  188. UA_TYPE_METHOD_PROTOTYPES (UA_XmlElement)
  189. /* ExpandedNodeId - Part: 6, Chapter: 5.2.2.10, Page: 19 */
  190. typedef struct T_UA_ExpandedNodeId
  191. {
  192. UA_NodeId nodeId;
  193. UA_String namespaceUri;
  194. UA_UInt32 serverIndex;
  195. }
  196. UA_ExpandedNodeId;
  197. UA_TYPE_METHOD_PROTOTYPES(UA_ExpandedNodeId)
  198. typedef UA_Int32 UA_IdentifierType;
  199. UA_TYPE_METHOD_PROTOTYPES(UA_IdentifierType)
  200. /* ExtensionObjectBinaryEncoding - Part: 6, Chapter: 5.2.2.15, Page: 21 */
  201. typedef struct T_UA_ExtensionObject {
  202. UA_NodeId typeId;
  203. UA_Byte encoding; //Type of the enum UA_ExtensionObjectEncodingMaskType
  204. UA_ByteString body;
  205. } UA_ExtensionObject;
  206. UA_TYPE_METHOD_PROTOTYPES(UA_ExtensionObject)
  207. enum UA_ExtensionObject_EncodingMaskType_enum
  208. {
  209. UA_EXTENSIONOBJECT_NOBODYISENCODED = 0x00,
  210. UA_EXTENSIONOBJECT_BODYISBYTESTRING = 0x01,
  211. UA_EXTENSIONOBJECT_BODYISXML = 0x02
  212. };
  213. /* QualifiedNameBinaryEncoding - Part: 6, Chapter: 5.2.2.13, Page: 20 */
  214. typedef struct T_UA_QualifiedName {
  215. UA_UInt16 namespaceIndex;
  216. UA_UInt16 reserved;
  217. UA_String name;
  218. } UA_QualifiedName;
  219. UA_TYPE_METHOD_PROTOTYPES(UA_QualifiedName)
  220. /* DataValue - Part: 6, Chapter: 5.2.2.17, Page: 23 */
  221. typedef struct UA_DataValue {
  222. UA_Byte encodingMask;
  223. UA_Variant value;
  224. UA_StatusCode status;
  225. UA_DateTime sourceTimestamp;
  226. UA_Int16 sourcePicoseconds;
  227. UA_DateTime serverTimestamp;
  228. UA_Int16 serverPicoseconds;
  229. } UA_DataValue;
  230. UA_TYPE_METHOD_PROTOTYPES(UA_DataValue)
  231. /** 62541-6, §5.2.2.17, Table 15 */
  232. enum UA_DataValue_EncodingMaskType_enum
  233. {
  234. UA_DATAVALUE_VARIANT = 0x01,
  235. UA_DATAVALUE_STATUSCODE = 0x02,
  236. UA_DATAVALUE_SOURCETIMESTAMP = 0x04,
  237. UA_DATAVALUE_SERVERTIMPSTAMP = 0x08,
  238. UA_DATAVALUE_SOURCEPICOSECONDS = 0x10,
  239. UA_DATAVALUE_SERVERPICOSECONDS = 0x20
  240. };
  241. /* DiagnosticInfo - Part: 6, Chapter: 5.2.2.12, Page: 20 */
  242. typedef struct T_UA_DiagnosticInfo {
  243. UA_Byte encodingMask; //Type of the Enum UA_DIAGNOSTICINFO_ENCODINGMASKTYPE
  244. UA_Int32 symbolicId;
  245. UA_Int32 namespaceUri;
  246. UA_Int32 localizedText;
  247. UA_Int32 locale;
  248. UA_String additionalInfo;
  249. UA_StatusCode innerStatusCode;
  250. struct T_UA_DiagnosticInfo* innerDiagnosticInfo;
  251. } UA_DiagnosticInfo;
  252. UA_TYPE_METHOD_PROTOTYPES(UA_DiagnosticInfo)
  253. enum UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_enum
  254. {
  255. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_SYMBOLICID = 0x01,
  256. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_NAMESPACE = 0x02,
  257. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_LOCALIZEDTEXT = 0x04,
  258. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_LOCALE = 0x08,
  259. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_ADDITIONALINFO = 0x10,
  260. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_INNERSTATUSCODE = 0x20,
  261. UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_INNERDIAGNOSTICINFO = 0x40
  262. };
  263. #endif /* OPCUA_BASICTYPES_H_ */