Module_ConfigTools.c 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994
  1. /*
  2. * Module_ConfigTools.c
  3. *
  4. * Created on: 2020¦~6¤ë22¤é
  5. * Author: foluswen
  6. */
  7. #include <sys/types.h>
  8. #include <sys/stat.h>
  9. #include <sys/time.h>
  10. #include <sys/timeb.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/mman.h>
  17. #include <linux/wireless.h>
  18. #include <arpa/inet.h>
  19. #include <netinet/in.h>
  20. #include <dirent.h>
  21. #include <unistd.h>
  22. #include <stdarg.h>
  23. #include <stdio.h>
  24. #include <stdlib.h>
  25. #include <unistd.h>
  26. #include <fcntl.h>
  27. #include <termios.h>
  28. #include <errno.h>
  29. #include <errno.h>
  30. #include <string.h>
  31. #include <time.h>
  32. #include <ctype.h>
  33. #include <ifaddrs.h>
  34. #include <stdbool.h>
  35. #include <stddef.h>
  36. #include <stdint.h>
  37. #include "define.h"
  38. #include "main.h"
  39. //=================================
  40. // System basic sample constant
  41. //=================================
  42. #define ARRAY_SIZE(A) (sizeof(A) / sizeof(A[0]))
  43. #define PASS 1
  44. #define FAIL -1
  45. #define YES 1
  46. #define NO 0
  47. #define ON 1
  48. #define OFF 0
  49. #define MtdBlockSize 0x300000
  50. struct SysConfigAndInfo *ShmSysConfigAndInfo;
  51. struct StatusCodeData *ShmStatusCodeData;
  52. struct OCPP16Data *ShmOCPP16Data;
  53. struct Charger *ShmCharger;
  54. int StoreLogMsg(const char *fmt, ...)
  55. {
  56. char Buf[4096+256];
  57. char buffer[4096];
  58. time_t CurrentTime;
  59. struct tm *tm;
  60. struct timeval tv;
  61. va_list args;
  62. va_start(args, fmt);
  63. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  64. va_end(args);
  65. memset(Buf,0,sizeof(Buf));
  66. CurrentTime = time(NULL);
  67. tm=localtime(&CurrentTime);
  68. gettimeofday(&tv, NULL); // get microseconds, 10^-6
  69. sprintf(Buf,"echo -n \"[%04d.%02d.%02d %02d:%02d:%02d.%06ld]%s\" >> /Storage/SystemLog/[%04d.%02d]ConfigToolsLog",
  70. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,tv.tv_usec,
  71. buffer,
  72. tm->tm_year+1900,tm->tm_mon+1);
  73. #ifdef SystemLogMessage
  74. system(Buf);
  75. #endif
  76. #ifdef ConsloePrintLog
  77. printf("[%04d.%02d.%02d %02d:%02d:%02d.%06ld]%s", tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,tv.tv_usec, buffer);
  78. #endif
  79. return rc;
  80. }
  81. int runShellCmd(const char*cmd)
  82. {
  83. int result = FAIL;
  84. char buf[256];
  85. FILE *fp;
  86. fp = popen(cmd, "r");
  87. if(fp != NULL)
  88. {
  89. while(fgets(buf, sizeof(buf), fp) != NULL)
  90. {
  91. DEBUG_INFO("%s\n", buf);
  92. }
  93. result = PASS;
  94. }
  95. pclose(fp);
  96. return result;
  97. }
  98. int StoreUsrConfigData(struct SysConfigData *UsrData)
  99. {
  100. int result = PASS;
  101. int fd,wrd;
  102. unsigned int i,Chk;
  103. unsigned char *ptr, *BufTmp;
  104. Chk=0;
  105. ptr=(unsigned char *)UsrData;
  106. if((BufTmp=malloc(MtdBlockSize))!=NULL)
  107. {
  108. memset(BufTmp,0,MtdBlockSize);
  109. memcpy(BufTmp,ptr,sizeof(struct SysConfigData));
  110. for(i=ARRAY_SIZE(UsrData->CsuBootLoadFwRev);i<MtdBlockSize-4;i++)
  111. Chk+=*(BufTmp+i);
  112. memcpy(BufTmp+MtdBlockSize-4, &Chk, 4);
  113. // Output configuration to file.
  114. fd = open("/mnt/EvseConfig.bin", O_RDWR|O_CREAT);
  115. if (fd < 0)
  116. {
  117. DEBUG_ERROR("open /mnt/EvseConfig.bin NG\n");
  118. free(BufTmp);
  119. return 0;
  120. }
  121. wrd=write(fd, BufTmp, MtdBlockSize);
  122. close(fd);
  123. if(wrd<MtdBlockSize)
  124. {
  125. DEBUG_ERROR("write /mnt/EvseConfig.bin NG\n");
  126. free(BufTmp);
  127. return 0;
  128. }
  129. DEBUG_INFO("EvseConfig write to file in /mnt OK.\n");
  130. DEBUG_INFO("Erase /dev/mtd10.\n");
  131. runShellCmd("flash_erase /dev/mtd10 0 0");
  132. DEBUG_INFO("Write /dev/mtd10.\n");
  133. runShellCmd("nandwrite -p /dev/mtd10 /mnt/EvseConfig.bin");
  134. DEBUG_INFO("Erase /dev/mtd11.\n");
  135. runShellCmd("flash_erase /dev/mtd11 0 0");
  136. DEBUG_INFO("Write /dev/mtd11.\n");
  137. runShellCmd("nandwrite -p /dev/mtd11 /mnt/EvseConfig.bin");
  138. system("rm -f /mnt/EvseConfig.bin");
  139. DEBUG_INFO("EvseConfig write to flash OK\n");
  140. }
  141. else
  142. {
  143. DEBUG_ERROR("alloc BlockSize NG\r\n");
  144. result = FAIL;
  145. }
  146. if(BufTmp!=NULL)
  147. free(BufTmp);
  148. return result;
  149. }
  150. int InitShareMemory()
  151. {
  152. int result = PASS;
  153. int MeterSMId;
  154. //Initial ShmSysConfigAndInfo
  155. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0)
  156. {
  157. DEBUG_ERROR("shmget ShmSysConfigAndInfo NG\n");
  158. result = FAIL;
  159. }
  160. else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  161. {
  162. DEBUG_ERROR("[shmat ShmSysConfigAndInfo NG\n");
  163. result = FAIL;
  164. }
  165. else
  166. {}
  167. //Initial ShmStatusCodeData
  168. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0)
  169. {
  170. DEBUG_ERROR("shmget ShmStatusCodeData NG\n");
  171. result = FAIL;
  172. }
  173. else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  174. {
  175. DEBUG_ERROR("shmat ShmStatusCodeData NG\n");
  176. result = FAIL;
  177. }
  178. else
  179. {}
  180. //Initial ShmOCPP16Data
  181. if ((MeterSMId = shmget(ShmOcppModuleKey, sizeof(struct OCPP16Data), 0777)) < 0)
  182. {
  183. DEBUG_ERROR("shmget ShmOCPP16Data NG\n");
  184. result = FAIL;
  185. }
  186. else if ((ShmOCPP16Data = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  187. {
  188. DEBUG_ERROR("shmat ShmOCPP16Data NG\n");
  189. result = FAIL;
  190. }
  191. else
  192. {}
  193. //Initial ShmCharger
  194. if ((MeterSMId = shmget(ShmChargerKey, sizeof(struct Charger), 0777)) < 0)
  195. {
  196. DEBUG_ERROR("shmget ShmCharger NG\n");
  197. result = FAIL;
  198. }
  199. else if ((ShmCharger = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  200. {
  201. DEBUG_ERROR("shmat ShmCharger NG\n");
  202. result = FAIL;
  203. }
  204. else
  205. {}
  206. return result;
  207. }
  208. int main(void)
  209. {
  210. char cmd[128];
  211. if(InitShareMemory() == FAIL)
  212. {
  213. #ifdef SystemLogMessage
  214. DEBUG_ERROR("InitShareMemory NG\n");
  215. #endif
  216. if(ShmStatusCodeData!=NULL)
  217. {
  218. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory=1;
  219. }
  220. sleep(5);
  221. return 0;
  222. }
  223. else
  224. {
  225. DEBUG_INFO("InitShareMemory OK.\n");
  226. }
  227. for(;;)
  228. {
  229. system("clear");
  230. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  231. printf("\n ===== main menu ==================================");
  232. printf("\n system: system configuration menu.");
  233. printf("\n ocpp: ocpp configuration menu.");
  234. printf("\n network: netwok configuration menu.");
  235. printf("\n test: charger start/stop test.");
  236. printf("\n upgrade: trigger firmware upgrade.");
  237. printf("\n save: Save config.");
  238. printf("\n exit: Exit config tools.");
  239. printf("\n ==================================================");
  240. printf("\n Please input item name to config: ");
  241. scanf("%s", &cmd[0]);
  242. if(strcmp(cmd, "system") == 0)
  243. {
  244. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  245. printf("\n ***** system configuration menu ******************");
  246. printf("\n modelname: EVSE model name.");
  247. printf("\n serialnumber: EVSE serial number.");
  248. printf("\n authentication: Authentication function.");
  249. printf("\n authbyevccid: Authorize by EVCCID.");
  250. printf("\n rfidendian: RFID read endian.");
  251. printf("\n **************************************************");
  252. printf("\n Please input operation item: ");
  253. scanf("%s", &cmd[0]);
  254. if(strcmp(cmd, "modelname") == 0)
  255. {
  256. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  257. printf("\n ***** modelname **********************************");
  258. printf("\n Current model name: %s", ShmSysConfigAndInfo->SysConfig.ModelName);
  259. printf("\n 0: Keep current config.");
  260. printf("\n 1: Input new model name.");
  261. printf("\n **************************************************");
  262. printf("\n Please input operation item: ");
  263. scanf("%s", &cmd[0]);
  264. if(atoi(cmd) == 1)
  265. {
  266. printf("\n Please input model name: ");
  267. scanf("%s", &cmd[0]);
  268. memset(&ShmSysConfigAndInfo->SysConfig.ModelName[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.ModelName));
  269. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.ModelName[0], (char*)&cmd[0]);
  270. DEBUG_INFO("Input model name: %s\n", ShmSysConfigAndInfo->SysConfig.ModelName);
  271. }
  272. }
  273. else if(strcmp(cmd, "serialnumber") == 0)
  274. {
  275. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  276. printf("\n ***** serialnumber *******************************");
  277. printf("\n Current serial number: %s", ShmSysConfigAndInfo->SysConfig.SerialNumber);
  278. printf("\n 0: Keep current config.");
  279. printf("\n 1: Input new serial number.");
  280. printf("\n **************************************************");
  281. printf("\n Please input operation item: ");
  282. scanf("%s", &cmd[0]);
  283. if(atoi(cmd) == 1)
  284. {
  285. printf("\n Please input serial number: ");
  286. scanf("%s", &cmd[0]);
  287. memset(&ShmSysConfigAndInfo->SysConfig.SerialNumber[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.SerialNumber));
  288. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.SerialNumber[0], (char*)&cmd[0]);
  289. DEBUG_INFO("Input serial number: %s\n", ShmSysConfigAndInfo->SysConfig.SerialNumber);
  290. }
  291. }
  292. else if(strcmp(cmd, "authentication") == 0)
  293. {
  294. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  295. printf("\n ***** authentication *****************************");
  296. printf("\n Current mode: %d", ShmSysConfigAndInfo->SysConfig.AuthorisationMode);
  297. printf("\n 0: Enable.");
  298. printf("\n 1: Disable.");
  299. printf("\n **************************************************");
  300. printf("\n Please input authentication mode: ");
  301. scanf("%s", &cmd[0]);
  302. ShmSysConfigAndInfo->SysConfig.AuthorisationMode = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd):0);
  303. if(ShmSysConfigAndInfo->SysConfig.AuthorisationMode)
  304. DEBUG_INFO("Authentication: Disable\n");
  305. else
  306. DEBUG_INFO("Authentication: Enable\n");
  307. }
  308. else if(strcmp(cmd, "authbyevccid") == 0)
  309. {
  310. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  311. printf("\n ***** authbyevccid *******************************");
  312. printf("\n Current mode: %d", ShmSysConfigAndInfo->SysConfig.isAuthrizeByEVCCID);
  313. printf("\n 0: Disable.");
  314. printf("\n 1: Enable.");
  315. printf("\n **************************************************");
  316. printf("\n Please input authorize by EVCCID configuration value: ");
  317. scanf("%s", &cmd[0]);
  318. ShmSysConfigAndInfo->SysConfig.isAuthrizeByEVCCID = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd):0);
  319. if(!ShmSysConfigAndInfo->SysConfig.isAuthrizeByEVCCID)
  320. DEBUG_INFO("Authotize by EVCCID: Disable\n");
  321. else
  322. DEBUG_INFO("Authorize by EVCCID: Enable\n");
  323. }
  324. else if(strcmp(cmd, "rfidendian") == 0)
  325. {
  326. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  327. printf("\n ***** rfidendian *********************************");
  328. printf("\n Current mode: %d", ShmSysConfigAndInfo->SysConfig.RfidCardNumEndian);
  329. printf("\n 0: Little endian.");
  330. printf("\n 1: Big endian.");
  331. printf("\n **************************************************");
  332. printf("\n Please input rfid endian mode: ");
  333. scanf("%s", &cmd[0]);
  334. ShmSysConfigAndInfo->SysConfig.RfidCardNumEndian = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd):0);
  335. if(ShmSysConfigAndInfo->SysConfig.RfidCardNumEndian)
  336. DEBUG_INFO("Authentication: Little endian\n");
  337. else
  338. DEBUG_INFO("Authentication: Big endian\n");
  339. }
  340. }
  341. else if(strcmp(cmd, "ocpp") == 0)
  342. {
  343. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  344. printf("\n ***** ocpp ***************************************");
  345. printf("\n ocppurl: OCPP backend server url.");
  346. printf("\n ocppsecurity: OCPP backend server security profile.");
  347. printf("\n mtserverurl: Maintain backend server url.");
  348. printf("\n cboxid: Charger box id.");
  349. printf("\n vender: Charger point vender.");
  350. printf("\n offlinepolicy: Charger off line policy.");
  351. printf("\n localloadbalance: Charger local load balance.");
  352. printf("\n maintainurl: Maintain server url.");
  353. printf("\n maintainsecurity: Maintain server security profile.");
  354. printf("\n **************************************************");
  355. printf("\n Please input operation item: ");
  356. scanf("%s", &cmd[0]);
  357. if(strcmp(cmd, "ocppurl") == 0)
  358. {
  359. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  360. printf("\n ***** ocppurl ************************************");
  361. printf("\n Current OCPP url: %s", ShmSysConfigAndInfo->SysConfig.OcppServerURL);
  362. printf("\n 0: Keep current config.");
  363. printf("\n 1: Input new ocpp url.");
  364. printf("\n **************************************************");
  365. printf("\n Please input operation item: ");
  366. scanf("%s", &cmd[0]);
  367. if(atoi(cmd) == 1)
  368. {
  369. printf("\n Please input ocpp url: ");
  370. scanf("%s", &cmd[0]);
  371. memset(&ShmSysConfigAndInfo->SysConfig.OcppServerURL[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.OcppServerURL));
  372. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.OcppServerURL[0], (char*)&cmd[0]);
  373. DEBUG_INFO("Input ocpp url: %s\n", ShmSysConfigAndInfo->SysConfig.OcppServerURL);
  374. }
  375. }
  376. if(strcmp(cmd, "mtserverurl") == 0)
  377. {
  378. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  379. printf("\n ***** mtserverurl *********************************");
  380. printf("\n Current maintain server url: %s", ShmSysConfigAndInfo->SysConfig.MaintainServerURL);
  381. printf("\n 0: Keep current config.");
  382. printf("\n 1: Input new ocpp url.");
  383. printf("\n **************************************************");
  384. printf("\n Please input operation item: ");
  385. scanf("%s", &cmd[0]);
  386. if(atoi(cmd) == 1)
  387. {
  388. printf("\n Please input maintain server url: ");
  389. scanf("%s", &cmd[0]);
  390. memset(&ShmSysConfigAndInfo->SysConfig.MaintainServerURL[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.MaintainServerURL));
  391. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.MaintainServerURL[0], (char*)&cmd[0]);
  392. DEBUG_INFO("Input maintain server url: %s\n", ShmSysConfigAndInfo->SysConfig.MaintainServerURL);
  393. }
  394. }
  395. else if(strcmp(cmd, "ocppsecurity") == 0)
  396. {
  397. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  398. printf("\n ***** ocppsecurity *******************************");
  399. printf("\n Current OCPP security profile: %d", ShmSysConfigAndInfo->SysConfig.OcppSecurityProfile);
  400. printf("\n 0: Profile-0.");
  401. printf("\n 1: Profile-1.");
  402. printf("\n 2: Profile-2.");
  403. printf("\n 3: Profile-3.");
  404. printf("\n **************************************************");
  405. printf("\n Please input OCPP security profile: ");
  406. scanf("%s", &cmd[0]);
  407. ShmSysConfigAndInfo->SysConfig.OcppSecurityProfile = ((0<=atoi(cmd))&&(atoi(cmd)<=3)&&(atoi(cmd)!=1)?atoi(cmd):0);
  408. DEBUG_INFO("OCPP security profile: %d.\n");
  409. }
  410. else if(strcmp(cmd, "cboxid") == 0)
  411. {
  412. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  413. printf("\n ***** cboxid *************************************");
  414. printf("\n Current OCPP charger box id: %s", ShmSysConfigAndInfo->SysConfig.ChargeBoxId);
  415. printf("\n 0: Keep current config.");
  416. printf("\n 1: Input new charger box id.");
  417. printf("\n **************************************************");
  418. printf("\n Please input operation item: ");
  419. scanf("%s", &cmd[0]);
  420. if(atoi(cmd) == 1)
  421. {
  422. printf("\n Please input OCPP charger box id: ");
  423. scanf("%s", &cmd[0]);
  424. memset(&ShmSysConfigAndInfo->SysConfig.ChargeBoxId[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.ChargeBoxId));
  425. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.ChargeBoxId[0], (char*)&cmd[0]);
  426. DEBUG_INFO("Input ocpp charger box id: %s\n", ShmSysConfigAndInfo->SysConfig.ChargeBoxId);
  427. }
  428. }
  429. else if(strcmp(cmd, "vender") == 0)
  430. {
  431. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  432. printf("\n ***** vender *************************************");
  433. printf("\n Current OCPP vender: %s", ShmSysConfigAndInfo->SysConfig.chargePointVendor);
  434. printf("\n 0: Keep current config.");
  435. printf("\n 1: Input new charger box id.");
  436. printf("\n **************************************************");
  437. printf("\n Please input operation item: ");
  438. scanf("%s", &cmd[0]);
  439. if(atoi(cmd) == 1)
  440. {
  441. printf("\n Please input OCPP vender: ");
  442. scanf("%s", &cmd[0]);
  443. memset(&ShmSysConfigAndInfo->SysConfig.chargePointVendor[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.chargePointVendor));
  444. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.chargePointVendor[0], (char*)&cmd[0]);
  445. DEBUG_INFO("Input ocpp vender: %s\n", ShmSysConfigAndInfo->SysConfig.chargePointVendor);
  446. }
  447. }
  448. else if(strcmp(cmd, "offlinepolicy") == 0)
  449. {
  450. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  451. printf("\n ***** offlinepolicy ******************************");
  452. printf("\n Current off line policy: %d", ShmSysConfigAndInfo->SysConfig.OfflinePolicy);
  453. printf("\n 0: Local list.");
  454. printf("\n 2: Free charging.");
  455. printf("\n 3: Deny charging.");
  456. printf("\n **************************************************");
  457. printf("\n Please input off line policy mode: ");
  458. scanf("%s", &cmd[0]);
  459. ShmSysConfigAndInfo->SysConfig.OfflinePolicy = ((0<=atoi(cmd))&&(atoi(cmd)<=3)&&(atoi(cmd)!=1)?atoi(cmd):0);
  460. switch(ShmSysConfigAndInfo->SysConfig.OfflinePolicy)
  461. {
  462. case 0:
  463. DEBUG_INFO("Off line policy: Local list.\n");
  464. break;
  465. case 2:
  466. DEBUG_INFO("Off line policy: Free charging.\n");
  467. break;
  468. case 3:
  469. DEBUG_INFO("Off line policy: Deny charging.\n");
  470. break;
  471. }
  472. }
  473. else if(strcmp(cmd, "localloadbalance") == 0)
  474. {
  475. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  476. printf("\n ***** localloadbalance ***************************");
  477. printf("\n Current local loading balance: %d", ShmSysConfigAndInfo->SysConfig.isEnableLocalPowerSharing);
  478. printf("\n 0: Disable.");
  479. printf("\n 1: Enable.");
  480. printf("\n **************************************************");
  481. printf("\n Please input local load balance mode: ");
  482. scanf("%s", &cmd[0]);
  483. ShmSysConfigAndInfo->SysConfig.isEnableLocalPowerSharing = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd):0);
  484. if(ShmSysConfigAndInfo->SysConfig.isEnableLocalPowerSharing)
  485. DEBUG_INFO("Local loading balance: Enable\n");
  486. else
  487. DEBUG_INFO("Local loading balance: Disable\n");
  488. }
  489. else if(strcmp(cmd, "maintainurl") == 0)
  490. {
  491. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  492. printf("\n ***** maintainurl *********************************");
  493. printf("\n Current maintain url: %s", ShmSysConfigAndInfo->SysConfig.MaintainServerURL);
  494. printf("\n 0: Keep current config.");
  495. printf("\n 1: Input new maintain url.");
  496. printf("\n **************************************************");
  497. printf("\n Please input operation item: ");
  498. scanf("%s", &cmd[0]);
  499. if(atoi(cmd) == 1)
  500. {
  501. printf("\n Please input maintain url: ");
  502. scanf("%s", &cmd[0]);
  503. memset(&ShmSysConfigAndInfo->SysConfig.MaintainServerURL[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.MaintainServerURL));
  504. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.MaintainServerURL[0], (char*)&cmd[0]);
  505. DEBUG_INFO("Input maintain url: %s\n", ShmSysConfigAndInfo->SysConfig.MaintainServerURL);
  506. }
  507. }
  508. else if(strcmp(cmd, "maintainsecurity") == 0)
  509. {
  510. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  511. printf("\n ***** maintainsecurity ****************************");
  512. printf("\n Current maintain security profile: %d", ShmSysConfigAndInfo->SysConfig.MaintainServerSecurityProfile);
  513. printf("\n 0: Profile-0.");
  514. printf("\n 1: Profile-1.");
  515. printf("\n 2: Profile-2.");
  516. printf("\n 3: Profile-3.");
  517. printf("\n **************************************************");
  518. printf("\n Please input maintain security profile: ");
  519. scanf("%s", &cmd[0]);
  520. ShmSysConfigAndInfo->SysConfig.MaintainServerSecurityProfile = ((0<=atoi(cmd))&&(atoi(cmd)<=3)&&(atoi(cmd)!=1)?atoi(cmd):0);
  521. DEBUG_INFO("Maintain security profile: %d.\n");
  522. }
  523. }
  524. else if(strcmp(cmd, "network") == 0)
  525. {
  526. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  527. printf("\n ***** network *************************************");
  528. printf("\n ethdhcp: Ethernet DHCP client.");
  529. printf("\n wifimode: WiFi mode.");
  530. printf("\n wifidhcp: WiFi DHCP client.");
  531. printf("\n wificssid: WiFi client SSID.");
  532. printf("\n wificpasswd: WiFi client password.");
  533. printf("\n telemode: Telecomm mode.");
  534. printf("\n teleapn: Telecomm APN.");
  535. printf("\n teleid: Telecomm login id.");
  536. printf("\n telepwd: Telecomm login password.");
  537. printf("\n firewallEnable: Firewall enable/disable.");
  538. printf("\n firewallRule: Firewall accepted list.");
  539. printf("\n **************************************************");
  540. printf("\n Please input operation item: ");
  541. scanf("%s", &cmd[0]);
  542. if(strcmp(cmd, "ethdhcp") == 0)
  543. {
  544. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  545. printf("\n ***** ethdhcp ************************************");
  546. printf("\n Current ethernet dhcp mode: %d", ShmSysConfigAndInfo->SysConfig.Eth0Interface.EthDhcpClient^1);
  547. printf("\n 0: Disable.");
  548. printf("\n 1: Enable.");
  549. printf("\n **************************************************");
  550. printf("\n Please input dhcp mode: ");
  551. scanf("%s", &cmd[0]);
  552. ShmSysConfigAndInfo->SysConfig.Eth0Interface.EthDhcpClient = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd)^1:0);
  553. if(ShmSysConfigAndInfo->SysConfig.Eth0Interface.EthDhcpClient)
  554. DEBUG_INFO("Ethernet dhcp client: Disable\n");
  555. else
  556. DEBUG_INFO("Ethernet dhcp client: Enable\n");
  557. }
  558. else if(strcmp(cmd, "wifimode") == 0)
  559. {
  560. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  561. printf("\n ***** wifimode ***********************************");
  562. printf("\n Current WiFi mode: %d", ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode);
  563. printf("\n 0: Disable.");
  564. printf("\n 1: Station.");
  565. printf("\n 2: Access point.");
  566. printf("\n **************************************************");
  567. printf("\n Please input WiFi mode: ");
  568. scanf("%s", &cmd[0]);
  569. ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode = ((0<=atoi(cmd))&&(atoi(cmd)<=2)?atoi(cmd):0);
  570. switch(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode)
  571. {
  572. case 0:
  573. DEBUG_INFO("Wifi mode: Disable.\n");
  574. break;
  575. case 1:
  576. DEBUG_INFO("Wifi mode: Station.\n");
  577. break;
  578. case 2:
  579. DEBUG_INFO("Wifi mode: AP.\n");
  580. break;
  581. }
  582. }
  583. else if(strcmp(cmd, "wifidhcp") == 0)
  584. {
  585. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  586. printf("\n ***** wifidhcp ***********************************");
  587. printf("\n Current WiFi dhcp client mode: %d", ShmSysConfigAndInfo->SysConfig.AthInterface.WifiDhcpClient^1);
  588. printf("\n 0: Disable.");
  589. printf("\n 1: Enable.");
  590. printf("\n **************************************************");
  591. printf("\n Please input WiFi mode: ");
  592. scanf("%s", &cmd[0]);
  593. ShmSysConfigAndInfo->SysConfig.AthInterface.WifiDhcpClient = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd)^1:0);
  594. if(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiDhcpClient)
  595. DEBUG_INFO("Wifi dhcp client: Disable\n");
  596. else
  597. DEBUG_INFO("Wifi dhcp client: Enable\n");
  598. }
  599. else if(strcmp(cmd, "wificssid") == 0)
  600. {
  601. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  602. printf("\n ***** wificssid **********************************");
  603. printf("\n Current WiFi client SSID: %s", ShmSysConfigAndInfo->SysConfig.AthInterface.WifiSsid);
  604. printf("\n 0: Keep current config.");
  605. printf("\n 1: Input new WiFi client SSID.");
  606. printf("\n **************************************************");
  607. printf("\n Please input operation item: ");
  608. scanf("%s", &cmd[0]);
  609. if(atoi(cmd) == 1)
  610. {
  611. printf("\n Please input WiFi client SSID: ");
  612. scanf("%s", &cmd[0]);
  613. memset(&ShmSysConfigAndInfo->SysConfig.AthInterface.WifiSsid[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiSsid));
  614. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.AthInterface.WifiSsid[0], (char*)&cmd[0]);
  615. DEBUG_INFO("Wifi client SSID: %s\n", ShmSysConfigAndInfo->SysConfig.AthInterface.WifiSsid);
  616. }
  617. }
  618. else if(strcmp(cmd, "wificpasswd") == 0)
  619. {
  620. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  621. printf("\n ***** wificpasswd ********************************");
  622. printf("\n Current WiFi client password: %s", ShmSysConfigAndInfo->SysConfig.AthInterface.WifiPassword);
  623. printf("\n 0: Keep current config.");
  624. printf("\n 1: Input new WiFi client password.");
  625. printf("\n **************************************************");
  626. printf("\n Please input operation item: ");
  627. scanf("%s", &cmd[0]);
  628. if(atoi(cmd) == 1)
  629. {
  630. printf("\n Please input WiFi client password: ");
  631. scanf("%s", &cmd[0]);
  632. memset(&ShmSysConfigAndInfo->SysConfig.AthInterface.WifiPassword[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiPassword));
  633. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.AthInterface.WifiPassword[0], (char*)&cmd[0]);
  634. DEBUG_INFO("Wifi client password: %s\n", ShmSysConfigAndInfo->SysConfig.AthInterface.WifiPassword);
  635. }
  636. }
  637. else if(strcmp(cmd, "telemode") == 0)
  638. {
  639. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  640. printf("\n ***** telemode ***********************************");
  641. printf("\n 0: Disable.");
  642. printf("\n 1: Enable.");
  643. printf("\n **************************************************");
  644. printf("\n Current telecomm mode: %d", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomModemMode^1);
  645. printf("\n Please input telecomm mode: ");
  646. scanf("%s", &cmd[0]);
  647. ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomModemMode = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd)^1:0);
  648. if(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomModemMode)
  649. DEBUG_INFO("Wifi dhcp client: Disable\n");
  650. else
  651. DEBUG_INFO("Wifi dhcp client: Enable\n");
  652. }
  653. else if(strcmp(cmd, "teleapn") == 0)
  654. {
  655. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  656. printf("\n ***** teleapn ************************************");
  657. printf("\n Current telecomm APN: %s", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomApn);
  658. printf("\n 0: Keep current config.");
  659. printf("\n 1: Input new telecomm APN.");
  660. printf("\n **************************************************");
  661. printf("\n Please input operation item: ");
  662. scanf("%s", &cmd[0]);
  663. if(atoi(cmd) == 1)
  664. {
  665. printf("\n Please input telecomm APN: ");
  666. scanf("%s", &cmd[0]);
  667. memset(&ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomApn[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomApn));
  668. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomApn[0], (char*)&cmd[0]);
  669. DEBUG_INFO("Telecomm APN: %s\n", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomApn);
  670. }
  671. }
  672. else if(strcmp(cmd, "teleid") == 0)
  673. {
  674. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  675. printf("\n ***** teleid *************************************");
  676. printf("\n Current telecomm login id: %s", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapId);
  677. printf("\n 0: Keep current config.");
  678. printf("\n 1: Input new telecomm login id.");
  679. printf("\n **************************************************");
  680. printf("\n Please input operation item: ");
  681. scanf("%s", &cmd[0]);
  682. if(atoi(cmd) == 1)
  683. {
  684. printf("\n Please input telecomm login id: ");
  685. scanf("%s", &cmd[0]);
  686. memset(&ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapId[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapId));
  687. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapId[0], (char*)&cmd[0]);
  688. DEBUG_INFO("Telecomm CHAP id: %s\n", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapId);
  689. }
  690. }
  691. else if(strcmp(cmd, "telepwd") == 0)
  692. {
  693. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  694. printf("\n ***** telepwd ************************************");
  695. printf("\n Current telecomm login password: %s", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapPwd);
  696. printf("\n 0: Keep current config.");
  697. printf("\n 1: Input new telecomm login password.");
  698. printf("\n **************************************************");
  699. printf("\n Please input operation item: ");
  700. scanf("%s", &cmd[0]);
  701. if(atoi(cmd) == 1)
  702. {
  703. printf("\n Please input telecomm login password: ");
  704. scanf("%s", &cmd[0]);
  705. memset(&ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapPwd[0], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapPwd));
  706. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapPwd[0], (char*)&cmd[0]);
  707. DEBUG_INFO("Telecomm CHAP password: %s\n", ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomChapPapPwd);
  708. }
  709. }
  710. else if(strcmp(cmd, "firewallEnable") == 0)
  711. {
  712. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  713. printf("\n ***** firewallEnable *****************************");
  714. printf("\n Current firewall mode: %d", ShmSysConfigAndInfo->SysConfig.isEnalbleFirewall);
  715. printf("\n 0: Disable.");
  716. printf("\n 1: Enable.");
  717. printf("\n **************************************************");
  718. printf("\n Please input firewall mode: ");
  719. scanf("%s", &cmd[0]);
  720. ShmSysConfigAndInfo->SysConfig.isEnalbleFirewall = ((0<=atoi(cmd))&&(atoi(cmd)<=1)?atoi(cmd):0);
  721. if(ShmSysConfigAndInfo->SysConfig.isEnalbleFirewall)
  722. DEBUG_INFO("Firewall mode: Enable\n");
  723. else
  724. DEBUG_INFO("Firewall mode: Disable\n");
  725. }
  726. else if(strcmp(cmd, "firewallRule") == 0)
  727. {
  728. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  729. printf("\n ***** firewallRule ************************************");
  730. for(uint8_t idx=0;idx<ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.FirewallAcceptAddr);idx++)
  731. printf("\n %d Accepted address-%d: %s", idx, idx, ShmSysConfigAndInfo->SysConfig.FirewallAcceptAddr[idx]);
  732. printf("\n **************************************************");
  733. printf("\n Please select item change: ");
  734. scanf("%s", &cmd[0]);
  735. uint8_t idxList = atoi(cmd);
  736. printf("\n Please input accepted address: ");
  737. scanf("%s", &cmd[0]);
  738. memset(&ShmSysConfigAndInfo->SysConfig.FirewallAcceptAddr[idxList], 0x00, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.FirewallAcceptAddr[idxList]));
  739. strcpy((char*)&ShmSysConfigAndInfo->SysConfig.FirewallAcceptAddr[idxList], (char*)&cmd[0]);
  740. DEBUG_INFO("Input accepted address-%d: %s\n", idxList, ShmSysConfigAndInfo->SysConfig.FirewallAcceptAddr[idxList]);
  741. }
  742. }
  743. else if(strcmp(cmd, "test") == 0)
  744. {
  745. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  746. printf("\n ***** test menu **********************************");
  747. printf("\n start: EVSE start charging request.");
  748. printf("\n stop: EVSE stop charging request.");
  749. printf("\n auth: Authorize request.");
  750. printf("\n ccs: CCS flow status.");
  751. printf("\n alarm: Simulate alarm status.");
  752. printf("\n cancel: return to main menu.");
  753. printf("\n **************************************************");
  754. printf("\n Please input operation item: ");
  755. scanf("%s", &cmd[0]);
  756. if(strcmp(cmd, "start") == 0)
  757. {
  758. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  759. printf("\n Please input gun index(1~2): ");
  760. scanf("%s", &cmd[0]);
  761. if((0 < atoi(cmd)) && (atoi(cmd) < 3))
  762. {
  763. ShmSysConfigAndInfo->SysInfo.AcChargingData[atoi(cmd)-1].schedule.isTriggerStart = ON;
  764. DEBUG_INFO("Test start gun-%d, start charging session.\n", atoi(cmd));
  765. }
  766. else
  767. {
  768. printf("\n Invalid input gun_index.");
  769. }
  770. }
  771. else if(strcmp(cmd, "stop") == 0)
  772. {
  773. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  774. printf("\n Please input gun index(1~2): ");
  775. scanf("%s", &cmd[0]);
  776. if((0 < atoi(cmd)) && (atoi(cmd) < 3))
  777. {
  778. ShmSysConfigAndInfo->SysInfo.AcChargingData[atoi(cmd)-1].schedule.isTriggerStop = ON;
  779. DEBUG_INFO("Test start gun-%d, stop charging session.\n", atoi(cmd));
  780. }
  781. else
  782. {
  783. printf("\n Invalid input gun_index.");
  784. }
  785. }
  786. else if(strcmp(cmd, "auth") == 0)
  787. {
  788. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  789. printf("\n Please input idtag: ");
  790. scanf("%s", &cmd[0]);
  791. sprintf((char*)ShmSysConfigAndInfo->SysConfig.UserId, "%s", cmd);
  792. ShmOCPP16Data->SpMsg.bits.AuthorizeReq = ON;
  793. DEBUG_INFO("Test authentication by %s.\n", ShmSysConfigAndInfo->SysConfig.UserId);
  794. }
  795. else if(strcmp(cmd, "ccs") == 0)
  796. {
  797. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  798. printf("\n Please input gun index(1~2): ");
  799. scanf("%s", &cmd[0]);
  800. if((0 < atoi(cmd)) && (atoi(cmd) < 3))
  801. {
  802. uint8_t gun_index = atoi(cmd)-1;
  803. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  804. printf("\n ***** ccs ****************************************");
  805. printf("\n ccs_hs_status: CCS hand shake status.");
  806. printf("\n cancel: return to main menu.");
  807. printf("\n **************************************************");
  808. printf("\n Please input operation item: ");
  809. scanf("%s", &cmd[0]);
  810. if(strcmp(cmd, "ccs_hs_status") == 0)
  811. {
  812. printf("\n ***** ccs_hs_status *******************************");
  813. printf("\n Current ccs_hs_status: %d", ShmCharger->gun_info[gun_index].ccsHandshakeState);
  814. printf("\n 1: HANDSHAKE_DUTY_5.");
  815. printf("\n 2: HANDSHAKE_DUTY_5_CHECK.");
  816. printf("\n 3: HANDSHAKE_CCS.");
  817. printf("\n 4: HANDSHAKE_CP_STATE_E.");
  818. printf("\n 5: HANDSHAKE_SET_MAX_CURRENT.");
  819. printf("\n 6: HANDSHAKE_BS_MODE.");
  820. printf("\n 7: HANDSHAKE_HLC_MODE.");
  821. printf("\n **************************************************");
  822. printf("\n Please input operation item: ");
  823. scanf("%s", &cmd[0]);
  824. if((0 < atoi(cmd)) && (atoi(cmd) < 9))
  825. {
  826. ShmCharger->gun_info[gun_index].ccsHandshakeState = atoi(cmd);
  827. DEBUG_INFO("Gun-%d CCS hand shake state: %d.\n", gun_index, ShmCharger->gun_info[gun_index].ccsHandshakeState);
  828. }
  829. else
  830. printf("\n Invalid hand shake state.");
  831. }
  832. }
  833. else
  834. {
  835. printf("\n Invalid input gun_index.");
  836. }
  837. }
  838. else if(strcmp(cmd, "alarm") == 0)
  839. {
  840. memset(cmd, 0x00, ARRAY_SIZE(cmd));
  841. printf("\n Please input gun index(1~2): ");
  842. scanf("%s", &cmd[0]);
  843. if((0 < atoi(cmd)) && (atoi(cmd) < 3))
  844. {
  845. DEBUG_INFO("Alarm simulate gun-%d, emergency stop.\n", atoi(cmd));
  846. while(1)
  847. {
  848. ShmCharger->gun_info[atoi(cmd)-1].systemAlarmCode.SystemAlarmCode |= ALARM_EMERGENCY_STOP;
  849. ShmCharger->gun_info[atoi(cmd)-1].primaryMcuAlarm.InputAlarmCode |= ALARM_EMERGENCY_STOP;
  850. }
  851. }
  852. else
  853. {
  854. printf("\n Invalid input gun_index.");
  855. sleep(1);
  856. }
  857. }
  858. else if(strcmp(cmd, "cancel") == 0)
  859. {}
  860. }
  861. else if(strcmp(cmd, "upgrade") == 0)
  862. {
  863. printf("\n Firmware upgrade trigger.");
  864. ShmSysConfigAndInfo->SysInfo.FirmwareUpdate = ON;
  865. DEBUG_INFO("Trigger firmware upgrade.\n");
  866. sleep(2);
  867. }
  868. else if(strcmp(cmd, "save") == 0)
  869. {
  870. if(StoreUsrConfigData(&ShmSysConfigAndInfo->SysConfig) != PASS)
  871. {
  872. printf("\n Write configuration fail.\r\n");
  873. }
  874. else
  875. {
  876. printf("\n Write configuration OK.\r\n");
  877. DEBUG_INFO("Save configuration.\n");
  878. }
  879. sleep(2);
  880. }
  881. else if(strcmp(cmd, "exit") == 0)
  882. {
  883. printf("\n exit program.\n\n");
  884. DEBUG_INFO("Exit configuration tools.\n");
  885. return FAIL;
  886. }
  887. }
  888. return -1;
  889. }