HealthManagerFSM.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. #ifndef __HEALTHMANAGER_FSM_H
  2. #define __HEALTHMANAGER_FSM_H
  3. #pragma once
  4. #include "stdafx.h"
  5. #include "SpFSM.h"
  6. #include <map>
  7. #include <vector>
  8. using namespace std;
  9. #include "HealthManager_msg_g.h"
  10. #include "../mod_accessauth/AccessAuthorization_client_g.h"
  11. #include "../mod_Initializer/Initializer_client_g.h"
  12. #include "../mod_DeviceControl/DeviceControl_client_g.h"
  13. #include "../mod_pinpad/PinPad_client_g.h"
  14. #include "../mod_cardswiper/CardSwiper_msg_g.h"
  15. using namespace AccessAuthorization;
  16. using namespace Initializer;
  17. using namespace DeviceControl;
  18. using namespace PinPad;
  19. using namespace CardSwiper;
  20. enum EvtType
  21. {
  22. USER_EVT_TEST = EVT_USER+1,
  23. USER_EVT_QUIT,
  24. USER_EVT_INIT,
  25. USER_EVT_WAIT_DEAMON_FINISHED,
  26. USER_EVT_COREBOOT_FINISHED,
  27. USER_EVT_SAFELOAD_FINISHED,
  28. USER_EVT_SAFELOAD_EXMINE_FINISHED,
  29. USER_EVT_OPERATING_FINISHED,
  30. USER_EVT_ACCESSAUTH_FINISHED,
  31. USER_EVT_MAITAIN,
  32. USER_EVT_MAITAIN_FINISHED,
  33. USER_EVT_ENTER_CUSTOMER_MANAGER,
  34. USER_EVT_SWITCH_BACK_TO_RVC,
  35. };
  36. enum LoadStage
  37. {
  38. LOADSTAGE_UNKNOWN,
  39. LOADSTAGE_COREBOOT,
  40. LOADSTAGE_SAFELOAD,
  41. LOADSTAGE_OPERATING
  42. };
  43. enum EntityLoadFaultStage
  44. {
  45. ENTITYLOAD_SAFELOADFAULT,
  46. ENTITYLOAD_OPERATINGFAULT,
  47. };
  48. enum EntityOption
  49. {
  50. WATCHDOG,
  51. UPS,
  52. HEARTBEAT,
  53. SELFCHECKER
  54. };
  55. enum LoadingOpt
  56. {
  57. LOADOPT_IGNORE,
  58. LOADOPT_ASYNC_VERIFY,
  59. LOADOPT_SYNC_VERIFY
  60. };
  61. enum LoadingResult
  62. {
  63. LOADING_SUCCEED,
  64. LOADING_INIT,
  65. LOADING_FAILED,
  66. LOADING_TIMEOUT,
  67. };
  68. enum CustomerManagerState
  69. {
  70. CM_INIT,
  71. CM_ENTER,
  72. CM_NOT_ENTER,
  73. };
  74. enum HealthManagerFSMState
  75. {
  76. HM_FSM_INIT,
  77. HM_FSM_STATE_COREBOOT,
  78. HM_FSM_STATE_SAFELOAD,
  79. HM_FSM_STATE_OP,
  80. HM_FSM_STATE_IDLE,
  81. HM_FSM_STATE_FAULT,
  82. HM_FSM_STATE_MAINTAINING,
  83. HM_FSM_STATE_PREPAREOFF,
  84. HM_FSM_STATE_TERMINATING,
  85. HM_FSM_STATE_EXITTING,
  86. HM_FSM_STATE_SLEEP,
  87. HM_FSM_STATE_CMS,
  88. };
  89. struct callback_entry : public IReleasable
  90. {
  91. virtual ~callback_entry() {}
  92. CSimpleStringA EntityName;
  93. union {
  94. void *pRawData;
  95. int state;
  96. };
  97. int op;
  98. ErrorCodeEnum ErrorResult;
  99. };
  100. struct EntityLoadInfo
  101. {
  102. int initSn;
  103. int loadOpt;
  104. LoadingResult eResult;
  105. };
  106. struct EntityLoadFault
  107. {
  108. CSimpleStringA name;
  109. int count;
  110. };
  111. extern unsigned long long GetTickCountRVC();
  112. class CHealthManagerEntity;
  113. class CHealthManagerFSM : public FSMImpl<CHealthManagerFSM>,public ICallbackListener
  114. {
  115. public:
  116. enum {s0,s1,s2,s3,s4,s5,s6,s7,s8,s9,s10,s11};
  117. BEGIN_FSM_STATE(CHealthManagerFSM)
  118. FSM_STATE_ENTRY(s0,"Init",s0_on_entry,s0_on_exit,s0_on_event)
  119. FSM_STATE_ENTRY(s1,"CoreBoot",s1_on_entry,s1_on_exit,s1_on_event)
  120. FSM_STATE_ENTRY(s2,"SafeLoad",s2_on_entry,s2_on_exit,s2_on_event)
  121. FSM_STATE_ENTRY(s3,"Loading",s3_on_entry,s3_on_exit,s3_on_event)
  122. FSM_STATE_ENTRY(s4,"Operating",s4_on_entry,s4_on_exit,s4_on_event)
  123. FSM_STATE_ENTRY(s5,"Fault",s5_on_entry,s5_on_exit,s5_on_event)
  124. FSM_STATE_ENTRY(s6,"Maintaining",s6_on_entry,s6_on_exit,s6_on_event)
  125. FSM_STATE_ENTRY(s7,"PrepareOff",s7_on_entry,s7_on_exit,s7_on_event)
  126. FSM_STATE_ENTRY(s8,"Terminating",s8_on_entry,s8_on_exit,s8_on_event)
  127. FSM_STATE_ENTRY(s9,"Exitting",s9_on_entry,s9_on_exit,s9_on_event)
  128. FSM_STATE_ENTRY(s10,"Sleep",s10_on_entry,s10_on_exit,s10_on_event)
  129. FSM_STATE_ENTRY(s11,"CustomerManager",s11_on_entry,s11_on_exit,s11_on_event)
  130. END_FSM_STATE()
  131. BEGIN_FSM_RULE(CHealthManagerFSM,s0)
  132. FSM_RULE_ENTRY(s0,s1,USER_EVT_WAIT_DEAMON_FINISHED,0)
  133. //FSM_RULE_ENTRY(s0,s5,USER_EVT_WAIT_DEAMON_FINISHED,1)
  134. FSM_RULE_ENTRY(s1,s2,USER_EVT_COREBOOT_FINISHED,0)
  135. FSM_RULE_ENTRY(s1,s2,USER_EVT_COREBOOT_FINISHED,1)
  136. FSM_RULE_ENTRY(s1,s5,USER_EVT_COREBOOT_FINISHED,2)
  137. FSM_RULE_ENTRY(s1,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  138. FSM_RULE_ENTRY(s2,s3,USER_EVT_SAFELOAD_FINISHED,0)
  139. FSM_RULE_ENTRY(s2,s5,USER_EVT_SAFELOAD_FINISHED,2)
  140. FSM_RULE_ENTRY(s2,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  141. //FSM_RULE_ENTRY(s2,s4,USER_EVT_ACCESSAUTH_FINISHED,0)
  142. //FSM_RULE_ENTRY(s2,s5,USER_EVT_ACCESSAUTH_FINISHED,1)
  143. FSM_RULE_ENTRY(s3,s4,USER_EVT_OPERATING_FINISHED,0)
  144. FSM_RULE_ENTRY(s3,s5,USER_EVT_OPERATING_FINISHED,2)
  145. FSM_RULE_ENTRY(s3,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  146. FSM_RULE_ENTRY(s4,s5,USER_EVT_ACCESSAUTH_FINISHED,1)
  147. FSM_RULE_ENTRY(s4,s6,USER_EVT_MAITAIN,0)
  148. FSM_RULE_ENTRY(s4,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  149. FSM_RULE_ENTRY(s5,s6,USER_EVT_MAITAIN,0)
  150. FSM_RULE_ENTRY(s5,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  151. FSM_RULE_ENTRY(s7,s6,USER_EVT_MAITAIN,0)
  152. FSM_RULE_ENTRY(s7,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  153. FSM_RULE_ENTRY(s8,s6,USER_EVT_MAITAIN,0)
  154. FSM_RULE_ENTRY(s8,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  155. FSM_RULE_ENTRY(s9,s6,USER_EVT_MAITAIN,0)
  156. FSM_RULE_ENTRY(s9,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  157. FSM_RULE_ENTRY(s10,s6,USER_EVT_MAITAIN,0)
  158. FSM_RULE_ENTRY(s10,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  159. FSM_RULE_ENTRY(s6,s4,USER_EVT_MAITAIN_FINISHED,4)
  160. FSM_RULE_ENTRY(s6,s5,USER_EVT_MAITAIN_FINISHED,5)
  161. FSM_RULE_ENTRY(s6,s7,USER_EVT_MAITAIN_FINISHED,7)
  162. FSM_RULE_ENTRY(s6,s8,USER_EVT_MAITAIN_FINISHED,8)
  163. FSM_RULE_ENTRY(s6,s9,USER_EVT_MAITAIN_FINISHED,9)
  164. FSM_RULE_ENTRY(s6,s10,USER_EVT_MAITAIN_FINISHED,10)
  165. FSM_RULE_ENTRY(s11, s6, USER_EVT_MAITAIN, 0)
  166. FSM_RULE_ENTRY(s11,s2,USER_EVT_SWITCH_BACK_TO_RVC,2)
  167. FSM_RULE_ENTRY(s11,s3,USER_EVT_SWITCH_BACK_TO_RVC,3)
  168. FSM_RULE_ENTRY(s11,s4,USER_EVT_SWITCH_BACK_TO_RVC,4)
  169. FSM_RULE_ENTRY(s11,s5,USER_EVT_SWITCH_BACK_TO_RVC,5)
  170. FSM_RULE_ENTRY(s11,s6,USER_EVT_SWITCH_BACK_TO_RVC,6)
  171. FSM_RULE_ENTRY(s11,s7,USER_EVT_SWITCH_BACK_TO_RVC,7)
  172. FSM_RULE_ENTRY(s11,s8,USER_EVT_SWITCH_BACK_TO_RVC,8)
  173. FSM_RULE_ENTRY(s11,s9,USER_EVT_SWITCH_BACK_TO_RVC,9)
  174. FSM_RULE_ENTRY(s11,s10,USER_EVT_SWITCH_BACK_TO_RVC,10)
  175. END_FSM_RULE()
  176. CHealthManagerFSM():m_eStage(LOADSTAGE_COREBOOT),m_SysState("I"),m_pACClient(NULL)
  177. ,m_bAccessAuth(false),m_bACFailed(false),m_pInitClient(NULL),m_bInitSuc(false),m_bInitFail(false)
  178. , m_bIdleToMaintain(false), m_custMngerState(0), m_pDevCtrlClient(NULL), m_bHasAuthEver(false)
  179. , m_checkCode(""), m_accessAuthCheckMD5(0), m_havReceiveMD5OK(0), m_bFirstAccessAuth(true), m_bEverAuthSucWithDevice(false)
  180. , m_bIEBeforeHealth(false), m_hasCfgGpioInRootIni(false), m_csErrEntity(""){}
  181. ~CHealthManagerFSM(){}
  182. virtual ErrorCodeEnum OnInit();
  183. virtual ErrorCodeEnum OnExit();
  184. void s0_on_entry();
  185. void s0_on_exit();
  186. unsigned int s0_on_event(FSMEvent* pEvt);
  187. void s1_on_entry();
  188. void s1_on_exit();
  189. unsigned int s1_on_event(FSMEvent* pEvt);
  190. void s2_on_entry();
  191. void s2_on_exit();
  192. unsigned int s2_on_event(FSMEvent* pEvt);
  193. void s3_on_entry();
  194. void s3_on_exit();
  195. unsigned int s3_on_event(FSMEvent* pEvt);
  196. void s4_on_entry();
  197. void s4_on_exit();
  198. unsigned int s4_on_event(FSMEvent* pEvt);
  199. void s5_on_entry();
  200. void s5_on_exit();
  201. unsigned int s5_on_event(FSMEvent* pEvt);
  202. void s6_on_entry();
  203. void s6_on_exit();
  204. unsigned int s6_on_event(FSMEvent* pEvt);
  205. void s7_on_entry();
  206. void s7_on_exit();
  207. unsigned int s7_on_event(FSMEvent* pEvt);
  208. void s8_on_entry();
  209. void s8_on_exit();
  210. unsigned int s8_on_event(FSMEvent* pEvt);
  211. void s9_on_entry();
  212. void s9_on_exit();
  213. unsigned int s9_on_event(FSMEvent* pEvt);
  214. void s10_on_entry();
  215. void s10_on_exit();
  216. unsigned int s10_on_event(FSMEvent* pEvt);
  217. void s11_on_entry();
  218. void s11_on_exit();
  219. unsigned int s11_on_event(FSMEvent* pEvt);
  220. ErrorCodeEnum Initial();
  221. int WaitDeamonFinish();
  222. int CoreBootDoWork();
  223. int SafeLoadDoWork();
  224. int OpLoadDoWork();
  225. int AccessAuthDoWork();
  226. int CheckLoadResult(LoadStage eStage);
  227. int CheckSafeLoadResult();
  228. int CheckOperatingResult();
  229. void SetAccessAuth(bool bResult=true);
  230. bool GetAccessAuthFlag(){return m_bAccessAuth;}
  231. void SetAccessFailedFlag(bool bValue = true) { m_bACFailed = bValue; }
  232. void SetInitSucFlag() {m_bInitSuc = true; m_bInitFail = false;}
  233. void SetInitFailFlag() {m_bInitFail = true; m_bInitSuc = false;}
  234. int StartPinPadEntity();
  235. int GetFSMState(){return m_fsmState;}
  236. void ToReAccessAuth(bool bEver=false);
  237. void SetCustomerMngerState(int iValue){m_custMngerState = iValue;}
  238. int GetCustomerMngerState(){return m_custMngerState;}
  239. int USBControl();
  240. CSimpleStringA GetEntityCfgInfo(CSimpleStringA name,int &loadOpt);
  241. CSimpleStringA GetUrlValue(){ return m_strURLValue; }
  242. void SetMD5OK(const int value){ m_havReceiveMD5OK = value; SetEvent(m_hMD5OKEvt); }
  243. int QueryAccessAuthStatus()
  244. {
  245. if (m_bAccessAuth)
  246. return 0;
  247. else
  248. {
  249. if (m_bHasAuthEver)
  250. return 1;
  251. else
  252. return 2;
  253. }
  254. }
  255. CSimpleStringA QueryCheckCode();
  256. CSimpleStringA QueryPinPadSM3DesInfo();
  257. void DeviceReConnect();
  258. bool IfIEBeforeHealth(){ return m_bIEBeforeHealth; }
  259. int QuitFrameworkAndSaveInfo(RebootTriggerEnum eTrigger, RebootWayEnum eWay = RebootWay_Unknown);
  260. void PostProcessAfterUpgrade();
  261. private:
  262. virtual ErrorCodeEnum AsyncStartEntity(const char *entity_name, const char *cmdline, void *pData);
  263. virtual ErrorCodeEnum AsyncStopEntity(const char *entity_name, void *pData);
  264. virtual ErrorCodeEnum AsyncPauseEntity(const char *entity_name, void *pData);
  265. virtual ErrorCodeEnum AsyncContinueEntity(const char *entity_name, void *pData);
  266. virtual ErrorCodeEnum AsyncTerminateEntity(const char *entity_name, void *pData);
  267. virtual void OnAnswer(CSmartPointer<IAsynWaitSp> pAsynWaitSp);
  268. int DoInitialization();
  269. void ToCheckUPS();
  270. void ToLogWarnTermAboutInfo();
  271. void ShowEntityBootFailedAtFront(LPCTSTR lpcszEntityName, ErrorCodeEnum bootFailedResult, bool isBlock = true);
  272. private:
  273. LoadStage m_eStage;
  274. CSimpleStringA m_SysState,m_strURL,m_strURLValue,m_checkCode,m_csErrEntity;
  275. map<int,int> m_enOpt;//entity option
  276. vector<CSimpleStringA> m_vCoreBoot,m_vSafeLoad,m_vOperating,m_vAllCfgEntity;
  277. map<CSimpleStringA,EntityLoadInfo> m_coreBootOpt;
  278. map<CSimpleStringA,EntityLoadInfo> m_safeLoadOpt;
  279. map<CSimpleStringA,EntityLoadInfo> m_operatingOpt;
  280. map<CSimpleStringA,EntityLoadFault> m_safeLoadFault;
  281. map<CSimpleStringA,EntityLoadFault> m_operatingFault;
  282. int m_devCfgNum, m_AccessAuthTries, m_InitTries, m_fsmState, m_stateBeforeMaintain, m_custMngerState, m_preFsmState, m_accessAuthCheckMD5
  283. ,m_havReceiveMD5OK;
  284. AccessAuthService_ClientBase *m_pACClient;
  285. InitializerService_ClientBase *m_pInitClient;
  286. bool m_bAccessAuth,m_bACFailed,m_bInitSuc,m_bInitFail,m_bIdleToMaintain,m_bHasAuthEver,m_bFirstAccessAuth,m_bEverAuthSucWithDevice
  287. ,m_bIEBeforeHealth, m_hasCfgGpioInRootIni;
  288. DWORD m_AccessAuthTimeout,m_InitializationTimeout;
  289. DeviceControlService_ClientBase *m_pDevCtrlClient;
  290. HANDLE m_hMD5OKEvt;
  291. CSystemStaticInfo m_sysInfo;
  292. //CHealthManagerEntity *m_pEntity;
  293. };
  294. struct WaitDeamonFinishTask : public ITaskSp
  295. {
  296. CHealthManagerFSM* fsm;
  297. WaitDeamonFinishTask(CHealthManagerFSM* f) : fsm(f) {}
  298. void Process()
  299. {
  300. LOG_FUNCTION();
  301. FSMEvent *e = new FSMEvent(USER_EVT_WAIT_DEAMON_FINISHED);
  302. e->param1 = fsm->WaitDeamonFinish();
  303. fsm->PostEventFIFO(e);
  304. }
  305. };
  306. struct CoreBootTask : public ITaskSp
  307. {
  308. CHealthManagerFSM* fsm;
  309. CoreBootTask(CHealthManagerFSM* f) : fsm(f) {}
  310. void Process()
  311. {
  312. LOG_FUNCTION();
  313. FSMEvent *e = new FSMEvent(USER_EVT_COREBOOT_FINISHED);
  314. e->param1 = fsm->CoreBootDoWork();
  315. fsm->PostEventFIFO(e);
  316. }
  317. };
  318. struct SafeLoadTask : public ITaskSp
  319. {
  320. CHealthManagerFSM* fsm;
  321. SafeLoadTask(CHealthManagerFSM* f) : fsm(f) {}
  322. void Process()
  323. {
  324. LOG_FUNCTION();
  325. FSMEvent *e = new FSMEvent(USER_EVT_SAFELOAD_FINISHED);
  326. e->param1 = fsm->SafeLoadDoWork();
  327. fsm->PostEventFIFO(e);
  328. }
  329. };
  330. struct OpLoadTask : public ITaskSp
  331. {
  332. CHealthManagerFSM* fsm;
  333. OpLoadTask(CHealthManagerFSM* f) : fsm(f) {}
  334. void Process()
  335. {
  336. LOG_FUNCTION();
  337. FSMEvent *e = new FSMEvent(USER_EVT_OPERATING_FINISHED);
  338. e->param1 = fsm->OpLoadDoWork();
  339. fsm->PostEventFIFO(e);
  340. }
  341. };
  342. struct AccessAuthTask : public ITaskSp
  343. {
  344. CHealthManagerFSM* fsm;
  345. AccessAuthTask(CHealthManagerFSM* f) : fsm(f) {}
  346. void Process()
  347. {
  348. LOG_FUNCTION();
  349. FSMEvent *e = new FSMEvent(USER_EVT_ACCESSAUTH_FINISHED);
  350. e->param1 = fsm->AccessAuthDoWork();
  351. fsm->PostEventFIFO(e);
  352. }
  353. };
  354. #endif // __HEALTHMANAGER_FSM_H