nbus_app.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. #include "nbus_app.h"
  2. nBus_TypeDef nBus;
  3. static uint8_t const crc8x_table[] = {
  4. 0x00,0x07,0x0E,0x09,0x1C,0x1B,0x12,0x15,0x38,0x3F,0x36,0x31,0x24,0x23,0x2A,0x2D,
  5. 0x70,0x77,0x7E,0x79,0x6C,0x6B,0x62,0x65,0x48,0x4F,0x46,0x41,0x54,0x53,0x5A,0x5D,
  6. 0xE0,0xE7,0xEE,0xE9,0xFC,0xFB,0xF2,0xF5,0xD8,0xDF,0xD6,0xD1,0xC4,0xC3,0xCA,0xCD,
  7. 0x90,0x97,0x9E,0x99,0x8C,0x8B,0x82,0x85,0xA8,0xAF,0xA6,0xA1,0xB4,0xB3,0xBA,0xBD,
  8. 0xC7,0xC0,0xC9,0xCE,0xDB,0xDC,0xD5,0xD2,0xFF,0xF8,0xF1,0xF6,0xE3,0xE4,0xED,0xEA,
  9. 0xB7,0xB0,0xB9,0xBE,0xAB,0xAC,0xA5,0xA2,0x8F,0x88,0x81,0x86,0x93,0x94,0x9D,0x9A,
  10. 0x27,0x20,0x29,0x2E,0x3B,0x3C,0x35,0x32,0x1F,0x18,0x11,0x16,0x03,0x04,0x0D,0x0A,
  11. 0x57,0x50,0x59,0x5E,0x4B,0x4C,0x45,0x42,0x6F,0x68,0x61,0x66,0x73,0x74,0x7D,0x7A,
  12. 0x89,0x8E,0x87,0x80,0x95,0x92,0x9B,0x9C,0xB1,0xB6,0xBF,0xB8,0xAD,0xAA,0xA3,0xA4,
  13. 0xF9,0xFE,0xF7,0xF0,0xE5,0xE2,0xEB,0xEC,0xC1,0xC6,0xCF,0xC8,0xDD,0xDA,0xD3,0xD4,
  14. 0x69,0x6E,0x67,0x60,0x75,0x72,0x7B,0x7C,0x51,0x56,0x5F,0x58,0x4D,0x4A,0x43,0x44,
  15. 0x19,0x1E,0x17,0x10,0x05,0x02,0x0B,0x0C,0x21,0x26,0x2F,0x28,0x3D,0x3A,0x33,0x34,
  16. 0x4E,0x49,0x40,0x47,0x52,0x55,0x5C,0x5B,0x76,0x71,0x78,0x7F,0x6A,0x6D,0x64,0x63,
  17. 0x3E,0x39,0x30,0x37,0x22,0x25,0x2C,0x2B,0x06,0x01,0x08,0x0F,0x1A,0x1D,0x14,0x13,
  18. 0xAE,0xA9,0xA0,0xA7,0xB2,0xB5,0xBC,0xBB,0x96,0x91,0x98,0x9F,0x8A,0x8D,0x84,0x83,
  19. 0xDE,0xD9,0xD0,0xD7,0xC2,0xC5,0xCC,0xCB,0xE6,0xE1,0xE8,0xEF,0xFA,0xFD,0xF4,0xF3
  20. };
  21. uint8_t crc8x_fast(void const *mem, uint16_t len) {
  22. uint8_t crc = CRC8_INIT_VALUE;
  23. uint8_t const *data = (uint8_t*)mem;
  24. if (data == NULL)
  25. return 0xff;
  26. crc &= 0xff;
  27. while (len--)
  28. crc = crc8x_table[crc ^ *data++];
  29. return crc;
  30. }
  31. void nbus_init(Peripheral_typeDef *periph){
  32. nBus.periph = periph;
  33. HAL_TIM_RegisterCallback(nBus.periph->uart_timer, HAL_TIM_PERIOD_ELAPSED_CB_ID, nbus_cb_TIM_periodElapsed);
  34. HAL_TIM_RegisterCallback(nBus.periph->measure_timer, HAL_TIM_PERIOD_ELAPSED_CB_ID, nbus_cb_TIM_periodElapsed_base);
  35. HAL_UART_RegisterCallback(nBus.periph->huart, HAL_UART_RX_COMPLETE_CB_ID, nbus_cb_UART_RX);
  36. nBus.rx_length = 0;
  37. nBus.data_timebase = 0;
  38. nBus.measure_active = MEASURE_STOPPED;
  39. // init restart timer
  40. nBus.uart_state = UART_RX_1B;
  41. HAL_TIM_Base_Start_IT(periph->uart_timer);
  42. HAL_TIM_Base_Stop_IT(periph->uart_timer);
  43. }
  44. inline void receiveOneByte(){
  45. HAL_UART_Receive_IT(nBus.periph->huart, nBus.rx_buffer, 1);
  46. nBus.uart_state = UART_RX_1B;
  47. }
  48. inline static void receiveNBytes(uint8_t n){
  49. nBus.rx_length = n;
  50. HAL_UART_Receive_IT(nBus.periph->huart, nBus.rx_buffer, nBus.rx_length);
  51. nBus.uart_state = UART_RX_PAYLOAD;
  52. }
  53. inline static void send_response(){
  54. if(nBus.send_response == SEND_RESPONSE) {
  55. nBus.tx_buffer[0] -= 1;
  56. #if USE_USART_DMA_TX == 1
  57. HAL_UART_Transmit_DMA(nBus.periph->huart, nBus.tx_buffer, nBus.tx_length);
  58. #else
  59. HAL_UART_Transmi(nBus.periph->huart, nBus.tx_buffer, nBus.tx_length, 10);
  60. #endif
  61. }
  62. }
  63. void nbus_cb_UART_RX(UART_HandleTypeDef *huart){
  64. if(nBus.uart_state == UART_RX_PAYLOAD) {
  65. nBus.uart_state = UART_RECEIVED;
  66. HAL_GPIO_WritePin(nBus.periph->led->port, nBus.periph->led->pin, GPIO_PIN_RESET);
  67. HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  68. }
  69. if(nBus.uart_state == UART_RX_1B) {
  70. HAL_GPIO_WritePin(nBus.periph->led->port, nBus.periph->led->pin, GPIO_PIN_SET);
  71. receiveNBytes(nBus.rx_buffer[0]);
  72. HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  73. nBus.periph->uart_timer->Instance->CNT = 1;
  74. HAL_TIM_Base_Start_IT(nBus.periph->uart_timer);
  75. }
  76. }
  77. void nbus_cb_TIM_periodElapsed_base(TIM_HandleTypeDef *htim) {
  78. HAL_GPIO_TogglePin(nBus.periph->led->port, nBus.periph->led->pin);
  79. }
  80. void nbus_cb_TIM_periodElapsed(TIM_HandleTypeDef *htim) {
  81. if(nBus.uart_state == UART_RX_PAYLOAD) {
  82. HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  83. HAL_UART_AbortReceive_IT(nBus.periph->huart);
  84. receiveOneByte();
  85. }
  86. }
  87. static nBusCommandType_t get_request_type(){
  88. nBus.addressModule = nBus.rx_buffer[0];
  89. nBus.sensorInfo = *(const nBus_sensorByte_t*)&nBus.rx_buffer[1];
  90. nBus.function_code = *(const nBus_functionCode_t*)&nBus.rx_buffer[2];
  91. if(nBus.sensorInfo.address != 0 && nBus.addressModule !=0 ){
  92. nBus.request_type = UNICAST_TO_SENSOR;
  93. return UNICAST_TO_SENSOR;
  94. }
  95. if(nBus.sensorInfo.address == 0 && nBus.addressModule !=0 ){
  96. nBus.request_type = UNICAST_TO_MODULE;
  97. return UNICAST_TO_MODULE;
  98. }
  99. if(nBus.sensorInfo.address != 0 && nBus.addressModule == 0 ){
  100. nBus.request_type = BROADCAST_SPECIFIC_SENSORS;
  101. return BROADCAST_SPECIFIC_SENSORS;
  102. }
  103. nBus.request_type = BROADCAST_GLOBAL;
  104. return BROADCAST_GLOBAL;
  105. }
  106. void process_request(){
  107. nBusCommandType_t request_type = get_request_type();
  108. nBus_functionCode_t *fc = &nBus.function_code;
  109. nBus.send_response = SEND_RESPONSE;
  110. nBus.tx_buffer[0] = 0;
  111. nBus.tx_buffer[1] = nBus.rx_buffer[0]; // Module address
  112. nBus.tx_buffer[2] = nBus.rx_buffer[1]; // Sensor address
  113. uint8_t crcC = crc8x_fast(nBus.rx_buffer, nBus.rx_length-1);
  114. if(crcC != nBus.rx_buffer[nBus.rx_length-1]){
  115. nBus.send_response = NO_RESPONSE;
  116. return;
  117. }
  118. // paket nie je adresovany tomuto modulu
  119. if(nBus.addressModule != MODULE_ADDRESS) {
  120. nBus.send_response = NO_RESPONSE;
  121. return;
  122. }
  123. // spracovanie broadcast komunikacie
  124. if((request_type == BROADCAST_SPECIFIC_SENSORS || request_type == BROADCAST_GLOBAL)) {
  125. nbus_broadcast(&nBus, request_type);
  126. return;
  127. }
  128. fc->error = 0;
  129. nBus.tx_length = META_SIZE;
  130. if(nBus.function_code.notReadWrite == REQUEST_GET) {
  131. if(request_type == UNICAST_TO_SENSOR) {
  132. fc = nbus_unicastToSensor(&nBus, fc);
  133. }
  134. if(request_type == UNICAST_TO_MODULE) {
  135. fc = nbus_unicastToModule(&nBus, fc);
  136. }
  137. nBus.tx_buffer[3] = *(uint8_t*)&fc;
  138. nBus.tx_buffer[nBus.tx_length-1] = crc8x_fast(&nBus.tx_buffer[1], nBus.tx_length-2);
  139. nBus.tx_buffer[0] = nBus.tx_length;
  140. } else { // else request if REQUEST_SET
  141. }
  142. }
  143. void nbus_stack(void){
  144. receiveOneByte();
  145. while(1){
  146. if(nBus.uart_state == UART_RECEIVED){
  147. //HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  148. process_request();
  149. // ready for next receiving
  150. receiveOneByte();
  151. send_response();
  152. }
  153. }
  154. }