nbus_app.c 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  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. /* -------------------------------------------------------- */
  22. /* ------------------ PRIVATE FUNCTIONS-------------------- */
  23. /* -------------------------------------------------------- */
  24. static uint8_t crc8x_fast(void const *mem, uint16_t len) {
  25. uint8_t crc = CRC8_INIT_VALUE;
  26. uint8_t const *data = (uint8_t*)mem;
  27. if (data == NULL)
  28. return 0xff;
  29. crc &= 0xff;
  30. while (len--)
  31. crc = crc8x_table[crc ^ *data++];
  32. return crc;
  33. }
  34. inline static void receiveOneByte(){
  35. //HAL_UART_AbortReceive_IT(nBus.periph->huart);
  36. nBus.hw_platform->uart_abort_receive();
  37. //HAL_UART_Receive_IT(nBus.periph->huart, nBus.rx_buffer, 1);
  38. nBus.hw_platform->uart_receive(nBus.rx_buffer, 1);
  39. nBus.uart_state = UART_RX_1B;
  40. nBus.rx_length = 1;
  41. }
  42. inline static void receiveNBytes(uint8_t n){
  43. nBus.rx_length = n;
  44. //HAL_UART_Receive_IT(nBus.periph->huart, nBus.rx_buffer, nBus.rx_length);
  45. nBus.hw_platform->uart_receive(nBus.rx_buffer, nBus.rx_length);
  46. nBus.uart_state = UART_RX_PAYLOAD;
  47. }
  48. inline static void send_response(){
  49. if(nBus.send_response == SEND_RESPONSE) {
  50. nBus.tx_buffer[0] -= 1; // prvý bajt sa nepočíta
  51. nBus.hw_platform->uart_transmit(nBus.tx_buffer, nBus.tx_length);
  52. /*
  53. #if USE_USART_DMA_TX == 1
  54. HAL_UART_Transmit_DMA(nBus.periph->huart, nBus.tx_buffer, nBus.tx_length);
  55. #else
  56. HAL_UART_Transmit(nBus.periph->huart, nBus.tx_buffer, nBus.tx_length, 10);
  57. #endif
  58. */
  59. }
  60. //HAL_GPIO_WritePin(nBus.periph->led->port, nBus.periph->led->pin, GPIO_PIN_RESET);
  61. nBus.hw_platform->led_off();
  62. }
  63. #if MODULE_MASTER == 1
  64. inline static void receive_slave_response(){
  65. }
  66. #endif
  67. static nBusCommandType_t get_request_type(){
  68. nBus.addressModule = nBus.rx_buffer[0];
  69. nBus.sensorInfo = *(const nBus_sensorByte_t*)&nBus.rx_buffer[1];
  70. nBus.function_code = *(const nBus_functionCode_t*)&nBus.rx_buffer[2];
  71. if(nBus.sensorInfo.address != 0 && nBus.addressModule !=0 ){
  72. nBus.request_type = UNICAST_TO_SENSOR;
  73. return UNICAST_TO_SENSOR;
  74. }
  75. if(nBus.sensorInfo.address == 0 && nBus.addressModule !=0 ){
  76. nBus.request_type = UNICAST_TO_MODULE;
  77. return UNICAST_TO_MODULE;
  78. }
  79. if(nBus.sensorInfo.address != 0 && nBus.addressModule == 0 ){
  80. nBus.request_type = BROADCAST_SPECIFIC_SENSORS;
  81. return BROADCAST_SPECIFIC_SENSORS;
  82. }
  83. nBus.request_type = BROADCAST_GLOBAL;
  84. return BROADCAST_GLOBAL;
  85. }
  86. static void process_request(){
  87. nBusCommandType_t request_type = get_request_type();
  88. nBus.send_response = SEND_RESPONSE;
  89. nBus.tx_buffer[0] = 0;
  90. nBus.tx_buffer[1] = nBus.rx_buffer[0]; // Module address
  91. nBus.tx_buffer[2] = nBus.rx_buffer[1]; // Sensor address
  92. uint8_t crcC = crc8x_fast(nBus.rx_buffer, nBus.rx_length-1);
  93. if(crcC != nBus.rx_buffer[nBus.rx_length-1]){
  94. nBus.send_response = NO_RESPONSE;
  95. return;
  96. }
  97. #if MODULE_SLAVE == 1
  98. // spracovanie broadcast komunikacie
  99. if((request_type == BROADCAST_SPECIFIC_SENSORS || request_type == BROADCAST_GLOBAL)) {
  100. nbus_slave_broadcast(&nBus, request_type);
  101. return;
  102. }
  103. #endif
  104. // paket nie je adresovany tomuto modulu
  105. if(nBus.addressModule != MODULE_ADDRESS) {
  106. nBus.send_response = NO_RESPONSE;
  107. return;
  108. }
  109. nBus.function_code.error = 0;
  110. nBus.tx_length = META_SIZE;
  111. #if MODULE_SLAVE == 1
  112. if(nBus.function_code.notReadWrite == REQUEST_GET) {
  113. if(request_type == UNICAST_TO_SENSOR) {
  114. nbus_slave_unicastToSensorGet(&nBus);
  115. }
  116. if(request_type == UNICAST_TO_MODULE) {
  117. nbus_slave_unicastToModuleGet(&nBus);
  118. }
  119. } else {
  120. // else request is REQUEST_SET
  121. if(request_type == UNICAST_TO_SENSOR) {
  122. nbus_slave_unicastToSensorSet(&nBus);
  123. }
  124. if(request_type == UNICAST_TO_MODULE) {
  125. nbus_slave_unicastToModuleSet(&nBus);
  126. }
  127. }
  128. nBus.tx_buffer[3] = *(uint8_t*)&nBus.function_code;
  129. nBus.tx_buffer[nBus.tx_length-1] = crc8x_fast(&nBus.tx_buffer[1], nBus.tx_length-2);
  130. nBus.tx_buffer[0] = nBus.tx_length;
  131. #endif
  132. #if MODULE_MASTER == 1
  133. if(nBus.function_code.notReadWrite == REQUEST_GET) {
  134. nbus_master_unicastToModuleGet(&nBus);
  135. } else {
  136. nbus_master_unicastToModuleSet(&nBus);
  137. }
  138. #endif
  139. }
  140. /* -------------------------------------------------------- */
  141. /* ----------------------- CALLBACKS----------------------- */
  142. /* -------------------------------------------------------- */
  143. //static void nbus_cb_UART_RX(UART_HandleTypeDef *huart){
  144. void nbus_cb_UART_RX(){
  145. if(nBus.uart_state == UART_RX_PAYLOAD) {
  146. nBus.uart_state = UART_RECEIVED;
  147. HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  148. }
  149. if(nBus.uart_state == UART_RX_1B) {
  150. //HAL_GPIO_WritePin(nBus.periph->led->port, nBus.periph->led->pin, GPIO_PIN_SET);
  151. nBus.hw_platform->led_on();
  152. if(nBus.rx_buffer[0] > 0) {
  153. receiveNBytes(nBus.rx_buffer[0]);
  154. HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  155. nBus.periph->uart_timer->Instance->CNT = 1;
  156. nBus.periph->uart_timer->Instance->ARR = 40*nBus.rx_buffer[0] + 400;
  157. HAL_TIM_Base_Start_IT(nBus.periph->uart_timer);
  158. } else {
  159. receiveOneByte();
  160. }
  161. }
  162. }
  163. static void nbus_cb_TIM_periodElapsed_base(TIM_HandleTypeDef *htim) {
  164. //HAL_GPIO_TogglePin(nBus.periph->led->port, nBus.periph->led->pin);
  165. nBus.hw_platform->led_toggle();
  166. }
  167. static void nbus_cb_TIM_periodElapsed(TIM_HandleTypeDef *htim) {
  168. if(nBus.uart_state == UART_RX_PAYLOAD) {
  169. //HAL_GPIO_WritePin(nBus.periph->led->port, nBus.periph->led->pin, GPIO_PIN_RESET);
  170. nBus.hw_platform->led_off();
  171. HAL_TIM_Base_Stop_IT(nBus.periph->uart_timer);
  172. //HAL_UART_AbortReceive_IT(nBus.periph->huart);
  173. nBus.hw_platform->uart_abort_receive();
  174. receiveOneByte();
  175. }
  176. }
  177. /* -------------------------------------------------------- */
  178. /* ------------------ PUBLIC FUNCTIONS-------------------- */
  179. /* -------------------------------------------------------- */
  180. void nbus_init(Peripheral_typeDef *periph, nBusAppInterface_t *interface, nBusPlatformInterface_t *hw){
  181. nBus.periph = periph;
  182. nBus.hw_platform = hw;
  183. HAL_TIM_RegisterCallback(nBus.periph->uart_timer, HAL_TIM_PERIOD_ELAPSED_CB_ID, nbus_cb_TIM_periodElapsed);
  184. HAL_TIM_RegisterCallback(nBus.periph->measure_timer, HAL_TIM_PERIOD_ELAPSED_CB_ID, nbus_cb_TIM_periodElapsed_base);
  185. // TODO vymysiet ako to urobit
  186. //HAL_UART_RegisterCallback(nBus.periph->huart, HAL_UART_RX_COMPLETE_CB_ID, nbus_cb_UART_RX);
  187. nBus.rx_length = 0;
  188. nBus.data_timebase = 0;
  189. nBus.measure_active = MEASURE_STOPPED;
  190. // init restart timer
  191. nBus.uart_state = UART_RX_1B;
  192. HAL_TIM_Base_Start_IT(periph->uart_timer);
  193. HAL_TIM_Base_Stop_IT(periph->uart_timer);
  194. nBus.interface = interface;
  195. }
  196. void nbus_init_app(void *hw_interface, void *hw_config){
  197. nBus.interface->init(hw_interface, hw_config);
  198. receiveOneByte();
  199. }
  200. void nbus_init_memory_driver(nBus_MemoryDriver *memDriver, uint16_t capacity){
  201. nbus_memory_init(memDriver);
  202. nBus.memoryInterface = getnbusMemoryInterface();
  203. }
  204. void nbus_stack(void){
  205. while(1){
  206. if(nBus.uart_state == UART_RECEIVED){
  207. process_request();
  208. // ready for next receiving
  209. receiveOneByte();
  210. send_response();
  211. #if MODULE_MASTER == 1
  212. receive_slave_response();
  213. #endif
  214. }
  215. }
  216. }