megatec.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  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. "T\r",
  37. "TL\r",
  38. "T",
  39. "Q\r",
  40. "S",
  41. "R",
  42. "C\r",
  43. "CT\r",
  44. "I\r",
  45. "F\r"
  46. };
  47. void init_UPS_value(void)
  48. {
  49. UPS.Freq_in = 0;
  50. UPS.VAC_in = 0;
  51. UPS.VAC_out = 0;
  52. UPS.Temp = 0;
  53. UPS.Load = 0;
  54. UPS.SOC = 0;
  55. UPS.work_time = 0;
  56. UPS.Status = 0;
  57. UPS.Present = false;
  58. memset(UPS.model, 0, 11);
  59. memset(UPS.vertion, 0, 11);
  60. }
  61. void send_MegaTec_cmd(cmdMegaTecEnums_t command)
  62. {
  63. if(command == ups_test_time){
  64. }
  65. else if(command == ups_shutdown){
  66. }
  67. else if(command == ups_shutdown_restore){
  68. }
  69. else{
  70. ups_send_block(MegaTecCMD[command], strlen(MegaTecCMD[command]));
  71. }
  72. }
  73. bool ups_megatec_rx_pdu(void)
  74. {
  75. int c = 0;
  76. ups_pdu.len = 0;
  77. while ((ups_pdu.len < UPS_PDU_MAX_LEN) && (c != 0x0d)) {
  78. c = ups_getchar(500);//portMAX_DELAY
  79. if(c < 0)
  80. {
  81. ups_pdu.len = 0;
  82. break;
  83. }
  84. ups_pdu.data[ups_pdu.len++] = c;
  85. }
  86. if (ups_pdu.len == 0)
  87. return false;
  88. return true;
  89. }
  90. void ups_status_response(char *data)
  91. {
  92. uint8_t i;
  93. char *endValue;
  94. char value[10];
  95. uint8_t len = 0;
  96. if(data[0] != '(')
  97. return;
  98. data++;
  99. memset(value, 0, 10);
  100. endValue = strpbrk(data," ");
  101. len = endValue - data;
  102. strncpy(value, data, len);
  103. data += (len + 1);
  104. UPS.VAC_in = atof(value);
  105. //TODO
  106. memset(value, 0, 10);
  107. endValue = strpbrk(data," ");
  108. len = endValue - data;
  109. strncpy(value, data, len);
  110. data += (len + 1);
  111. memset(value, 0, 10);
  112. endValue = strpbrk(data," ");
  113. len = endValue - data;
  114. strncpy(value, data, len);
  115. data += (len + 1);
  116. UPS.VAC_out = atof(value);
  117. memset(value, 0, 10);
  118. endValue = strpbrk(data," ");
  119. len = endValue - data;
  120. strncpy(value, data, len);
  121. data += (len + 1);
  122. UPS.Load = atoi(value);
  123. memset(value, 0, 10);
  124. endValue = strpbrk(data," ");
  125. len = endValue - data;
  126. strncpy(value, data, len);
  127. data += (len + 1);
  128. UPS.Freq_in = atof(value);
  129. //TODO
  130. memset(value, 0, 10);
  131. endValue = strpbrk(data," ");
  132. len = endValue - data;
  133. strncpy(value, data, len);
  134. data += (len + 1);
  135. memset(value, 0, 10);
  136. endValue = strpbrk(data," ");
  137. len = endValue - data;
  138. strncpy(value, data, len);
  139. data += (len + 1);
  140. UPS.Temp = atof(value);
  141. memset(value, 0, 10);
  142. endValue = strpbrk(data,"\r");
  143. len = endValue - data;
  144. strncpy(value, data, len);
  145. for(i = 0; i < len; i ++)
  146. {
  147. UPS.Status |= (value[i] - 0x30) << (7-i);
  148. }
  149. }
  150. void ups_info_response(char *data)
  151. {
  152. uint8_t i = 0;
  153. char *endValue;
  154. uint8_t len = 0;
  155. if(data[0] != '#')
  156. return;
  157. data++;
  158. data += 16;
  159. while(data[0] == ' '){
  160. data ++;
  161. i ++;
  162. }
  163. if(i < 11){
  164. endValue = strpbrk(data," ");
  165. len = endValue - data;
  166. strncpy(UPS.model, data, len);
  167. data += (len + 1);
  168. }
  169. endValue = strpbrk(data,"\r");
  170. len = endValue - data;
  171. strncpy(UPS.vertion, data, len);
  172. }
  173. void ups_megatec_process_pdu(cmdMegaTecEnums_t command)
  174. {
  175. switch(command)
  176. {
  177. case ups_status_req:
  178. ups_status_response(ups_pdu.data);
  179. break;
  180. case ups_info:
  181. ups_info_response(ups_pdu.data);
  182. break;
  183. case ups_rating_info:
  184. break;
  185. default:
  186. break;
  187. }
  188. }
  189. void request_task(void)
  190. {
  191. for(;;)
  192. {
  193. send_MegaTec_cmd(ups_status_req);
  194. if (ups_megatec_rx_pdu())
  195. ups_megatec_process_pdu(ups_status_req);
  196. send_MegaTec_cmd(ups_info);
  197. if (ups_megatec_rx_pdu())
  198. ups_megatec_process_pdu(ups_info);
  199. vTaskDelay(1000);
  200. }
  201. }
  202. void ups_megatec_init(void) {
  203. init_UPS_value();
  204. xTaskCreate(request_task, ( char * ) "request_task", configMINIMAL_STACK_SIZE * 2, NULL, tskIDLE_PRIORITY, NULL);
  205. }