Module_LcmControl.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898
  1. #include "Module_LcmContro.h"
  2. void PRINTF_FUNC(char *string, ...);
  3. int StoreLogMsg(const char *fmt, ...);
  4. #define DEBUG_INFO(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  5. #define DEBUG_WARN(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  6. #define DEBUG_ERROR(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  7. char* getTimeString(void);
  8. //=================================
  9. // Common routine
  10. //=================================
  11. int StoreLogMsg(const char *fmt, ...)
  12. {
  13. char Buf[4096+256];
  14. char buffer[4096];
  15. time_t CurrentTime;
  16. struct tm *tm;
  17. va_list args;
  18. va_start(args, fmt);
  19. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  20. va_end(args);
  21. memset(Buf,0,sizeof(Buf));
  22. CurrentTime = time(NULL);
  23. tm=localtime(&CurrentTime);
  24. sprintf(Buf,"echo \"%04d-%02d-%02d %02d:%02d:%02d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog",
  25. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,
  26. buffer,
  27. tm->tm_year+1900,tm->tm_mon+1);
  28. system(Buf);
  29. return rc;
  30. }
  31. char* getTimeString(void)
  32. {
  33. char *result=malloc(21);
  34. time_t timep;
  35. struct tm *p;
  36. time(&timep);
  37. p=gmtime(&timep);
  38. sprintf(result, "[%04d-%02d-%02d %02d:%02d:%02d]", (1900+p->tm_year), (1+p->tm_mon), p->tm_mday, p->tm_hour, p->tm_hour, p->tm_sec);
  39. return result;
  40. }
  41. void PRINTF_FUNC(char *string, ...)
  42. {
  43. if (DEBUG)
  44. {
  45. va_list args;
  46. char buffer[4096];
  47. va_start(args, string);
  48. vsnprintf(buffer, sizeof(buffer), string, args);
  49. va_end(args);
  50. printf("%s \n", buffer);
  51. }
  52. }
  53. //==========================================
  54. // Init all share memory
  55. //==========================================
  56. int InitShareMemory()
  57. {
  58. int result = PASS;
  59. int MeterSMId;
  60. //creat ShmSysConfigAndInfo
  61. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0)
  62. {
  63. #ifdef SystemLogMessage
  64. DEBUG_ERROR("shmget ShmSysConfigAndInfo NG\n");
  65. #endif
  66. result = FAIL;
  67. }
  68. else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  69. {
  70. #ifdef SystemLogMessage
  71. DEBUG_ERROR("shmat ShmSysConfigAndInfo NG\n");
  72. #endif
  73. result = FAIL;
  74. }
  75. else
  76. {}
  77. //creat ShmStatusCodeData
  78. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0)
  79. {
  80. #ifdef SystemLogMessage
  81. DEBUG_ERROR("shmget ShmStatusCodeData NG\n");
  82. #endif
  83. result = FAIL;
  84. }
  85. else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  86. {
  87. #ifdef SystemLogMessage
  88. DEBUG_ERROR("shmat ShmStatusCodeData NG\n");
  89. #endif
  90. result = FAIL;
  91. }
  92. else
  93. {}
  94. return result;
  95. }
  96. //==========================================
  97. // Open and Close RS232 and R/W
  98. //==========================================
  99. int CreateCommunicationLcmPort()
  100. {
  101. int fd;
  102. struct termios tios;
  103. fd = open(pPortName, O_RDWR);
  104. if (fd <= 0) {
  105. #ifdef SystemLogMessage
  106. DEBUG_ERROR("open /dev/ttyS3 NG \n");
  107. #endif
  108. return -1;
  109. }
  110. ioctl(fd, TCGETS, &tios);
  111. tios.c_cflag = B115200 | CS8 | CLOCAL | CREAD;
  112. tios.c_lflag = 0;
  113. tios.c_iflag = 0;
  114. tios.c_oflag = 0;
  115. tios.c_cc[VMIN] = 0;
  116. tios.c_cc[VTIME] = (unsigned char) 5;
  117. tios.c_lflag = 0;
  118. tcflush(fd, TCIFLUSH);
  119. ioctl(fd, TCSETS, &tios);
  120. return fd;
  121. }
  122. void CloseCommunicationLcmPort()
  123. {
  124. close(_port);
  125. }
  126. void WriteCmdToLcm(byte *cmd, byte cmdLen)
  127. {
  128. int len = write(_port, cmd, cmdLen);
  129. if(len >= sizeof(cmd))
  130. {
  131. //PRINTF_FUNC("Write cmd to LCM successfully. \n");
  132. }
  133. }
  134. void ReadMsgFromLcm(byte *msg, byte readLen)
  135. {
  136. read(_port, msg, readLen);
  137. if(*msg == CMD_TITLE_1 && *(msg + 1) == CMD_TITLE_2)
  138. {
  139. if(*(msg + 3) == CMD_WRITE)
  140. {
  141. switch (*(msg + 4))
  142. {
  143. case CMD_REGISTER:
  144. {
  145. // 頁面
  146. _currentPage = (unsigned short) (*(msg + 6) << 8) + (unsigned short) *(msg + 7);
  147. }
  148. break;
  149. }
  150. }
  151. else if (*(msg + 3) == CMD_MULTI_READ)
  152. {
  153. // switch ((unsigned short) (*(msg + 4) << 8) + (unsigned short) *(msg + 5))
  154. // {
  155. // case BUTTON_GUN_INDEX:
  156. // {
  157. // // 當前選的槍號
  158. // _curGunIndex = (*(msg + 8));
  159. // }
  160. // break;
  161. // }
  162. }
  163. }
  164. // for (byte idx = 0; idx < len; idx++)
  165. // PRINTF_FUNC("[system_command]-RX: %X\n", *(msg + idx));
  166. }
  167. //================================================
  168. // Function
  169. //================================================
  170. void ChangeToOtherPage(short newPage)
  171. {
  172. byte cmd[7];
  173. memset(cmd, 0x00, sizeof(cmd));
  174. cmd[0] = CMD_TITLE_1;
  175. cmd[1] = CMD_TITLE_2;
  176. cmd[2] = 0x02 + sizeof(newPage);
  177. cmd[3] = CMD_READ;
  178. cmd[4] = CMD_REGISTER;
  179. cmd[5] = newPage >> 8;
  180. cmd[6] = newPage & 0x00FF;
  181. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  182. usleep(100000);
  183. }
  184. void ChangeBackLight(bool islight)
  185. {
  186. byte value = 0x01;
  187. if (islight)
  188. {
  189. value = 0x20;
  190. }
  191. byte cmd[7];
  192. memset(cmd, 0x00, sizeof(cmd));
  193. cmd[0] = CMD_TITLE_1;
  194. cmd[1] = CMD_TITLE_2;
  195. cmd[2] = 0x03;
  196. cmd[3] = CMD_READ;
  197. cmd[4] = CMD_BACKLIGHT;
  198. cmd[5] = value;
  199. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  200. usleep(100000);
  201. }
  202. void GetCurrentPage()
  203. {
  204. byte cmd[6];
  205. memset(cmd, 0x00, sizeof(cmd));
  206. byte msg[8];
  207. memset(msg, 0x00, sizeof(msg));
  208. cmd[0] = CMD_TITLE_1;
  209. cmd[1] = CMD_TITLE_2;
  210. cmd[2] = 0x03; // 底下總長度
  211. cmd[3] = CMD_WRITE;
  212. cmd[4] = CMD_REGISTER;
  213. cmd[5] = 0x02;
  214. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  215. usleep(100000);
  216. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  217. }
  218. void DisplayValueToLcm(short address, byte *data, byte len)
  219. {
  220. byte cmd[256];
  221. memset(cmd, 0x00, sizeof(cmd));
  222. cmd[0] = CMD_TITLE_1;
  223. cmd[1] = CMD_TITLE_2;
  224. cmd[2] = 0x03 + len;
  225. cmd[3] = CMD_MULTI_WRITE;
  226. cmd[4] = address >> 8;
  227. cmd[5] = address & 0x00FF;
  228. for(byte count = 0; count < len; count++)
  229. {
  230. cmd[6 + count] = *(data + count);
  231. }
  232. WriteCmdToLcm(cmd, cmd[2] + 3);
  233. }
  234. void ChangeDisplay2Value(short address, short value)
  235. {
  236. byte data[2];
  237. data[0] = value >> 8;
  238. data[1] = value & 0x00FF;
  239. DisplayValueToLcm(address, data, sizeof(data));
  240. }
  241. void GetBtnStatus(short address, byte len)
  242. {
  243. byte cmd[8];
  244. memset(cmd, 0x00, sizeof(cmd));
  245. byte msg[8];
  246. memset(msg, 0x00, sizeof(msg));
  247. cmd[0] = CMD_TITLE_1;
  248. cmd[1] = CMD_TITLE_2;
  249. cmd[2] = 0x03 + len;
  250. cmd[3] = CMD_MULTI_READ;
  251. cmd[4] = address >> 8;
  252. cmd[5] = address & 0x00FF;
  253. cmd[6] = 0x00 + len;
  254. WriteCmdToLcm(cmd, cmd[2] + 3);
  255. usleep(100000);
  256. ReadMsgFromLcm(msg, (len * 2) + sizeof(msg));
  257. }
  258. //================================================
  259. // Warning process
  260. //================================================
  261. void string2ByteArray(unsigned char *input, byte *output)
  262. {
  263. int loop;
  264. int i;
  265. loop = 0;
  266. i = 0;
  267. while(input[loop] != '\0')
  268. {
  269. output[i++] = input[loop++];
  270. }
  271. output[loop] = '\0';
  272. }
  273. void ChangeWarningFunc()
  274. {
  275. byte cmd[7];
  276. byte i = 0;
  277. //PRINTF_FUNC("ChangeWarningFunc \n");
  278. // 最多一次五筆
  279. //PRINTF_FUNC("LCM PageIndex = %d \n", ShmSysConfigAndInfo->SysWarningInfo.PageIndex);
  280. //PRINTF_FUNC("WarningCount = %d \n", ShmSysConfigAndInfo->SysWarningInfo.WarningCount);
  281. for(i = 0; (i + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 5) < ShmSysConfigAndInfo->SysWarningInfo.WarningCount; i++)
  282. {
  283. memset(cmd, 0x00, sizeof(cmd));
  284. if(i >= 5)
  285. {
  286. break;
  287. }
  288. //error code
  289. string2ByteArray(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[i + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 5][0], cmd);
  290. DisplayValueToLcm(0x0010 + (i * 6), cmd, sizeof(cmd));
  291. //警告標示
  292. memset(cmd, 0x00, sizeof(cmd));
  293. cmd[0] = 0x00;
  294. cmd[1] = 0x01;
  295. DisplayValueToLcm(0x0002 + (i * 2), cmd, 2);
  296. }
  297. memset(cmd, 0x00, sizeof(cmd));
  298. for(; i < 5; i++)
  299. {
  300. DisplayValueToLcm(0x0010 + (i * 6), cmd, sizeof(cmd));
  301. DisplayValueToLcm(0x0002 + (i * 2), cmd, 2);
  302. }
  303. }
  304. //================================================
  305. // QR Code process
  306. //================================================
  307. void ChangeQrCode_Idle(char *input)
  308. {
  309. int len = strlen(input);
  310. byte cmd[len];
  311. int loop = 0;
  312. int i = 0;
  313. while(input[loop] != '\0')
  314. {
  315. cmd[i++] = input[loop++];
  316. }
  317. DisplayValueToLcm(__qr_code, cmd, len);
  318. }
  319. void ChangeQrCode_Charge(char *input)
  320. {
  321. int len = strlen(input);
  322. byte cmd[len];
  323. int loop = 0;
  324. int i = 0;
  325. while(input[loop] != '\0')
  326. {
  327. cmd[i++] = input[loop++];
  328. }
  329. DisplayValueToLcm(__qr_code_pre, cmd, len);
  330. }
  331. //================================================
  332. // Change current page
  333. //================================================
  334. void ChangeCurPage()
  335. {
  336. //PRINTF_FUNC("cur = %d, new = %d \n", _currentPage, ShmSysConfigAndInfo->SysInfo.PageIndex);
  337. if (_currentPage != ShmSysConfigAndInfo->SysInfo.PageIndex)
  338. {
  339. _currentPage = ShmSysConfigAndInfo->SysInfo.PageIndex;
  340. ChangeToOtherPage(_currentPage);
  341. _everyPageRollChange = 0;
  342. }
  343. }
  344. //================================================
  345. // Main process
  346. //================================================
  347. byte demoCount = 0;
  348. void DemoFunction()
  349. {
  350. if (demoCount == 0)
  351. {
  352. ShmSysConfigAndInfo->SysWarningInfo.WarningCount = 6;
  353. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[0][0], "000001", 7);
  354. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[1][0], "000002", 7);
  355. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[2][0], "000003", 7);
  356. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[3][0], "000004", 7);
  357. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[4][0], "000005", 7);
  358. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[5][0], "000006", 7);
  359. }
  360. else
  361. {
  362. if (demoCount == 20) {
  363. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_IDLE;
  364. } else if (demoCount == 80) {
  365. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZING;
  366. } else if (demoCount == 100) {
  367. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZ_COMP;
  368. } else if (demoCount == 120) {
  369. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZ_FAIL;
  370. } else if (demoCount == 140) {
  371. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_PRE_CHARGE;
  372. } else if (demoCount == 180) {
  373. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_CHARGING;
  374. }
  375. }
  376. if (demoCount < 180)
  377. demoCount++;
  378. }
  379. //================================================
  380. // Main process
  381. //================================================
  382. bool FindChargingInfoData(byte target, struct ChargingInfoData **_chargingData)
  383. {
  384. for (byte index = 0; index < CHAdeMO_QUANTITY; index++)
  385. {
  386. if (ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index].Index == target)
  387. {
  388. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index];
  389. return true;
  390. }
  391. }
  392. for (byte index = 0; index < CCS_QUANTITY; index++)
  393. {
  394. if (ShmSysConfigAndInfo->SysInfo.CcsChargingData[index].Index == target)
  395. {
  396. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.CcsChargingData[index];
  397. return true;
  398. }
  399. }
  400. for (byte index = 0; index < GB_QUANTITY; index++)
  401. {
  402. if (ShmSysConfigAndInfo->SysInfo.GbChargingData[index].Index == target)
  403. {
  404. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.GbChargingData[index];
  405. return true;
  406. }
  407. }
  408. return false;
  409. }
  410. void ChangeBattMapAndValue(short page, int soc)
  411. {
  412. // srand(time(NULL));
  413. // int min = 10;
  414. // int max = 90;
  415. // soc = rand() % (max - min + 1) + min;
  416. if (page == _LCM_CHARGING)
  417. {
  418. if (soc < 20)
  419. ChangeDisplay2Value(__batt_map, _battery_cap_20);
  420. else if (soc >= 20 && soc < 40)
  421. ChangeDisplay2Value(__batt_map, _battery_cap_40);
  422. else if (soc >= 40 && soc < 60)
  423. ChangeDisplay2Value(__batt_map, _battery_cap_60);
  424. else if (soc >= 60 && soc < 80)
  425. ChangeDisplay2Value(__batt_map, _battery_cap_80);
  426. else if (soc >= 80 && soc <= 100)
  427. ChangeDisplay2Value(__batt_map, _battery_cap_100);
  428. }
  429. else if (page == _LCM_COMPLETE)
  430. {
  431. if (soc < 20)
  432. ChangeDisplay2Value(__batt_map, _battery_soc_20);
  433. else if (soc >= 20 && soc < 40)
  434. ChangeDisplay2Value(__batt_map, _battery_soc_40);
  435. else if (soc >= 40 && soc < 60)
  436. ChangeDisplay2Value(__batt_map, _battery_soc_60);
  437. else if (soc >= 60 && soc < 80)
  438. ChangeDisplay2Value(__batt_map, _battery_soc_80);
  439. else if (soc >= 80 && soc <= 100)
  440. ChangeDisplay2Value(__batt_map, _battery_soc_100);
  441. }
  442. byte cmd[4];
  443. byte value[4];
  444. memset(cmd, 0x00, sizeof(cmd));
  445. sprintf((char *)value, "%d%%", soc);
  446. string2ByteArray(value, cmd);
  447. DisplayValueToLcm(__soc_value_charging, cmd, sizeof(cmd));
  448. }
  449. void ChangeRemainTime(int sec)
  450. {
  451. int h, m, s;
  452. byte cmd[10];
  453. byte value[10];
  454. memset(cmd, 0x00, sizeof(cmd));
  455. // srand(time(NULL));
  456. // int min = 0;
  457. // int max = 65536;
  458. // sec = rand() % (max - min + 1) + min;
  459. h = (sec / 3600);
  460. m = (sec - (3600 * h)) / 60;
  461. s = (sec - (3600 * h) - (m * 60));
  462. sprintf((char *)value, "%02d:%02d:%02d", h, m, s);
  463. string2ByteArray(value, cmd);
  464. DisplayValueToLcm(__remain_time_tx, cmd, sizeof(cmd));
  465. }
  466. void ChangeChargingPowerValue(float pow)
  467. {
  468. byte cmd[10];
  469. byte value[10];
  470. memset(cmd, 0x00, sizeof(cmd));
  471. // float min = 0.0;
  472. // float max = 50;
  473. // pow = (max - min) * rand() / (RAND_MAX + 1.0) + min;
  474. sprintf((char *) value, "%.1f kW", pow);
  475. string2ByteArray(value, cmd);
  476. DisplayValueToLcm(__output_eng_tx, cmd, sizeof(cmd));
  477. }
  478. void ChangeStopMap(byte value)
  479. {
  480. }
  481. void RefreshPageAnimation(byte value)
  482. {
  483. switch(_currentPage)
  484. {
  485. case _LCM_IDLE:
  486. {
  487. if (value == 0)
  488. {
  489. ChangeToOtherPage(_currentPage);
  490. }
  491. else if (value == 15)
  492. {
  493. ChangeToOtherPage(_currentPage + 1);
  494. }
  495. else if (value == 30)
  496. {
  497. ChangeToOtherPage(_currentPage + 2);
  498. }
  499. _everyPageRollChange > 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  500. }
  501. break;
  502. case _LCM_WAIT_FOR_PLUG:
  503. {
  504. if(_everyPageRollChange == 0)
  505. ChangeDisplay2Value(__plug_in_arrow, _arrow_dark);
  506. else if(_everyPageRollChange == 15)
  507. ChangeDisplay2Value(__plug_in_arrow, _arrow_light);
  508. _everyPageRollChange > 30 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  509. }
  510. break;
  511. case _LCM_PRE_CHARGE:
  512. case _LCM_CHARGING:
  513. case _LCM_COMPLETE:
  514. {
  515. if (_currentPage == _LCM_PRE_CHARGE)
  516. {
  517. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  518. ChangeDisplay2Value(__conn_line, _conn_map1);
  519. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  520. ChangeDisplay2Value(__conn_line, _conn_map2);
  521. }
  522. else if (_currentPage == _LCM_CHARGING)
  523. {
  524. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  525. ChangeDisplay2Value(__conn_line_chag, _charging_map1);
  526. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  527. ChangeDisplay2Value(__conn_line_chag, _charging_map2);
  528. }
  529. else if (_currentPage == _LCM_COMPLETE)
  530. {
  531. if (_everyPageRollChange == 0)
  532. ChangeDisplay2Value(__conn_line_comp, _complete_map);
  533. }
  534. if (_totalCount == 2 && _currentPage != _LCM_PRE_CHARGE)
  535. {
  536. byte index = 0;
  537. for (index = 0; index < _totalCount; index++) {
  538. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  539. {
  540. break;
  541. }
  542. }
  543. ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  544. if (_chargingInfoData[index]->SystemStatus == S_IDLE)
  545. {
  546. if(value == 0)
  547. {
  548. ChangeDisplay2Value(__side_top, _side_rfid_1);
  549. ChangeDisplay2Value(__side_down, _side_rfid_2);
  550. }
  551. else if (value == 15)
  552. {
  553. ChangeDisplay2Value(__side_top, _side_qr_1);
  554. ChangeDisplay2Value(__side_down, _side_qr_2);
  555. }
  556. else if (value == 30)
  557. {
  558. ChangeDisplay2Value(__side_top, _side_app_1);
  559. ChangeDisplay2Value(__side_down, _side_app_2);
  560. }
  561. }
  562. else
  563. {
  564. ChangeDisplay2Value(__side_top, _disappear);
  565. ChangeDisplay2Value(__side_down, _disappear);
  566. ChangeDisplay2Value(__qr_code_pre, _disappear);
  567. }
  568. }
  569. else
  570. {
  571. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  572. ChangeDisplay2Value(__side_top, _disappear);
  573. ChangeDisplay2Value(__side_down, _disappear);
  574. ChangeDisplay2Value(__qr_code_pre, _disappear);
  575. }
  576. _everyPageRollChange >= 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  577. }
  578. break;
  579. }
  580. }
  581. void RefreshConnStatus()
  582. {
  583. // Wifi priority is higher than Ethernet
  584. if (ShmSysConfigAndInfo->SysConfig.AthInterface.WifiNetworkConn == 0x01)
  585. {
  586. if (!_wifi_conn_status)
  587. {
  588. _wifi_conn_status = true;
  589. ChangeDisplay2Value(__wifi_status, _wifi_connect);
  590. ChangeDisplay2Value(__ethernet_status, _disappear);
  591. }
  592. }
  593. else
  594. {
  595. if(_wifi_conn_status)
  596. {
  597. _wifi_conn_status = false;
  598. ChangeDisplay2Value(__wifi_status, _disappear);
  599. }
  600. }
  601. if (!_wifi_conn_status)
  602. {
  603. if (ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomNetworkConn == PASS)
  604. {
  605. if(!_net_conn_status)
  606. {
  607. _net_conn_status = true;
  608. ChangeDisplay2Value(__ethernet_status, _ethernet_connect);
  609. }
  610. }
  611. else
  612. {
  613. if(_net_conn_status)
  614. {
  615. _net_conn_status = false;
  616. ChangeDisplay2Value(__ethernet_status, _ethernet_disconnect);
  617. }
  618. }
  619. }
  620. // 連線到後台
  621. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == 0x01)
  622. ChangeDisplay2Value(__conn_status, _connect);
  623. else
  624. ChangeDisplay2Value(__conn_status, _disconnect);
  625. }
  626. void ProcessPageInfo()
  627. {
  628. switch(_currentPage)
  629. {
  630. case _LCM_IDLE:
  631. {
  632. // QR Code 處理
  633. ChangeQrCode_Idle("http://google.com.tw");
  634. }
  635. break;
  636. case _LCM_PRE_CHARGE:
  637. case _LCM_CHARGING:
  638. case _LCM_COMPLETE:
  639. {
  640. // gun type and charging info
  641. for(byte i = 0; i < _totalCount; i++)
  642. {
  643. switch(_chargingInfoData[i]->Type)
  644. {
  645. case _Type_Chademo:
  646. {
  647. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  648. {
  649. ChangeDisplay2Value(__gun_type_index + (i * 2), _chademo_light);
  650. }
  651. else
  652. {
  653. ChangeDisplay2Value(__gun_type_index + (i * 2), _chademo_dark);
  654. }
  655. }
  656. break;
  657. case _Type_CCS_2:
  658. {
  659. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  660. {
  661. ChangeDisplay2Value(__gun_type_index + (i * 2), _ccs_light);
  662. }
  663. else
  664. {
  665. ChangeDisplay2Value(__gun_type_index + (i * 2), _ccs_dark);
  666. }
  667. }
  668. break;
  669. }
  670. if (_currentPage == _LCM_CHARGING)
  671. {
  672. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  673. {
  674. ChangeBattMapAndValue(_LCM_CHARGING, _chargingInfoData[i]->EvBatterySoc);
  675. if (_chargingInfoData[i]->RemainChargingDuration > 0)
  676. ChangeRemainTime(_chargingInfoData[i]->RemainChargingDuration);
  677. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  678. if (strcmp((char *)_chargingInfoData[i]->StartUserId, "") == 0)
  679. ChangeDisplay2Value(__stop_method_btn, _stop_charging_btn);
  680. else
  681. ChangeDisplay2Value(__stop_method_btn, _stop_charging_btn_scan);
  682. }
  683. }
  684. else if (_currentPage == _LCM_COMPLETE)
  685. {
  686. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  687. {
  688. ChangeBattMapAndValue(_LCM_COMPLETE, _chargingInfoData[i]->EvBatterySoc);
  689. if (_chargingInfoData[i]->RemainChargingDuration > 0)
  690. ChangeRemainTime(_chargingInfoData[i]->RemainChargingDuration);
  691. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  692. }
  693. }
  694. }
  695. // gun btn and QR code
  696. if (_totalCount == 2 && _currentPage != _LCM_PRE_CHARGE)
  697. {
  698. byte index = 0;
  699. for(index = 0; index < _totalCount; index++)
  700. {
  701. if(ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  702. {
  703. break;
  704. }
  705. }
  706. if (_chargingInfoData[index]->SystemStatus == S_IDLE ||
  707. _chargingInfoData[index]->SystemStatus == S_BOOTING)
  708. {
  709. // QR Code 處理
  710. ChangeQrCode_Charge("http://google.com.tw");
  711. }
  712. }
  713. }
  714. break;
  715. }
  716. }
  717. void Initialization()
  718. {
  719. strcpy((char *)ShmSysConfigAndInfo->SysInfo.LcmHwRev, moduleName);
  720. bool isPass = false;
  721. byte count = 5;
  722. while(!isPass && count > 0)
  723. {
  724. isPass = true;
  725. for (byte _index = 0; _index < _totalCount; _index++)
  726. {
  727. if (!FindChargingInfoData(_index, &_chargingInfoData[0]))
  728. {
  729. DEBUG_ERROR("EvComm (main) : FindChargingInfoData false \n");
  730. isPass = false;
  731. count--;
  732. break;
  733. }
  734. }
  735. }
  736. if (count == 0)
  737. PRINTF_FUNC("LCM Initialization Gun Fail.............\n");
  738. }
  739. int main(void)
  740. {
  741. if(InitShareMemory() == FAIL)
  742. {
  743. #ifdef SystemLogMessage
  744. DEBUG_ERROR("InitShareMemory NG\n");
  745. #endif
  746. if (ShmStatusCodeData != NULL)
  747. {
  748. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory = 1;
  749. }
  750. sleep(5);
  751. return 0;
  752. }
  753. _port = CreateCommunicationLcmPort();
  754. byte changeWarningPriority = 0;
  755. byte curWarningCount = 255;
  756. //ChangeBackLight(true);
  757. Initialization();
  758. // ChangeToOtherPage(_LCM_FIX);
  759. // return 0;
  760. while(_port != -1)
  761. {
  762. //DemoFunction();
  763. // Warning 處理
  764. if(curWarningCount != ShmSysConfigAndInfo->SysWarningInfo.WarningCount)
  765. {
  766. changeWarningPriority = 0;
  767. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  768. curWarningCount = ShmSysConfigAndInfo->SysWarningInfo.WarningCount;
  769. ChangeWarningFunc();
  770. }
  771. else if (ShmSysConfigAndInfo->SysWarningInfo.WarningCount > 5 && changeWarningPriority == 0)
  772. {
  773. // 當有兩頁 Warning 則每隔三秒改變一次
  774. if(ShmSysConfigAndInfo->SysWarningInfo.PageIndex == 0)
  775. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 1;
  776. else
  777. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  778. ChangeWarningFunc();
  779. }
  780. // 頁面資訊處理
  781. ProcessPageInfo();
  782. // 網路 - wifi - 連線訊號處理
  783. RefreshConnStatus();
  784. // 換頁處理
  785. ChangeCurPage();
  786. RefreshPageAnimation(_everyPageRollChange);
  787. changeWarningPriority >= 30 ? changeWarningPriority = 0 : changeWarningPriority++;
  788. usleep(100000);
  789. }
  790. CloseCommunicationLcmPort();
  791. return FAIL;
  792. }