nbus_app.c 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  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. nBus.hw_platform->uart_abort_receive();
  36. nBus.hw_platform->uart_receive(nBus.rx_buffer, 1);
  37. nBus.uart_state = UART_RX_1B;
  38. nBus.rx_length = 1;
  39. }
  40. inline static void receiveNBytes(uint8_t n){
  41. nBus.rx_length = n;
  42. nBus.hw_platform->uart_receive(nBus.rx_buffer, nBus.rx_length);
  43. nBus.uart_state = UART_RX_PAYLOAD;
  44. }
  45. inline static void send_response(){
  46. if(nBus.send_response == SEND_RESPONSE) {
  47. nBus.tx_buffer[0] -= 1; // prvý bajt sa nepočíta
  48. nBus.hw_platform->uart_transmit(nBus.tx_buffer, nBus.tx_length);
  49. }
  50. nBus.hw_platform->led_off();
  51. }
  52. #if MODULE_MASTER == 1
  53. inline static void receive_slave_response(){
  54. }
  55. #endif
  56. static nBusCommandType_t get_request_type(){
  57. nBus.addressModule = nBus.rx_buffer[0];
  58. nBus.sensorInfo = *(const nBus_sensorByte_t*)&nBus.rx_buffer[1];
  59. nBus.function_code = *(const nBus_functionCode_t*)&nBus.rx_buffer[2];
  60. if(nBus.sensorInfo.address != 0 && nBus.addressModule !=0 ){
  61. nBus.request_type = UNICAST_TO_SENSOR;
  62. return UNICAST_TO_SENSOR;
  63. }
  64. if(nBus.sensorInfo.address == 0 && nBus.addressModule !=0 ){
  65. nBus.request_type = UNICAST_TO_MODULE;
  66. return UNICAST_TO_MODULE;
  67. }
  68. if(nBus.sensorInfo.address != 0 && nBus.addressModule == 0 ){
  69. nBus.request_type = BROADCAST_SPECIFIC_SENSORS;
  70. return BROADCAST_SPECIFIC_SENSORS;
  71. }
  72. nBus.request_type = BROADCAST_GLOBAL;
  73. return BROADCAST_GLOBAL;
  74. }
  75. static void process_request(){
  76. nBusCommandType_t request_type = get_request_type();
  77. nBus.send_response = SEND_RESPONSE;
  78. nBus.tx_buffer[0] = 0;
  79. nBus.tx_buffer[1] = nBus.rx_buffer[0]; // Module address
  80. nBus.tx_buffer[2] = nBus.rx_buffer[1]; // Sensor address
  81. uint8_t crcC = crc8x_fast(nBus.rx_buffer, nBus.rx_length-1);
  82. if(crcC != nBus.rx_buffer[nBus.rx_length-1]){
  83. nBus.send_response = NO_RESPONSE;
  84. return;
  85. }
  86. #if MODULE_SLAVE == 1
  87. // spracovanie broadcast komunikacie
  88. if((request_type == BROADCAST_SPECIFIC_SENSORS || request_type == BROADCAST_GLOBAL)) {
  89. nbus_slave_broadcast(&nBus, request_type);
  90. return;
  91. }
  92. #endif
  93. // paket nie je adresovany tomuto modulu
  94. if(nBus.addressModule != MODULE_ADDRESS) {
  95. nBus.send_response = NO_RESPONSE;
  96. return;
  97. }
  98. nBus.function_code.error = 0;
  99. nBus.tx_length = META_SIZE;
  100. #if MODULE_SLAVE == 1
  101. if(nBus.function_code.notReadWrite == REQUEST_GET) {
  102. if(request_type == UNICAST_TO_SENSOR) {
  103. nbus_slave_unicastToSensorGet(&nBus);
  104. }
  105. if(request_type == UNICAST_TO_MODULE) {
  106. nbus_slave_unicastToModuleGet(&nBus);
  107. }
  108. } else {
  109. // else request is REQUEST_SET
  110. if(request_type == UNICAST_TO_SENSOR) {
  111. nbus_slave_unicastToSensorSet(&nBus);
  112. }
  113. if(request_type == UNICAST_TO_MODULE) {
  114. nbus_slave_unicastToModuleSet(&nBus);
  115. }
  116. }
  117. nBus.tx_buffer[3] = *(uint8_t*)&nBus.function_code;
  118. nBus.tx_buffer[nBus.tx_length-1] = crc8x_fast(&nBus.tx_buffer[1], nBus.tx_length-2);
  119. nBus.tx_buffer[0] = nBus.tx_length;
  120. #endif
  121. #if MODULE_MASTER == 1
  122. if(nBus.function_code.notReadWrite == REQUEST_GET) {
  123. nbus_master_unicastToModuleGet(&nBus);
  124. } else {
  125. nbus_master_unicastToModuleSet(&nBus);
  126. }
  127. #endif
  128. }
  129. /* -------------------------------------------------------- */
  130. /* ----------------------- CALLBACKS----------------------- */
  131. /* -------------------------------------------------------- */
  132. void nbus_cb_UART_RX(void){
  133. if(nBus.uart_state == UART_RX_PAYLOAD) {
  134. nBus.uart_state = UART_RECEIVED;
  135. nBus.hw_platform->timer_uart_stop();
  136. }
  137. if(nBus.uart_state == UART_RX_1B) {
  138. nBus.hw_platform->led_on();
  139. if(nBus.rx_buffer[0] > 0) {
  140. receiveNBytes(nBus.rx_buffer[0]);
  141. nBus.hw_platform->timer_uart_stop();
  142. nBus.hw_platform->timer_uart_start(nBus.rx_buffer[0]);
  143. } else {
  144. receiveOneByte();
  145. }
  146. }
  147. }
  148. void nbus_cb_TIM_periodElapsed(void) {
  149. if(nBus.uart_state == UART_RX_PAYLOAD) {
  150. nBus.hw_platform->led_off();
  151. nBus.hw_platform->timer_uart_stop();
  152. nBus.hw_platform->uart_abort_receive();
  153. receiveOneByte();
  154. }
  155. }
  156. /* -------------------------------------------------------- */
  157. /* ------------------ PUBLIC FUNCTIONS-------------------- */
  158. /* -------------------------------------------------------- */
  159. void nbus_init(nBusAppInterface_t *interface, nBusPlatformInterface_t *hw){
  160. nBus.hw_platform = hw;
  161. nBus.rx_length = 0;
  162. nBus.data_timebase = 0;
  163. nBus.measure_active = MEASURE_STOPPED;
  164. // init restart timer
  165. nBus.uart_state = UART_RX_1B;
  166. nBus.hw_platform->timer_uart_start(100); // dummy value
  167. nBus.hw_platform->timer_uart_stop();
  168. nBus.interface = interface;
  169. receiveOneByte();
  170. }
  171. void nbus_init_app(void *hw_interface, void *hw_config){
  172. nBus.interface->init(hw_interface, hw_config);
  173. }
  174. void nbus_init_memory_driver(nBus_MemoryDriver *memDriver, uint16_t capacity){
  175. nbus_memory_init(memDriver);
  176. nBus.memoryInterface = getnbusMemoryInterface();
  177. }
  178. void nbus_stack(void){
  179. while(1){
  180. if(nBus.uart_state == UART_RECEIVED){
  181. process_request();
  182. // ready for next receiving
  183. receiveOneByte();
  184. send_response();
  185. #if MODULE_MASTER == 1
  186. receive_slave_response();
  187. #endif
  188. }
  189. }
  190. }