ReadCmdline.c 46 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250
  1. /*
  2. * Main.c
  3. *
  4. * Created on: 2019年8月6日
  5. * Author: 7564
  6. */
  7. #include <sys/time.h>
  8. #include <sys/timeb.h>
  9. #include <sys/types.h>
  10. #include <sys/stat.h>
  11. #include <sys/types.h>
  12. #include <sys/ioctl.h>
  13. #include <sys/socket.h>
  14. #include <sys/ipc.h>
  15. #include <sys/shm.h>
  16. #include <sys/shm.h>
  17. #include <sys/mman.h>
  18. #include <linux/wireless.h>
  19. #include <arpa/inet.h>
  20. #include <netinet/in.h>
  21. #include <unistd.h>
  22. #include <stdarg.h>
  23. #include <stdio.h> /*標準輸入輸出定義*/
  24. #include <stdlib.h> /*標準函數庫定義*/
  25. #include <stdint.h>
  26. #include <unistd.h> /*Unix 標準函數定義*/
  27. #include <fcntl.h> /*檔控制定義*/
  28. #include <termios.h> /*PPSIX 終端控制定義*/
  29. #include <errno.h> /*錯誤號定義*/
  30. #include <errno.h>
  31. #include <string.h>
  32. #include <time.h>
  33. #include <ctype.h>
  34. #include <ifaddrs.h>
  35. #include <math.h>
  36. #include <stdbool.h>
  37. #include "./Define/define.h"
  38. #include "Config.h"
  39. #include "./SelectGun/SelectGun.h"
  40. #define DEFAULT_AC_INDEX 2
  41. #define AUTORUN_STEP1_TIME_START 140 // Minutes
  42. #define AUTORUN_STEP1_TIME_END 150
  43. #define AUTORUN_STEP2_TIME_START 210
  44. #define AUTORUN_STEP2_TIME_END 410
  45. #define AUTORUN_END_TIME 480
  46. #define AUTORUN_CYCLE_COUNT 30
  47. #define TTY_PATH "/dev/tty"
  48. #define STTY_US "stty raw -echo -F "
  49. #define STTY_DEF "stty -raw echo -F "
  50. uint8_t _curAutoRunCount = 0;
  51. uint8_t _usingAutoRun = 0;
  52. struct timeval _autoTime;
  53. struct SysConfigAndInfo *ShmSysConfigAndInfo = NULL;
  54. struct StatusCodeData *ShmStatusCodeData = NULL;
  55. struct PrimaryMcuData *ShmPrimaryMcuData = NULL;
  56. struct CHAdeMOData *ShmCHAdeMOData = NULL;
  57. struct CcsData *ShmCcsData = NULL;
  58. struct GBTData *ShmGBTData = NULL;
  59. struct FanModuleData *ShmFanModuleData = NULL;
  60. struct RelayModuleData *ShmRelayModuleData = NULL;
  61. struct LedModuleData *ShmLedModuleData = NULL;
  62. struct PsuData *ShmPsuData = NULL;
  63. struct OCPP16Data *ShmOCPP16Data = NULL;
  64. static SelectGunInfo *ShmSelectGunInfo = NULL; //Jerry add
  65. struct ChargingInfoData *_chargingData[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  66. struct ChargingInfoData *ac_chargingInfo[AC_QUANTITY];
  67. char *msg = "state : get gun state (index) \n"
  68. "card : scanning card (x) : \n"
  69. "gun : get gun plugit state (index) \n"
  70. "lock : get gun locked state (index) \n"
  71. "self : self test state (x) \n"
  72. "ver : ver of board (407 or index or rb or fan) \n"
  73. "ac : get ac relay state (x) \n";
  74. bool FindChargingInfoData(uint8_t target, struct ChargingInfoData **chargingData)
  75. {
  76. for (uint8_t index = 0; index < CHAdeMO_QUANTITY; index++) {
  77. if (ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index].Index == target) {
  78. chargingData[target] = &ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index];
  79. return true;
  80. }
  81. }
  82. for (uint8_t index = 0; index < CCS_QUANTITY; index++) {
  83. if (ShmSysConfigAndInfo->SysInfo.CcsChargingData[index].Index == target) {
  84. chargingData[target] = &ShmSysConfigAndInfo->SysInfo.CcsChargingData[index];
  85. return true;
  86. }
  87. }
  88. for (uint8_t index = 0; index < GB_QUANTITY; index++) {
  89. if (ShmSysConfigAndInfo->SysInfo.GbChargingData[index].Index == target) {
  90. chargingData[target] = &ShmSysConfigAndInfo->SysInfo.GbChargingData[index];
  91. return true;
  92. }
  93. }
  94. return false;
  95. }
  96. bool FindAcChargingInfoData(uint8_t target, struct ChargingInfoData **acChargingData)
  97. {
  98. if (target < AC_QUANTITY) {
  99. acChargingData[target] = &ShmSysConfigAndInfo->SysInfo.AcChargingData[target];
  100. return true;
  101. }
  102. return false;
  103. }
  104. int InitShareMemory()
  105. {
  106. int result = PASS;
  107. int MeterSMId;
  108. //initial ShmSysConfigAndInfo
  109. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0) {
  110. result = FAIL;
  111. } else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  112. result = FAIL;
  113. }
  114. //initial ShmStatusCodeData
  115. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0) {
  116. result = FAIL;
  117. } else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  118. result = FAIL;
  119. }
  120. if (CHAdeMO_QUANTITY > 0) {
  121. if ((MeterSMId = shmget(ShmCHAdeMOCommKey, sizeof(struct CHAdeMOData),
  122. IPC_CREAT | 0777)) < 0) {
  123. result = FAIL;
  124. } else if ((ShmCHAdeMOData = shmat(MeterSMId, NULL, 0))
  125. == (void *) - 1) {
  126. result = FAIL;
  127. }
  128. }
  129. if (CCS_QUANTITY > 0) {
  130. if ((MeterSMId = shmget(ShmCcsCommKey, sizeof(struct CcsData),
  131. IPC_CREAT | 0777)) < 0) {
  132. result = FAIL;
  133. } else if ((ShmCcsData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  134. result = FAIL;
  135. }
  136. }
  137. if (GB_QUANTITY > 0) {
  138. if ((MeterSMId = shmget(ShmGBTCommKey, sizeof(struct GBTData),
  139. IPC_CREAT | 0777)) < 0) {
  140. return 0;
  141. } else if ((ShmGBTData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  142. return 0;
  143. }
  144. memset(ShmGBTData, 0, sizeof(struct GBTData));
  145. }
  146. if ((MeterSMId = shmget(ShmPrimaryMcuKey, sizeof(struct PrimaryMcuData), IPC_CREAT | 0777)) < 0) {
  147. result = FAIL;
  148. } else if ((ShmPrimaryMcuData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  149. result = FAIL;
  150. }
  151. if ((MeterSMId = shmget(ShmFanBdKey, sizeof(struct FanModuleData), IPC_CREAT | 0777)) < 0) {
  152. result = FAIL;
  153. } else if ((ShmFanModuleData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  154. result = FAIL;
  155. }
  156. if ((MeterSMId = shmget(ShmRelayBdKey, sizeof(struct RelayModuleData), IPC_CREAT | 0777)) < 0) {
  157. result = FAIL;
  158. } else if ((ShmRelayModuleData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  159. result = FAIL;
  160. }
  161. if ((MeterSMId = shmget(ShmLedBdKey, sizeof(struct LedModuleData), 0777)) < 0) {
  162. result = FAIL;
  163. } else if ((ShmLedModuleData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  164. result = FAIL;
  165. }
  166. if ((MeterSMId = shmget(ShmPsuKey, sizeof(struct PsuData), IPC_CREAT | 0777)) < 0) {
  167. result = FAIL;
  168. } else if ((ShmPsuData = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  169. result = FAIL;
  170. }
  171. //creat ShmOCPP16Data
  172. if ((MeterSMId = shmget(ShmOcppModuleKey, sizeof(struct OCPP16Data), IPC_CREAT | 0777)) < 0) {
  173. return FAIL;
  174. } else if ((ShmOCPP16Data = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  175. return FAIL;
  176. }
  177. if ((MeterSMId = shmget(ShmSelectGunInfoKey, sizeof(SelectGunInfo), IPC_CREAT | 0777)) < 0) {
  178. return FAIL;
  179. } else if ((ShmSelectGunInfo = shmat(MeterSMId, NULL, 0)) == (void *) - 1) {
  180. return FAIL;
  181. }
  182. return result;
  183. }
  184. unsigned long GetTimeoutValue(struct timeval _sour_time)
  185. {
  186. struct timeval _end_time;
  187. gettimeofday(&_end_time, NULL);
  188. return (_end_time.tv_sec - _sour_time.tv_sec);
  189. }
  190. void RunStatusProc(char *v1, char *v2)
  191. {
  192. printf("OrderCharging = %d \n", ShmSysConfigAndInfo->SysInfo.OrderCharging);
  193. printf("WaitForPlugit = %d \n", ShmSysConfigAndInfo->SysInfo.WaitForPlugit);
  194. if (strcmp(v1, "ac") == 0) {
  195. if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) {
  196. printf("FindChargingInfoData (AC) false \n");
  197. }
  198. printf("AC Status = %d \n", ac_chargingInfo[0]->ConnectorPlugIn);
  199. return;
  200. }
  201. int _index = atoi(v1);
  202. if (_index <= 1) {
  203. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  204. printf ("FindChargingInfoData error\n");
  205. return;
  206. }
  207. if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) {
  208. // get
  209. printf ("index = %x, status = %x (%d)\n", _index, _chargingData[_index]->SystemStatus, _chargingData[_index]->IsAvailable);
  210. printf ("SystemTimeoutFlag = %d, PageIndex = %d\n",
  211. ShmSysConfigAndInfo->SysInfo.SystemTimeoutFlag, ShmSysConfigAndInfo->SysInfo.PageIndex);
  212. } else {
  213. // set
  214. _chargingData[_index]->SystemStatus = atoi(v2);
  215. }
  216. } else {
  217. if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) {
  218. printf("FindChargingInfoData (AC) false \n");
  219. }
  220. if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) {
  221. // get
  222. printf ("AC Type, status = %x (%d)\n", ac_chargingInfo[0]->SystemStatus, ac_chargingInfo[0]->IsAvailable);
  223. } else {
  224. // set
  225. ac_chargingInfo[0]->SystemStatus = atoi(v2);
  226. }
  227. }
  228. }
  229. void RunCardProc(char *v1, char *v2)
  230. {
  231. if (strcmp(v1, "-1") == 0 || strcmp(v1, "") == 0) {
  232. if (ShmSysConfigAndInfo->SysInfo.WaitForPlugit) {
  233. ShmSysConfigAndInfo->SysInfo.WaitForPlugit = 0x00;
  234. printf ("SysInfo.WaitForPlugit = %x \n", ShmSysConfigAndInfo->SysInfo.WaitForPlugit);
  235. } else {
  236. ShmSysConfigAndInfo->SysInfo.WaitForPlugit = 0x01;
  237. printf ("SysInfo.WaitForPlugit = %x \n", ShmSysConfigAndInfo->SysInfo.WaitForPlugit);
  238. }
  239. } else {
  240. strcpy((char *)ShmSysConfigAndInfo->SysConfig.UserId, "");
  241. memcpy((char *)ShmSysConfigAndInfo->SysConfig.UserId, v1, strlen(v1));
  242. ShmSysConfigAndInfo->SysConfig.UserId[strlen(v1)] = '\0';
  243. printf("StartUserId = %s \n", ShmSysConfigAndInfo->SysConfig.UserId);
  244. }
  245. }
  246. void RunGunPlugitProc(char *v1, char *v2)
  247. {
  248. if (strcmp(v1, "ac") == 0) {
  249. if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) {
  250. printf("FindChargingInfoData (AC) false \n");
  251. }
  252. if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) {
  253. // get
  254. printf("ConnectorPlugIn = %d \n", ac_chargingInfo[0]->ConnectorPlugIn);
  255. } else {
  256. // set
  257. ac_chargingInfo[0]->ConnectorPlugIn = atoi(v2);
  258. }
  259. return;
  260. }
  261. int _index = atoi(v1);
  262. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  263. printf("FindChargingInfoData error\n");
  264. return;
  265. }
  266. if (strcmp(v2, "-1") == 0 || strcmp(v2, "") == 0) {
  267. // get
  268. printf("index = %x, plug it = %x\n", _index, _chargingData[_index]->ConnectorPlugIn);
  269. } else {
  270. // set
  271. _chargingData[_index]->ConnectorPlugIn = atoi(v2);
  272. }
  273. }
  274. void GetGunLockStatusProc(char *v1, char *v2)
  275. {
  276. int _index = atoi(v1);
  277. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  278. printf("FindChargingInfoData error\n");
  279. return;
  280. }
  281. if (strcmp(v2, "-1") != 0 && strcmp(v2, "") != 0) {
  282. _chargingData[_index]->GunLocked = atoi(v2);
  283. }
  284. printf("Gun Locked Status = %d \n", _chargingData[_index]->GunLocked);
  285. }
  286. void SetSystemIDProc()
  287. {
  288. char *systemId = "Alston_Test";
  289. memcpy(&ShmSysConfigAndInfo->SysConfig.SystemId, systemId, strlen(systemId));
  290. }
  291. void RunSelfProc()
  292. {
  293. printf("self test status = %x\n", ShmSysConfigAndInfo->SysInfo.SelfTestSeq);
  294. }
  295. void GetFwVerProc(char *v1)
  296. {
  297. if (strcmp(v1, "407") == 0) {
  298. printf("407 FW Version = %s \n", ShmPrimaryMcuData->version);
  299. } else if (strcmp(v1, "0") == 0 || strcmp(v1, "1") == 0) {
  300. int _index = atoi(v1);
  301. if (_index == 0) {
  302. printf("Gun 0 FW Version = %s \n", ShmSysConfigAndInfo->SysInfo.Connector1FwRev);
  303. } else if (_index == 1) {
  304. printf("Gun 1 FW Version = %s \n", ShmSysConfigAndInfo->SysInfo.Connector2FwRev);
  305. }
  306. } else if (strcmp(v1, "rb") == 0) {
  307. printf("RB Version = %s \n", ShmSysConfigAndInfo->SysInfo.RelayModuleFwRev);
  308. } else if (strcmp(v1, "fan") == 0) {
  309. printf("FAN Version = %s \n", ShmSysConfigAndInfo->SysInfo.FanModuleFwRev);
  310. } else if (strcmp(v1, "dc") == 0) {
  311. printf("DC Main Version = %s \n", ShmSysConfigAndInfo->SysInfo.CsuRootFsFwRev);
  312. } else if (strcmp(v1, "led") == 0) {
  313. printf("LED Version = %s \n", ShmSysConfigAndInfo->SysInfo.LedModuleFwRev);
  314. } else if (strcmp(v1, "ac") == 0) {
  315. if (!FindAcChargingInfoData(0, &ac_chargingInfo[0])) {
  316. printf("FindChargingInfoData (AC) false \n");
  317. }
  318. printf("AC Version = %s \n", ac_chargingInfo[0]->version);
  319. }
  320. }
  321. void CreateOneError(char *v1)
  322. {
  323. int value = atoi(v1);
  324. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.SystemL1InputOVP = value;
  325. ShmSysConfigAndInfo->SysConfig.BillingData.isBilling = value;
  326. }
  327. void GetAuthorizeFlag(char *v1)
  328. {
  329. if (strcmp(v1, "-1") == 0 || strcmp(v1, "") == 0) {
  330. printf("AuthorizeFlag = %d \n", ShmSysConfigAndInfo->SysInfo.AuthorizeFlag);
  331. } else {
  332. ShmSysConfigAndInfo->SysInfo.AuthorizeFlag = atoi(v1);
  333. }
  334. }
  335. void GetRelayStatus(char *v1)
  336. {
  337. int _index = atoi(v1);
  338. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  339. printf("FindChargingInfoData error\n");
  340. return;
  341. }
  342. printf("RelayK1K2Status = %d \n", _chargingData[_index]->RelayK1K2Status);
  343. printf("RelayKPK2Status = %d \n", _chargingData[_index]->RelayKPK2Status);
  344. }
  345. void FwUpdateFlagProc()
  346. {
  347. ShmSysConfigAndInfo->SysInfo.FirmwareUpdate = 0x01;
  348. }
  349. void CheckAcStatus(char *v1)
  350. {
  351. if (strcmp(v1, "-1") == 0 || strcmp(v1, "") == 0) {
  352. printf("AC Status = %d \n", ShmSysConfigAndInfo->SysInfo.AcContactorStatus);
  353. }
  354. }
  355. void SetCableChkStatus(char *v1, char *v2)
  356. {
  357. int _index = atoi(v1);
  358. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  359. printf ("FindChargingInfoData error\n");
  360. return;
  361. }
  362. _chargingData[_index]->GroundFaultStatus = atoi(v2);
  363. }
  364. void SetChargingInfoCCID(char *v1, char *v2)
  365. {
  366. int _index = atoi(v1);
  367. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  368. printf ("FindChargingInfoData error\n");
  369. return;
  370. }
  371. memcpy(_chargingData[_index]->EVCCID, v2, 8);
  372. _chargingData[_index]->EVCCID[8] = '\0';
  373. }
  374. void SetPowerValue(char *v1, char *v2)
  375. {
  376. int _index = atoi(v1);
  377. float _Current = atof(v2);
  378. // 盲沖的時候才允許使用~
  379. if (_chargingData[_index]->Type != 9) {
  380. return;
  381. }
  382. if (!FindChargingInfoData(_index, &_chargingData[0])) {
  383. printf ("FindChargingInfoData error\n");
  384. return;
  385. }
  386. _chargingData[_index]->EvBatterytargetCurrent = _Current;
  387. }
  388. void GetSystemInfo()
  389. {
  390. printf ("ModelName = %s \n", ShmSysConfigAndInfo->SysConfig.ModelName);
  391. printf ("SerialNumber = %s \n", ShmSysConfigAndInfo->SysConfig.SerialNumber);
  392. printf ("InternetConn = %d \n", ShmSysConfigAndInfo->SysInfo.InternetConn);
  393. printf ("MaxChargingPower = %d, MaxChargingCurrent = %d \n",
  394. ShmSysConfigAndInfo->SysConfig.MaxChargingPower,
  395. ShmSysConfigAndInfo->SysConfig.MaxChargingCurrent);
  396. }
  397. void ChangeGunNum()
  398. {
  399. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected + 1 < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount) {
  400. ShmSysConfigAndInfo->SysInfo.CurGunSelected += 1;
  401. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = NO_DEFINE;
  402. } else if (ShmSysConfigAndInfo->SysConfig.AcConnectorCount > 0 &&
  403. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc == NO_DEFINE) {
  404. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = DEFAULT_AC_INDEX;
  405. } else {
  406. ShmSysConfigAndInfo->SysInfo.CurGunSelected = 0;
  407. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = NO_DEFINE;
  408. }
  409. }
  410. void GetGunSelectedNum(char *v1)
  411. {
  412. if (strcmp(v1, "-1") == 0 || strcmp(v1, "") == 0) {
  413. if (AC_QUANTITY > 0 &&
  414. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc != NO_DEFINE) {
  415. printf("connector select changed = AC \n");
  416. } else {
  417. printf("connector selected = %d \n", ShmSysConfigAndInfo->SysInfo.CurGunSelected);
  418. }
  419. } else {
  420. int _index = atoi(v1);
  421. if (_index <= 1) {
  422. ShmSysConfigAndInfo->SysInfo.CurGunSelected = _index;
  423. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = NO_DEFINE;
  424. printf("connector select changed = %d \n", _index);
  425. } else if (AC_QUANTITY > 0) {
  426. ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc = DEFAULT_AC_INDEX;
  427. printf("connector select changed = AC \n");
  428. }
  429. }
  430. }
  431. void SetFanSpeed(char *v1)
  432. {
  433. int speed = atoi(v1);
  434. ShmFanModuleData->TestFanSpeed = speed;
  435. }
  436. void GetFanSpeed()
  437. {
  438. printf("ShmFanModuleData->PresentFan1Speed = %d \n", ShmFanModuleData->PresentFan1Speed);
  439. printf("ShmFanModuleData->PresentFan2Speed = %d \n", ShmFanModuleData->PresentFan2Speed);
  440. printf("ShmFanModuleData->PresentFan3Speed = %d \n", ShmFanModuleData->PresentFan3Speed);
  441. printf("ShmFanModuleData->PresentFan4Speed = %d \n", ShmFanModuleData->PresentFan4Speed);
  442. }
  443. void SetDebugMode(char *v1)
  444. {
  445. int mode = atoi(v1);
  446. ShmSysConfigAndInfo->SysConfig.SwitchDebugFlag = mode;
  447. }
  448. void SetGFDMode(char *v1)
  449. {
  450. int mode = atoi(v1);
  451. ShmSysConfigAndInfo->SysConfig.AlwaysGfdFlag = mode;
  452. }
  453. void GetPsuTemp()
  454. {
  455. for (uint8_t index = 0; index < ShmPsuData->GroupCount; index++) {
  456. for (uint8_t count = 0; count < ShmPsuData->PsuGroup[index].GroupPresentPsuQuantity; count++) {
  457. printf("PSU Temp = %d \n", ShmPsuData->PsuGroup[index].PsuModule[count].ExletTemp);
  458. }
  459. }
  460. }
  461. void GetAcInputVol()
  462. {
  463. printf("L1N_L12 = %f, L2N_L23 = %f, L3N_L31 = %f \n",
  464. ShmSysConfigAndInfo->SysInfo.InputVoltageR,
  465. ShmSysConfigAndInfo->SysInfo.InputVoltageS,
  466. ShmSysConfigAndInfo->SysInfo.InputVoltageT);
  467. }
  468. void GetPsuInformation(char *v1, char *v2, char *v3)
  469. {
  470. printf("**********************AC Contact needed*************************\n");
  471. if (strcmp(v1, "count") == 0) {
  472. for (int i = 0; i < 4; i++) {
  473. printf("Group Index = %d, Module Count = %d \n", i, ShmPsuData->PsuGroup[i].GroupPresentPsuQuantity);
  474. }
  475. } else if (strcmp(v1, "ver") == 0) {
  476. for (int i = 0; i < ShmPsuData->SystemPresentPsuQuantity; i++) {
  477. printf("Psu Index = %d, PriVersion = %s, SecVersion = %s \n",
  478. i, ShmPsuData->PsuVersion[i].FwPrimaryVersion, ShmPsuData->PsuVersion[i].FwSecondVersion);
  479. }
  480. for (int i = 0; i < ShmPsuData->GroupCount; i++) {
  481. for (int j = 0; j < ShmPsuData->PsuGroup[i].GroupPresentPsuQuantity; j++) {
  482. printf("Group Index = %d, Psu Index = %d, Version = %s \n",
  483. i, j, ShmPsuData->PsuGroup[i].PsuModule[j].FwVersion);
  484. }
  485. }
  486. } else if (strcmp(v1, "cap") == 0) {
  487. for (int i = 0; i < ShmPsuData->GroupCount; i++) {
  488. printf("Group Index = %d, MaxCur = %d, Power = %d \n",
  489. i, ShmPsuData->PsuGroup[i].GroupAvailableCurrent, ShmPsuData->PsuGroup[i].GroupAvailablePower);
  490. }
  491. } else if (strcmp(v1, "input") == 0) {
  492. for (int i = 0; i < ShmPsuData->GroupCount; i++) {
  493. for (uint8_t count = 0; count < ShmPsuData->PsuGroup[i].GroupPresentPsuQuantity; count++) {
  494. printf("gp = %d, Index = %d, volR = %d, volS = %d, volT = %d \n",
  495. i, count,
  496. ShmPsuData->PsuGroup[i].PsuModule[count].InputVoltageL1,
  497. ShmPsuData->PsuGroup[i].PsuModule[count].InputVoltageL2,
  498. ShmPsuData->PsuGroup[i].PsuModule[count].InputVoltageL3);
  499. }
  500. }
  501. } else if (strcmp(v1, "output") == 0) {
  502. for (int i = 0; i < ShmPsuData->GroupCount; i++) {
  503. printf("Group Index = %d, OutputV = %d, OutputC = %d \n",
  504. i, ShmPsuData->PsuGroup[i].GroupPresentOutputVoltage, ShmPsuData->PsuGroup[i].GroupPresentOutputCurrent);
  505. }
  506. for (int i = 0; i < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; i++) {
  507. if (!FindChargingInfoData(i, &_chargingData[0])) {
  508. printf ("FindChargingInfoData error\n");
  509. continue;
  510. }
  511. printf("Form RB : Group Index = %d, OutputV = %f \n",
  512. i, _chargingData[i]->FireChargingVoltage);
  513. }
  514. } else if (strcmp(v1, "test") == 0) {
  515. int mode = atoi(v2);
  516. if (mode >= _TEST_MODE && mode <= _TEST_MODE) {
  517. ShmPsuData->Work_Step = mode;
  518. }
  519. } else if (strcmp(v1, "out") == 0) {
  520. float vol = atof(v2);
  521. float cur = atof(v3);
  522. if (ShmPsuData->Work_Step >= _TEST_MODE && ShmPsuData->Work_Step <= _TEST_MODE) {
  523. if (!FindChargingInfoData(0, &_chargingData[0])) {
  524. printf ("FindChargingInfoData error\n");
  525. return;
  526. }
  527. _chargingData[0]->EvBatterytargetVoltage = vol;
  528. _chargingData[0]->EvBatterytargetCurrent = cur;
  529. }
  530. }
  531. printf("*************************************************\n");
  532. }
  533. void GetConnectorCapInfo(char *v1)
  534. {
  535. int _GunIndex = atoi(v1);
  536. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  537. printf ("FindChargingInfoData error\n");
  538. return;
  539. }
  540. printf ("Charger Max Current = %d, Max Power = %d \n",
  541. ShmSysConfigAndInfo->SysConfig.MaxChargingCurrent * 10,
  542. ShmSysConfigAndInfo->SysConfig.MaxChargingPower * 10);
  543. printf ("Index = %d, MaxPow = %f, MaxVol = %f, MaxCur = %f\n",
  544. _GunIndex,
  545. _chargingData[_GunIndex]->RealMaxPower,
  546. _chargingData[_GunIndex]->RealMaxVoltage,
  547. _chargingData[_GunIndex]->RealMaxCurrent);
  548. }
  549. static void get_char(char *word)
  550. {
  551. fd_set rfds;
  552. struct timeval tv;
  553. FD_ZERO(&rfds);
  554. FD_SET(0, &rfds);
  555. tv.tv_sec = 0;
  556. tv.tv_usec = 10; //wait input timout time
  557. //if input
  558. if (select(1, &rfds, NULL, NULL, &tv) > 0) {
  559. fgets(word, 128, stdin);
  560. }
  561. }
  562. static void setConfirmSelGun(uint8_t selGun)
  563. {
  564. if (selGun == LEFT_GUN_NUM && ShmSelectGunInfo->SelGunInfo.LeftGun == SEL_GUN_RELEASE) {
  565. ShmSelectGunInfo->SelGunInfo.LeftGun = SEL_GUN_CONFIRM;
  566. //printf("confirmSelGun left\r\n");
  567. } else if (selGun == RIGHT_GUN_NUM && ShmSelectGunInfo->SelGunInfo.RightGun == SEL_GUN_RELEASE) {
  568. ShmSelectGunInfo->SelGunInfo.RightGun = SEL_GUN_CONFIRM;
  569. //printf("confirmSelGun right\r\n");
  570. }
  571. }
  572. void RunUnconditionalChargeIndex1(char *v1, char *v2, char *v3)
  573. {
  574. int _GunIndex;
  575. uint8_t gunIndex = 0;
  576. uint8_t stopChg = 0;
  577. uint8_t curGun = 0;
  578. float _Voltage;
  579. float _Current;
  580. uint8_t PreviousSystemStatus[2] = {0xff};
  581. if (strcmp(v1, "auto") == EQUAL) {
  582. _usingAutoRun = 0x01;
  583. _GunIndex = 0;
  584. _Voltage = 500;
  585. _Current = (ShmSysConfigAndInfo->SysConfig.MaxChargingPower * 1000) / _Voltage;
  586. } else {
  587. _usingAutoRun = 0x00;
  588. _GunIndex = atoi(v1);
  589. _Voltage = atof(v2);
  590. _Current = atof(v3);
  591. }
  592. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  593. printf ("FindChargingInfoData error\n");
  594. return;
  595. }
  596. printf("Power = %d, ReqVoltage = %f, ReqCurrent = %f\n",
  597. ShmSysConfigAndInfo->SysConfig.MaxChargingPower,
  598. _Voltage,
  599. _Current);
  600. if (_Voltage > 1000 || _Voltage < 50) {
  601. printf ("Input Voltage over range\n");
  602. return;
  603. }
  604. // if(_Current > 100 || _Current < 2){
  605. //
  606. // printf ("Input Current over range\n");
  607. // return;
  608. // }
  609. //測試期間先跳過自我測試 _STEST_COMPLETE = 0xfe
  610. //ShmSysConfigAndInfo->SysInfo.SelfTestSeq = 0xfe;
  611. //kill ev task
  612. system("killall Module_EvComm");
  613. //_Voltage = (_Voltage * 10);
  614. //_Current = (_Current * 10);
  615. //system(STTY_US TTY_PATH);
  616. ShmSysConfigAndInfo->SysInfo.CurGunSelected = _GunIndex;
  617. while (true) {
  618. curGun = ShmSysConfigAndInfo->SysInfo.CurGunSelected;
  619. //fix gun 1
  620. switch (_chargingData[curGun]->SystemStatus) {
  621. case S_IDLE:
  622. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  623. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  624. #if defined DD360Audi
  625. setConfirmSelGun(curGun);
  626. #endif //defined DD360Audi
  627. strcpy((char *)ShmSysConfigAndInfo->SysConfig.UserId, "AutoStartCharging");
  628. _chargingData[curGun]->ConnectorPlugIn = 1;
  629. printf ("[UnconditionalCharge - S_IDLE]\n");
  630. _chargingData[curGun]->Type = 9;
  631. }
  632. if (ShmOCPP16Data->SpMsg.bits.AuthorizeConf == 1) {
  633. ShmSysConfigAndInfo->SysInfo.StartToChargingFlag = 0x01;
  634. _chargingData[curGun]->SystemStatus = S_PREPARNING;
  635. }
  636. break;
  637. case S_PREPARNING:
  638. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  639. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  640. printf ("[UnconditionalCharge - S_PREPARNIN]\n");
  641. //等待 AC Relay 搭上且找到模組 (main 在此 statue 其它 task 會去做完)
  642. printf ("wait find module\n");
  643. }
  644. //main 會在此階段判斷以下資料跳到下一個 state
  645. //用來得知 AC 是否有搭上 (搭上模組的資訊才會出來) 因為每次 AC_Contactor
  646. //ShmPsuData->SystemPresentPsuQuantity;
  647. //ShmPsuData->PsuGroup[gun_index].GroupPresentPsuQuantity;
  648. //ShmPsuData->PsuGroup[gun_index].GroupAvailablePower;
  649. //_chargingData[gun_index]->AvailableChargingPower;
  650. //等待 AC Relay 搭上且找到模組 (main 在此 statue 其它 task 會去做完)
  651. //sleep(10);
  652. //清除 main timeout 機制
  653. _chargingData[curGun]->TimeoutFlag = 0;
  654. //不論是什麼 type 的槍都固意設成 Chademo 不跑 Prechage step
  655. _chargingData[curGun]->Type = 9;
  656. break;
  657. case S_PREPARING_FOR_EV:
  658. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  659. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  660. printf ("[UnconditionalCharge - S_PREPARING_FOR_EV]\n");
  661. printf ("ReqVoltage = %f, ReqCurrent = %f \n", _Voltage * 10, _Current * 10);
  662. }
  663. //清除 main timeout 機制
  664. _chargingData[curGun]->TimeoutFlag = 0;
  665. //不論是什麼 type 的槍都固意設成 Chademo 不跑 Prechage step
  666. _chargingData[curGun]->Type = 9;
  667. //充電電壓電流
  668. _chargingData[curGun]->EvBatterySoc = 50;
  669. _chargingData[curGun]->EvBatterytargetVoltage = 500;
  670. _chargingData[curGun]->EvBatterytargetCurrent = 2;
  671. _chargingData[curGun]->AvailableChargingCurrent = 1000;
  672. //****** 注意~此行為是防止 K1K2 先開導到無法升壓 ( Relay Board 在此 state 還未搭上 K1K2 )
  673. //確定模組己升壓完成
  674. //if(_chargingData[curGun]->PresentChargingVoltage <= (3000+500) &&
  675. // _chargingData[curGun]->PresentChargingVoltage >= (3000-500) )
  676. {
  677. printf ("Precharge Done = %f \n",
  678. _chargingData[curGun]->PresentChargingVoltage);
  679. //EV done
  680. _chargingData[curGun]->SystemStatus = S_PREPARING_FOR_EVSE;
  681. }
  682. break;
  683. case S_PREPARING_FOR_EVSE:
  684. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  685. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  686. printf ("[UnconditionalCharge - S_PREPARING_FOR_EVSE]\n");
  687. }
  688. //printf ("tar vol = %d \n", _Voltage);
  689. //printf ("tar cur = %d \n", _Current);
  690. //清除 main timeout 機制
  691. _chargingData[curGun]->TimeoutFlag = 0;
  692. //不論是什麼 type 的槍都固意設成 Chademo 不跑 Prechage step
  693. _chargingData[curGun]->Type = 9;
  694. //充電電壓電流
  695. _chargingData[curGun]->EvBatterySoc = 50;
  696. _chargingData[curGun]->EvBatterytargetVoltage = 500;
  697. _chargingData[curGun]->EvBatterytargetCurrent = 2;
  698. _chargingData[curGun]->AvailableChargingCurrent = 1000;
  699. //printf ("tar vol_ = %d \n", _chargingData[curGun]->EvBatterytargetVoltage);
  700. // printf ("tar cur_ = %d \n", _chargingData[curGun]->EvBatterytargetCurrent);
  701. //****** 注意~此行為是防止 K1K2 先開導到無法升壓 ( Relay Board 在此 state 還未搭上 K1K2 )
  702. //確定模組己升壓完成
  703. if (_chargingData[curGun]->GroundFaultStatus == 0x01 ||
  704. _chargingData[curGun]->GroundFaultStatus == 0x03) {
  705. printf ("First Ground Fault State (%d)\n",
  706. _chargingData[curGun]->GroundFaultStatus);
  707. printf ("Wait K1K2 = %f \n", _chargingData[curGun]->PresentChargingVoltage);
  708. sleep(5);
  709. //EV done
  710. _chargingData[curGun]->SystemStatus = S_CHARGING;
  711. } else if (_chargingData[curGun]->GroundFaultStatus > 0x02) {
  712. printf ("First Ground Fault check Fail (%d)\n",
  713. _chargingData[curGun]->GroundFaultStatus);
  714. _chargingData[curGun]->SystemStatus = S_TERMINATING;
  715. }
  716. break;
  717. case S_CHARGING:
  718. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  719. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  720. if (_usingAutoRun == 0x00) {
  721. //充電電壓電流
  722. _chargingData[curGun]->EvBatterytargetVoltage = _Voltage;
  723. _chargingData[curGun]->EvBatterytargetCurrent = _Current;
  724. } else {
  725. _curAutoRunCount = 0;
  726. gettimeofday(&_autoTime, NULL);
  727. }
  728. _chargingData[curGun]->EvBatterySoc = 50;
  729. _chargingData[curGun]->AvailableChargingCurrent = 1000;
  730. printf ("[UnconditionalCharge - S_CHARGING]\n");
  731. }
  732. if (_usingAutoRun == 0x01) {
  733. if (((GetTimeoutValue(_autoTime)) >= AUTORUN_STEP1_TIME_START * 60 &&
  734. (GetTimeoutValue(_autoTime)) <= AUTORUN_STEP1_TIME_END * 60) ||
  735. ((GetTimeoutValue(_autoTime)) >= AUTORUN_STEP2_TIME_START * 60 &&
  736. (GetTimeoutValue(_autoTime)) <= AUTORUN_STEP2_TIME_END * 60)
  737. ) {
  738. _chargingData[curGun]->EvBatterytargetVoltage = _Voltage;
  739. _chargingData[curGun]->EvBatterytargetCurrent = _Current;
  740. } else if ((GetTimeoutValue(_autoTime)) >= AUTORUN_END_TIME * 60) {
  741. _curAutoRunCount++;
  742. if (_curAutoRunCount >= AUTORUN_CYCLE_COUNT) {
  743. _chargingData[curGun]->SystemStatus = S_TERMINATING;
  744. } else {
  745. gettimeofday(&_autoTime, NULL);
  746. }
  747. } else {
  748. _chargingData[curGun]->EvBatterytargetVoltage = 0;
  749. _chargingData[curGun]->EvBatterytargetCurrent = 0;
  750. }
  751. }
  752. // printf("out : vol = %f, cur = %f \n",
  753. // _chargingData[curGun]->EvBatterytargetVoltage,
  754. // _chargingData[curGun]->EvBatterytargetCurrent);
  755. //ev task do this
  756. _chargingData[curGun]->PresentChargingPower =
  757. ((float)((_chargingData[curGun]->PresentChargingVoltage) *
  758. (_chargingData[curGun]->PresentChargingCurrent)) / 1000);
  759. if (_chargingData[curGun]->GroundFaultStatus == 0x02) {
  760. printf ("Charging Ground Fault check Fail (%d)\n",
  761. _chargingData[curGun]->GroundFaultStatus);
  762. _chargingData[curGun]->SystemStatus = S_TERMINATING;
  763. }
  764. break;
  765. case S_TERMINATING:
  766. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  767. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  768. printf ("[UnconditionalCharge - S_TERMINATING]\n");
  769. //無阻塞偵測 keybaord 結束
  770. system(STTY_DEF TTY_PATH);
  771. }
  772. _chargingData[curGun]->SystemStatus = S_COMPLETE;
  773. break;
  774. case S_COMPLETE:
  775. if (PreviousSystemStatus[curGun] != _chargingData[curGun]->SystemStatus) {
  776. PreviousSystemStatus[curGun] = _chargingData[curGun]->SystemStatus;
  777. printf ("[UnconditionalCharge - S_COMPLETE]\n");
  778. }
  779. PreviousSystemStatus[curGun] = 0xFF;
  780. stopChg = 0;
  781. for (gunIndex = 0; gunIndex < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; gunIndex++) {
  782. if (PreviousSystemStatus[gunIndex] == 0xFF) {
  783. _chargingData[curGun]->SystemStatus = S_IDLE;
  784. }
  785. if (_chargingData[gunIndex]->SystemStatus == S_IDLE) {
  786. stopChg++;
  787. }
  788. }
  789. _chargingData[curGun]->PresentChargingPower = 0;
  790. if (stopChg == ShmSysConfigAndInfo->SysConfig.TotalConnectorCount) {
  791. system("/root/Module_EvComm &");
  792. sleep(3);
  793. return;
  794. }
  795. break;
  796. }
  797. char word[128];
  798. char newString[7][10];
  799. int i, j, ctr;
  800. memset(word, 0x00, sizeof(word));
  801. get_char(word);
  802. if (strlen(word) == 0) {
  803. continue;
  804. }
  805. j = 0; ctr = 0;
  806. strcpy(newString[1], "-1");
  807. strcpy(newString[2], "-1");
  808. for (i = 0; i <= (strlen(word)); i++) {
  809. if (word[i] == ' ' || word[i] == '\0' || word[i] == 10) {
  810. newString[ctr][j] = '\0';
  811. ctr++;
  812. j = 0;
  813. } else {
  814. newString[ctr][j] = word[i];
  815. j++;
  816. }
  817. }
  818. if (strcmp(newString[0], "strchg") == 0) {
  819. if (strcmp(newString[1], "-1") == 0 ||
  820. strcmp(newString[1], "") == 0 ||
  821. strcmp(newString[2], "-1") == 0 ||
  822. strcmp(newString[2], "") == 0
  823. ) {
  824. printf ("Input cmd fail ------ strchg [vol 150-1000] [cru 2-100]\n");
  825. continue;
  826. }
  827. if (atoi(newString[1]) == ShmSysConfigAndInfo->SysInfo.CurGunSelected) {
  828. continue;
  829. }
  830. _GunIndex = atoi((char *)newString[1]);
  831. _Voltage = atof((char *)newString[2]);
  832. _Current = atof((char *)newString[3]);
  833. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  834. printf ("FindChargingInfoData error\n");
  835. continue;
  836. }
  837. printf ("Power = %d, ReqVoltage = %f, ReqCurrent = %f\n",
  838. ShmSysConfigAndInfo->SysConfig.MaxChargingPower,
  839. _Voltage,
  840. _Current);
  841. if (_Voltage > 1000 || _Voltage < 50) {
  842. _Voltage = 200;
  843. printf ("Input Voltage over range\n");
  844. continue;
  845. }
  846. ShmSysConfigAndInfo->SysInfo.CurGunSelected = _GunIndex;
  847. strcpy((char *)ShmSysConfigAndInfo->SysConfig.UserId, "");
  848. } else if (strcmp(newString[0], "chg") == 0) {
  849. if (strcmp(newString[1], "-1") == 0) {
  850. continue;
  851. }
  852. if (strcmp(newString[2], "-1") == 0 ||
  853. strcmp(newString[2], "") == 0) {
  854. continue;
  855. }
  856. if (strcmp(newString[3], "-1") == 0 ||
  857. strcmp(newString[3], "") == 0) {
  858. continue;
  859. }
  860. _GunIndex = atoi((char *)newString[1]);
  861. float _vol = atof(newString[2]);
  862. float _cur = atof(newString[3]);
  863. if (_cur <= 0 || _cur <= 0) {
  864. continue;
  865. }
  866. printf("vol = %f, cur = %f \n", _vol, _cur);
  867. _chargingData[_GunIndex]->EvBatterytargetVoltage = _vol;
  868. _chargingData[_GunIndex]->EvBatterytargetCurrent = _cur;
  869. } else if (strcmp(newString[0], "c") == 0) {
  870. if (atoi((char *)newString[1]) != -1) {
  871. ShmSysConfigAndInfo->SysInfo.CurGunSelected = atoi((char *)newString[1]);
  872. }
  873. printf("stop \n\r");
  874. ShmSysConfigAndInfo->SysInfo.StartToChargingFlag = 0x00;
  875. _chargingData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus = S_TERMINATING;
  876. }
  877. usleep(100000);
  878. }
  879. }
  880. int main(void)
  881. {
  882. if (InitShareMemory() == FAIL) {
  883. printf ("InitShareMemory = FAIL \n");
  884. if (ShmStatusCodeData != NULL) {
  885. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory = 1;
  886. }
  887. sleep(5);
  888. return 0;
  889. }
  890. for (;;) {
  891. char word[128];
  892. char newString[7][10];
  893. int i, j, ctr;
  894. fgets(word, sizeof(word), stdin);
  895. j = 0; ctr = 0;
  896. strcpy(newString[1], "-1");
  897. strcpy(newString[2], "-1");
  898. for (i = 0; i <= (strlen(word)); i++) {
  899. if (word[i] == ' ' || word[i] == '\0' || word[i] == 10) {
  900. newString[ctr][j] = '\0';
  901. ctr++;
  902. j = 0;
  903. } else {
  904. newString[ctr][j] = word[i];
  905. j++;
  906. }
  907. }
  908. if (strcmp(newString[0], "state") == 0) {
  909. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  910. continue;
  911. }
  912. // 槍狀態
  913. RunStatusProc(newString[1], newString[2]);
  914. } else if (strcmp(newString[0], "card") == 0) {
  915. // 刷卡狀態
  916. RunCardProc(newString[1], newString[2]);
  917. } else if (strcmp(newString[0], "gun") == 0) {
  918. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  919. continue;
  920. }
  921. // 插槍狀態
  922. RunGunPlugitProc(newString[1], newString[2]);
  923. } else if (strcmp(newString[0], "lock") == 0) {
  924. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  925. continue;
  926. }
  927. // 插槍狀態
  928. GetGunLockStatusProc(newString[1], newString[2]);
  929. } else if (strcmp(newString[0], "sysid") == 0) {
  930. // 測試 sys id
  931. SetSystemIDProc();
  932. } else if (strcmp(newString[0], "self") == 0) {
  933. // CSU 自我檢測狀態
  934. RunSelfProc(newString[1]);
  935. } else if (strcmp(newString[0], "ver") == 0) {
  936. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  937. continue;
  938. }
  939. // 取 FW 版號
  940. GetFwVerProc(newString[1]);
  941. } else if (strcmp(newString[0], "update") == 0) {
  942. // 更新
  943. FwUpdateFlagProc(newString[1]);
  944. } else if (strcmp(newString[0], "ac") == 0) {
  945. // AC contactor 狀態
  946. CheckAcStatus(newString[1]);
  947. } else if (strcmp(newString[0], "cable") == 0) {
  948. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  949. continue;
  950. }
  951. // cable check pass
  952. SetCableChkStatus(newString[1], newString[2]);
  953. } else if (strcmp(newString[0], "pow") == 0) {
  954. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  955. continue;
  956. }
  957. // cable check pass
  958. SetPowerValue(newString[1], newString[2]);
  959. } else if (strcmp(newString[0], "model") == 0) {
  960. GetSystemInfo();
  961. } else if (strcmp(newString[0], "select") == 0) {
  962. // 取得 / 設定 當前選的槍號
  963. GetGunSelectedNum(newString[1]);
  964. } else if (strcmp(newString[0], "change") == 0) {
  965. // 模擬按鈕改變選槍
  966. ChangeGunNum();
  967. } else if (strcmp(newString[0], "fan") == 0) {
  968. // 設定風扇速度
  969. SetFanSpeed(newString[1]);
  970. } else if (strcmp(newString[0], "speed") == 0) {
  971. // 取得風扇速度
  972. GetFanSpeed();
  973. } else if (strcmp(newString[0], "debug") == 0) {
  974. // 設定 debug mode
  975. SetDebugMode(newString[1]);
  976. } else if (strcmp(newString[0], "gfd") == 0) {
  977. // 設定盲沖使用 GFD 功能
  978. SetGFDMode(newString[1]);
  979. } else if (strcmp(newString[0], "temp") == 0) {
  980. // 取得 PSU 溫度
  981. GetPsuTemp();
  982. } else if (strcmp(newString[0], "acin") == 0) {
  983. // 取得三向輸入電壓
  984. GetAcInputVol();
  985. } else if (strcmp(newString[0], "psu") == 0) {
  986. //如果連一個參數都沒有 (此命令不理會) 加上判斷第二參數
  987. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0) {
  988. printf ("PSU : Param fail..Please retry again......\n");
  989. continue;
  990. }
  991. // 取得 PSU 資訊
  992. GetPsuInformation(newString[1], newString[2], newString[3]);
  993. } else if (strcmp(newString[0], "cap") == 0) {
  994. GetConnectorCapInfo(newString[1]);
  995. } else if (strcmp(newString[0], "error") == 0) {
  996. CreateOneError(newString[1]);
  997. } else if (strcmp(newString[0], "auth") == 0) {
  998. GetAuthorizeFlag(newString[1]);
  999. } else if (strcmp(newString[0], "relay") == 0) {
  1000. GetRelayStatus(newString[1]);
  1001. } else if (strcmp(newString[0], "ccid") == 0) {
  1002. if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0 ||
  1003. strcmp(newString[2], "-1") == 0 || strcmp(newString[2], "") == 0) {
  1004. printf ("Input ccid fail.\n");
  1005. continue;
  1006. }
  1007. SetChargingInfoCCID(newString[1], newString[2]);
  1008. } else if (strcmp(newString[0], "strchg") == 0) {
  1009. //如果連一個參數都沒有 (此命令不理會) 加上判斷第二參數
  1010. if (strcmp(newString[1], "auto") == 0) {
  1011. newString[2][0] = 0;
  1012. newString[3][0] = 0;
  1013. } else if (strcmp(newString[1], "-1") == 0 || strcmp(newString[1], "") == 0 ||
  1014. strcmp(newString[2], "-1") == 0 || strcmp(newString[2], "") == 0) {
  1015. printf ("Input cmd fail ------ strchg [vol 150-1000] [cru 2-100]\n");
  1016. continue;
  1017. }
  1018. // 槍狀態
  1019. RunUnconditionalChargeIndex1(newString[1], newString[2], newString[3]);
  1020. } else if (strcmp(newString[0], "tempT") == 0) {
  1021. if (strcmp(newString[1], "0") == 0) {
  1022. uint8_t _GunIndex = 0;
  1023. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  1024. printf ("FindChargingInfoData error\n");
  1025. return 0;
  1026. }
  1027. _chargingData[0]->ConnectorTemp = atoi(newString[2]);
  1028. printf("ReadCmdline temp 0 = %d\r\n", _chargingData[0]->ConnectorTemp);
  1029. } else if (strcmp(newString[1], "1") == 0) {
  1030. uint8_t _GunIndex = 1;
  1031. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  1032. printf ("FindChargingInfoData error\n");
  1033. return 0;
  1034. }
  1035. _chargingData[1]->ConnectorTemp = atoi(newString[2]);
  1036. printf("ReadCmdline temp 1 = %d\r\n", _chargingData[1]->ConnectorTemp);
  1037. }
  1038. } else if (strcmp(newString[0], "tempC") == 0) {
  1039. if (strcmp(newString[1], "0") == 0) {
  1040. uint8_t _GunIndex = 0;
  1041. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  1042. printf ("FindChargingInfoData error\n");
  1043. return 0;
  1044. }
  1045. _chargingData[0]->ChillerTemp = atoi(newString[2]);
  1046. printf("ReadCmdline temp 0 = %d\r\n", _chargingData[0]->ChillerTemp);
  1047. } else if (strcmp(newString[1], "1") == 0) {
  1048. uint8_t _GunIndex = 1;
  1049. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  1050. printf ("FindChargingInfoData error\n");
  1051. return 0;
  1052. }
  1053. _chargingData[1]->ChillerTemp = atoi(newString[2]);
  1054. printf("ReadCmdline temp 1 = %d\r\n", _chargingData[1]->ChillerTemp);
  1055. }
  1056. } else if (strcmp(newString[0], "TempCR") == 0) {
  1057. if (strcmp(newString[1], "0") == 0) {
  1058. uint8_t _GunIndex = 0;
  1059. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  1060. printf ("FindChargingInfoData error\n");
  1061. return 0;
  1062. }
  1063. printf("ReadCmdline temp 0 = %d\r\n", _chargingData[0]->ChillerTemp);
  1064. } else if (strcmp(newString[1], "1") == 0) {
  1065. uint8_t _GunIndex = 1;
  1066. if (!FindChargingInfoData(_GunIndex, &_chargingData[0])) {
  1067. printf ("FindChargingInfoData error\n");
  1068. return 0;
  1069. }
  1070. printf("ReadCmdline temp 1 = %d\r\n", _chargingData[1]->ChillerTemp);
  1071. }
  1072. } else {
  1073. printf ("%s\n", msg);
  1074. }
  1075. usleep(100000);
  1076. }
  1077. return 0;
  1078. }