ua_config.h.in 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. /* This Source Code Form is subject to the terms of the Mozilla Public
  2. * License, v. 2.0. If a copy of the MPL was not distributed with this
  3. * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
  4. #ifndef UA_CONFIG_H_
  5. #define UA_CONFIG_H_
  6. #ifdef __cplusplus
  7. extern "C" {
  8. #endif
  9. /**
  10. * open62541 Version
  11. * ----------------- */
  12. #define UA_OPEN62541_VER_MAJOR ${OPEN62541_VER_MAJOR}
  13. #define UA_OPEN62541_VER_MINOR ${OPEN62541_VER_MINOR}
  14. #define UA_OPEN62541_VER_PATCH ${OPEN62541_VER_PATCH}
  15. #define UA_OPEN62541_VER_LABEL "${OPEN62541_VER_LABEL}" /* Release candidate label, etc. */
  16. #define UA_OPEN62541_VER_COMMIT "${OPEN62541_VER_COMMIT}"
  17. /**
  18. * Feature Options
  19. * ---------------
  20. * Changing the feature options has no effect on a pre-compiled library. */
  21. #define UA_LOGLEVEL ${UA_LOGLEVEL}
  22. #cmakedefine UA_ENABLE_METHODCALLS
  23. #cmakedefine UA_ENABLE_NODEMANAGEMENT
  24. #cmakedefine UA_ENABLE_SUBSCRIPTIONS
  25. #cmakedefine UA_ENABLE_PUBSUB
  26. #cmakedefine UA_ENABLE_PUBSUB_DELTAFRAMES
  27. #cmakedefine UA_ENABLE_PUBSUB_INFORMATIONMODEL
  28. #cmakedefine UA_ENABLE_ENCRYPTION
  29. #cmakedefine UA_ENABLE_HISTORIZING
  30. #cmakedefine UA_ENABLE_SUBSCRIPTIONS_EVENTS
  31. /* Multithreading */
  32. #cmakedefine UA_ENABLE_MULTITHREADING
  33. #cmakedefine UA_ENABLE_IMMUTABLE_NODES
  34. #if defined(UA_ENABLE_MULTITHREADING) && !defined(UA_ENABLE_IMMUTABLE_NODES)
  35. #error "The multithreading feature requires nodes to be immutable"
  36. #endif
  37. /* Advanced Options */
  38. #cmakedefine UA_ENABLE_STATUSCODE_DESCRIPTIONS
  39. #cmakedefine UA_ENABLE_TYPENAMES
  40. #cmakedefine UA_ENABLE_DETERMINISTIC_RNG
  41. #cmakedefine UA_ENABLE_NONSTANDARD_UDP
  42. #cmakedefine UA_ENABLE_DISCOVERY
  43. #cmakedefine UA_ENABLE_DISCOVERY_MULTICAST
  44. #cmakedefine UA_ENABLE_QUERY
  45. #cmakedefine UA_ENABLE_DISCOVERY_SEMAPHORE
  46. #cmakedefine UA_ENABLE_UNIT_TEST_FAILURE_HOOKS
  47. #cmakedefine UA_ENABLE_VALGRIND_INTERACTIVE
  48. #define UA_VALGRIND_INTERACTIVE_INTERVAL ${UA_VALGRIND_INTERACTIVE_INTERVAL}
  49. #cmakedefine UA_GENERATED_NAMESPACE_ZERO
  50. /* Options for Debugging */
  51. #cmakedefine UA_DEBUG
  52. #cmakedefine UA_DEBUG_DUMP_PKGS
  53. /**
  54. * C99 Definitions
  55. * --------------- */
  56. #include <string.h>
  57. #include <stddef.h>
  58. /* Include stdint.h and stdbool.h or workaround for older Visual Studios */
  59. #if !defined(_MSC_VER) || _MSC_VER >= 1600
  60. # include <stdint.h>
  61. # include <stdbool.h> /* C99 Boolean */
  62. # if defined(_WRS_KERNEL)
  63. # define UINT32_C(x) ((x) + (UINT32_MAX - UINT32_MAX))
  64. # endif
  65. #else
  66. # include "ms_stdint.h"
  67. # if !defined(__bool_true_false_are_defined)
  68. # define bool unsigned char
  69. # define true 1
  70. # define false 0
  71. # define __bool_true_false_are_defined
  72. # endif
  73. #endif
  74. /**
  75. * Assertions
  76. * ----------
  77. * The assert macro is disabled by defining NDEBUG. It is often forgotten to
  78. * include -DNDEBUG in the compiler flags when using the single-file release. So
  79. * we make assertions dependent on the UA_DEBUG definition handled by CMake. */
  80. #ifdef UA_DEBUG
  81. # include <assert.h>
  82. # define UA_assert(ignore) assert(ignore)
  83. #else
  84. # define UA_assert(ignore)
  85. #endif
  86. /* Outputs an error message at compile time if the assert fails.
  87. * Example usage:
  88. * UA_STATIC_ASSERT(sizeof(long)==7, use_another_compiler_luke)
  89. * See: https://stackoverflow.com/a/4815532/869402 */
  90. #if defined(__cplusplus) && __cplusplus >= 201103L /* C++11 or above */
  91. # define UA_STATIC_ASSERT(cond,msg) static_assert(cond, #msg)
  92. #elif defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L /* C11 or above */
  93. # define UA_STATIC_ASSERT(cond,msg) _Static_assert(cond, #msg)
  94. #elif defined(__GNUC__) || defined(__clang__) || defined(_MSC_VER) /* GCC, Clang, MSC */
  95. # define UA_CTASTR2(pre,post) pre ## post
  96. # define UA_CTASTR(pre,post) UA_CTASTR2(pre,post)
  97. # ifndef __COUNTER__ /* PPC GCC fix */
  98. # define __COUNTER__ __LINE__
  99. # endif
  100. # define UA_STATIC_ASSERT(cond,msg) \
  101. typedef struct { \
  102. int UA_CTASTR(static_assertion_failed_,msg) : !!(cond); \
  103. } UA_CTASTR(static_assertion_failed_,__COUNTER__)
  104. #else /* Everybody else */
  105. # define UA_STATIC_ASSERT(cond,msg) typedef char static_assertion_##msg[(cond)?1:-1]
  106. #endif
  107. /**
  108. * Memory Management
  109. * -----------------
  110. * The default is to use the malloc implementation from ``stdlib.h``. Override
  111. * if required. Changing the settings has no effect on a pre-compiled
  112. * library. */
  113. #include <stdlib.h>
  114. #if defined(_WIN32) && !defined(__clang__)
  115. # include <malloc.h>
  116. #endif
  117. #if !defined(UA_FREERTOS)
  118. # define UA_free(ptr) free(ptr)
  119. # define UA_malloc(size) malloc(size)
  120. # define UA_calloc(num, size) calloc(num, size)
  121. # define UA_realloc(ptr, size) realloc(ptr, size)
  122. #else
  123. # include <FreeRTOS.h>
  124. # define UA_free(ptr) vPortFree(ptr)
  125. # define UA_malloc(size) pvPortMalloc(size)
  126. # define UA_calloc(num, size) pvPortCalloc(num, size)
  127. # define UA_realloc(ptr, size) pvPortRealloc(ptr, size)
  128. #endif
  129. /* Stack-allocation of memory. Use C99 variable-length arrays if possible.
  130. * Otherwise revert to alloca. Note that alloca is not supported on some
  131. * plattforms. */
  132. #if defined(__GNUC__) || defined(__clang__)
  133. # define UA_STACKARRAY(TYPE, NAME, SIZE) TYPE NAME[SIZE]
  134. #elif defined(_WIN32)
  135. # define UA_STACKARRAY(TYPE, NAME, SIZE) \
  136. TYPE *NAME = (TYPE*)_alloca(sizeof(TYPE) * SIZE)
  137. #else
  138. # include <alloca.h>
  139. # define UA_STACKARRAY(TYPE, NAME, SIZE) \
  140. TYPE *NAME = (TYPE*)alloca(sizeof(TYPE) * SIZE)
  141. #endif
  142. /**
  143. * Function Export
  144. * ---------------
  145. * On Win32: Define ``UA_DYNAMIC_LINKING`` and ``UA_DYNAMIC_LINKING_EXPORT`` in
  146. * order to export symbols for a DLL. Define ``UA_DYNAMIC_LINKING`` only to
  147. * import symbols from a DLL.*/
  148. #cmakedefine UA_DYNAMIC_LINKING
  149. #if defined(_WIN32) && defined(UA_DYNAMIC_LINKING)
  150. # ifdef UA_DYNAMIC_LINKING_EXPORT /* export dll */
  151. # ifdef __GNUC__
  152. # define UA_EXPORT __attribute__ ((dllexport))
  153. # else
  154. # define UA_EXPORT __declspec(dllexport)
  155. # endif
  156. # else /* import dll */
  157. # ifdef __GNUC__
  158. # define UA_EXPORT __attribute__ ((dllimport))
  159. # else
  160. # define UA_EXPORT __declspec(dllimport)
  161. # endif
  162. # endif
  163. #else /* non win32 */
  164. # if __GNUC__ || __clang__
  165. # define UA_EXPORT __attribute__ ((visibility ("default")))
  166. # endif
  167. #endif
  168. #ifndef UA_EXPORT
  169. # define UA_EXPORT /* fallback to default */
  170. #endif
  171. /**
  172. * Inline Functions
  173. * ---------------- */
  174. #ifdef _MSC_VER
  175. # define UA_INLINE __inline
  176. #else
  177. # define UA_INLINE inline
  178. #endif
  179. /**
  180. * Non-aliasing pointers
  181. * -------------------- */
  182. #ifdef _MSC_VER
  183. # define UA_RESTRICT __restrict
  184. #elif defined(__GNUC__)
  185. # define UA_RESTRICT __restrict__
  186. #else
  187. # define UA_RESTRICT restrict
  188. #endif
  189. /**
  190. * Function attributes
  191. * ------------------- */
  192. #if defined(__GNUC__) || defined(__clang__)
  193. # define UA_FUNC_ATTR_MALLOC __attribute__((malloc))
  194. # define UA_FUNC_ATTR_PURE __attribute__ ((pure))
  195. # define UA_FUNC_ATTR_CONST __attribute__((const))
  196. # define UA_FUNC_ATTR_WARN_UNUSED_RESULT __attribute__((warn_unused_result))
  197. # define UA_FORMAT(X,Y) __attribute__ ((format (printf, X, Y)))
  198. #else
  199. # define UA_FUNC_ATTR_MALLOC
  200. # define UA_FUNC_ATTR_PURE
  201. # define UA_FUNC_ATTR_CONST
  202. # define UA_FUNC_ATTR_WARN_UNUSED_RESULT
  203. # define UA_FORMAT(X,Y)
  204. #endif
  205. #if defined(__GNUC__) || defined(__clang__)
  206. # define UA_DEPRECATED __attribute__((deprecated))
  207. #elif defined(_MSC_VER)
  208. # define UA_DEPRECATED __declspec(deprecated)
  209. #else
  210. # define UA_DEPRECATED
  211. #endif
  212. /**
  213. * Detect Endianness and IEEE 754 floating point
  214. * ---------------------------------------------
  215. * Integers and floating point numbers are transmitted in little-endian (IEEE
  216. * 754 for floating point) encoding. If the target architecture uses the same
  217. * format, numeral datatypes can be memcpy'd (overlayed) on the network buffer.
  218. * Otherwise, a slow default encoding routine is used that works for every
  219. * architecture.
  220. *
  221. * Integer Endianness
  222. * ^^^^^^^^^^^^^^^^^^
  223. * The definition ``UA_LITTLE_ENDIAN`` is true when the integer representation
  224. * of the target architecture is little-endian. */
  225. #if defined(_WIN32)
  226. # define UA_LITTLE_ENDIAN 1
  227. #elif (defined(__BYTE_ORDER__) && defined(__ORDER_LITTLE_ENDIAN__) && \
  228. (__BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__))
  229. # define UA_LITTLE_ENDIAN 1
  230. #elif defined(__linux__) /* Linux (including Android) */
  231. # include <endian.h>
  232. # if __BYTE_ORDER == __LITTLE_ENDIAN
  233. # define UA_LITTLE_ENDIAN 1
  234. # endif
  235. #elif defined(__OpenBSD__) /* OpenBSD */
  236. # include <sys/endian.h>
  237. # if BYTE_ORDER == LITTLE_ENDIAN
  238. # define UA_LITTLE_ENDIAN 1
  239. # endif
  240. #elif defined(__NetBSD__) || defined(__FreeBSD__) || defined(__DragonFly__) /* Other BSD */
  241. # include <sys/endian.h>
  242. # if _BYTE_ORDER == _LITTLE_ENDIAN
  243. # define UA_LITTLE_ENDIAN 1
  244. # endif
  245. #elif defined(__APPLE__) /* Apple (MacOS, iOS) */
  246. # include <libkern/OSByteOrder.h>
  247. # if defined(__LITTLE_ENDIAN__)
  248. # define UA_LITTLE_ENDIAN 1
  249. # endif
  250. #elif defined(__QNX__) || defined(__QNXNTO__) /* QNX */
  251. # include <gulliver.h>
  252. # if defined(__LITTLEENDIAN__)
  253. # define UA_LITTLE_ENDIAN 1
  254. # endif
  255. #endif
  256. #ifndef UA_LITTLE_ENDIAN
  257. # define UA_LITTLE_ENDIAN 0
  258. #endif
  259. /* Can the integers be memcpy'd onto the network buffer? Add additional checks
  260. * here. Some platforms (e.g. QNX) have sizeof(bool) > 1. Manually disable
  261. * overlayed integer encoding if that is the case. */
  262. #if (UA_LITTLE_ENDIAN == 1)
  263. UA_STATIC_ASSERT(sizeof(bool) == 1, cannot_overlay_integers_with_large_bool);
  264. # define UA_BINARY_OVERLAYABLE_INTEGER 1
  265. #else
  266. # define UA_BINARY_OVERLAYABLE_INTEGER 0
  267. #endif
  268. /**
  269. * Float Endianness
  270. * ^^^^^^^^^^^^^^^^
  271. * The definition ``UA_FLOAT_IEEE754`` is set to true when the floating point
  272. * number representation of the target architecture is IEEE 754. The definition
  273. * ``UA_FLOAT_LITTLE_ENDIAN`` is set to true when the floating point number
  274. * representation is in little-endian encoding. */
  275. #if defined(_WIN32)
  276. # define UA_FLOAT_IEEE754 1
  277. #elif defined(__i386__) || defined(__x86_64__) || defined(__amd64__) || \
  278. defined(__ia64__) || defined(__powerpc__) || defined(__sparc__) || \
  279. defined(__arm__)
  280. # define UA_FLOAT_IEEE754 1
  281. #elif defined(__STDC_IEC_559__)
  282. # define UA_FLOAT_IEEE754 1
  283. #else
  284. # define UA_FLOAT_IEEE754 0
  285. #endif
  286. /* Wikipedia says (https://en.wikipedia.org/wiki/Endianness): Although the
  287. * ubiquitous x86 processors of today use little-endian storage for all types of
  288. * data (integer, floating point, BCD), there are a number of hardware
  289. * architectures where floating-point numbers are represented in big-endian form
  290. * while integers are represented in little-endian form. */
  291. #if defined(_WIN32)
  292. # define UA_FLOAT_LITTLE_ENDIAN 1
  293. #elif defined(__i386__) || defined(__x86_64__) || defined(__amd64__)
  294. # define UA_FLOAT_LITTLE_ENDIAN 1
  295. #elif defined(__FLOAT_WORD_ORDER__) && defined(__ORDER_LITTLE_ENDIAN__) && \
  296. (__FLOAT_WORD_ORDER__ == __ORDER_LITTLE_ENDIAN__) /* Defined only in GCC */
  297. # define UA_FLOAT_LITTLE_ENDIAN 1
  298. #elif defined(__FLOAT_WORD_ORDER) && defined(__LITTLE_ENDIAN) && \
  299. (__FLOAT_WORD_ORDER == __LITTLE_ENDIAN) /* Defined only in GCC */
  300. # define UA_FLOAT_LITTLE_ENDIAN 1
  301. #endif
  302. #ifndef UA_FLOAT_LITTLE_ENDIAN
  303. # define UA_FLOAT_LITTLE_ENDIAN 0
  304. #endif
  305. /* Only if the floating points are litle-endian **and** in IEEE 754 format can
  306. * we memcpy directly onto the network buffer. */
  307. #if (UA_FLOAT_IEEE754 == 1) && (UA_FLOAT_LITTLE_ENDIAN == 1)
  308. # define UA_BINARY_OVERLAYABLE_FLOAT 1
  309. #else
  310. # define UA_BINARY_OVERLAYABLE_FLOAT 0
  311. #endif
  312. #ifdef __cplusplus
  313. } // extern "C"
  314. #endif
  315. #endif /* UA_CONFIG_H_ */