core_mqtt_config_defaults.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. /*
  2. * coreMQTT <DEVELOPMENT BRANCH>
  3. * Copyright (C) 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.
  4. *
  5. * SPDX-License-Identifier: MIT
  6. *
  7. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  8. * this software and associated documentation files (the "Software"), to deal in
  9. * the Software without restriction, including without limitation the rights to
  10. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  11. * the Software, and to permit persons to whom the Software is furnished to do so,
  12. * subject to the following conditions:
  13. *
  14. * The above copyright notice and this permission notice shall be included in all
  15. * copies or substantial portions of the Software.
  16. *
  17. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  19. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  20. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  21. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  22. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  23. */
  24. /**
  25. * @file core_mqtt_config_defaults.h
  26. * @brief This represents the default values for the configuration macros
  27. * for the MQTT library.
  28. *
  29. * @note This file SHOULD NOT be modified. If custom values are needed for
  30. * any configuration macro, a core_mqtt_config.h file should be provided to
  31. * the MQTT library to override the default values defined in this file.
  32. * To use the custom config file, the MQTT_DO_NOT_USE_CUSTOM_CONFIG preprocessor
  33. * macro SHOULD NOT be set.
  34. */
  35. #ifndef CORE_MQTT_CONFIG_DEFAULTS_H_
  36. #define CORE_MQTT_CONFIG_DEFAULTS_H_
  37. /* *INDENT-OFF* */
  38. #ifdef __cplusplus
  39. extern "C" {
  40. #endif
  41. /* *INDENT-ON* */
  42. /* MQTT_DO_NOT_USE_CUSTOM_CONFIG allows building the MQTT library
  43. * without a custom config. If a custom config is provided, the
  44. * MQTT_DO_NOT_USE_CUSTOM_CONFIG macro should not be defined. */
  45. #ifndef MQTT_DO_NOT_USE_CUSTOM_CONFIG
  46. /* Include custom config file before other headers. */
  47. #include "core_mqtt_config.h"
  48. #endif
  49. /* The macro definition for MQTT_DO_NOT_USE_CUSTOM_CONFIG is for Doxygen
  50. * documentation only. */
  51. /**
  52. * @brief Define this macro to build the MQTT library without the custom config
  53. * file core_mqtt_config.h.
  54. *
  55. * Without the custom config, the MQTT library builds with
  56. * default values of config macros defined in core_mqtt_config_defaults.h file.
  57. *
  58. * If a custom config is provided, then MQTT_DO_NOT_USE_CUSTOM_CONFIG should not
  59. * be defined.
  60. */
  61. #ifdef DOXYGEN
  62. #define MQTT_DO_NOT_USE_CUSTOM_CONFIG
  63. #endif
  64. /**
  65. * @ingroup mqtt_constants
  66. * @brief Maximum number of vectors in subscribe and unsubscribe packet.
  67. */
  68. #ifndef MQTT_SUB_UNSUB_MAX_VECTORS
  69. #define MQTT_SUB_UNSUB_MAX_VECTORS ( 4U )
  70. #endif
  71. /**
  72. * @brief The number of retries for receiving CONNACK.
  73. *
  74. * The MQTT_MAX_CONNACK_RECEIVE_RETRY_COUNT will be used only when the
  75. * timeoutMs parameter of #MQTT_Connect is passed as 0 . The transport
  76. * receive for CONNACK will be retried MQTT_MAX_CONNACK_RECEIVE_RETRY_COUNT
  77. * times before timing out. A value of 0 for this config will cause the
  78. * transport receive for CONNACK to be invoked only once.
  79. *
  80. * <b>Possible values:</b> Any positive 16 bit integer. <br>
  81. * <b>Default value:</b> `5`
  82. */
  83. #ifndef MQTT_MAX_CONNACK_RECEIVE_RETRY_COUNT
  84. /* Default value for the CONNACK receive retries. */
  85. #define MQTT_MAX_CONNACK_RECEIVE_RETRY_COUNT ( 5U )
  86. #endif
  87. /**
  88. * @brief Maximum number of milliseconds to wait for a ping response to a ping
  89. * request as part of the keep-alive mechanism.
  90. *
  91. * If a ping response is not received before this timeout, then
  92. * #MQTT_ProcessLoop will return #MQTTKeepAliveTimeout.
  93. *
  94. * @note If this value is more than half of the keep alive interval, and the
  95. * server does not receive the previous ping request, then it is likely that the
  96. * server will disconnect the client before #MQTTKeepAliveTimeout can be returned.
  97. *
  98. * @note If a dummy implementation of the #MQTTGetCurrentTimeFunc_t timer function,
  99. * is supplied to the library, then the keep-alive mechanism is not supported by the
  100. * #MQTT_ProcessLoop API function. In that case, the value of #MQTT_PINGRESP_TIMEOUT_MS
  101. * is irrelevant to the behavior of the library.
  102. *
  103. * <b>Possible values:</b> Any positive integer up to SIZE_MAX. <br>
  104. * <b>Default value:</b> `5000`
  105. */
  106. #ifndef MQTT_PINGRESP_TIMEOUT_MS
  107. /* Wait 5 seconds by default for a ping response. */
  108. #define MQTT_PINGRESP_TIMEOUT_MS ( 5000U )
  109. #endif
  110. /**
  111. * @brief Maximum number of milliseconds of TX inactivity to wait
  112. * before initiating a PINGREQ
  113. *
  114. * @note If this value is less than the keep alive interval than
  115. * it will be used instead.
  116. *
  117. * <b>Possible values:</b> Any positive integer up to SIZE_MAX. <br>
  118. * <b>Default value:</b> '30000'
  119. */
  120. #ifndef PACKET_TX_TIMEOUT_MS
  121. #define PACKET_TX_TIMEOUT_MS ( 30000U )
  122. #endif
  123. /**
  124. * @brief Maximum number of milliseconds of RX inactivity to wait
  125. * before initiating a PINGREQ
  126. *
  127. * <b>Possible values:</b> Any positive integer up to SIZE_MAX. <br>
  128. * <b>Default value:</b> '30000'
  129. *
  130. */
  131. #ifndef PACKET_RX_TIMEOUT_MS
  132. #define PACKET_RX_TIMEOUT_MS ( 30000U )
  133. #endif
  134. /**
  135. * @brief The maximum duration between non-empty network reads while
  136. * receiving an MQTT packet via the #MQTT_ProcessLoop or #MQTT_ReceiveLoop
  137. * API functions.
  138. *
  139. * When an incoming MQTT packet is detected, the transport receive function
  140. * may be called multiple times until all of the expected number of bytes of the
  141. * packet are received. This timeout represents the maximum polling duration that
  142. * is allowed without any data reception from the network for the incoming packet.
  143. *
  144. * If the timeout expires, the #MQTT_ProcessLoop and #MQTT_ReceiveLoop functions
  145. * return #MQTTRecvFailed.
  146. *
  147. * @note If a dummy implementation of the #MQTTGetCurrentTimeFunc_t timer function,
  148. * is supplied to the library, then #MQTT_RECV_POLLING_TIMEOUT_MS MUST be set to 0.
  149. *
  150. * <b>Possible values:</b> Any positive 32 bit integer. Recommended to use a
  151. * small timeout value. <br>
  152. * <b>Default value:</b> `10`
  153. *
  154. */
  155. #ifndef MQTT_RECV_POLLING_TIMEOUT_MS
  156. #define MQTT_RECV_POLLING_TIMEOUT_MS ( 10U )
  157. #endif
  158. /**
  159. * @brief The maximum duration allowed to send an MQTT packet over the transport
  160. * interface.
  161. *
  162. * When sending an MQTT packet, the transport send or writev functions may be
  163. * called multiple times until all of the required number of bytes are sent.
  164. * This timeout represents the maximum duration that is allowed to send the MQTT
  165. * packet while calling the transport send or writev functions.
  166. *
  167. * If the timeout expires, #MQTTSendFailed will be returned by the public API
  168. * functions.
  169. *
  170. * @note If a dummy implementation of the #MQTTGetCurrentTimeFunc_t timer function,
  171. * is supplied to the library, then #MQTT_SEND_TIMEOUT_MS MUST be set to 0.
  172. *
  173. * <b>Possible values:</b> Any positive 32 bit integer. <br>
  174. * <b>Default value:</b> `20000`
  175. *
  176. */
  177. #ifndef MQTT_SEND_TIMEOUT_MS
  178. #define MQTT_SEND_TIMEOUT_MS ( 20000U )
  179. #endif
  180. #ifdef MQTT_SEND_RETRY_TIMEOUT_MS
  181. #error MQTT_SEND_RETRY_TIMEOUT_MS is deprecated. Instead use MQTT_SEND_TIMEOUT_MS.
  182. #endif
  183. /**
  184. * @brief Macro that is called in the MQTT library for logging "Error" level
  185. * messages.
  186. *
  187. * To enable error level logging in the MQTT library, this macro should be mapped to the
  188. * application-specific logging implementation that supports error logging.
  189. *
  190. * @note This logging macro is called in the MQTT library with parameters wrapped in
  191. * double parentheses to be ISO C89/C90 standard compliant. For a reference
  192. * POSIX implementation of the logging macros, refer to core_mqtt_config.h files, and the
  193. * logging-stack in demos folder of the
  194. * [AWS IoT Embedded C SDK repository](https://github.com/aws/aws-iot-device-sdk-embedded-C).
  195. *
  196. * <b>Default value</b>: Error logging is turned off, and no code is generated for calls
  197. * to the macro in the MQTT library on compilation.
  198. */
  199. #ifndef LogError
  200. #define LogError( message )
  201. #endif
  202. /**
  203. * @brief Macro that is called in the MQTT library for logging "Warning" level
  204. * messages.
  205. *
  206. * To enable warning level logging in the MQTT library, this macro should be mapped to the
  207. * application-specific logging implementation that supports warning logging.
  208. *
  209. * @note This logging macro is called in the MQTT library with parameters wrapped in
  210. * double parentheses to be ISO C89/C90 standard compliant. For a reference
  211. * POSIX implementation of the logging macros, refer to core_mqtt_config.h files, and the
  212. * logging-stack in demos folder of the
  213. * [AWS IoT Embedded C SDK repository](https://github.com/aws/aws-iot-device-sdk-embedded-C/).
  214. *
  215. * <b>Default value</b>: Warning logs are turned off, and no code is generated for calls
  216. * to the macro in the MQTT library on compilation.
  217. */
  218. #ifndef LogWarn
  219. #define LogWarn( message )
  220. #endif
  221. /**
  222. * @brief Macro that is called in the MQTT library for logging "Info" level
  223. * messages.
  224. *
  225. * To enable info level logging in the MQTT library, this macro should be mapped to the
  226. * application-specific logging implementation that supports info logging.
  227. *
  228. * @note This logging macro is called in the MQTT library with parameters wrapped in
  229. * double parentheses to be ISO C89/C90 standard compliant. For a reference
  230. * POSIX implementation of the logging macros, refer to core_mqtt_config.h files, and the
  231. * logging-stack in demos folder of the
  232. * [AWS IoT Embedded C SDK repository](https://github.com/aws/aws-iot-device-sdk-embedded-C/).
  233. *
  234. * <b>Default value</b>: Info logging is turned off, and no code is generated for calls
  235. * to the macro in the MQTT library on compilation.
  236. */
  237. #ifndef LogInfo
  238. #define LogInfo( message )
  239. #endif
  240. /**
  241. * @brief Macro that is called in the MQTT library for logging "Debug" level
  242. * messages.
  243. *
  244. * To enable debug level logging from MQTT library, this macro should be mapped to the
  245. * application-specific logging implementation that supports debug logging.
  246. *
  247. * @note This logging macro is called in the MQTT library with parameters wrapped in
  248. * double parentheses to be ISO C89/C90 standard compliant. For a reference
  249. * POSIX implementation of the logging macros, refer to core_mqtt_config.h files, and the
  250. * logging-stack in demos folder of the
  251. * [AWS IoT Embedded C SDK repository](https://github.com/aws/aws-iot-device-sdk-embedded-C/).
  252. *
  253. * <b>Default value</b>: Debug logging is turned off, and no code is generated for calls
  254. * to the macro in the MQTT library on compilation.
  255. */
  256. #ifndef LogDebug
  257. #define LogDebug( message )
  258. #endif
  259. /* *INDENT-OFF* */
  260. #ifdef __cplusplus
  261. }
  262. #endif
  263. /* *INDENT-ON* */
  264. #endif /* ifndef CORE_MQTT_CONFIG_DEFAULTS_H_ */