opcua_basictypes.h 11 KB

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