nbus_defines.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /**
  2. * @file nbus_defines.h
  3. *
  4. * @date: Nov 26, 2025
  5. * @author: Juraj Dudak, Matus Necas
  6. */
  7. #ifndef INC_NBUS_DEFINES_H_
  8. #define INC_NBUS_DEFINES_H_
  9. /* BEGIN GENERAL NBUS DEFINES */
  10. /** @brief Macro for broadcast address (MA = 0). */
  11. #define NBUS_BROADCAST_ADDRESS 0x00
  12. /** @brief Macro for NBus Bridge address (MA = 0, SA = BRIDGE). */
  13. #define NBUS_BRIDGE_ADDRESS 0xFF
  14. /** @brief Macro for RX meta size in bytes. */
  15. #define NBUS_RX_META_SIZE 4
  16. /** @brief Macro for module address in RX packet. */
  17. #define NBUS_RX_MODULE_ADDRESS(packet) (packet)[0]
  18. /** @brief Macro for sensor address in RX packet. */
  19. #define NBUS_RX_SENSOR_ADDRESS(packet) (packet)[1]
  20. /** @brief Macro for function code in RX packet. */
  21. #define NBUS_RX_FUNCTION_CODE(packet) (packet)[2]
  22. /** @brief Macro for #0 data byte in RX packet. */
  23. #define NBUS_RX_DATA0(packet) (packet)[3]
  24. /** @brief Macro for CRC8 byte in RX packet. */
  25. #define NBUS_RX_CRC8(packet, size) (packet)[(size) - 1]
  26. /** @brief Macro for TX meta size in bytes. */
  27. #define NBUS_TX_META_SIZE 5
  28. /** @brief Macro for #0 data byte in TX packet. */
  29. #define NBUS_TX_DATA0(packet) (packet)[4]
  30. /** @brief Macro for set command flag. */
  31. #define NBUS_SET_CMD(cmd) ((cmd) | 0x20)
  32. /** @brief Macro to set error response. */
  33. #define NBUS_SET_ERR_RESPONSE(fc) ((fc) | 0x80)
  34. #define NBUS_CHECK_ERR_RESPONSE(packet) ((packet)[2] & 0x80)
  35. /* END GENERAL NBUS DEFINES */
  36. /** @brief Enumerate for function codes */
  37. typedef enum {
  38. FC_FIND = 0,
  39. FC_ECHO, /* 1 */
  40. FC_STOP, /* 2 */
  41. FC_START, /* 3 */
  42. FC_PARAM, /* 4 */
  43. FC_SENSOR_CNT, /* 5 */
  44. FC_SLEEP, /* 6 */
  45. FC_WAKEUP, /* 7 */
  46. FC_CALIBRATE, /* 8 */
  47. FC_RESET, /* 9 */
  48. FC_STORE, /* 0xA => 10 */
  49. FC_DATA, /* 0xB => 11 */
  50. FC_SYNC, /* 0xC => 12 */
  51. FC_SENSOR_TYPE, /* 0xD => 13 */
  52. FC_INFO, /* 0xE => 14 */
  53. FC_SENSOR_FORMAT, /* 0xF => 15 */
  54. FC_SLAVES, /* 0x10 => 16 */
  55. } Nbus_FC_e;
  56. /** @brief Enumerate for Bridge run state. */
  57. typedef enum {
  58. STATE_STOPPED,
  59. STATE_TO_STOP,
  60. STATE_RUNNING,
  61. } Nbus_RunState_e;
  62. /** @brief Structure for PDU data. */
  63. typedef struct {
  64. uint8_t ma;
  65. uint8_t sa;
  66. Nbus_FC_e fc;
  67. } Nbus_PDU_t;
  68. /** @brief Structure for sensor count. */
  69. typedef struct
  70. {
  71. uint8_t read_only_count;
  72. uint8_t read_write_count;
  73. } Nbus_SensorCnt_t;
  74. /** @brief Enumerate for error codes. */
  75. typedef enum {
  76. OK_CODE = 0x00,
  77. ILLEGAL_FUNCTION = 0x01,
  78. ILLEGAL_DEVICE_ADDRESS = 0x02,
  79. ILLEGAL_DATA_VALUE = 0x03,
  80. SLAVE_DEVICE_FAILURE = 0x04,
  81. ACKNOWLEDGE = 0x05,
  82. DEVICE_BUSY = 0x06,
  83. DEVICE_NOT_READY = 0x07,
  84. PARAM_NOT_IMPLEMENTED = 0x10,
  85. ILLEGAL_FUNCTION_PARAM = 0x11,
  86. DEVICE_IS_READ_ONLY = 0x12,
  87. GENERIC_SUBSLAVE_ERROR = 0x13,
  88. ERR_SUBSLAVE_INIT_FAIL = 0x14,
  89. SUBSLAVE_CUSTOM_ERR_1 = 0x1A,
  90. SUBSLAVE_CUSTOM_ERR_2 = 0x1B,
  91. SUBSLAVE_CUSTOM_ERR_3 = 0x1C,
  92. SUBSLAVE_CUSTOM_ERR_4 = 0x1D,
  93. SUBSLAVE_CUSTOM_ERR_5 = 0x1E,
  94. SUBSLAVE_CUSTOM_ERR_6 = 0x1F,
  95. ERR_OUTPUT_ONLY = 0x21,
  96. ERR_INPUT_ONLY = 0x22
  97. } Nbus_EC_e;
  98. /** @brief Enumerate for status codes. */
  99. typedef enum {
  100. STATUS_NOT_SUPPORTED = 0xFF,
  101. STATUS_SUCCESS = 0x00,
  102. STATUS_FAIL = 0x01
  103. } Nbus_SC_e;
  104. #endif /* INC_NBUS_DEFINES_H_ */