Module_ChkSysTask.c 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. /*
  2. * CheckTask.c
  3. *
  4. * Created on: 2021年9月22日
  5. * Author: 8513
  6. */
  7. #include <stdio.h> /*標準輸入輸出定義*/
  8. #include <stdlib.h> /*標準函數庫定義*/
  9. #include <string.h>
  10. #include <stdint.h>
  11. #include <sys/types.h>
  12. #include <dirent.h>
  13. #include "../Config.h"
  14. #include "../Log/log.h"
  15. #include "../Define/define.h"
  16. #include "../ShareMemory/shmMem.h"
  17. #include "Module_ChkSysTask.h"
  18. struct SysConfigData *pSysConfig = NULL;
  19. struct SysInfoData *pSysInfo = NULL;
  20. struct OCPP16Data *ShmOCPP16Data = NULL;
  21. struct ChargingInfoData *pAcChargingInfo = NULL;
  22. static struct ChargingInfoData *pDcChargingInfo = NULL;
  23. struct SysConfigAndInfo *ShmSysConfigAndInfo;
  24. struct StatusCodeData *ShmStatusCodeData;
  25. static DcCommonInfo* ShmDcCommonData = NULL;
  26. bool Taskconutstring(char *src, char *taskname)
  27. {
  28. bool result = false;
  29. if (src == NULL || strlen(src) == 0)
  30. return result;
  31. if (strstr(src, taskname) != NULL &&
  32. strstr(src, "grep") == NULL &&
  33. strstr(src, "[") == NULL)
  34. {
  35. result = true;
  36. }
  37. return result;
  38. }
  39. int GetProcessCount(char *procName)
  40. {
  41. int result = 0;
  42. FILE *fp;
  43. char cmd[256];
  44. char buf[256];
  45. sprintf(cmd, "ps -ef |grep %s", procName);
  46. fp = popen(cmd, "r");
  47. if(fp != NULL)
  48. {
  49. while(fgets(buf, sizeof(buf), fp) != NULL)
  50. {
  51. if (Taskconutstring(buf, procName))
  52. result++;
  53. }
  54. }
  55. pclose(fp);
  56. return result;
  57. }
  58. unsigned char CheckSystemTask(unsigned char systemPage)
  59. {
  60. unsigned char result = 0;
  61. unsigned char count_main = GetProcessCount("main");
  62. unsigned char count_evComm = GetProcessCount("Module_EvComm");
  63. unsigned char count_interComm = GetProcessCount("Module_InternalComm");
  64. unsigned char count_eventComm = GetProcessCount("Module_EventLogging");
  65. unsigned char count_primaryComm = GetProcessCount("Module_PrimaryComm");
  66. unsigned char count_lcmComm = GetProcessCount("Module_LcmControl");
  67. unsigned char count_doComm = GetProcessCount("Module_DoComm");
  68. unsigned char count_produceComm = GetProcessCount("Module_ProduceUtils");
  69. unsigned char count_updateFW = GetProcessCount("Module_UpdateFW");
  70. //if (systemPage != _LCM_FIX )
  71. {
  72. if (count_main < _SYSTEM_TASK_COUNT_MAIN )
  73. {
  74. ///*
  75. system("/usr/bin/fuser -k /dev/watchdog");
  76. sleep(1);
  77. system("echo V > /dev/watchdog");
  78. system("killall main");
  79. system("killall Module_EventLogging");
  80. system("killall Module_PrimaryComm");
  81. system("killall Module_EvComm");
  82. system("killall Module_LcmControl");
  83. system("killall Module_InternalComm");
  84. system("killall Module_DoComm");
  85. system("killall Module_ProduceUtils");
  86. system("killall Module_UpdateFW");
  87. sleep(3);
  88. system("/root/main &");
  89. sleep(20);
  90. //*/
  91. /*
  92. log_info("System task lost (CSU). ");
  93. sleep(3);
  94. system("reboot -f");
  95. */
  96. }
  97. else
  98. {
  99. if (count_evComm < _SYSTEM_TASK_COUNT_EVCOMM )
  100. {
  101. system("killall Module_EvComm");
  102. sleep(3);
  103. system("/root/Module_EvComm &");
  104. }
  105. if (count_interComm < _SYSTEM_TASK_COUNT_INTERNALCOMM )
  106. {
  107. system("killall Module_InternalComm");
  108. sleep(3);
  109. system("/root/Module_InternalComm &");
  110. }
  111. if (count_eventComm < _SYSTEM_TASK_COUNT_EVENTLOGGING )
  112. {
  113. system("killall Module_EventLogging");
  114. sleep(3);
  115. system("/root/Module_EventLogging &");
  116. }
  117. if (count_primaryComm < _SYSTEM_TASK_COUNT_PRIMARYCOMM )
  118. {
  119. system("killall Module_PrimaryComm");
  120. sleep(3);
  121. system("/root/Module_PrimaryComm &");
  122. }
  123. if (count_lcmComm < _SYSTEM_TASK_COUNT_LCM )
  124. {
  125. system("killall Module_LcmControl");
  126. sleep(3);
  127. system("/root/Module_LcmControl &");
  128. }
  129. if (count_doComm < _SYSTEM_TASK_COUNT_DOCOMM )
  130. {
  131. system("killall Module_DoComm");
  132. sleep(3);
  133. system("/root/Module_DoComm &");
  134. }
  135. if (count_produceComm < _SYSTEM_TASK_COUNT_PRODUCEUTILS )
  136. {
  137. system("killall Module_ProduceUtils");
  138. sleep(3);
  139. system("/root/Module_ProduceUtils &");
  140. }
  141. if (count_updateFW < _SYSTEM_TASK_COUNT_UPDATEFW )
  142. {
  143. system("killall Module_UpdateFW");
  144. sleep(3);
  145. system("/root/Module_UpdateFW &");
  146. }
  147. }
  148. }
  149. if (count_main < _SYSTEM_TASK_COUNT_MAIN)
  150. result = _SYSTEM_TASK_LOST_ITEM_MAIN;
  151. else if (count_evComm < _SYSTEM_TASK_COUNT_EVCOMM)
  152. result = _SYSTEM_TASK_LOST_ITEM_EVCOMM;
  153. /* else if (count_psuComm < 2)
  154. result = 3; */
  155. else if (count_eventComm < _SYSTEM_TASK_COUNT_EVENTLOGGING )
  156. result = _SYSTEM_TASK_LOST_ITEM_EVENTLOG;
  157. else if (count_primaryComm < _SYSTEM_TASK_COUNT_PRIMARYCOMM)
  158. result = _SYSTEM_TASK_LOST_ITEM_PRIMARYCOMM;
  159. else if (count_lcmComm < _SYSTEM_TASK_COUNT_LCM)
  160. result = _SYSTEM_TASK_LOST_ITEM_LCMCONTROL;
  161. else if (count_interComm < _SYSTEM_TASK_COUNT_INTERNALCOMM )
  162. result = _SYSTEM_TASK_LOST_ITEM_INTERCOMM;
  163. else if (count_doComm < _SYSTEM_TASK_COUNT_DOCOMM)
  164. result = _SYSTEM_TASK_LOST_ITEM_DOCOMM;
  165. else if (count_produceComm < _SYSTEM_TASK_COUNT_PRODUCEUTILS)
  166. result = _SYSTEM_TASK_LOST_ITEM_PRODUCTUTILS;
  167. else if (count_updateFW < _SYSTEM_TASK_COUNT_UPDATEFW)
  168. result = _SYSTEM_TASK_LOST_ITEM_UPDATEFW;
  169. return result;
  170. }
  171. //===============================================
  172. // Check System Task alive
  173. // ==============================================
  174. void CheckSystemTaskAlive()
  175. {
  176. unsigned char lostId = CheckSystemTask(ShmSysConfigAndInfo->SysInfo.SystemPage);
  177. if (lostId != 0) {
  178. if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost == NO) {
  179. if (lostId == _SYSTEM_TASK_LOST_ITEM_MAIN)
  180. log_error("System task lost (CSU). ");
  181. else if (lostId == _SYSTEM_TASK_LOST_ITEM_EVCOMM)
  182. log_error("System task lost (EVComm). ");
  183. // else if (lostId == _SYSTEM_TASK_LOST_ITEM_PSUCOMM)
  184. // PRINTF_FUNC("System task lost (PSU Task). ");
  185. else if (lostId == _SYSTEM_TASK_LOST_ITEM_EVENTLOG)
  186. log_error("System task lost (Event log). ");
  187. else if (lostId == _SYSTEM_TASK_LOST_ITEM_PRIMARYCOMM)
  188. log_error("System task lost (Primary). ");
  189. else if (lostId == _SYSTEM_TASK_LOST_ITEM_LCMCONTROL)
  190. log_error("System task lost (LCM Comm). ");
  191. else if (lostId == _SYSTEM_TASK_LOST_ITEM_INTERCOMM)
  192. log_error("System task lost (Internal Comm). ");
  193. else if (lostId == _SYSTEM_TASK_LOST_ITEM_DOCOMM)
  194. log_error("System task lost (Do Comm). ");
  195. else if (lostId == _SYSTEM_TASK_LOST_ITEM_PRODUCTUTILS)
  196. log_error("System task lost (ProcductUtils Comm). ");
  197. else if (lostId == _SYSTEM_TASK_LOST_ITEM_UPDATEFW)
  198. log_error("System task lost (Update FW) ");
  199. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost = YES;
  200. }
  201. } else
  202. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemTaskLost = NO;
  203. }
  204. int main(void)
  205. {
  206. if (CreateAllCsuShareMemory() == FAIL) {
  207. log_error("create share memory error");
  208. return FAIL;
  209. }
  210. pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
  211. pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
  212. ShmOCPP16Data = (struct OCPP16Data *)GetShmOCPP16Data();
  213. ShmSysConfigAndInfo = (struct SysConfigAndInfo *)GetShmSysConfigAndInfo();
  214. ShmStatusCodeData = (struct StatusCodeData*)GetShmStatusCodeData();
  215. ShmDcCommonData = (DcCommonInfo*)GetShmDcCommonData();
  216. MappingGunChargingInfo("CheckSystem Task");
  217. while(true)
  218. {
  219. sleep(3);
  220. for (uint8_t gun = 0; gun < pSysConfig->TotalConnectorCount; gun++) {
  221. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gun);
  222. if (pDcChargingInfo->SystemStatus == SYS_MODE_UPDATE )
  223. continue;
  224. }
  225. if (ShmDcCommonData->DebugFlag == TRUE) {
  226. continue;
  227. }
  228. CheckSystemTaskAlive();
  229. }
  230. return FAIL;
  231. }