megatec.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. /*
  2. * megatec.c
  3. *
  4. * Created on: 22.05.2017
  5. * Author: balbekova
  6. */
  7. #include "FreeRTOS.h"
  8. #include "task.h"
  9. #include "usart.h"
  10. #include "megatec.h"
  11. #ifdef PRINTF_STDLIB
  12. #include <stdio.h>
  13. #endif
  14. #ifdef PRINTF_CUSTOM
  15. #include "tinystdio.h"
  16. #endif
  17. #include <string.h>
  18. #include <math.h>
  19. #define UPS_PDU_MAX_LEN 50
  20. enum {
  21. NORMAL = 0x00,
  22. VER_ERROR = 0x01,
  23. CHKSUM_ERROR = 0x02,
  24. LCHKSUM_ERROR = 0x03,
  25. CID2_INVALID = 0x04,
  26. CMD_FMT_ERROR = 0x05,
  27. INVALID_DATA = 0x06,
  28. };
  29. static struct {
  30. uint8_t data[UPS_PDU_MAX_LEN];
  31. uint16_t len;
  32. } ups_pdu;
  33. const char* MegaTecCMD[] =
  34. {
  35. "Q1\r",
  36. "TL\r",
  37. "T",
  38. "Q\r",
  39. "S",
  40. "R",
  41. "C\r",
  42. "CT\r",
  43. "I\r",
  44. "F\r"
  45. };
  46. void init_UPS_value(void)
  47. {
  48. UPS.Freq_in = 0;
  49. UPS.VAC_in = 0;
  50. UPS.VAC_out = 0;
  51. UPS.Temp = 0;
  52. UPS.Load = 0;
  53. UPS.SOC = 0;
  54. UPS.work_time = 0;
  55. UPS.Status = 0;
  56. UPS.Present = false;
  57. }
  58. void send_MegaTec_cmd(cmdMegaTecEnums_t command)
  59. {
  60. if(command == ups_test_time){
  61. }
  62. else if(command == ups_shutdown){
  63. }
  64. else if(command == ups_shutdown_restore){
  65. }
  66. else{
  67. ups_send_block(MegaTecCMD[command], strlen(MegaTecCMD[command]));
  68. }
  69. }
  70. bool ups_megatec_rx_pdu(void)
  71. {
  72. int c = 0;
  73. ups_pdu.len = 0;
  74. while ((ups_pdu.len < UPS_PDU_MAX_LEN) && (c != 0x0d)) {
  75. c = ups_getchar(500);//portMAX_DELAY
  76. if(c < 0)
  77. {
  78. ups_pdu.len = 0;
  79. break;
  80. }
  81. ups_pdu.data[ups_pdu.len++] = c;
  82. }
  83. if (ups_pdu.len == 0)
  84. return false;
  85. return true;
  86. }
  87. void ups_status_response(char *data)
  88. {
  89. char *endValue;
  90. char value[10];
  91. uint8_t len = 0;
  92. if(data[0] != '(')
  93. return;
  94. data++;
  95. memset(value, 0, 10);
  96. endValue = strpbrk(data," ");
  97. len = endValue - data;
  98. strncpy(value, data, len);
  99. data += (len + 1);
  100. UPS.VAC_in = atof(value);
  101. //TODO
  102. memset(value, 0, 10);
  103. endValue = strpbrk(data," ");
  104. len = endValue - data;
  105. strncpy(value, data, len);
  106. data += (len + 1);
  107. memset(value, 0, 10);
  108. endValue = strpbrk(data," ");
  109. len = endValue - data;
  110. strncpy(value, data, len);
  111. data += (len + 1);
  112. UPS.VAC_out = atof(value);
  113. memset(value, 0, 10);
  114. endValue = strpbrk(data," ");
  115. len = endValue - data;
  116. strncpy(value, data, len);
  117. data += (len + 1);
  118. UPS.Load = atoi(value);
  119. memset(value, 0, 10);
  120. endValue = strpbrk(data," ");
  121. len = endValue - data;
  122. strncpy(value, data, len);
  123. data += (len + 1);
  124. UPS.Freq_in = atof(value);
  125. //TODO
  126. memset(value, 0, 10);
  127. endValue = strpbrk(data," ");
  128. len = endValue - data;
  129. strncpy(value, data, len);
  130. data += (len + 1);
  131. memset(value, 0, 10);
  132. endValue = strpbrk(data," ");
  133. len = endValue - data;
  134. strncpy(value, data, len);
  135. data += (len + 1);
  136. UPS.Temp = atof(value);
  137. //TODO
  138. }
  139. void ups_info_response(uint8_t *data)
  140. {
  141. }
  142. void ups_megatec_process_pdu(cmdMegaTecEnums_t command)
  143. {
  144. switch(command)
  145. {
  146. case ups_status_req:
  147. ups_status_response(ups_pdu.data);
  148. break;
  149. case ups_info:
  150. ups_info_response(ups_pdu.data);
  151. break;
  152. case ups_rating_info:
  153. break;
  154. default:
  155. break;
  156. }
  157. }
  158. void request_task(void)
  159. {
  160. for(;;)
  161. {
  162. send_MegaTec_cmd(ups_status_req);
  163. if (ups_megatec_rx_pdu())
  164. ups_megatec_process_pdu(ups_status_req);
  165. vTaskDelay(1000);
  166. }
  167. }
  168. void ups_megatec_init(void) {
  169. init_UPS_value();
  170. xTaskCreate(request_task, ( char * ) "request_task", configMINIMAL_STACK_SIZE * 2, NULL, tskIDLE_PRIORITY, NULL);
  171. }