Module_EvComm.c 193 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603
  1. #include <sys/time.h>
  2. #include <sys/timeb.h>
  3. #include <sys/types.h>
  4. #include <sys/stat.h>
  5. #include <sys/types.h>
  6. #include <sys/ioctl.h>
  7. #include <sys/socket.h>
  8. #include <sys/ipc.h>
  9. #include <sys/shm.h>
  10. #include <sys/shm.h>
  11. #include <sys/mman.h>
  12. #include <linux/can.h>
  13. #include <linux/can/raw.h>
  14. #include <linux/wireless.h>
  15. #include <arpa/inet.h>
  16. #include <netinet/in.h>
  17. #include <unistd.h>
  18. #include <stdarg.h>
  19. #include <stdio.h> /*標準輸入輸出定義*/
  20. #include <stdlib.h> /*標準函數庫定義*/
  21. #include <unistd.h> /*Unix 標準函數定義*/
  22. #include <fcntl.h> /*檔控制定義*/
  23. #include <termios.h> /*PPSIX 終端控制定義*/
  24. #include <errno.h> /*錯誤號定義*/
  25. #include <errno.h>
  26. #include <string.h>
  27. #include <time.h>
  28. #include <ctype.h>
  29. #include <ifaddrs.h>
  30. #include "../../define.h"
  31. #include "Module_EvComm.h"
  32. #define ARRAY_SIZE(A) (sizeof(A) / sizeof(A[0]))
  33. #define PASS 1
  34. #define FAIL -1
  35. #define START 1
  36. #define STOP 0
  37. #define COMMUNICATION 2
  38. #define YES 1
  39. #define NO 0
  40. #define EQUAL 0
  41. struct SysConfigAndInfo *ShmSysConfigAndInfo;
  42. struct StatusCodeData *ShmStatusCodeData;
  43. struct FanModuleData *ShmFanModuleData;
  44. struct CHAdeMOData *ShmCHAdeMOData;
  45. struct GBTData *ShmGBTData;
  46. struct CcsData *ShmCcsData;
  47. byte gun_count;
  48. int chargingTime[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  49. float _pow_1 = 0;
  50. float _cur_1 = 0;
  51. float _pow_2 = 0;
  52. float _cur_2 = 0;
  53. float _outVol_1 = 0;
  54. float _outCur_1 = 0;
  55. float _outVol_2 = 0;
  56. float _outCur_2 = 0;
  57. // 限制最大充電電壓,因應不同 type 槍線來限制
  58. // Chademo : 500V, 125A,
  59. // GB : 750, 120A
  60. // CCS : 950V, 120A
  61. float maxChargingVol[2] = { 9500, 9500 }; // 限制最大充電電壓,如依照模塊則填上 0
  62. // 限制最大充電電流與能量透過 Web
  63. float maxChargingCur[2] = { 600, 600 }; // 限制最大充電電流,如依照模塊則填上 0
  64. float maxChargingPow = 0; // 限制最大充電能量,如依照模塊則填上 0
  65. // 槍資訊
  66. struct ChargingInfoData *_chargingData[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  67. struct timeval _chk_ratingPower_timeout[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  68. struct timeval _chk_chademo_permission_timeout[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  69. bool chkChademoPermission[2] = { false, false };
  70. struct Ev_Board_Cmd Ev_Cmd={
  71. 0,
  72. 0x00000200,
  73. 0x00000400,
  74. 0x00000500,
  75. 0x00000600,
  76. 0x00000700,
  77. 0x00000800,
  78. 0x00000900,
  79. 0x00000A00,
  80. 0x00000C00,
  81. 0x00000D00,
  82. 0x00000E00,
  83. 0x00000F00,
  84. 0x00001000,
  85. 0x00001100,
  86. 0x00001200,
  87. 0x00001400,
  88. 0x00001500,
  89. };
  90. unsigned char mask_table[] = { 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80 };
  91. void PRINTF_FUNC(char *string, ...);
  92. void GetMaxVolAndCurMethod(byte index, float *vol, float *cur);
  93. void GetMaxPowerMethod(byte index, float *pow);
  94. unsigned long GetTimeoutValue(struct timeval _sour_time);
  95. #define DEBUG_INFO(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  96. #define DEBUG_WARN(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  97. #define DEBUG_ERROR(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  98. unsigned long GetTimeoutValue(struct timeval _sour_time)
  99. {
  100. struct timeval _end_time;
  101. gettimeofday(&_end_time, NULL);
  102. return 1000000 * (_end_time.tv_sec - _sour_time.tv_sec) + _end_time.tv_usec - _sour_time.tv_usec;
  103. }
  104. int StoreLogMsg(const char *fmt, ...)
  105. {
  106. char Buf[4096+256];
  107. char buffer[4096];
  108. va_list args;
  109. struct timeb SeqEndTime;
  110. struct tm *tm;
  111. va_start(args, fmt);
  112. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  113. va_end(args);
  114. memset(Buf,0,sizeof(Buf));
  115. ftime(&SeqEndTime);
  116. SeqEndTime.time = time(NULL);
  117. tm=localtime(&SeqEndTime.time);
  118. if (ShmSysConfigAndInfo->SysConfig.SwitchDebugFlag == YES)
  119. {
  120. sprintf(Buf,"%02d:%02d:%02d.%03d - %s",
  121. tm->tm_hour,tm->tm_min,tm->tm_sec,SeqEndTime.millitm, buffer);
  122. printf("%s \n", Buf);
  123. }
  124. else
  125. {
  126. sprintf(Buf,"echo \"%04d-%02d-%02d %02d:%02d:%02d.%03d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog",
  127. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,SeqEndTime.millitm,
  128. buffer,
  129. tm->tm_year+1900,tm->tm_mon+1);
  130. system(Buf);
  131. }
  132. return rc;
  133. }
  134. int DiffTimeb(struct timeb ST, struct timeb ET)
  135. {
  136. //return milli-second
  137. unsigned int StartTime,StopTime;
  138. StartTime=(unsigned int)ST.time;
  139. StopTime=(unsigned int)ET.time;
  140. return (StopTime-StartTime)*1000+ET.millitm-ST.millitm;
  141. }
  142. void PRINTF_FUNC(char *string, ...)
  143. {
  144. va_list args;
  145. char buffer[4096];
  146. va_start(args, string);
  147. vsnprintf(buffer, sizeof(buffer), string, args);
  148. va_end(args);
  149. DEBUG_INFO("%s \n", buffer);
  150. }
  151. //=================================
  152. // Common routine
  153. //=================================
  154. void getTimeString(char *buff)
  155. {
  156. time_t timep;
  157. struct tm *p;
  158. time(&timep);
  159. p=gmtime(&timep);
  160. sprintf(buff, "[%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);
  161. }
  162. bool CheckUniqNumber(byte value)
  163. {
  164. for (byte index = 0; index < gun_count; index++)
  165. {
  166. if (_chargingData[index]->Evboard_id == value)
  167. {
  168. struct timeval _end_time;
  169. gettimeofday(&_end_time, NULL);
  170. unsigned long diff = 1000000 * (_end_time.tv_sec - _id_assign_time.tv_sec) + _end_time.tv_usec - _id_assign_time.tv_usec;
  171. if (diff >= 3000000)
  172. {
  173. gettimeofday(&_id_assign_time, NULL);
  174. return true;
  175. }
  176. else
  177. {
  178. return false;
  179. }
  180. }
  181. }
  182. gettimeofday(&_id_assign_time, NULL);
  183. return true;
  184. }
  185. //==========================================
  186. // Init all share memory
  187. //==========================================
  188. int InitShareMemory()
  189. {
  190. int result = PASS;
  191. int MeterSMId;
  192. //initial ShmSysConfigAndInfo
  193. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0)
  194. {
  195. #ifdef SystemLogMessage
  196. DEBUG_ERROR("shmget ShmSysConfigAndInfo NG\n");
  197. #endif
  198. result = FAIL;
  199. }
  200. else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  201. {
  202. #ifdef SystemLogMessage
  203. DEBUG_ERROR("shmat ShmSysConfigAndInfo NG\n");
  204. #endif
  205. result = FAIL;
  206. }
  207. else
  208. {}
  209. //initial ShmStatusCodeData
  210. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0)
  211. {
  212. #ifdef SystemLogMessage
  213. DEBUG_ERROR("shmget ShmStatusCodeData NG\n");
  214. #endif
  215. result = FAIL;
  216. }
  217. else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  218. {
  219. #ifdef SystemLogMessage
  220. DEBUG_ERROR("shmat ShmStatusCodeData NG\n");
  221. #endif
  222. result = FAIL;
  223. }
  224. else
  225. {}
  226. if(CHAdeMO_QUANTITY > 0)
  227. {
  228. if ((MeterSMId = shmget(ShmCHAdeMOCommKey, sizeof(struct CHAdeMOData), IPC_CREAT | 0777)) < 0)
  229. {
  230. #ifdef SystemLogMessage
  231. DEBUG_ERROR("[shmget ShmCHAdeMOData NG \n");
  232. #endif
  233. return FAIL;
  234. }
  235. else if ((ShmCHAdeMOData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  236. {
  237. #ifdef SystemLogMessage
  238. DEBUG_ERROR("shmat ShmCHAdeMOData NG \n");
  239. #endif
  240. return FAIL;
  241. }
  242. else
  243. {}
  244. }
  245. if(GB_QUANTITY > 0)
  246. {
  247. if ((MeterSMId = shmget(ShmGBTCommKey, sizeof(struct GBTData), IPC_CREAT | 0777)) < 0)
  248. {
  249. #ifdef SystemLogMessage
  250. DEBUG_ERROR("[shmget ShmGBTData NG \n");
  251. #endif
  252. return FAIL;
  253. }
  254. else if ((ShmGBTData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  255. {
  256. #ifdef SystemLogMessage
  257. DEBUG_ERROR("shmat ShmGBTData NG \n");
  258. #endif
  259. return FAIL;
  260. }
  261. else
  262. {}
  263. }
  264. if(CCS_QUANTITY > 0)
  265. {
  266. if ((MeterSMId = shmget(ShmCcsCommKey, sizeof(struct CcsData), IPC_CREAT | 0777)) < 0)
  267. {
  268. #ifdef SystemLogMessage
  269. DEBUG_ERROR("shmget ShmCcsData NG \n");
  270. #endif
  271. return FAIL;
  272. }
  273. else if ((ShmCcsData = shmat(MeterSMId, NULL, 0)) == (void *) -1) {
  274. #ifdef SystemLogMessage
  275. DEBUG_ERROR("shmat ShmCcsData NG \n");
  276. #endif
  277. return FAIL;
  278. }
  279. else
  280. {}
  281. }
  282. return result;
  283. }
  284. //================================================
  285. // initial can-bus
  286. //================================================
  287. int InitCanBus()
  288. {
  289. int s0,nbytes;
  290. struct timeval tv;
  291. struct ifreq ifr0;
  292. struct sockaddr_can addr0;
  293. system("/sbin/ip link set can0 down");
  294. system("/sbin/ip link set can0 type can bitrate 500000 restart-ms 100");
  295. system("/sbin/ip link set can0 up");
  296. s0 = socket(PF_CAN, SOCK_RAW, CAN_RAW);
  297. tv.tv_sec = 0;
  298. tv.tv_usec = 10000;
  299. if (setsockopt(s0, SOL_SOCKET, SO_RCVTIMEO, (char *)&tv, sizeof(struct timeval)) < 0)
  300. {
  301. #ifdef SystemLogMessage
  302. DEBUG_ERROR("Set SO_RCVTIMEO NG");
  303. #endif
  304. }
  305. nbytes=40960;
  306. if (setsockopt(s0, SOL_SOCKET, SO_RCVBUF, &nbytes, sizeof(int)) < 0)
  307. {
  308. #ifdef SystemLogMessage
  309. DEBUG_ERROR("Set SO_RCVBUF NG");
  310. #endif
  311. }
  312. nbytes=40960;
  313. if (setsockopt(s0, SOL_SOCKET, SO_SNDBUF, &nbytes, sizeof(int)) < 0)
  314. {
  315. #ifdef SystemLogMessage
  316. DEBUG_ERROR("Set SO_SNDBUF NG");
  317. #endif
  318. }
  319. strcpy(ifr0.ifr_name, "can0" );
  320. ioctl(s0, SIOCGIFINDEX, &ifr0); /* ifr.ifr_ifindex gets filled with that device's index */
  321. addr0.can_family = AF_CAN;
  322. addr0.can_ifindex = ifr0.ifr_ifindex;
  323. bind(s0, (struct sockaddr *)&addr0, sizeof(addr0));
  324. return s0;
  325. }
  326. //================================================
  327. //================================================
  328. // CANBUS receive task
  329. //================================================
  330. //================================================
  331. bool FindChargingInfoData(byte target, struct ChargingInfoData **chargingData)
  332. {
  333. for (byte index = 0; index < CHAdeMO_QUANTITY; index++)
  334. {
  335. if (ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index].Index == target)
  336. {
  337. chargingData[target] = &ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index];
  338. return true;
  339. }
  340. }
  341. for (byte index = 0; index < CCS_QUANTITY; index++)
  342. {
  343. if (ShmSysConfigAndInfo->SysInfo.CcsChargingData[index].Index == target)
  344. {
  345. chargingData[target] = &ShmSysConfigAndInfo->SysInfo.CcsChargingData[index];
  346. return true;
  347. }
  348. }
  349. for (byte index = 0; index < GB_QUANTITY; index++)
  350. {
  351. if (ShmSysConfigAndInfo->SysInfo.GbChargingData[index].Index == target)
  352. {
  353. chargingData[target] = &ShmSysConfigAndInfo->SysInfo.GbChargingData[index];
  354. return true;
  355. }
  356. }
  357. return false;
  358. }
  359. void AddrAssignment(byte *data)
  360. {
  361. byte target_number[8];
  362. byte index = 0x00;
  363. memcpy(target_number, data, sizeof(target_number));
  364. index = *(data + 4);
  365. if (gun_count == 1)
  366. index = 0x01;
  367. // if (CheckUniqNumber(index))
  368. {
  369. PRINTF_FUNC("EV board id = %x \n", index);
  370. // PRINTF_FUNC("target_number[0] = %x \n", target_number[0]);
  371. // PRINTF_FUNC("target_number[1] = %x \n", target_number[1]);
  372. // PRINTF_FUNC("target_number[2] = %x \n", target_number[2]);
  373. // PRINTF_FUNC("target_number[3] = %x \n", target_number[3]);
  374. // PRINTF_FUNC("target_number[4] = %x \n", target_number[4]);
  375. PRINTF_FUNC("SetTargetAddr = %d, type = %d \n", index, _chargingData[index - 1]->Type);
  376. SetTargetAddr(target_number, index);
  377. }
  378. }
  379. void ClearAbnormalStatus_Chademo(byte gun_index)
  380. {
  381. bool isCleanCheck = false;
  382. char code[7];
  383. if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "", 6) == EQUAL)
  384. return;
  385. if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023700", 6) == EQUAL &&
  386. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoEvCommFail == YES)
  387. {
  388. memcpy(code, "023700", 6);
  389. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  390. isCleanCheck = true;
  391. }
  392. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023704", 6) == EQUAL &&
  393. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryMalfun == YES)
  394. {
  395. memcpy(code, "023704", 6);
  396. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  397. isCleanCheck = true;
  398. }
  399. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023705", 6) == EQUAL &&
  400. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoNoPermission == YES)
  401. {
  402. memcpy(code, "023705", 6);
  403. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  404. isCleanCheck = true;
  405. }
  406. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023706", 6) == EQUAL &&
  407. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryIncompatibility == YES)
  408. {
  409. memcpy(code, "023706", 6);
  410. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  411. isCleanCheck = true;
  412. }
  413. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023707", 6) == EQUAL &&
  414. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOVP == YES)
  415. {
  416. memcpy(code, "023707", 6);
  417. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  418. isCleanCheck = true;
  419. }
  420. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023708", 6) == EQUAL &&
  421. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryUVP == YES)
  422. {
  423. memcpy(code, "023708", 6);
  424. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  425. isCleanCheck = true;
  426. }
  427. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023709", 6) == EQUAL &&
  428. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOTP == YES)
  429. {
  430. memcpy(code, "023709", 6);
  431. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  432. isCleanCheck = true;
  433. }
  434. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023710", 6) == EQUAL &&
  435. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryCurrentDiff == YES)
  436. {
  437. memcpy(code, "023710", 6);
  438. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  439. isCleanCheck = true;
  440. }
  441. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023711", 6) == EQUAL &&
  442. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryVoltageDiff == YES)
  443. {
  444. memcpy(code, "023711", 6);
  445. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  446. isCleanCheck = true;
  447. }
  448. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023712", 6) == EQUAL &&
  449. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoShiftPosition == YES)
  450. {
  451. memcpy(code, "023712", 6);
  452. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  453. isCleanCheck = true;
  454. }
  455. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023713", 6) == EQUAL &&
  456. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOtherFault == YES)
  457. {
  458. memcpy(code, "023713", 6);
  459. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  460. isCleanCheck = true;
  461. }
  462. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023714", 6) == EQUAL &&
  463. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargingSystemError == YES)
  464. {
  465. memcpy(code, "023714", 6);
  466. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  467. isCleanCheck = true;
  468. }
  469. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023715", 6) == EQUAL &&
  470. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoEvNormalStop == YES)
  471. {
  472. memcpy(code, "023715", 6);
  473. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  474. isCleanCheck = true;
  475. }
  476. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023716", 6) == EQUAL &&
  477. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoTempSensorBroken == YES)
  478. {
  479. memcpy(code, "023716", 6);
  480. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  481. isCleanCheck = true;
  482. }
  483. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023717", 6) == EQUAL &&
  484. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoConnectorLockFail == YES)
  485. {
  486. memcpy(code, "023717", 6);
  487. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  488. isCleanCheck = true;
  489. }
  490. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023718", 6) == EQUAL &&
  491. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoD1OnNoReceive == YES)
  492. {
  493. memcpy(code, "023718", 6);
  494. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  495. isCleanCheck = true;
  496. }
  497. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023719", 6) == EQUAL &&
  498. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsKtoJTimeout == YES)
  499. {
  500. memcpy(code, "023719", 6);
  501. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  502. isCleanCheck = true;
  503. }
  504. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023720", 6) == EQUAL &&
  505. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsChargeAllowTimeout == YES)
  506. {
  507. memcpy(code, "023720", 6);
  508. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  509. isCleanCheck = true;
  510. }
  511. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023721", 6) == EQUAL &&
  512. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoWaitGfdTimeout == YES)
  513. {
  514. memcpy(code, "023721", 6);
  515. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  516. isCleanCheck = true;
  517. }
  518. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023722", 6) == EQUAL &&
  519. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsEvRelayTimeout == YES)
  520. {
  521. memcpy(code, "023722", 6);
  522. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  523. isCleanCheck = true;
  524. }
  525. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023723", 6) == EQUAL &&
  526. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsReqCurrentTimeout == YES)
  527. {
  528. memcpy(code, "023723", 6);
  529. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  530. isCleanCheck = true;
  531. }
  532. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023724", 6) == EQUAL &&
  533. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsKtoJOffTimeout == YES)
  534. {
  535. memcpy(code, "023724", 6);
  536. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  537. isCleanCheck = true;
  538. }
  539. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023725", 6) == EQUAL &&
  540. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsEvRelayOffTimeout == YES)
  541. {
  542. memcpy(code, "023725", 6);
  543. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  544. isCleanCheck = true;
  545. }
  546. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023726", 6) == EQUAL &&
  547. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoAdcMoreThan10V == YES)
  548. {
  549. memcpy(code, "023726", 6);
  550. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  551. isCleanCheck = true;
  552. }
  553. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023727", 6) == EQUAL &&
  554. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoAdcMoreThan20V == YES)
  555. {
  556. memcpy(code, "023727", 6);
  557. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  558. isCleanCheck = true;
  559. }
  560. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023728", 6) == EQUAL &&
  561. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsChargeBeforeStop == YES)
  562. {
  563. memcpy(code, "023728", 6);
  564. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  565. isCleanCheck = true;
  566. }
  567. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023729", 6) == EQUAL &&
  568. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargerGetNormalStop == YES)
  569. {
  570. memcpy(code, "023729", 6);
  571. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  572. isCleanCheck = true;
  573. }
  574. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023730", 6) == EQUAL &&
  575. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargerGetEmergencyStop == YES)
  576. {
  577. memcpy(code, "023730", 6);
  578. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  579. isCleanCheck = true;
  580. }
  581. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023731", 6) == EQUAL &&
  582. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoIsolationResultFail == YES)
  583. {
  584. memcpy(code, "023731", 6);
  585. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  586. isCleanCheck = true;
  587. }
  588. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023732", 6) == EQUAL &&
  589. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoMissLinkWithMotherBoard == YES)
  590. {
  591. memcpy(code, "023732", 6);
  592. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  593. isCleanCheck = true;
  594. }
  595. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023733", 6) == EQUAL &&
  596. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoOutputVolMoreThanLimit == YES)
  597. {
  598. memcpy(code, "023733", 6);
  599. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  600. isCleanCheck = true;
  601. }
  602. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023734", 6) == EQUAL &&
  603. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoReqCurrentMoreThanLimit == YES)
  604. {
  605. memcpy(code, "023734", 6);
  606. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  607. isCleanCheck = true;
  608. }
  609. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023735", 6) == EQUAL &&
  610. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoReCapBmsEqrCurrentExceed == YES)
  611. {
  612. memcpy(code, "023735", 6);
  613. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  614. isCleanCheck = true;
  615. }
  616. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023736", 6) == EQUAL &&
  617. ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargeRemainCountDown == YES)
  618. {
  619. memcpy(code, "023736", 6);
  620. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  621. isCleanCheck = true;
  622. }
  623. if (isCleanCheck)
  624. {
  625. for (byte index = 0; index < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; index++)
  626. {
  627. if (index != gun_index || ShmSysConfigAndInfo->SysConfig.TotalConnectorCount == 1)
  628. {
  629. PRINTF_FUNC("CHA clean error : index = %d, EvConnAlarmCode = %s, code = %s \n", index, _chargingData[index]->EvConnAlarmCode, code);
  630. if (strncmp((char *)_chargingData[index]->EvConnAlarmCode, code, 6) != EQUAL)
  631. {
  632. if (strncmp(code, "023700", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoEvCommFail = NO;
  633. if (strncmp(code, "023704", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryMalfun = NO;
  634. if (strncmp(code, "023705", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoNoPermission = NO;
  635. if (strncmp(code, "023706", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryIncompatibility = NO;
  636. if (strncmp(code, "023707", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOVP = NO;
  637. if (strncmp(code, "023708", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryUVP = NO;
  638. if (strncmp(code, "023709", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOTP = NO;
  639. if (strncmp(code, "023710", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryCurrentDiff = NO;
  640. if (strncmp(code, "023711", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryVoltageDiff = NO;
  641. if (strncmp(code, "023712", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoShiftPosition = NO;
  642. if (strncmp(code, "023713", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOtherFault = NO;
  643. if (strncmp(code, "023714", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargingSystemError = NO;
  644. if (strncmp(code, "023715", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoEvNormalStop = NO;
  645. if (strncmp(code, "023716", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoTempSensorBroken = NO;
  646. if (strncmp(code, "023717", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoConnectorLockFail = NO;
  647. if (strncmp(code, "023718", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoD1OnNoReceive = NO;
  648. if (strncmp(code, "023719", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsKtoJTimeout = NO;
  649. if (strncmp(code, "023720", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsChargeAllowTimeout = NO;
  650. if (strncmp(code, "023721", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoWaitGfdTimeout = NO;
  651. if (strncmp(code, "023722", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsEvRelayTimeout = NO;
  652. if (strncmp(code, "023723", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsReqCurrentTimeout = NO;
  653. if (strncmp(code, "023724", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsKtoJOffTimeout = NO;
  654. if (strncmp(code, "023725", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsEvRelayOffTimeout = NO;
  655. if (strncmp(code, "023726", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoAdcMoreThan10V = NO;
  656. if (strncmp(code, "023727", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoAdcMoreThan20V = NO;
  657. if (strncmp(code, "023728", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsChargeBeforeStop = NO;
  658. if (strncmp(code, "023729", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargerGetNormalStop = NO;
  659. if (strncmp(code, "023730", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargerGetEmergencyStop = NO;
  660. if (strncmp(code, "023731", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoIsolationResultFail = NO;
  661. if (strncmp(code, "023732", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoMissLinkWithMotherBoard = NO;
  662. if (strncmp(code, "023733", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoOutputVolMoreThanLimit = NO;
  663. if (strncmp(code, "023734", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoReqCurrentMoreThanLimit = NO;
  664. if (strncmp(code, "023735", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoReCapBmsEqrCurrentExceed = NO;
  665. if (strncmp(code, "023736", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargeRemainCountDown = NO;
  666. }
  667. }
  668. }
  669. }
  670. }
  671. void ClearAbnormalStatus_GB(byte gun_index)
  672. {
  673. bool isCleanCheck = false;
  674. char code[7];
  675. if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "", 6) == EQUAL)
  676. return;
  677. if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023702", 6) == EQUAL &&
  678. ShmStatusCodeData->InfoCode.InfoEvents.bits.GbEvCommFail == YES)
  679. {
  680. memcpy(code, "023702", 6);
  681. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  682. isCleanCheck = true;
  683. }
  684. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023900", 6) == EQUAL &&
  685. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_LOS_CC1 == YES)
  686. {
  687. memcpy(code, "023900", 6);
  688. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  689. isCleanCheck = true;
  690. }
  691. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023901", 6) == EQUAL &&
  692. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CONNECTOR_LOCK_FAIL == YES)
  693. {
  694. memcpy(code, "023901", 6);
  695. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  696. isCleanCheck = true;
  697. }
  698. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023902", 6) == EQUAL &&
  699. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BATTERY_INCOMPATIBLE == YES)
  700. {
  701. memcpy(code, "023902", 6);
  702. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  703. isCleanCheck = true;
  704. }
  705. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023903", 6) == EQUAL &&
  706. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_BROAA_TIMEOUT == YES)
  707. {
  708. memcpy(code, "023903", 6);
  709. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  710. isCleanCheck = true;
  711. }
  712. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023904", 6) == EQUAL &&
  713. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CSU_PRECHARGE_TIMEOUT == YES)
  714. {
  715. memcpy(code, "023904", 6);
  716. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  717. isCleanCheck = true;
  718. }
  719. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023905", 6) == EQUAL &&
  720. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_PRESENT_VOLTAGE_FAULT == YES)
  721. {
  722. memcpy(code, "023905", 6);
  723. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  724. isCleanCheck = true;
  725. }
  726. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023906", 6) == EQUAL &&
  727. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_VOLTAGE_OVER_RANGE == YES)
  728. {
  729. memcpy(code, "023906", 6);
  730. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  731. isCleanCheck = true;
  732. }
  733. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023907", 6) == EQUAL &&
  734. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BSM_CHARGE_ALLOW_00_10MIN_COUUNTDONE == YES)
  735. {
  736. memcpy(code, "023907", 6);
  737. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  738. isCleanCheck = true;
  739. }
  740. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023908", 6) == EQUAL &&
  741. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_WAIT_GROUNDFAULT_TIMEOUT == YES)
  742. {
  743. memcpy(code, "023908", 6);
  744. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  745. isCleanCheck = true;
  746. }
  747. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023909", 6) == EQUAL &&
  748. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ADC_MORE_THAN_10V == YES)
  749. {
  750. memcpy(code, "023909", 6);
  751. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  752. isCleanCheck = true;
  753. }
  754. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023910", 6) == EQUAL &&
  755. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ADC_MORE_THAN_60V == YES)
  756. {
  757. memcpy(code, "023910", 6);
  758. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  759. isCleanCheck = true;
  760. }
  761. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023911", 6) == EQUAL &&
  762. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CHARGER_GET_NORMAL_STOP_CMD == YES)
  763. {
  764. memcpy(code, "023911", 6);
  765. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  766. isCleanCheck = true;
  767. }
  768. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023912", 6) == EQUAL &&
  769. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CHARGER_GET_EMERGENCY_STOP_CMD == YES)
  770. {
  771. memcpy(code, "023912", 6);
  772. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  773. isCleanCheck = true;
  774. }
  775. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023913", 6) == EQUAL &&
  776. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ISOLATION_RESULT_FAIL == YES)
  777. {
  778. memcpy(code, "023913", 6);
  779. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  780. isCleanCheck = true;
  781. }
  782. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023914", 6) == EQUAL &&
  783. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_MOTHER_BOARD_MISS_LINK == YES)
  784. {
  785. memcpy(code, "023914", 6);
  786. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  787. isCleanCheck = true;
  788. }
  789. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023915", 6) == EQUAL &&
  790. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_MORE_THAN_LIMIT == YES)
  791. {
  792. memcpy(code, "023915", 6);
  793. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  794. isCleanCheck = true;
  795. }
  796. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023916", 6) == EQUAL &&
  797. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_REQ_CURRENT_MORE_THAN_LIMIT == YES)
  798. {
  799. memcpy(code, "023916", 6);
  800. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  801. isCleanCheck = true;
  802. }
  803. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023917", 6) == EQUAL &&
  804. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_MORE_THAN_10_PERCENT == YES)
  805. {
  806. memcpy(code, "023917", 6);
  807. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  808. isCleanCheck = true;
  809. }
  810. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023918", 6) == EQUAL &&
  811. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_DIFF_BCS_5_PERCENT == YES)
  812. {
  813. memcpy(code, "023918", 6);
  814. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  815. isCleanCheck = true;
  816. }
  817. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023919", 6) == EQUAL &&
  818. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_STOP_ADC_MORE_THAN_10V == YES)
  819. {
  820. memcpy(code, "023919", 6);
  821. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  822. isCleanCheck = true;
  823. }
  824. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023930", 6) == EQUAL &&
  825. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BHM_TIMEOUT == YES)
  826. {
  827. memcpy(code, "023930", 6);
  828. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  829. isCleanCheck = true;
  830. }
  831. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023931", 6) == EQUAL &&
  832. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BRM_TIMEOUT == YES)
  833. {
  834. memcpy(code, "023931", 6);
  835. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  836. isCleanCheck = true;
  837. }
  838. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023932", 6) == EQUAL &&
  839. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCP_TIMEOUT == YES)
  840. {
  841. memcpy(code, "023932", 6);
  842. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  843. isCleanCheck = true;
  844. }
  845. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023933", 6) == EQUAL &&
  846. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BRO_TIMEOUT == YES)
  847. {
  848. memcpy(code, "023933", 6);
  849. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  850. isCleanCheck = true;
  851. }
  852. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023934", 6) == EQUAL &&
  853. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCL_TIMEOUT == YES)
  854. {
  855. memcpy(code, "023934", 6);
  856. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  857. isCleanCheck = true;
  858. }
  859. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023935", 6) == EQUAL &&
  860. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCS_TIMEOUT == YES)
  861. {
  862. memcpy(code, "023935", 6);
  863. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  864. isCleanCheck = true;
  865. }
  866. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023936", 6) == EQUAL &&
  867. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BSM_TIMEOUT == YES)
  868. {
  869. memcpy(code, "023936", 6);
  870. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  871. isCleanCheck = true;
  872. }
  873. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023937", 6) == EQUAL &&
  874. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BST_TIMEOUT == YES)
  875. {
  876. memcpy(code, "023937", 6);
  877. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  878. isCleanCheck = true;
  879. }
  880. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023938", 6) == EQUAL &&
  881. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BSD_TIMEOUT == YES)
  882. {
  883. memcpy(code, "023938", 6);
  884. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  885. isCleanCheck = true;
  886. }
  887. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023939", 6) == EQUAL &&
  888. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BEM_OTHER_TIMEOUT == YES)
  889. {
  890. memcpy(code, "023939", 6);
  891. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  892. isCleanCheck = true;
  893. }
  894. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023940", 6) == EQUAL &&
  895. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRM_TIMEOUT == YES)
  896. {
  897. memcpy(code, "023940", 6);
  898. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  899. isCleanCheck = true;
  900. }
  901. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023941", 6) == EQUAL &&
  902. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRMAA_TIMEOUT == YES)
  903. {
  904. memcpy(code, "023941", 6);
  905. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  906. isCleanCheck = true;
  907. }
  908. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023942", 6) == EQUAL &&
  909. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CTS_CML_TIMEOUT == YES)
  910. {
  911. memcpy(code, "023942", 6);
  912. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  913. isCleanCheck = true;
  914. }
  915. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023943", 6) == EQUAL &&
  916. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRO_TIMEOUT == YES)
  917. {
  918. memcpy(code, "023943", 6);
  919. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  920. isCleanCheck = true;
  921. }
  922. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023944", 6) == EQUAL &&
  923. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CCS_TIMEOUT == YES)
  924. {
  925. memcpy(code, "023944", 6);
  926. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  927. isCleanCheck = true;
  928. }
  929. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023945", 6) == EQUAL &&
  930. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CST_TIMEOUT == YES)
  931. {
  932. memcpy(code, "023945", 6);
  933. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  934. isCleanCheck = true;
  935. }
  936. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023946", 6) == EQUAL &&
  937. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CSD_TIMEOUT == YES)
  938. {
  939. memcpy(code, "023946", 6);
  940. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  941. isCleanCheck = true;
  942. }
  943. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023947", 6) == EQUAL &&
  944. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_BEM_OTHER_TIMEOUT == YES)
  945. {
  946. memcpy(code, "023947", 6);
  947. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  948. isCleanCheck = true;
  949. }
  950. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023950", 6) == EQUAL &&
  951. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_SOC_GOAL == YES)
  952. {
  953. memcpy(code, "023950", 6);
  954. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  955. isCleanCheck = true;
  956. }
  957. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023951", 6) == EQUAL &&
  958. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_TOTAL_VOLTAGE_GOAL == YES)
  959. {
  960. memcpy(code, "023951", 6);
  961. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  962. isCleanCheck = true;
  963. }
  964. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023952", 6) == EQUAL &&
  965. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CELL_VOLTAGE_GOAL == YES)
  966. {
  967. memcpy(code, "023952", 6);
  968. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  969. isCleanCheck = true;
  970. }
  971. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023953", 6) == EQUAL &&
  972. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_GET_CST == YES)
  973. {
  974. memcpy(code, "023953", 6);
  975. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  976. isCleanCheck = true;
  977. }
  978. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023954", 6) == EQUAL &&
  979. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_ISOLATION == YES)
  980. {
  981. memcpy(code, "023954", 6);
  982. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  983. isCleanCheck = true;
  984. }
  985. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023955", 6) == EQUAL &&
  986. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OUTPUT_CONNECTOR_OTP == YES)
  987. {
  988. memcpy(code, "023955", 6);
  989. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  990. isCleanCheck = true;
  991. }
  992. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023956", 6) == EQUAL &&
  993. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_COMPONENT == YES)
  994. {
  995. memcpy(code, "023956", 6);
  996. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  997. isCleanCheck = true;
  998. }
  999. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023957", 6) == EQUAL &&
  1000. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CHARGE_CONNECTOR == YES)
  1001. {
  1002. memcpy(code, "023957", 6);
  1003. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1004. isCleanCheck = true;
  1005. }
  1006. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023958", 6) == EQUAL &&
  1007. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OTP == YES)
  1008. {
  1009. memcpy(code, "023958", 6);
  1010. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1011. isCleanCheck = true;
  1012. }
  1013. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023959", 6) == EQUAL &&
  1014. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OTHER == YES)
  1015. {
  1016. memcpy(code, "023959", 6);
  1017. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1018. isCleanCheck = true;
  1019. }
  1020. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023960", 6) == EQUAL &&
  1021. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_HIGH_V == YES)
  1022. {
  1023. memcpy(code, "023960", 6);
  1024. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1025. isCleanCheck = true;
  1026. }
  1027. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023961", 6) == EQUAL &&
  1028. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CC2 == YES)
  1029. {
  1030. memcpy(code, "023961", 6);
  1031. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1032. isCleanCheck = true;
  1033. }
  1034. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023962", 6) == EQUAL &&
  1035. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CURRENT == YES)
  1036. {
  1037. memcpy(code, "023962", 6);
  1038. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1039. isCleanCheck = true;
  1040. }
  1041. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023963", 6) == EQUAL &&
  1042. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_VOLTAGE == YES)
  1043. {
  1044. memcpy(code, "023963", 6);
  1045. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1046. isCleanCheck = true;
  1047. }
  1048. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023964", 6) == EQUAL &&
  1049. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GET_BST_NO_REASON == YES)
  1050. {
  1051. memcpy(code, "023964", 6);
  1052. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1053. isCleanCheck = true;
  1054. }
  1055. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023970", 6) == EQUAL &&
  1056. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CELL_OVER_VOLTAGE == YES)
  1057. {
  1058. memcpy(code, "023970", 6);
  1059. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1060. isCleanCheck = true;
  1061. }
  1062. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023971", 6) == EQUAL &&
  1063. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CELL_UNDER_VOLTAGE == YES)
  1064. {
  1065. memcpy(code, "023971", 6);
  1066. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1067. isCleanCheck = true;
  1068. }
  1069. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023972", 6) == EQUAL &&
  1070. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_OVER_SOC == YES)
  1071. {
  1072. memcpy(code, "023972", 6);
  1073. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1074. isCleanCheck = true;
  1075. }
  1076. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023973", 6) == EQUAL &&
  1077. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_UNDER_SOC == YES)
  1078. {
  1079. memcpy(code, "023973", 6);
  1080. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1081. isCleanCheck = true;
  1082. }
  1083. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023974", 6) == EQUAL &&
  1084. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CURRENT == YES)
  1085. {
  1086. memcpy(code, "023974", 6);
  1087. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1088. isCleanCheck = true;
  1089. }
  1090. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023975", 6) == EQUAL &&
  1091. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_TEMPERATURE == YES)
  1092. {
  1093. memcpy(code, "023975", 6);
  1094. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1095. isCleanCheck = true;
  1096. }
  1097. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023976", 6) == EQUAL &&
  1098. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_ISOLATE == YES)
  1099. {
  1100. memcpy(code, "023976", 6);
  1101. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1102. isCleanCheck = true;
  1103. }
  1104. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023977", 6) == EQUAL &&
  1105. ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_OUTPUT_CONNECTOR == YES)
  1106. {
  1107. memcpy(code, "023977", 6);
  1108. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1109. isCleanCheck = true;
  1110. }
  1111. if (isCleanCheck)
  1112. {
  1113. for (byte index = 0; index < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; index++)
  1114. {
  1115. if (index != gun_index || ShmSysConfigAndInfo->SysConfig.TotalConnectorCount == 1)
  1116. {
  1117. PRINTF_FUNC("GBT clean error : index = %d, EvConnAlarmCode = %s, code = %s \n", index, _chargingData[index]->EvConnAlarmCode, code);
  1118. if (strncmp((char *)_chargingData[index]->EvConnAlarmCode, code, 6) != EQUAL)
  1119. {
  1120. if (strncmp(code, "023702", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.GbEvCommFail = NO;
  1121. if (strncmp(code, "023900", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_LOS_CC1 = NO;
  1122. if (strncmp(code, "023901", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CONNECTOR_LOCK_FAIL = NO;
  1123. if (strncmp(code, "023902", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BATTERY_INCOMPATIBLE = NO;
  1124. if (strncmp(code, "023903", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_BROAA_TIMEOUT = NO;
  1125. if (strncmp(code, "023904", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CSU_PRECHARGE_TIMEOUT = NO;
  1126. if (strncmp(code, "023905", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_PRESENT_VOLTAGE_FAULT = NO;
  1127. if (strncmp(code, "023906", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_VOLTAGE_OVER_RANGE = NO;
  1128. if (strncmp(code, "023907", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BSM_CHARGE_ALLOW_00_10MIN_COUUNTDONE = NO;
  1129. if (strncmp(code, "023908", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_WAIT_GROUNDFAULT_TIMEOUT = NO;
  1130. if (strncmp(code, "023909", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ADC_MORE_THAN_10V = NO;
  1131. if (strncmp(code, "023910", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ADC_MORE_THAN_60V = NO;
  1132. if (strncmp(code, "023911", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CHARGER_GET_NORMAL_STOP_CMD = NO;
  1133. if (strncmp(code, "023912", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CHARGER_GET_EMERGENCY_STOP_CMD = NO;
  1134. if (strncmp(code, "023913", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ISOLATION_RESULT_FAIL = NO;
  1135. if (strncmp(code, "023914", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_MOTHER_BOARD_MISS_LINK = NO;
  1136. if (strncmp(code, "023915", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_MORE_THAN_LIMIT = NO;
  1137. if (strncmp(code, "023916", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_REQ_CURRENT_MORE_THAN_LIMIT = NO;
  1138. if (strncmp(code, "023917", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_MORE_THAN_10_PERCENT = NO;
  1139. if (strncmp(code, "023918", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_DIFF_BCS_5_PERCENT = NO;
  1140. if (strncmp(code, "023919", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_STOP_ADC_MORE_THAN_10V = NO;
  1141. if (strncmp(code, "023930", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BHM_TIMEOUT = NO;
  1142. if (strncmp(code, "023931", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BRM_TIMEOUT = NO;
  1143. if (strncmp(code, "023932", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCP_TIMEOUT = NO;
  1144. if (strncmp(code, "023933", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BRO_TIMEOUT = NO;
  1145. if (strncmp(code, "023934", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCL_TIMEOUT = NO;
  1146. if (strncmp(code, "023935", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCS_TIMEOUT = NO;
  1147. if (strncmp(code, "023936", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BSM_TIMEOUT = NO;
  1148. if (strncmp(code, "023937", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BST_TIMEOUT = NO;
  1149. if (strncmp(code, "023938", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BSD_TIMEOUT = NO;
  1150. if (strncmp(code, "023939", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BEM_OTHER_TIMEOUT = NO;
  1151. if (strncmp(code, "023940", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRM_TIMEOUT = NO;
  1152. if (strncmp(code, "023941", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRMAA_TIMEOUT = NO;
  1153. if (strncmp(code, "023942", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CTS_CML_TIMEOUT = NO;
  1154. if (strncmp(code, "023943", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRO_TIMEOUT = NO;
  1155. if (strncmp(code, "023944", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CCS_TIMEOUT = NO;
  1156. if (strncmp(code, "023945", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CST_TIMEOUT = NO;
  1157. if (strncmp(code, "023946", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CSD_TIMEOUT = NO;
  1158. if (strncmp(code, "023947", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_BEM_OTHER_TIMEOUT = NO;
  1159. if (strncmp(code, "023950", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_SOC_GOAL = NO;
  1160. if (strncmp(code, "023951", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_TOTAL_VOLTAGE_GOAL = NO;
  1161. if (strncmp(code, "023952", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CELL_VOLTAGE_GOAL = NO;
  1162. if (strncmp(code, "023953", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_GET_CST = NO;
  1163. if (strncmp(code, "023954", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_ISOLATION = NO;
  1164. if (strncmp(code, "023955", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OUTPUT_CONNECTOR_OTP = NO;
  1165. if (strncmp(code, "023956", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_COMPONENT = NO;
  1166. if (strncmp(code, "023957", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CHARGE_CONNECTOR = NO;
  1167. if (strncmp(code, "023958", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OTP = NO;
  1168. if (strncmp(code, "023959", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OTHER = NO;
  1169. if (strncmp(code, "023960", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_HIGH_V = NO;
  1170. if (strncmp(code, "023961", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CC2 = NO;
  1171. if (strncmp(code, "023962", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CURRENT = NO;
  1172. if (strncmp(code, "023963", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_VOLTAGE = NO;
  1173. if (strncmp(code, "023964", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GET_BST_NO_REASON = NO;
  1174. if (strncmp(code, "023970", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CELL_OVER_VOLTAGE = NO;
  1175. if (strncmp(code, "023971", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CELL_UNDER_VOLTAGE = NO;
  1176. if (strncmp(code, "023972", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_OVER_SOC = NO;
  1177. if (strncmp(code, "023973", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_UNDER_SOC = NO;
  1178. if (strncmp(code, "023974", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CURRENT = NO;
  1179. if (strncmp(code, "023975", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_TEMPERATURE = NO;
  1180. if (strncmp(code, "023976", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_ISOLATE = NO;
  1181. if (strncmp(code, "023977", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_OUTPUT_CONNECTOR = NO;
  1182. }
  1183. }
  1184. }
  1185. }
  1186. }
  1187. void ClearAbnormalStatus_CCS(byte gun_index)
  1188. {
  1189. bool isCleanCheck = false;
  1190. char code[7];
  1191. if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "", 6) == EQUAL)
  1192. return;
  1193. if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023701", 6) == EQUAL &&
  1194. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEvCommFail == YES)
  1195. {
  1196. memcpy(code, "023701", 6);
  1197. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1198. isCleanCheck = true;
  1199. }
  1200. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023737", 6) == EQUAL &&
  1201. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsRESTemperatureInhibit == YES)
  1202. {
  1203. memcpy(code, "023737", 6);
  1204. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1205. isCleanCheck = true;
  1206. }
  1207. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023738", 6) == EQUAL &&
  1208. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVShiftPosition == YES)
  1209. {
  1210. memcpy(code, "023738", 6);
  1211. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1212. isCleanCheck = true;
  1213. }
  1214. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023739", 6) == EQUAL &&
  1215. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargerConnectorLockFault == YES)
  1216. {
  1217. memcpy(code, "023739", 6);
  1218. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1219. isCleanCheck = true;
  1220. }
  1221. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023740", 6) == EQUAL &&
  1222. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVRESSMalfunction == YES)
  1223. {
  1224. memcpy(code, "023740", 6);
  1225. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1226. isCleanCheck = true;
  1227. }
  1228. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023741", 6) == EQUAL &&
  1229. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingCurrentdifferential == YES)
  1230. {
  1231. memcpy(code, "023741", 6);
  1232. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1233. isCleanCheck = true;
  1234. }
  1235. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023742", 6) == EQUAL &&
  1236. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingVoltageOutOfRange == YES)
  1237. {
  1238. memcpy(code, "023742", 6);
  1239. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1240. isCleanCheck = true;
  1241. }
  1242. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023743", 6) == EQUAL &&
  1243. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingSystemIncompatibility == YES)
  1244. {
  1245. memcpy(code, "023743", 6);
  1246. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1247. isCleanCheck = true;
  1248. }
  1249. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023744", 6) == EQUAL &&
  1250. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEmergencyEvent == YES)
  1251. {
  1252. memcpy(code, "023744", 6);
  1253. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1254. isCleanCheck = true;
  1255. }
  1256. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023745", 6) == EQUAL &&
  1257. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsBreaker == YES)
  1258. {
  1259. memcpy(code, "023745", 6);
  1260. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1261. isCleanCheck = true;
  1262. }
  1263. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023746", 6) == EQUAL &&
  1264. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoData == YES)
  1265. {
  1266. memcpy(code, "023746", 6);
  1267. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1268. isCleanCheck = true;
  1269. }
  1270. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023747", 6) == EQUAL &&
  1271. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_A == YES)
  1272. {
  1273. memcpy(code, "023747", 6);
  1274. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1275. isCleanCheck = true;
  1276. }
  1277. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023748", 6) == EQUAL &&
  1278. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_B == YES)
  1279. {
  1280. memcpy(code, "023748", 6);
  1281. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1282. isCleanCheck = true;
  1283. }
  1284. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023749", 6) == EQUAL &&
  1285. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_C == YES)
  1286. {
  1287. memcpy(code, "023749", 6);
  1288. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1289. isCleanCheck = true;
  1290. }
  1291. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023750", 6) == EQUAL &&
  1292. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_1 == YES)
  1293. {
  1294. memcpy(code, "023750", 6);
  1295. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1296. isCleanCheck = true;
  1297. }
  1298. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023751", 6) == EQUAL &&
  1299. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_2 == YES)
  1300. {
  1301. memcpy(code, "023751", 6);
  1302. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1303. isCleanCheck = true;
  1304. }
  1305. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023752", 6) == EQUAL &&
  1306. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_3 == YES)
  1307. {
  1308. memcpy(code, "023752", 6);
  1309. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1310. isCleanCheck = true;
  1311. }
  1312. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023753", 6) == EQUAL &&
  1313. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_1 == YES)
  1314. {
  1315. memcpy(code, "023753", 6);
  1316. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1317. isCleanCheck = true;
  1318. }
  1319. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023754", 6) == EQUAL &&
  1320. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_2 == YES)
  1321. {
  1322. memcpy(code, "023754", 6);
  1323. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1324. isCleanCheck = true;
  1325. }
  1326. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023755", 6) == EQUAL &&
  1327. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_3 == YES)
  1328. {
  1329. memcpy(code, "023755", 6);
  1330. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1331. isCleanCheck = true;
  1332. }
  1333. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023756", 6) == EQUAL &&
  1334. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_4 == YES)
  1335. {
  1336. memcpy(code, "023756", 6);
  1337. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1338. isCleanCheck = true;
  1339. }
  1340. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023757", 6) == EQUAL &&
  1341. ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_5 == YES)
  1342. {
  1343. memcpy(code, "023757", 6);
  1344. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1345. isCleanCheck = true;
  1346. }
  1347. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023758", 6) == EQUAL &&
  1348. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSequenceError == YES)
  1349. {
  1350. memcpy(code, "023758", 6);
  1351. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1352. isCleanCheck = true;
  1353. }
  1354. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023759", 6) == EQUAL &&
  1355. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSignatureError == YES)
  1356. {
  1357. memcpy(code, "023759", 6);
  1358. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1359. isCleanCheck = true;
  1360. }
  1361. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023760", 6) == EQUAL &&
  1362. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUnknownSession == YES)
  1363. {
  1364. memcpy(code, "023760", 6);
  1365. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1366. isCleanCheck = true;
  1367. }
  1368. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023761", 6) == EQUAL &&
  1369. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceIDInvalid == YES)
  1370. {
  1371. memcpy(code, "023761", 6);
  1372. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1373. isCleanCheck = true;
  1374. }
  1375. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023762", 6) == EQUAL &&
  1376. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPaymentSelectionInvalid == YES)
  1377. {
  1378. memcpy(code, "023762", 6);
  1379. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1380. isCleanCheck = true;
  1381. }
  1382. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023763", 6) == EQUAL &&
  1383. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsIdentificationSelectionInvalid == YES)
  1384. {
  1385. memcpy(code, "023763", 6);
  1386. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1387. isCleanCheck = true;
  1388. }
  1389. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023764", 6) == EQUAL &&
  1390. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceSelectionInvalid == YES)
  1391. {
  1392. memcpy(code, "023764", 6);
  1393. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1394. isCleanCheck = true;
  1395. }
  1396. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023765", 6) == EQUAL &&
  1397. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateExpired == YES)
  1398. {
  1399. memcpy(code, "023765", 6);
  1400. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1401. isCleanCheck = true;
  1402. }
  1403. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023766", 6) == EQUAL &&
  1404. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateNotYetValid == YES)
  1405. {
  1406. memcpy(code, "023766", 6);
  1407. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1408. isCleanCheck = true;
  1409. }
  1410. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023767", 6) == EQUAL &&
  1411. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateRevoked == YES)
  1412. {
  1413. memcpy(code, "023767", 6);
  1414. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1415. isCleanCheck = true;
  1416. }
  1417. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023768", 6) == EQUAL &&
  1418. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoCertificateAvailable == YES)
  1419. {
  1420. memcpy(code, "023768", 6);
  1421. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1422. isCleanCheck = true;
  1423. }
  1424. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023769", 6) == EQUAL &&
  1425. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertChainError == YES)
  1426. {
  1427. memcpy(code, "023769", 6);
  1428. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1429. isCleanCheck = true;
  1430. }
  1431. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023770", 6) == EQUAL &&
  1432. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertValidationError == YES)
  1433. {
  1434. memcpy(code, "023770", 6);
  1435. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1436. isCleanCheck = true;
  1437. }
  1438. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023771", 6) == EQUAL &&
  1439. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertVerificationError == YES)
  1440. {
  1441. memcpy(code, "023771", 6);
  1442. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1443. isCleanCheck = true;
  1444. }
  1445. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023772", 6) == EQUAL &&
  1446. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractCanceled == YES)
  1447. {
  1448. memcpy(code, "023772", 6);
  1449. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1450. isCleanCheck = true;
  1451. }
  1452. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023773", 6) == EQUAL &&
  1453. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChallengeInvalid == YES)
  1454. {
  1455. memcpy(code, "023773", 6);
  1456. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1457. isCleanCheck = true;
  1458. }
  1459. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023774", 6) == EQUAL &&
  1460. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWrongEnergyTransferMode == YES)
  1461. {
  1462. memcpy(code, "023774", 6);
  1463. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1464. isCleanCheck = true;
  1465. }
  1466. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023775", 6) == EQUAL &&
  1467. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWrongChargeParameter == YES)
  1468. {
  1469. memcpy(code, "023775", 6);
  1470. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1471. isCleanCheck = true;
  1472. }
  1473. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023776", 6) == EQUAL &&
  1474. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingProfileInvalid == YES)
  1475. {
  1476. memcpy(code, "023776", 6);
  1477. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1478. isCleanCheck = true;
  1479. }
  1480. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023777", 6) == EQUAL &&
  1481. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTariffSelectionInvalid == YES)
  1482. {
  1483. memcpy(code, "023777", 6);
  1484. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1485. isCleanCheck = true;
  1486. }
  1487. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023778", 6) == EQUAL &&
  1488. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVSEPresentVoltageToLow == YES)
  1489. {
  1490. memcpy(code, "023778", 6);
  1491. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1492. isCleanCheck = true;
  1493. }
  1494. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023779", 6) == EQUAL &&
  1495. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPowerDeliveryNotApplied == YES)
  1496. {
  1497. memcpy(code, "023779", 6);
  1498. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1499. isCleanCheck = true;
  1500. }
  1501. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023780", 6) == EQUAL &&
  1502. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMeteringSignatureNotValid == YES)
  1503. {
  1504. memcpy(code, "023780", 6);
  1505. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1506. isCleanCheck = true;
  1507. }
  1508. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023781", 6) == EQUAL &&
  1509. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoChargeServiceSelected == YES)
  1510. {
  1511. memcpy(code, "023781", 6);
  1512. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1513. isCleanCheck = true;
  1514. }
  1515. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023782", 6) == EQUAL &&
  1516. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContactorError == YES)
  1517. {
  1518. memcpy(code, "023782", 6);
  1519. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1520. isCleanCheck = true;
  1521. }
  1522. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023783", 6) == EQUAL &&
  1523. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateNotAllowedAtThisEVSE == YES)
  1524. {
  1525. memcpy(code, "023783", 6);
  1526. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1527. isCleanCheck = true;
  1528. }
  1529. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023784", 6) == EQUAL &&
  1530. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsGAChargeStop == YES)
  1531. {
  1532. memcpy(code, "023784", 6);
  1533. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1534. isCleanCheck = true;
  1535. }
  1536. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023785", 6) == EQUAL &&
  1537. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsAlignmentError == YES)
  1538. {
  1539. memcpy(code, "023785", 6);
  1540. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1541. isCleanCheck = true;
  1542. }
  1543. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023786", 6) == EQUAL &&
  1544. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsACDError == YES)
  1545. {
  1546. memcpy(code, "023786", 6);
  1547. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1548. isCleanCheck = true;
  1549. }
  1550. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023787", 6) == EQUAL &&
  1551. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsAssociationError == YES)
  1552. {
  1553. memcpy(code, "023787", 6);
  1554. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1555. isCleanCheck = true;
  1556. }
  1557. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023788", 6) == EQUAL &&
  1558. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVSEChargeAbort == YES)
  1559. {
  1560. memcpy(code, "023788", 6);
  1561. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1562. isCleanCheck = true;
  1563. }
  1564. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023789", 6) == EQUAL &&
  1565. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoSupportedAppProtocol == YES)
  1566. {
  1567. memcpy(code, "023789", 6);
  1568. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1569. isCleanCheck = true;
  1570. }
  1571. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023790", 6) == EQUAL &&
  1572. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractNotAccepted == YES)
  1573. {
  1574. memcpy(code, "023790", 6);
  1575. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1576. isCleanCheck = true;
  1577. }
  1578. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023791", 6) == EQUAL &&
  1579. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMOUnknown == YES)
  1580. {
  1581. memcpy(code, "023791", 6);
  1582. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1583. isCleanCheck = true;
  1584. }
  1585. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023792", 6) == EQUAL &&
  1586. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_Prov_CertificateRevoke == YES)
  1587. {
  1588. memcpy(code, "023792", 6);
  1589. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1590. isCleanCheck = true;
  1591. }
  1592. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023793", 6) == EQUAL &&
  1593. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_SubCA1_CertificateRevoked == YES)
  1594. {
  1595. memcpy(code, "023793", 6);
  1596. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1597. isCleanCheck = true;
  1598. }
  1599. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023794", 6) == EQUAL &&
  1600. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_SubCA2_CertificateRevoked == YES)
  1601. {
  1602. memcpy(code, "023794", 6);
  1603. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1604. isCleanCheck = true;
  1605. }
  1606. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023795", 6) == EQUAL &&
  1607. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_RootCA_CertificateRevoked == YES)
  1608. {
  1609. memcpy(code, "023795", 6);
  1610. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1611. isCleanCheck = true;
  1612. }
  1613. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023796", 6) == EQUAL &&
  1614. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_Prov_CertificateRevoked == YES)
  1615. {
  1616. memcpy(code, "023796", 6);
  1617. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1618. isCleanCheck = true;
  1619. }
  1620. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023797", 6) == EQUAL &&
  1621. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_SubCA1_CertificateRevoked == YES)
  1622. {
  1623. memcpy(code, "023797", 6);
  1624. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1625. isCleanCheck = true;
  1626. }
  1627. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023798", 6) == EQUAL &&
  1628. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_SubCA2_CertificateRevoked == YES)
  1629. {
  1630. memcpy(code, "023798", 6);
  1631. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1632. isCleanCheck = true;
  1633. }
  1634. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023799", 6) == EQUAL &&
  1635. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_RootCA_CertificateRevoked == YES)
  1636. {
  1637. memcpy(code, "023799", 6);
  1638. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1639. isCleanCheck = true;
  1640. }
  1641. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023800", 6) == EQUAL &&
  1642. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_Prov_CertificateRevoked == YES)
  1643. {
  1644. memcpy(code, "023800", 6);
  1645. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1646. isCleanCheck = true;
  1647. }
  1648. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023801", 6) == EQUAL &&
  1649. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_SubCA1_CertificateRevoked == YES)
  1650. {
  1651. memcpy(code, "023801", 6);
  1652. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1653. isCleanCheck = true;
  1654. }
  1655. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023802", 6) == EQUAL &&
  1656. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_SubCA2_CertificateRevoked == YES)
  1657. {
  1658. memcpy(code, "023802", 6);
  1659. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1660. isCleanCheck = true;
  1661. }
  1662. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023803", 6) == EQUAL &&
  1663. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_RootCA_CertificateRevoked == YES)
  1664. {
  1665. memcpy(code, "023803", 6);
  1666. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1667. isCleanCheck = true;
  1668. }
  1669. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023809", 6) == EQUAL &&
  1670. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_SLAC_init == YES)
  1671. {
  1672. memcpy(code, "023809", 6);
  1673. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1674. isCleanCheck = true;
  1675. }
  1676. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023810", 6) == EQUAL &&
  1677. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_match_response == YES)
  1678. {
  1679. memcpy(code, "023810", 6);
  1680. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1681. isCleanCheck = true;
  1682. }
  1683. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023811", 6) == EQUAL &&
  1684. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_match_sequence == YES)
  1685. {
  1686. memcpy(code, "023811", 6);
  1687. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1688. isCleanCheck = true;
  1689. }
  1690. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023812", 6) == EQUAL &&
  1691. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_match_MNBC == YES)
  1692. {
  1693. memcpy(code, "023812", 6);
  1694. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1695. isCleanCheck = true;
  1696. }
  1697. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023813", 6) == EQUAL &&
  1698. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_avg_atten_calc == YES)
  1699. {
  1700. memcpy(code, "023813", 6);
  1701. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1702. isCleanCheck = true;
  1703. }
  1704. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023814", 6) == EQUAL &&
  1705. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_match_response == YES)
  1706. {
  1707. memcpy(code, "023814", 6);
  1708. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1709. isCleanCheck = true;
  1710. }
  1711. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023815", 6) == EQUAL &&
  1712. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_match_session == YES)
  1713. {
  1714. memcpy(code, "023815", 6);
  1715. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1716. isCleanCheck = true;
  1717. }
  1718. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023816", 6) == EQUAL &&
  1719. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_assoc_session == YES)
  1720. {
  1721. memcpy(code, "023816", 6);
  1722. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1723. isCleanCheck = true;
  1724. }
  1725. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023817", 6) == EQUAL &&
  1726. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_vald_toggle == YES)
  1727. {
  1728. memcpy(code, "023817", 6);
  1729. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1730. isCleanCheck = true;
  1731. }
  1732. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023818", 6) == EQUAL &&
  1733. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccSlacTimeoutCmMnbcSound == YES)
  1734. {
  1735. memcpy(code, "023818", 6);
  1736. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1737. isCleanCheck = true;
  1738. }
  1739. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023819", 6) == EQUAL &&
  1740. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccSlacTimeoutCmValidateReq == YES)
  1741. {
  1742. memcpy(code, "023819", 6);
  1743. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1744. isCleanCheck = true;
  1745. }
  1746. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023823", 6) == EQUAL &&
  1747. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUDP_TT_match_join == YES)
  1748. {
  1749. memcpy(code, "023823", 6);
  1750. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1751. isCleanCheck = true;
  1752. }
  1753. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023824", 6) == EQUAL &&
  1754. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTCP_TT_match_join == YES)
  1755. {
  1756. memcpy(code, "023824", 6);
  1757. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1758. isCleanCheck = true;
  1759. }
  1760. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023825", 6) == EQUAL &&
  1761. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_amp_map_exchange == YES)
  1762. {
  1763. memcpy(code, "023825", 6);
  1764. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1765. isCleanCheck = true;
  1766. }
  1767. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023826", 6) == EQUAL &&
  1768. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_link_ready_notification == YES)
  1769. {
  1770. memcpy(code, "023826", 6);
  1771. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1772. isCleanCheck = true;
  1773. }
  1774. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023832", 6) == EQUAL &&
  1775. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSupportedAppProtocolRes == YES)
  1776. {
  1777. memcpy(code, "023832", 6);
  1778. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1779. isCleanCheck = true;
  1780. }
  1781. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023833", 6) == EQUAL &&
  1782. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSessionSetupRes == YES)
  1783. {
  1784. memcpy(code, "023833", 6);
  1785. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1786. isCleanCheck = true;
  1787. }
  1788. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023834", 6) == EQUAL &&
  1789. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceDiscoveryRes == YES)
  1790. {
  1791. memcpy(code, "023834", 6);
  1792. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1793. isCleanCheck = true;
  1794. }
  1795. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023835", 6) == EQUAL &&
  1796. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServicePaymentSelectionRes == YES)
  1797. {
  1798. memcpy(code, "023835", 6);
  1799. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1800. isCleanCheck = true;
  1801. }
  1802. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023836", 6) == EQUAL &&
  1803. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractAuthenticationRes == YES)
  1804. {
  1805. memcpy(code, "023836", 6);
  1806. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1807. isCleanCheck = true;
  1808. }
  1809. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023837", 6) == EQUAL &&
  1810. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargeParameterDiscoveryRes == YES)
  1811. {
  1812. memcpy(code, "023837", 6);
  1813. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1814. isCleanCheck = true;
  1815. }
  1816. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023838", 6) == EQUAL &&
  1817. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPowerDeliveryRes == YES)
  1818. {
  1819. memcpy(code, "023838", 6);
  1820. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1821. isCleanCheck = true;
  1822. }
  1823. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023839", 6) == EQUAL &&
  1824. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCableCheckRes == YES)
  1825. {
  1826. memcpy(code, "023839", 6);
  1827. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1828. isCleanCheck = true;
  1829. }
  1830. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023840", 6) == EQUAL &&
  1831. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPreChargeRes == YES)
  1832. {
  1833. memcpy(code, "023840", 6);
  1834. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1835. isCleanCheck = true;
  1836. }
  1837. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023841", 6) == EQUAL &&
  1838. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCurrentDemandRes == YES)
  1839. {
  1840. memcpy(code, "023841", 6);
  1841. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1842. isCleanCheck = true;
  1843. }
  1844. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023842", 6) == EQUAL &&
  1845. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWeldingDetectionRes == YES)
  1846. {
  1847. memcpy(code, "023842", 6);
  1848. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1849. isCleanCheck = true;
  1850. }
  1851. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023843", 6) == EQUAL &&
  1852. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSessionStopRes == YES)
  1853. {
  1854. memcpy(code, "023843", 6);
  1855. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1856. isCleanCheck = true;
  1857. }
  1858. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023844", 6) == EQUAL &&
  1859. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSequence_Time == YES)
  1860. {
  1861. memcpy(code, "023844", 6);
  1862. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1863. isCleanCheck = true;
  1864. }
  1865. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023845", 6) == EQUAL &&
  1866. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsReadyToCharge_Performance_Time == YES)
  1867. {
  1868. memcpy(code, "023845", 6);
  1869. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1870. isCleanCheck = true;
  1871. }
  1872. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023846", 6) == EQUAL &&
  1873. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCommunicationSetup_Performance_Time == YES)
  1874. {
  1875. memcpy(code, "023846", 6);
  1876. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1877. isCleanCheck = true;
  1878. }
  1879. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023847", 6) == EQUAL &&
  1880. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCableCheck_Performance_Time == YES)
  1881. {
  1882. memcpy(code, "023847", 6);
  1883. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1884. isCleanCheck = true;
  1885. }
  1886. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023848", 6) == EQUAL &&
  1887. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPState_Detection_Time == YES)
  1888. {
  1889. memcpy(code, "023848", 6);
  1890. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1891. isCleanCheck = true;
  1892. }
  1893. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023849", 6) == EQUAL &&
  1894. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPOscillator_Retain_Time == YES)
  1895. {
  1896. memcpy(code, "023849", 6);
  1897. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1898. isCleanCheck = true;
  1899. }
  1900. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023850", 6) == EQUAL &&
  1901. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccTimeoutV2GPreChargePerformaceTime == YES)
  1902. {
  1903. memcpy(code, "023850", 6);
  1904. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1905. isCleanCheck = true;
  1906. }
  1907. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023855", 6) == EQUAL &&
  1908. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_EV_TARGET_INFO == YES)
  1909. {
  1910. memcpy(code, "023855", 6);
  1911. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1912. isCleanCheck = true;
  1913. }
  1914. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023856", 6) == EQUAL &&
  1915. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_EV_TARGET_INFO == YES)
  1916. {
  1917. memcpy(code, "023856", 6);
  1918. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1919. isCleanCheck = true;
  1920. }
  1921. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023857", 6) == EQUAL &&
  1922. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_EV_BATTERY_INFO == YES)
  1923. {
  1924. memcpy(code, "023857", 6);
  1925. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1926. isCleanCheck = true;
  1927. }
  1928. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023858", 6) == EQUAL &&
  1929. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_EV_BATTERY_INFO == YES)
  1930. {
  1931. memcpy(code, "023858", 6);
  1932. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1933. isCleanCheck = true;
  1934. }
  1935. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023859", 6) == EQUAL &&
  1936. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EV_STOP_EVENT == YES)
  1937. {
  1938. memcpy(code, "023859", 6);
  1939. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1940. isCleanCheck = true;
  1941. }
  1942. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023860", 6) == EQUAL &&
  1943. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EV_STOP_EVENT == YES)
  1944. {
  1945. memcpy(code, "023860", 6);
  1946. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1947. isCleanCheck = true;
  1948. }
  1949. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023861", 6) == EQUAL &&
  1950. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_STOP_EVENT == YES)
  1951. {
  1952. memcpy(code, "023861", 6);
  1953. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1954. isCleanCheck = true;
  1955. }
  1956. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023862", 6) == EQUAL &&
  1957. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_STOP_EVENT == YES)
  1958. {
  1959. memcpy(code, "023862", 6);
  1960. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1961. isCleanCheck = true;
  1962. }
  1963. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023863", 6) == EQUAL &&
  1964. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_MISC_INFO == YES)
  1965. {
  1966. memcpy(code, "023863", 6);
  1967. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1968. isCleanCheck = true;
  1969. }
  1970. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023864", 6) == EQUAL &&
  1971. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_MISC_INFO == YES)
  1972. {
  1973. memcpy(code, "023864", 6);
  1974. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1975. isCleanCheck = true;
  1976. }
  1977. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023865", 6) == EQUAL &&
  1978. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DOWNLOAD_REQUEST == YES)
  1979. {
  1980. memcpy(code, "023865", 6);
  1981. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1982. isCleanCheck = true;
  1983. }
  1984. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023866", 6) == EQUAL &&
  1985. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DOWNLOAD_REQUEST == YES)
  1986. {
  1987. memcpy(code, "023866", 6);
  1988. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1989. isCleanCheck = true;
  1990. }
  1991. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023867", 6) == EQUAL &&
  1992. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_START_BLOCK_TRANSFER == YES)
  1993. {
  1994. memcpy(code, "023867", 6);
  1995. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  1996. isCleanCheck = true;
  1997. }
  1998. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023868", 6) == EQUAL &&
  1999. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_START_BLOCK_TRANSFER == YES)
  2000. {
  2001. memcpy(code, "023868", 6);
  2002. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2003. isCleanCheck = true;
  2004. }
  2005. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023869", 6) == EQUAL &&
  2006. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DATA_TRANSFER == YES)
  2007. {
  2008. memcpy(code, "023869", 6);
  2009. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2010. isCleanCheck = true;
  2011. }
  2012. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023870", 6) == EQUAL &&
  2013. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DATA_TRANSFER == YES)
  2014. {
  2015. memcpy(code, "023870", 6);
  2016. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2017. isCleanCheck = true;
  2018. }
  2019. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023871", 6) == EQUAL &&
  2020. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DOWNLOAD_FINISH == YES)
  2021. {
  2022. memcpy(code, "023871", 6);
  2023. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2024. isCleanCheck = true;
  2025. }
  2026. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023872", 6) == EQUAL &&
  2027. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DOWNLOAD_FINISH == YES)
  2028. {
  2029. memcpy(code, "023872", 6);
  2030. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2031. isCleanCheck = true;
  2032. }
  2033. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023873", 6) == EQUAL &&
  2034. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_ISOLATION_STATUS == YES)
  2035. {
  2036. memcpy(code, "023873", 6);
  2037. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2038. isCleanCheck = true;
  2039. }
  2040. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023874", 6) == EQUAL &&
  2041. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_ISOLATION_STATUS == YES)
  2042. {
  2043. memcpy(code, "023874", 6);
  2044. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2045. isCleanCheck = true;
  2046. }
  2047. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023875", 6) == EQUAL &&
  2048. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_CONNECTOR_INFO == YES)
  2049. {
  2050. memcpy(code, "023875", 6);
  2051. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2052. isCleanCheck = true;
  2053. }
  2054. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023876", 6) == EQUAL &&
  2055. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_CONNECTOR_INFO == YES)
  2056. {
  2057. memcpy(code, "023876", 6);
  2058. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2059. isCleanCheck = true;
  2060. }
  2061. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023877", 6) == EQUAL &&
  2062. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_RTC_INFO == YES)
  2063. {
  2064. memcpy(code, "023877", 6);
  2065. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2066. isCleanCheck = true;
  2067. }
  2068. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023878", 6) == EQUAL &&
  2069. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_RTC_INFO == YES)
  2070. {
  2071. memcpy(code, "023878", 6);
  2072. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2073. isCleanCheck = true;
  2074. }
  2075. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023879", 6) == EQUAL &&
  2076. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_PRECHARGE_INFO == YES)
  2077. {
  2078. memcpy(code, "023879", 6);
  2079. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2080. isCleanCheck = true;
  2081. }
  2082. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023880", 6) == EQUAL &&
  2083. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_PRECHARGE_INFO == YES)
  2084. {
  2085. memcpy(code, "023880", 6);
  2086. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2087. isCleanCheck = true;
  2088. }
  2089. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023881", 6) == EQUAL &&
  2090. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMSG_Sequence == YES)
  2091. {
  2092. memcpy(code, "023881", 6);
  2093. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2094. isCleanCheck = true;
  2095. }
  2096. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023882", 6) == EQUAL &&
  2097. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCAN_MSG_Unrecognized_CMD_ID == YES)
  2098. {
  2099. memcpy(code, "023882", 6);
  2100. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2101. isCleanCheck = true;
  2102. }
  2103. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023883", 6) == EQUAL &&
  2104. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsDIN_Msg_Decode_Error == YES)
  2105. {
  2106. memcpy(code, "023883", 6);
  2107. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2108. isCleanCheck = true;
  2109. }
  2110. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023884", 6) == EQUAL &&
  2111. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsDIN_Msg_Encode_Error == YES)
  2112. {
  2113. memcpy(code, "023884", 6);
  2114. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2115. isCleanCheck = true;
  2116. }
  2117. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023885", 6) == EQUAL &&
  2118. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO1_Msg_Decode_Error == YES)
  2119. {
  2120. memcpy(code, "023885", 6);
  2121. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2122. isCleanCheck = true;
  2123. }
  2124. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023886", 6) == EQUAL &&
  2125. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO1_Msg_Encode_Error == YES)
  2126. {
  2127. memcpy(code, "023886", 6);
  2128. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2129. isCleanCheck = true;
  2130. }
  2131. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023887", 6) == EQUAL &&
  2132. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO2_Msg_Decode_Error == YES)
  2133. {
  2134. memcpy(code, "023887", 6);
  2135. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2136. isCleanCheck = true;
  2137. }
  2138. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023888", 6) == EQUAL &&
  2139. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO2_Msg_Encode_Error == YES)
  2140. {
  2141. memcpy(code, "023888", 6);
  2142. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2143. isCleanCheck = true;
  2144. }
  2145. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023889", 6) == EQUAL &&
  2146. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCpStatus_Error == YES)
  2147. {
  2148. memcpy(code, "023889", 6);
  2149. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2150. isCleanCheck = true;
  2151. }
  2152. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023890", 6) == EQUAL &&
  2153. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUnexpectVolBeforeCharing_Error == YES)
  2154. {
  2155. memcpy(code, "023890", 6);
  2156. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2157. isCleanCheck = true;
  2158. }
  2159. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023891", 6) == EQUAL &&
  2160. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccNotReadyForCharging == YES)
  2161. {
  2162. memcpy(code, "023891", 6);
  2163. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2164. isCleanCheck = true;
  2165. }
  2166. // "023892" CcsSeccTimeoutQCA7000Comm is fault event, will never recoverable until to QCA 7000 data installed.
  2167. else if (strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "023893", 6) == EQUAL &&
  2168. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccFailForQCA7000SetKey == YES)
  2169. {
  2170. memcpy(code, "023893", 6);
  2171. memcpy(_chargingData[gun_index]->EvConnAlarmCode, "", 6);
  2172. isCleanCheck = true;
  2173. }
  2174. if (isCleanCheck)
  2175. {
  2176. for (byte index = 0; index < ShmSysConfigAndInfo->SysConfig.TotalConnectorCount; index++)
  2177. {
  2178. if (index != gun_index || ShmSysConfigAndInfo->SysConfig.TotalConnectorCount == 1)
  2179. {
  2180. PRINTF_FUNC("CCS clean error : index = %d, EvConnAlarmCode = %s, code = %s \n", index, _chargingData[index]->EvConnAlarmCode, code);
  2181. if (strncmp((char *)_chargingData[index]->EvConnAlarmCode, code, 6) != EQUAL)
  2182. {
  2183. if (strncmp(code, "023701", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEvCommFail = NO;
  2184. if (strncmp(code, "023737", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsRESTemperatureInhibit = NO;
  2185. if (strncmp(code, "023738", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVShiftPosition = NO;
  2186. if (strncmp(code, "023739", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargerConnectorLockFault = NO;
  2187. if (strncmp(code, "023740", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVRESSMalfunction = NO;
  2188. if (strncmp(code, "023741", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingCurrentdifferential = NO;
  2189. if (strncmp(code, "023742", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingVoltageOutOfRange = NO;
  2190. if (strncmp(code, "023743", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingSystemIncompatibility = NO;
  2191. if (strncmp(code, "023744", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEmergencyEvent = NO;
  2192. if (strncmp(code, "023745", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsBreaker = NO;
  2193. if (strncmp(code, "023746", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoData = NO;
  2194. if (strncmp(code, "023747", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_A = NO;
  2195. if (strncmp(code, "023748", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_B = NO;
  2196. if (strncmp(code, "023749", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_C = NO;
  2197. if (strncmp(code, "023750", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_1 = NO;
  2198. if (strncmp(code, "023751", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_2 = NO;
  2199. if (strncmp(code, "023752", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_3 = NO;
  2200. if (strncmp(code, "023753", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_1 = NO;
  2201. if (strncmp(code, "023754", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_2 = NO;
  2202. if (strncmp(code, "023755", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_3 = NO;
  2203. if (strncmp(code, "023756", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_4 = NO;
  2204. if (strncmp(code, "023757", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_5 = NO;
  2205. if (strncmp(code, "023758", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSequenceError = NO;
  2206. if (strncmp(code, "023759", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSignatureError = NO;
  2207. if (strncmp(code, "023760", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUnknownSession = NO;
  2208. if (strncmp(code, "023761", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceIDInvalid = NO;
  2209. if (strncmp(code, "023762", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPaymentSelectionInvalid = NO;
  2210. if (strncmp(code, "023763", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsIdentificationSelectionInvalid = NO;
  2211. if (strncmp(code, "023764", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceSelectionInvalid = NO;
  2212. if (strncmp(code, "023765", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateExpired = NO;
  2213. if (strncmp(code, "023766", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateNotYetValid = NO;
  2214. if (strncmp(code, "023767", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateRevoked = NO;
  2215. if (strncmp(code, "023768", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoCertificateAvailable = NO;
  2216. if (strncmp(code, "023769", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertChainError = NO;
  2217. if (strncmp(code, "023770", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertValidationError = NO;
  2218. if (strncmp(code, "023771", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertVerificationError = NO;
  2219. if (strncmp(code, "023772", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractCanceled = NO;
  2220. if (strncmp(code, "023773", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChallengeInvalid = NO;
  2221. if (strncmp(code, "023774", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWrongEnergyTransferMode = NO;
  2222. if (strncmp(code, "023775", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWrongChargeParameter = NO;
  2223. if (strncmp(code, "023776", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingProfileInvalid = NO;
  2224. if (strncmp(code, "023777", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTariffSelectionInvalid = NO;
  2225. if (strncmp(code, "023778", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVSEPresentVoltageToLow = NO;
  2226. if (strncmp(code, "023779", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPowerDeliveryNotApplied = NO;
  2227. if (strncmp(code, "023780", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMeteringSignatureNotValid = NO;
  2228. if (strncmp(code, "023781", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoChargeServiceSelected = NO;
  2229. if (strncmp(code, "023782", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContactorError = NO;
  2230. if (strncmp(code, "023783", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateNotAllowedAtThisEVSE = NO;
  2231. if (strncmp(code, "023784", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsGAChargeStop = NO;
  2232. if (strncmp(code, "023785", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsAlignmentError = NO;
  2233. if (strncmp(code, "023786", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsACDError = NO;
  2234. if (strncmp(code, "023787", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsAssociationError = NO;
  2235. if (strncmp(code, "023788", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVSEChargeAbort = NO;
  2236. if (strncmp(code, "023789", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoSupportedAppProtocol = NO;
  2237. if (strncmp(code, "023790", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractNotAccepted = NO;
  2238. if (strncmp(code, "023791", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMOUnknown = NO;
  2239. if (strncmp(code, "023792", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_Prov_CertificateRevoke = NO;
  2240. if (strncmp(code, "023793", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_SubCA1_CertificateRevoked = NO;
  2241. if (strncmp(code, "023794", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_SubCA2_CertificateRevoked = NO;
  2242. if (strncmp(code, "023795", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_RootCA_CertificateRevoked = NO;
  2243. if (strncmp(code, "023796", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_Prov_CertificateRevoked = NO;
  2244. if (strncmp(code, "023797", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_SubCA1_CertificateRevoked = NO;
  2245. if (strncmp(code, "023798", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_SubCA2_CertificateRevoked = NO;
  2246. if (strncmp(code, "023799", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_RootCA_CertificateRevoked = NO;
  2247. if (strncmp(code, "023800", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_Prov_CertificateRevoked = NO;
  2248. if (strncmp(code, "023801", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_SubCA1_CertificateRevoked = NO;
  2249. if (strncmp(code, "023802", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_SubCA2_CertificateRevoked = NO;
  2250. if (strncmp(code, "023803", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_RootCA_CertificateRevoked = NO;
  2251. if (strncmp(code, "023809", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_SLAC_init = NO;
  2252. if (strncmp(code, "023810", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_match_response = NO;
  2253. if (strncmp(code, "023811", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_match_sequence = NO;
  2254. if (strncmp(code, "023812", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_match_MNBC = NO;
  2255. if (strncmp(code, "023813", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_avg_atten_calc = NO;
  2256. if (strncmp(code, "023814", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_match_response = NO;
  2257. if (strncmp(code, "023815", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_match_session = NO;
  2258. if (strncmp(code, "023816", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_assoc_session = NO;
  2259. if (strncmp(code, "023817", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_vald_toggle = NO;
  2260. if (strncmp(code, "023818", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccSlacTimeoutCmMnbcSound = NO;
  2261. if (strncmp(code, "023819", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccSlacTimeoutCmValidateReq = NO;
  2262. if (strncmp(code, "023823", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUDP_TT_match_join = NO;
  2263. if (strncmp(code, "023824", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTCP_TT_match_join = NO;
  2264. if (strncmp(code, "023825", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_amp_map_exchange = NO;
  2265. if (strncmp(code, "023826", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_link_ready_notification = NO;
  2266. if (strncmp(code, "023832", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSupportedAppProtocolRes = NO;
  2267. if (strncmp(code, "023833", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSessionSetupRes = NO;
  2268. if (strncmp(code, "023834", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceDiscoveryRes = NO;
  2269. if (strncmp(code, "023835", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServicePaymentSelectionRes = NO;
  2270. if (strncmp(code, "023836", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractAuthenticationRes = NO;
  2271. if (strncmp(code, "023837", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargeParameterDiscoveryRes = NO;
  2272. if (strncmp(code, "023838", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPowerDeliveryRes = NO;
  2273. if (strncmp(code, "023839", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCableCheckRes = NO;
  2274. if (strncmp(code, "023840", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPreChargeRes = NO;
  2275. if (strncmp(code, "023841", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCurrentDemandRes = NO;
  2276. if (strncmp(code, "023842", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWeldingDetectionRes = NO;
  2277. if (strncmp(code, "023843", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSessionStopRes = NO;
  2278. if (strncmp(code, "023844", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSequence_Time = NO;
  2279. if (strncmp(code, "023845", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsReadyToCharge_Performance_Time = NO;
  2280. if (strncmp(code, "023846", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCommunicationSetup_Performance_Time = NO;
  2281. if (strncmp(code, "023847", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCableCheck_Performance_Time = NO;
  2282. if (strncmp(code, "023848", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPState_Detection_Time = NO;
  2283. if (strncmp(code, "023849", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPOscillator_Retain_Time = NO;
  2284. if (strncmp(code, "023850", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccTimeoutV2GPreChargePerformaceTime = NO;
  2285. if (strncmp(code, "023855", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_EV_TARGET_INFO = NO;
  2286. if (strncmp(code, "023856", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_EV_TARGET_INFO = NO;
  2287. if (strncmp(code, "023857", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_EV_BATTERY_INFO = NO;
  2288. if (strncmp(code, "023858", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_EV_BATTERY_INFO = NO;
  2289. if (strncmp(code, "023859", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EV_STOP_EVENT = NO;
  2290. if (strncmp(code, "023860", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EV_STOP_EVENT = NO;
  2291. if (strncmp(code, "023861", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_STOP_EVENT = NO;
  2292. if (strncmp(code, "023862", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_STOP_EVENT = NO;
  2293. if (strncmp(code, "023863", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_MISC_INFO = NO;
  2294. if (strncmp(code, "023864", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_MISC_INFO = NO;
  2295. if (strncmp(code, "023865", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DOWNLOAD_REQUEST = NO;
  2296. if (strncmp(code, "023866", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DOWNLOAD_REQUEST = NO;
  2297. if (strncmp(code, "023867", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_START_BLOCK_TRANSFER = NO;
  2298. if (strncmp(code, "023868", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_START_BLOCK_TRANSFER = NO;
  2299. if (strncmp(code, "023869", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DATA_TRANSFER = NO;
  2300. if (strncmp(code, "023870", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DATA_TRANSFER = NO;
  2301. if (strncmp(code, "023871", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DOWNLOAD_FINISH = NO;
  2302. if (strncmp(code, "023872", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DOWNLOAD_FINISH = NO;
  2303. if (strncmp(code, "023873", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_ISOLATION_STATUS = NO;
  2304. if (strncmp(code, "023874", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_ISOLATION_STATUS = NO;
  2305. if (strncmp(code, "023875", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_CONNECTOR_INFO = NO;
  2306. if (strncmp(code, "023876", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_CONNECTOR_INFO = NO;
  2307. if (strncmp(code, "023877", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_RTC_INFO = NO;
  2308. if (strncmp(code, "023878", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_RTC_INFO = NO;
  2309. if (strncmp(code, "023879", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_PRECHARGE_INFO = NO;
  2310. if (strncmp(code, "023880", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_PRECHARGE_INFO = NO;
  2311. if (strncmp(code, "023881", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMSG_Sequence = NO;
  2312. if (strncmp(code, "023882", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCAN_MSG_Unrecognized_CMD_ID = NO;
  2313. if (strncmp(code, "023883", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsDIN_Msg_Decode_Error = NO;
  2314. if (strncmp(code, "023884", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsDIN_Msg_Encode_Error = NO;
  2315. if (strncmp(code, "023885", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO1_Msg_Decode_Error = NO;
  2316. if (strncmp(code, "023886", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO1_Msg_Encode_Error = NO;
  2317. if (strncmp(code, "023887", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO2_Msg_Decode_Error = NO;
  2318. if (strncmp(code, "023888", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO2_Msg_Encode_Error = NO;
  2319. if (strncmp(code, "023889", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCpStatus_Error = NO;
  2320. if (strncmp(code, "023890", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUnexpectVolBeforeCharing_Error = NO;
  2321. if (strncmp(code, "023891", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccNotReadyForCharging = NO;
  2322. // "023892" CcsSeccTimeoutQCA7000Comm is fault event, will never recoverable until to QCA 7000 data installed.
  2323. if (strncmp(code, "023893", 6) == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccFailForQCA7000SetKey = NO;
  2324. }
  2325. }
  2326. }
  2327. }
  2328. }
  2329. void AbnormalStopAnalysis(byte gun_index, byte *errCode)
  2330. {
  2331. char string[7];
  2332. sprintf(string, "%d%d%d%d%d%d", *(errCode + 0), *(errCode + 1), *(errCode + 2), *(errCode + 3), *(errCode + 4), *(errCode + 5));
  2333. PRINTF_FUNC("NOTIFICATION_EV_STOP : Err Code = %s \n", string);
  2334. if (strncmp(string, "000000", 6) == EQUAL ||
  2335. strncmp((char *)_chargingData[gun_index]->EvConnAlarmCode, "", 6) != EQUAL)
  2336. return;
  2337. memcpy(_chargingData[gun_index]->EvConnAlarmCode, string, 6);
  2338. PRINTF_FUNC("NOTIFICATION_EV_STOP : EvConnAlarmCode = %s \n", _chargingData[gun_index]->EvConnAlarmCode);
  2339. if (strcmp(string, "023700") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoEvCommFail = YES;
  2340. if (strcmp(string, "023704") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryMalfun = YES;
  2341. if (strcmp(string, "023705") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoNoPermission = YES;
  2342. if (strcmp(string, "023706") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryIncompatibility = YES;
  2343. if (strcmp(string, "023707") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOVP = YES;
  2344. if (strcmp(string, "023708") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryUVP = YES;
  2345. if (strcmp(string, "023709") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOTP = YES;
  2346. if (strcmp(string, "023710") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryCurrentDiff = YES;
  2347. if (strcmp(string, "023711") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryVoltageDiff = YES;
  2348. if (strcmp(string, "023712") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoShiftPosition = YES;
  2349. if (strcmp(string, "023713") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBatteryOtherFault = YES;
  2350. if (strcmp(string, "023714") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargingSystemError = YES;
  2351. if (strcmp(string, "023715") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoEvNormalStop = YES;
  2352. if (strcmp(string, "023716") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoTempSensorBroken = YES;
  2353. if (strcmp(string, "023717") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoConnectorLockFail = YES;
  2354. if (strcmp(string, "023718") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoD1OnNoReceive = YES;
  2355. if (strcmp(string, "023719") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsKtoJTimeout = YES;
  2356. if (strcmp(string, "023720") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsChargeAllowTimeout = YES;
  2357. if (strcmp(string, "023721") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoWaitGfdTimeout = YES;
  2358. if (strcmp(string, "023722") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsEvRelayTimeout = YES;
  2359. if (strcmp(string, "023723") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsReqCurrentTimeout = YES;
  2360. if (strcmp(string, "023724") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsKtoJOffTimeout = YES;
  2361. if (strcmp(string, "023725") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsEvRelayOffTimeout = YES;
  2362. if (strcmp(string, "023726") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoAdcMoreThan10V = YES;
  2363. if (strcmp(string, "023727") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoAdcMoreThan20V = YES;
  2364. if (strcmp(string, "023728") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoBmsChargeBeforeStop = YES;
  2365. if (strcmp(string, "023729") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargerGetNormalStop = YES;
  2366. if (strcmp(string, "023730") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargerGetEmergencyStop = YES;
  2367. if (strcmp(string, "023731") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoIsolationResultFail = YES;
  2368. if (strcmp(string, "023732") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoMissLinkWithMotherBoard = YES;
  2369. if (strcmp(string, "023733") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoOutputVolMoreThanLimit = YES;
  2370. if (strcmp(string, "023734") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoReqCurrentMoreThanLimit = YES;
  2371. if (strcmp(string, "023735") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoReCapBmsEqrCurrentExceed = YES;
  2372. if (strcmp(string, "023736") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ChademoChargeRemainCountDown = YES;
  2373. if (strcmp(string, "023701") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEvCommFail = YES;
  2374. if (strcmp(string, "023737") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsRESTemperatureInhibit = YES;
  2375. if (strcmp(string, "023738") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVShiftPosition = YES;
  2376. if (strcmp(string, "023739") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargerConnectorLockFault = YES;
  2377. if (strcmp(string, "023740") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVRESSMalfunction = YES;
  2378. if (strcmp(string, "023741") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingCurrentdifferential = YES;
  2379. if (strcmp(string, "023742") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingVoltageOutOfRange = YES;
  2380. if (strcmp(string, "023743") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingSystemIncompatibility = YES;
  2381. if (strcmp(string, "023744") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEmergencyEvent = YES;
  2382. if (strcmp(string, "023745") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsBreaker = YES;
  2383. if (strcmp(string, "023746") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoData = YES;
  2384. if (strcmp(string, "023747") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_A = YES;
  2385. if (strcmp(string, "023748") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_B = YES;
  2386. if (strcmp(string, "023749") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_DIN_C = YES;
  2387. if (strcmp(string, "023750") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_1 = YES;
  2388. if (strcmp(string, "023751") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_2 = YES;
  2389. if (strcmp(string, "023752") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_ISO_3 = YES;
  2390. if (strcmp(string, "023753") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_1 = YES;
  2391. if (strcmp(string, "023754") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_2 = YES;
  2392. if (strcmp(string, "023755") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_3 = YES;
  2393. if (strcmp(string, "023756") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_4 = YES;
  2394. if (strcmp(string, "023757") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.Ccsreserved_by_OEM_5 = YES;
  2395. if (strcmp(string, "023758") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSequenceError = YES;
  2396. if (strcmp(string, "023759") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSignatureError = YES;
  2397. if (strcmp(string, "023760") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUnknownSession = YES;
  2398. if (strcmp(string, "023761") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceIDInvalid = YES;
  2399. if (strcmp(string, "023762") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPaymentSelectionInvalid = YES;
  2400. if (strcmp(string, "023763") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsIdentificationSelectionInvalid = YES;
  2401. if (strcmp(string, "023764") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceSelectionInvalid = YES;
  2402. if (strcmp(string, "023765") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateExpired = YES;
  2403. if (strcmp(string, "023766") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateNotYetValid = YES;
  2404. if (strcmp(string, "023767") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateRevoked = YES;
  2405. if (strcmp(string, "023768") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoCertificateAvailable = YES;
  2406. if (strcmp(string, "023769") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertChainError = YES;
  2407. if (strcmp(string, "023770") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertValidationError = YES;
  2408. if (strcmp(string, "023771") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertVerificationError = YES;
  2409. if (strcmp(string, "023772") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractCanceled = YES;
  2410. if (strcmp(string, "023773") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChallengeInvalid = YES;
  2411. if (strcmp(string, "023774") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWrongEnergyTransferMode = YES;
  2412. if (strcmp(string, "023775") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWrongChargeParameter = YES;
  2413. if (strcmp(string, "023776") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargingProfileInvalid = YES;
  2414. if (strcmp(string, "023777") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTariffSelectionInvalid = YES;
  2415. if (strcmp(string, "023778") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVSEPresentVoltageToLow = YES;
  2416. if (strcmp(string, "023779") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPowerDeliveryNotApplied = YES;
  2417. if (strcmp(string, "023780") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMeteringSignatureNotValid = YES;
  2418. if (strcmp(string, "023781") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoChargeServiceSelected = YES;
  2419. if (strcmp(string, "023782") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContactorError = YES;
  2420. if (strcmp(string, "023783") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCertificateNotAllowedAtThisEVSE = YES;
  2421. if (strcmp(string, "023784") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsGAChargeStop = YES;
  2422. if (strcmp(string, "023785") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsAlignmentError = YES;
  2423. if (strcmp(string, "023786") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsACDError = YES;
  2424. if (strcmp(string, "023787") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsAssociationError = YES;
  2425. if (strcmp(string, "023788") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsEVSEChargeAbort = YES;
  2426. if (strcmp(string, "023789") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsNoSupportedAppProtocol = YES;
  2427. if (strcmp(string, "023790") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractNotAccepted = YES;
  2428. if (strcmp(string, "023791") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMOUnknown = YES;
  2429. if (strcmp(string, "023792") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_Prov_CertificateRevoke = YES;
  2430. if (strcmp(string, "023793") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_SubCA1_CertificateRevoked = YES;
  2431. if (strcmp(string, "023794") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_SubCA2_CertificateRevoked = YES;
  2432. if (strcmp(string, "023795") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsOEM_RootCA_CertificateRevoked = YES;
  2433. if (strcmp(string, "023796") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_Prov_CertificateRevoked = YES;
  2434. if (strcmp(string, "023797") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_SubCA1_CertificateRevoked = YES;
  2435. if (strcmp(string, "023798") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_SubCA2_CertificateRevoked = YES;
  2436. if (strcmp(string, "023799") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMO_RootCA_CertificateRevoked = YES;
  2437. if (strcmp(string, "023800") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_Prov_CertificateRevoked = YES;
  2438. if (strcmp(string, "023801") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_SubCA1_CertificateRevoked = YES;
  2439. if (strcmp(string, "023802") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_SubCA2_CertificateRevoked = YES;
  2440. if (strcmp(string, "023803") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPS_RootCA_CertificateRevoked = YES;
  2441. if (strcmp(string, "023809") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_SLAC_init = YES;
  2442. if (strcmp(string, "023810") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_match_response = YES;
  2443. if (strcmp(string, "023811") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_match_sequence = YES;
  2444. if (strcmp(string, "023812") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_match_MNBC = YES;
  2445. if (strcmp(string, "023813") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_avg_atten_calc = YES;
  2446. if (strcmp(string, "023814") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_match_response = YES;
  2447. if (strcmp(string, "023815") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_match_session = YES;
  2448. if (strcmp(string, "023816") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_assoc_session = YES;
  2449. if (strcmp(string, "023817") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_vald_toggle = YES;
  2450. if (strcmp(string, "023818") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccSlacTimeoutCmMnbcSound = YES;
  2451. if (strcmp(string, "023819") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccSlacTimeoutCmValidateReq = YES;
  2452. if (strcmp(string, "023823") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUDP_TT_match_join = YES;
  2453. if (strcmp(string, "023824") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTCP_TT_match_join = YES;
  2454. if (strcmp(string, "023825") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_amp_map_exchange = YES;
  2455. if (strcmp(string, "023826") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_link_ready_notification = YES;
  2456. if (strcmp(string, "023832") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSupportedAppProtocolRes = YES;
  2457. if (strcmp(string, "023833") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSessionSetupRes = YES;
  2458. if (strcmp(string, "023834") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServiceDiscoveryRes = YES;
  2459. if (strcmp(string, "023835") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsServicePaymentSelectionRes = YES;
  2460. if (strcmp(string, "023836") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsContractAuthenticationRes = YES;
  2461. if (strcmp(string, "023837") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsChargeParameterDiscoveryRes = YES;
  2462. if (strcmp(string, "023838") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPowerDeliveryRes = YES;
  2463. if (strcmp(string, "023839") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCableCheckRes = YES;
  2464. if (strcmp(string, "023840") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsPreChargeRes = YES;
  2465. if (strcmp(string, "023841") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCurrentDemandRes = YES;
  2466. if (strcmp(string, "023842") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsWeldingDetectionRes = YES;
  2467. if (strcmp(string, "023843") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSessionStopRes = YES;
  2468. if (strcmp(string, "023844") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSequence_Time = YES;
  2469. if (strcmp(string, "023845") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsReadyToCharge_Performance_Time = YES;
  2470. if (strcmp(string, "023846") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCommunicationSetup_Performance_Time = YES;
  2471. if (strcmp(string, "023847") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCableCheck_Performance_Time = YES;
  2472. if (strcmp(string, "023848") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPState_Detection_Time = YES;
  2473. if (strcmp(string, "023849") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCPOscillator_Retain_Time = YES;
  2474. if (strcmp(string, "023850") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccTimeoutV2GPreChargePerformaceTime = YES;
  2475. if (strcmp(string, "023855") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_EV_TARGET_INFO = YES;
  2476. if (strcmp(string, "023856") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_EV_TARGET_INFO = YES;
  2477. if (strcmp(string, "023857") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_EV_BATTERY_INFO = YES;
  2478. if (strcmp(string, "023858") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_EV_BATTERY_INFO = YES;
  2479. if (strcmp(string, "023859") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EV_STOP_EVENT = YES;
  2480. if (strcmp(string, "023860") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EV_STOP_EVENT = YES;
  2481. if (strcmp(string, "023861") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_STOP_EVENT = YES;
  2482. if (strcmp(string, "023862") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_STOP_EVENT = YES;
  2483. if (strcmp(string, "023863") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_GET_MISC_INFO = YES;
  2484. if (strcmp(string, "023864") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_GET_MISC_INFO = YES;
  2485. if (strcmp(string, "023865") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DOWNLOAD_REQUEST = YES;
  2486. if (strcmp(string, "023866") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DOWNLOAD_REQUEST = YES;
  2487. if (strcmp(string, "023867") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_START_BLOCK_TRANSFER = YES;
  2488. if (strcmp(string, "023868") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_START_BLOCK_TRANSFER = YES;
  2489. if (strcmp(string, "023869") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DATA_TRANSFER = YES;
  2490. if (strcmp(string, "023870") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DATA_TRANSFER = YES;
  2491. if (strcmp(string, "023871") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_DOWNLOAD_FINISH = YES;
  2492. if (strcmp(string, "023872") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_DOWNLOAD_FINISH = YES;
  2493. if (strcmp(string, "023873") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_ISOLATION_STATUS = YES;
  2494. if (strcmp(string, "023874") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_ISOLATION_STATUS = YES;
  2495. if (strcmp(string, "023875") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_CONNECTOR_INFO = YES;
  2496. if (strcmp(string, "023876") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_CONNECTOR_INFO = YES;
  2497. if (strcmp(string, "023877") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_RTC_INFO = YES;
  2498. if (strcmp(string, "023878") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_RTC_INFO = YES;
  2499. if (strcmp(string, "023879") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTP_EVSE_PRECHARGE_INFO = YES;
  2500. if (strcmp(string, "023880") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsTT_EVSE_PRECHARGE_INFO = YES;
  2501. if (strcmp(string, "023881") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsMSG_Sequence = YES;
  2502. if (strcmp(string, "023882") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCAN_MSG_Unrecognized_CMD_ID = YES;
  2503. if (strcmp(string, "023883") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsDIN_Msg_Decode_Error = YES;
  2504. if (strcmp(string, "023884") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsDIN_Msg_Encode_Error = YES;
  2505. if (strcmp(string, "023885") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO1_Msg_Decode_Error = YES;
  2506. if (strcmp(string, "023886") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO1_Msg_Encode_Error = YES;
  2507. if (strcmp(string, "023887") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO2_Msg_Decode_Error = YES;
  2508. if (strcmp(string, "023888") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsISO2_Msg_Encode_Error = YES;
  2509. if (strcmp(string, "023889") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsCpStatus_Error = YES;
  2510. if (strcmp(string, "023890") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsUnexpectVolBeforeCharing_Error = YES;
  2511. if (strcmp(string, "023891") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccNotReadyForCharging = YES;
  2512. if (strcmp(string, "023892") == EQUAL)
  2513. {
  2514. ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccTimeoutQCA7000Comm = YES;
  2515. //CcsSeccTimeoutQCA7000Comm is fault event, should enter fix page.
  2516. ShmSysConfigAndInfo->SysWarningInfo.Level = 2;
  2517. }
  2518. if (strcmp(string, "023893") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.CcsSeccFailForQCA7000SetKey = YES;
  2519. if (strcmp(string, "023702") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.GbEvCommFail = YES;
  2520. if (strcmp(string, "023900") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_LOS_CC1 = YES;
  2521. if (strcmp(string, "023901") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CONNECTOR_LOCK_FAIL = YES;
  2522. if (strcmp(string, "023902") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BATTERY_INCOMPATIBLE = YES;
  2523. if (strcmp(string, "023903") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_BROAA_TIMEOUT = YES;
  2524. if (strcmp(string, "023904") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CSU_PRECHARGE_TIMEOUT = YES;
  2525. if (strcmp(string, "023905") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_PRESENT_VOLTAGE_FAULT = YES;
  2526. if (strcmp(string, "023906") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BMS_VOLTAGE_OVER_RANGE = YES;
  2527. if (strcmp(string, "023907") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_BSM_CHARGE_ALLOW_00_10MIN_COUUNTDONE = YES;
  2528. if (strcmp(string, "023908") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_WAIT_GROUNDFAULT_TIMEOUT = YES;
  2529. if (strcmp(string, "023909") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ADC_MORE_THAN_10V = YES;
  2530. if (strcmp(string, "023910") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ADC_MORE_THAN_60V = YES;
  2531. if (strcmp(string, "023911") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CHARGER_GET_NORMAL_STOP_CMD = YES;
  2532. if (strcmp(string, "023912") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_CHARGER_GET_EMERGENCY_STOP_CMD = YES;
  2533. if (strcmp(string, "023913") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_ISOLATION_RESULT_FAIL = YES;
  2534. if (strcmp(string, "023914") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_MOTHER_BOARD_MISS_LINK = YES;
  2535. if (strcmp(string, "023915") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_MORE_THAN_LIMIT = YES;
  2536. if (strcmp(string, "023916") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_REQ_CURRENT_MORE_THAN_LIMIT = YES;
  2537. if (strcmp(string, "023917") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_MORE_THAN_10_PERCENT = YES;
  2538. if (strcmp(string, "023918") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_OUTPUT_VOLTAGE_DIFF_BCS_5_PERCENT = YES;
  2539. if (strcmp(string, "023919") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GBT_STOP_ADC_MORE_THAN_10V = YES;
  2540. if (strcmp(string, "023930") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BHM_TIMEOUT = YES;
  2541. if (strcmp(string, "023931") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BRM_TIMEOUT = YES;
  2542. if (strcmp(string, "023932") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCP_TIMEOUT = YES;
  2543. if (strcmp(string, "023933") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BRO_TIMEOUT = YES;
  2544. if (strcmp(string, "023934") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCL_TIMEOUT = YES;
  2545. if (strcmp(string, "023935") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BCS_TIMEOUT = YES;
  2546. if (strcmp(string, "023936") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BSM_TIMEOUT = YES;
  2547. if (strcmp(string, "023937") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BST_TIMEOUT = YES;
  2548. if (strcmp(string, "023938") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BSD_TIMEOUT = YES;
  2549. if (strcmp(string, "023939") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_CEM_BEM_OTHER_TIMEOUT = YES;
  2550. if (strcmp(string, "023940") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRM_TIMEOUT = YES;
  2551. if (strcmp(string, "023941") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRMAA_TIMEOUT = YES;
  2552. if (strcmp(string, "023942") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CTS_CML_TIMEOUT = YES;
  2553. if (strcmp(string, "023943") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CRO_TIMEOUT = YES;
  2554. if (strcmp(string, "023944") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CCS_TIMEOUT = YES;
  2555. if (strcmp(string, "023945") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CST_TIMEOUT = YES;
  2556. if (strcmp(string, "023946") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_CSD_TIMEOUT = YES;
  2557. if (strcmp(string, "023947") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BEM_BEM_OTHER_TIMEOUT = YES;
  2558. if (strcmp(string, "023950") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_SOC_GOAL = YES;
  2559. if (strcmp(string, "023951") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_TOTAL_VOLTAGE_GOAL = YES;
  2560. if (strcmp(string, "023952") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CELL_VOLTAGE_GOAL = YES;
  2561. if (strcmp(string, "023953") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_GET_CST = YES;
  2562. if (strcmp(string, "023954") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_ISOLATION = YES;
  2563. if (strcmp(string, "023955") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OUTPUT_CONNECTOR_OTP = YES;
  2564. if (strcmp(string, "023956") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_COMPONENT = YES;
  2565. if (strcmp(string, "023957") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CHARGE_CONNECTOR = YES;
  2566. if (strcmp(string, "023958") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OTP = YES;
  2567. if (strcmp(string, "023959") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_OTHER = YES;
  2568. if (strcmp(string, "023960") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_HIGH_V = YES;
  2569. if (strcmp(string, "023961") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CC2 = YES;
  2570. if (strcmp(string, "023962") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_CURRENT = YES;
  2571. if (strcmp(string, "023963") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BST_VOLTAGE = YES;
  2572. if (strcmp(string, "023964") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_GET_BST_NO_REASON = YES;
  2573. if (strcmp(string, "023970") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CELL_OVER_VOLTAGE = YES;
  2574. if (strcmp(string, "023971") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CELL_UNDER_VOLTAGE = YES;
  2575. if (strcmp(string, "023972") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_OVER_SOC = YES;
  2576. if (strcmp(string, "023973") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_UNDER_SOC = YES;
  2577. if (strcmp(string, "023974") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_CURRENT = YES;
  2578. if (strcmp(string, "023975") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_TEMPERATURE = YES;
  2579. if (strcmp(string, "023976") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_ISOLATE = YES;
  2580. if (strcmp(string, "023977") == EQUAL) ShmStatusCodeData->InfoCode.InfoEvents.bits.ERROR_CODE_BSM_OUTPUT_CONNECTOR = YES;
  2581. }
  2582. void CANReceiver()
  2583. {
  2584. pid_t canRecPid;
  2585. canRecPid = fork();
  2586. if(canRecPid > 0)
  2587. {
  2588. int nbytes;
  2589. struct can_frame frame;
  2590. int intCmd;
  2591. // 槍資訊
  2592. struct ChargingInfoData *_chargingData[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  2593. struct timeval _cmd_ack_timeout[CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY];
  2594. bool isPass = false;
  2595. gun_count = ShmSysConfigAndInfo->SysConfig.TotalConnectorCount;
  2596. while(!isPass)
  2597. {
  2598. isPass = true;
  2599. for (byte _index = 0; _index < gun_count; _index++)
  2600. {
  2601. if (!FindChargingInfoData(_index, &_chargingData[0]))
  2602. {
  2603. DEBUG_ERROR("EvComm (main) : FindChargingInfoData false \n");
  2604. isPass = false;
  2605. break;
  2606. }
  2607. }
  2608. sleep(1);
  2609. }
  2610. for (byte _index = 0; _index < gun_count; _index++)
  2611. gettimeofday(&_cmd_ack_timeout[_index], NULL);
  2612. while (1)
  2613. {
  2614. memset(&frame, 0, sizeof(struct can_frame));
  2615. nbytes = read(CanFd, &frame, sizeof(struct can_frame));
  2616. for (byte _index = 0; _index < gun_count; _index++)
  2617. {
  2618. if (GetTimeoutValue(_cmd_ack_timeout[_index]) >= 5000000)
  2619. {
  2620. // ACK timeout
  2621. //PRINTF_FUNC("gun = %x, ack timeout \n", _index);
  2622. }
  2623. }
  2624. if (nbytes > 0)
  2625. {
  2626. byte target;
  2627. byte targetGun = 0x00;
  2628. intCmd = (int) (frame.can_id & CAN_EFF_MASK);
  2629. if (intCmd == ADDRESS_REQ)
  2630. {
  2631. AddrAssignment(frame.data);
  2632. continue;
  2633. }
  2634. intCmd = (int) (frame.can_id & CAN_EFF_MASK & 0xFFFFFF00);
  2635. target = ((byte) (frame.can_id & 0x000000FF)); // 0x01 or 0x02
  2636. for (byte _index = 0; _index < gun_count; _index++)
  2637. {
  2638. if (_chargingData[_index]->Evboard_id == target)
  2639. {
  2640. targetGun = _index;
  2641. break;
  2642. }
  2643. }
  2644. if(targetGun < 0 || targetGun >= CHAdeMO_QUANTITY + CCS_QUANTITY + GB_QUANTITY)
  2645. {
  2646. PRINTF_FUNC("EvComm (CANReceiver) : Target index = %x is < 0 or > QUANTITY \n", targetGun);
  2647. continue;
  2648. }
  2649. if(intCmd == 256)
  2650. {
  2651. continue;
  2652. }
  2653. gettimeofday(&_cmd_ack_timeout[targetGun], NULL);
  2654. switch (intCmd)
  2655. {
  2656. case NOTIFICATION_EV_STATUS:
  2657. {
  2658. if (_chargingData[targetGun]->ConnectorPlugIn != frame.data[0])
  2659. PRINTF_FUNC("index = %d, ConnectorPlugIn = %x, data[0] = %x \n", targetGun, _chargingData[targetGun]->ConnectorPlugIn, frame.data[0]);
  2660. _chargingData[targetGun]->ConnectorPlugIn = frame.data[0];
  2661. _chargingData[targetGun]->PilotVoltage = frame.data[1];
  2662. //PRINTF_FUNC("index = %d, ConnectorPlugIn = %x, data[0] = %x \n", targetGun, _chargingData[targetGun]->ConnectorPlugIn, frame.data[0]);
  2663. //PRINTF_FUNC("ConnectorPlugIn = %x \n", (-120 + frame.data[1]) / 10);
  2664. }
  2665. break;
  2666. case ACK_EV_FW_VERSION:
  2667. {
  2668. byte ver[16];
  2669. memset(ver, 0, sizeof(ver));
  2670. if (_chargingData[targetGun]->Type == _Type_Chademo)
  2671. {
  2672. memcpy(ver, frame.data, frame.can_dlc);
  2673. memcpy(ShmCHAdeMOData->evse[_chargingData[targetGun]->type_index].version, ver, ARRAY_SIZE(ver));
  2674. ShmCHAdeMOData->evse[_chargingData[targetGun]->type_index].SelfTest_Comp = PASS;
  2675. PRINTF_FUNC("chademo ver. : %s\n", ShmCHAdeMOData->evse[_chargingData[targetGun]->type_index].version);
  2676. }
  2677. else if (_chargingData[targetGun]->Type == _Type_GB)
  2678. {
  2679. memcpy(ver, frame.data, frame.can_dlc);
  2680. memcpy(ShmGBTData->evse[_chargingData[targetGun]->type_index].version, ver, ARRAY_SIZE(ver));
  2681. ShmGBTData->evse[_chargingData[targetGun]->type_index].SelfTest_Comp = PASS;
  2682. PRINTF_FUNC("gbt ver. : %s\n", ShmGBTData->evse[_chargingData[targetGun]->type_index].version);
  2683. }
  2684. else if (_chargingData[targetGun]->Type == _Type_CCS_2)
  2685. {
  2686. if (ShmCcsData->CommProtocol == _CCS_COMM_V2GMessage_DIN70121)
  2687. {
  2688. //For previous CCS test version, if the firmware version without '.', insert '.'(0x2E) into array.
  2689. if(frame.data[2] != 0x2E)
  2690. {
  2691. for (byte _vCount = 0, _vPoint = 0; _vCount < frame.can_dlc; _vCount++)
  2692. {
  2693. if (_vCount % 2 == 0 && _vCount != 0)
  2694. {
  2695. ver[_vCount + _vPoint] = 0x2E;
  2696. _vPoint++;
  2697. }
  2698. ver[_vCount + _vPoint] = frame.data[_vCount];
  2699. }
  2700. }
  2701. //For formal CCS firmware version, use the string from CCS directly.
  2702. else
  2703. {
  2704. memcpy(ver, frame.data, frame.can_dlc);
  2705. }
  2706. memcpy(&ShmCcsData->V2GMessage_DIN70121[_chargingData[targetGun]->type_index].version, ver, ARRAY_SIZE(ver));
  2707. ShmCcsData->V2GMessage_DIN70121[_chargingData[targetGun]->type_index].SelfTest_Comp = PASS;
  2708. PRINTF_FUNC("CCS FW = %s \n", ShmCcsData->V2GMessage_DIN70121[_chargingData[targetGun]->type_index].version);
  2709. }
  2710. }
  2711. if (targetGun == 0)
  2712. {
  2713. memset(ShmSysConfigAndInfo->SysInfo.Connector1FwRev, 0, sizeof(ShmSysConfigAndInfo->SysInfo.Connector1FwRev));
  2714. memcpy(ShmSysConfigAndInfo->SysInfo.Connector1FwRev, ver, ARRAY_SIZE(ver));
  2715. }
  2716. else
  2717. {
  2718. memset(ShmSysConfigAndInfo->SysInfo.Connector2FwRev, 0, sizeof(ShmSysConfigAndInfo->SysInfo.Connector2FwRev));
  2719. memcpy(ShmSysConfigAndInfo->SysInfo.Connector2FwRev, ver, ARRAY_SIZE(ver));
  2720. }
  2721. }
  2722. break;
  2723. case ACK_EV_HW_VERSION:
  2724. {
  2725. //PRINTF_FUNC("Get EV HW = %s \n", frame.data);
  2726. }
  2727. break;
  2728. case ACK_GET_OUTPUT_REQ:
  2729. {
  2730. _chargingData[targetGun]->EvBatterySoc = frame.data[1];
  2731. _chargingData[targetGun]->EvBatterytargetVoltage = (float)((frame.data[3] << 8) + frame.data[2]) / 10;
  2732. _chargingData[targetGun]->EvBatterytargetCurrent = (float)((frame.data[5] << 8) + frame.data[4]) / 10;
  2733. _chargingData[targetGun]->RemainChargingDuration = ((short) frame.data[7] << 8) + (short) frame.data[6];
  2734. if (_chargingData[targetGun]->Type == _Type_Chademo)
  2735. {
  2736. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].PresentMsgFlowStatus = frame.data[0];
  2737. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].EvDetection = frame.data[0];
  2738. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].SOC = _chargingData[targetGun]->EvBatterySoc;
  2739. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].TargetBatteryVoltage = (_chargingData[targetGun]->EvBatterytargetVoltage * 10);
  2740. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].ChargingCurrentRequest = (_chargingData[targetGun]->EvBatterytargetCurrent * 10);
  2741. }
  2742. else if (_chargingData[targetGun]->Type == _Type_GB)
  2743. {
  2744. ShmGBTData->ev[_chargingData[targetGun]->type_index].PresentMsgFlowStatus = frame.data[0];
  2745. ShmGBTData->ev[_chargingData[targetGun]->type_index].EvDetection = frame.data[0];
  2746. ShmGBTData->ev[_chargingData[targetGun]->type_index].SOC = _chargingData[targetGun]->EvBatterySoc;
  2747. ShmGBTData->ev[_chargingData[targetGun]->type_index].TargetBatteryVoltage = (_chargingData[targetGun]->EvBatterytargetVoltage * 10);
  2748. ShmGBTData->ev[_chargingData[targetGun]->type_index].ChargingCurrentRequest = (_chargingData[targetGun]->EvBatterytargetCurrent * 10);
  2749. }
  2750. else if (_chargingData[targetGun]->Type == _Type_CCS_2)
  2751. {
  2752. if(ShmCcsData->CommProtocol == _CCS_COMM_V2GMessage_DIN70121)
  2753. {
  2754. ShmCcsData->V2GMessage_DIN70121[_chargingData[targetGun]->type_index].PresentMsgFlowStatus = frame.data[0];
  2755. }
  2756. }
  2757. //PRINTF_FUNC("EvBatterytargetVoltage = %f \n", _chargingData[targetGun]->EvBatterytargetVoltage);
  2758. //PRINTF_FUNC("EvBatterytargetCurrent = %f \n", _chargingData[targetGun]->EvBatterytargetCurrent);
  2759. //PRINTF_FUNC("BatteryVoltage = %d \n", ShmCHAdeMOData->ev[_chargingData[target]->type_index].TargetBatteryVoltage);
  2760. //PRINTF_FUNC("CurrentRequest = %d \n", ShmCHAdeMOData->ev[_chargingData[target]->type_index].ChargingCurrentRequest);
  2761. }
  2762. break;
  2763. case ACK_GET_EV_BATTERY_INFO:
  2764. {
  2765. //_chargingData[target].EvACorDCcharging = frame.data[0];
  2766. //_chargingData[target]->TotalBatteryCap = ((float) frame.data[4] << 8) + (short) frame.data[3];
  2767. _chargingData[targetGun]->EvBatteryMaxVoltage = (((short) frame.data[4] << 8) + (short) frame.data[3]) / 10;
  2768. //_chargingData[target]->EvBatteryMaxCurrent = ((float) frame.data[4] << 8) + (short) frame.data[3];
  2769. //_chargingData[target].MaxiBatteryCurrent = ((short) frame.data[6] << 8) + (short) frame.data[5];
  2770. if (_chargingData[targetGun]->Type == _Type_Chademo)
  2771. {
  2772. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].TotalBatteryCapacity = ((short) frame.data[2] << 8) + (short) frame.data[1];
  2773. ShmCHAdeMOData->ev[_chargingData[targetGun]->type_index].MaxiBatteryVoltage = _chargingData[targetGun]->EvBatteryMaxVoltage;
  2774. //PRINTF_FUNC("EvBatteryMaxVoltage = %f \n", _chargingData[target]->EvBatteryMaxVoltage);
  2775. //PRINTF_FUNC("TotalBatteryCapacity = %d \n", ShmCHAdeMOData->ev[_chargingData[target]->type_index].TotalBatteryCapacity);
  2776. //PRINTF_FUNC("MaxiBatteryVoltage = %d \n", ShmCHAdeMOData->ev[_chargingData[target]->type_index].MaxiBatteryVoltage);
  2777. }
  2778. else if (_chargingData[targetGun]->Type == _Type_GB)
  2779. {
  2780. ShmGBTData->ev[_chargingData[targetGun]->type_index].TotalBatteryCapacity = ((short) frame.data[2] << 8) + (short) frame.data[1];
  2781. ShmGBTData->ev[_chargingData[targetGun]->type_index].MaxiBatteryVoltage = _chargingData[targetGun]->EvBatteryMaxVoltage;
  2782. }
  2783. else if (_chargingData[targetGun]->Type == _Type_CCS_2)
  2784. {
  2785. }
  2786. }
  2787. break;
  2788. case ACK_GET_MISCELLANEOUS_INFO:
  2789. {
  2790. _chargingData[targetGun]->GunLocked = frame.data[0];
  2791. _chargingData[targetGun]->PilotVoltage = (float)(-120 + frame.data[3]) / 10;
  2792. if (_chargingData[targetGun]->Type == _Type_Chademo)
  2793. {
  2794. ShmCHAdeMOData->evse[_chargingData[targetGun]->type_index].ConnectorTemperatureP = frame.data[1];
  2795. ShmCHAdeMOData->evse[_chargingData[targetGun]->type_index].ConnectorTemperatureN = frame.data[2];
  2796. ShmCHAdeMOData->evse[_chargingData[targetGun]->type_index].EvboardStatus = frame.data[7];
  2797. }
  2798. else if (_chargingData[targetGun]->Type == _Type_GB)
  2799. {
  2800. ShmGBTData->evse[_chargingData[targetGun]->type_index].ConnectorTemperatureP = frame.data[1];
  2801. ShmGBTData->evse[_chargingData[targetGun]->type_index].ConnectorTemperatureN = frame.data[2];
  2802. ShmGBTData->evse[_chargingData[targetGun]->type_index].EvboardStatus = frame.data[7];
  2803. }
  2804. else if (_chargingData[targetGun]->Type == _Type_CCS_2)
  2805. {
  2806. if (ShmCcsData->CommProtocol == _CCS_COMM_V2GMessage_DIN70121)
  2807. {
  2808. //ShmCcsData->V2GMessage_DIN70121[_chargingData[targetGun]->type_index]. .ConnectorTemperatureP = frame.data[1];
  2809. //ShmCcsData->V2GMessage_DIN70121[_chargingData[targetGun]->type_index]. .ConnectorTemperatureN = frame.data[2];
  2810. }
  2811. }
  2812. //PRINTF_FUNC("EvboardStatus = %x \n", ShmCHAdeMOData->evse[_chargingData[target]->type_index].EvboardStatus);
  2813. //PRINTF_FUNC("ConnectorPlug locked = %x \n", frame.data[0]);
  2814. //PRINTF_FUNC("ConnectorTemp 0= %d \n", ShmCHAdeMOData->evse[_chargingData[target]->type_index].ConnectorTemperatureP);
  2815. //PRINTF_FUNC("ConnectorTemp 1= %d \n", ShmCHAdeMOData->evse[_chargingData[target]->type_index].ConnectorTemperatureN);
  2816. //PRINTF_FUNC("PilotVoltage = %x \n", (-120 + frame.data[3]) / 10);
  2817. }
  2818. break;
  2819. case ACK_EVSE_ISOLATION_STATUS: {}
  2820. break;
  2821. case ACK_EVSE_PRECHAGE_INFO:
  2822. {
  2823. _chargingData[targetGun]->PrechargeStatus = frame.data[0];
  2824. }
  2825. break;
  2826. case NOTIFICATION_EV_STOP:
  2827. {
  2828. // 車端要求停止
  2829. // frame.data[0] : 0x01 => normal stop, 0x02 => ev emergency stop
  2830. PRINTF_FUNC("(%d) NOTIFICATION_EV_STOP err level = %d-----------------------------\n", targetGun, frame.data[0]);
  2831. AbnormalStopAnalysis(targetGun, frame.data + 1);
  2832. _chargingData[targetGun]->StopChargeFlag = YES;
  2833. }
  2834. break;
  2835. default:
  2836. PRINTF_FUNC("EV board = %d, Ack none defined. intCmd = %d \n", targetGun, intCmd);
  2837. break;
  2838. }
  2839. }
  2840. usleep(10000);
  2841. }
  2842. }
  2843. }
  2844. //================================================
  2845. // Main process
  2846. //================================================
  2847. // 檢查 Byte 中某個 Bit 的值
  2848. // _byte : 欲改變的 byte
  2849. // _bit : 該 byte 的第幾個 bit
  2850. unsigned char EvDetectionStatus(unsigned char _byte, unsigned char _bit)
  2851. {
  2852. return ( _byte & mask_table[_bit] ) != 0x00;
  2853. }
  2854. bool IsConnectorPlugIn(struct ChargingInfoData *chargingData)
  2855. {
  2856. return (chargingData->ConnectorPlugIn == 0x01) ? true : false;
  2857. }
  2858. void SetPresentChargingOutputPower(struct ChargingInfoData *chargingData_1, struct ChargingInfoData *chargingData_2)
  2859. {
  2860. float vol1 = 0, cur1 = 0;
  2861. float vol2 = 0, cur2 = 0;
  2862. vol1 = chargingData_1->FireChargingVoltage;
  2863. cur1 = (chargingData_1->PresentChargingCurrent * 10);
  2864. vol2 = chargingData_2->FireChargingVoltage;
  2865. cur2 = (chargingData_2->PresentChargingCurrent * 10);
  2866. if (_outVol_1 != vol1 ||
  2867. _outCur_1 != cur1 ||
  2868. _outVol_2 != vol2 ||
  2869. _outCur_2 != cur2)
  2870. {
  2871. PRINTF_FUNC("G1 -> Output Vol = %f, Output Cur = %f -- G2 -> Output Vol = %f, Output Cur = %f \n",
  2872. vol1, cur1, vol2, cur2);
  2873. _outVol_1 = vol1; _outCur_1 = cur1; _outVol_2 = vol2; _outCur_2 = cur2;
  2874. }
  2875. SetPresentOutputPower(vol1, cur1, vol2, cur2);
  2876. }
  2877. void SetPresentChargingOutputCap(struct ChargingInfoData *chargingData_1, struct ChargingInfoData *chargingData_2)
  2878. {
  2879. float pow1 = 0, cur1 = 0;
  2880. float pow2 = 0, cur2 = 0;
  2881. float vol = 0;
  2882. pow1 = chargingData_1->AvailableChargingPower;
  2883. cur1 = chargingData_1->AvailableChargingCurrent;
  2884. vol = chargingData_1->MaximumChargingVoltage;
  2885. GetMaxVolAndCurMethod(chargingData_1->Index, &vol, &cur1);
  2886. GetMaxPowerMethod(chargingData_1->Index, &pow1);
  2887. pow2 = chargingData_2->AvailableChargingPower;
  2888. cur2 = chargingData_2->AvailableChargingCurrent;
  2889. vol = chargingData_2->MaximumChargingVoltage;
  2890. GetMaxVolAndCurMethod(chargingData_2->Index, &vol, &cur2);
  2891. GetMaxPowerMethod(chargingData_2->Index, &pow2);
  2892. if (_pow_1 != pow1 ||
  2893. _cur_1 != cur1 ||
  2894. _pow_2 != pow2 ||
  2895. _cur_2 != cur2)
  2896. {
  2897. PRINTF_FUNC("To EV (Real) Power_1 = %f, Cur_1 = %f, Power_2 = %f, Cur_2 = %f \n",
  2898. pow1, cur1, pow2, cur2);
  2899. _pow_1 = pow1; _cur_1 = cur1; _pow_2 = pow2; _cur_2 = cur2;
  2900. chargingData_1->RealMaxCurrent = _cur_1;
  2901. chargingData_1->RealMaxPower = pow1;
  2902. if (gun_count == 2)
  2903. {
  2904. chargingData_2->RealMaxCurrent = cur2;
  2905. chargingData_2->RealMaxPower = pow2;
  2906. }
  2907. }
  2908. SetPresentOutputCapacity(pow1, cur1, pow2, cur2);
  2909. }
  2910. void Initialization()
  2911. {
  2912. bool isPass = false;
  2913. while(!isPass)
  2914. {
  2915. isPass = true;
  2916. for (byte _index = 0; _index < gun_count; _index++)
  2917. {
  2918. if (!FindChargingInfoData(_index, &_chargingData[0]))
  2919. {
  2920. DEBUG_ERROR("EvComm (main) : FindChargingInfoData false \n");
  2921. isPass = false;
  2922. break;
  2923. }
  2924. }
  2925. sleep(1);
  2926. }
  2927. }
  2928. void GetMaxVolAndCurMethod(byte index, float *vol, float *cur)
  2929. {
  2930. if (maxChargingVol[index] != 0 && maxChargingVol[index] <= *vol)
  2931. *vol = maxChargingVol[index];
  2932. if (maxChargingCur[index] != 0 && maxChargingCur[index] <= *cur)
  2933. *cur = maxChargingCur[index];
  2934. if (_chargingData[index]->SystemStatus == S_CHARGING &&
  2935. _chargingData[index]->ChargingProfileCurrent > 0 &&
  2936. _chargingData[index]->ChargingProfileCurrent <= *cur)
  2937. {
  2938. *cur = _chargingData[index]->ChargingProfileCurrent;
  2939. }
  2940. }
  2941. void GetMaxPowerMethod(byte index, float *pow)
  2942. {
  2943. if (maxChargingPow != 0 && maxChargingPow <= *pow)
  2944. *pow = maxChargingPow;
  2945. if (_chargingData[index]->SystemStatus == S_CHARGING &&
  2946. _chargingData[index]->ChargingProfilePower > 0 &&
  2947. _chargingData[index]->ChargingProfilePower <= *pow)
  2948. {
  2949. *pow = _chargingData[index]->ChargingProfilePower;
  2950. }
  2951. }
  2952. time_t GetRtcInfoForEpoch()
  2953. {
  2954. struct timeb csuTime;
  2955. struct tm *tmCSU;
  2956. struct tm t;
  2957. time_t result;
  2958. ftime(&csuTime);
  2959. tmCSU = localtime(&csuTime.time);
  2960. t.tm_year = tmCSU->tm_year;
  2961. t.tm_mon = tmCSU->tm_mon;
  2962. t.tm_mday = tmCSU->tm_mday;
  2963. t.tm_hour = tmCSU->tm_hour;
  2964. t.tm_min = tmCSU->tm_min;
  2965. t.tm_sec = tmCSU->tm_sec;
  2966. t.tm_isdst = -1;
  2967. result = mktime(&t);
  2968. return result;
  2969. }
  2970. byte GetStopChargingReasonByEvse(byte gunIndex, byte *reason)
  2971. {
  2972. byte result = NO;
  2973. if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.EmergencyStopTrip == 0x01)
  2974. {
  2975. // 012251
  2976. *(reason + 5) = 0;
  2977. *(reason + 4) = 1;
  2978. *(reason + 3) = 2;
  2979. *(reason + 2) = 2;
  2980. *(reason + 1) = 5;
  2981. *(reason + 0) = 1;
  2982. result = YES;
  2983. }
  2984. if (_chargingData[gunIndex]->Type == _Type_Chademo)
  2985. {
  2986. if (ShmStatusCodeData->FaultCode.FaultEvents.bits.ChademoOutputRelayDrivingFault == YES)
  2987. {
  2988. // 011012
  2989. *(reason + 5) = 0;
  2990. *(reason + 4) = 1;
  2991. *(reason + 3) = 1;
  2992. *(reason + 2) = 0;
  2993. *(reason + 1) = 1;
  2994. *(reason + 0) = 2;
  2995. result = YES;
  2996. }
  2997. else if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.ChademoOutputUVPFail == YES)
  2998. {
  2999. // 012289
  3000. *(reason + 5) = 0;
  3001. *(reason + 4) = 1;
  3002. *(reason + 3) = 2;
  3003. *(reason + 2) = 2;
  3004. *(reason + 1) = 8;
  3005. *(reason + 0) = 9;
  3006. result = YES;
  3007. }
  3008. else if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.ChademoGfdTrip == YES)
  3009. {
  3010. // 012234
  3011. *(reason + 5) = 0;
  3012. *(reason + 4) = 1;
  3013. *(reason + 3) = 2;
  3014. *(reason + 2) = 2;
  3015. *(reason + 1) = 3;
  3016. *(reason + 0) = 4;
  3017. result = YES;
  3018. }
  3019. }
  3020. else if (_chargingData[gunIndex]->Type == _Type_GB)
  3021. {
  3022. if (ShmStatusCodeData->FaultCode.FaultEvents.bits.ChademoOutputRelayDrivingFault == YES)
  3023. {
  3024. // 012290
  3025. *(reason + 5) = 0;
  3026. *(reason + 4) = 1;
  3027. *(reason + 3) = 2;
  3028. *(reason + 2) = 2;
  3029. *(reason + 1) = 9;
  3030. *(reason + 0) = 0;
  3031. result = YES;
  3032. }
  3033. else if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.GbGfdTrip == YES)
  3034. {
  3035. // 012236
  3036. *(reason + 5) = 0;
  3037. *(reason + 4) = 1;
  3038. *(reason + 3) = 2;
  3039. *(reason + 2) = 2;
  3040. *(reason + 1) = 3;
  3041. *(reason + 0) = 6;
  3042. result = YES;
  3043. }
  3044. }
  3045. else if (_chargingData[gunIndex]->Type == _Type_CCS_2)
  3046. {
  3047. if (ShmStatusCodeData->FaultCode.FaultEvents.bits.CcsOutputRelayDrivingFault == YES)
  3048. {
  3049. // 011014
  3050. *(reason + 5) = 0;
  3051. *(reason + 4) = 1;
  3052. *(reason + 3) = 1;
  3053. *(reason + 2) = 0;
  3054. *(reason + 1) = 1;
  3055. *(reason + 0) = 4;
  3056. result = YES;
  3057. }
  3058. else if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.CcsOutputUVPFail == YES)
  3059. {
  3060. // 012288
  3061. *(reason + 5) = 0;
  3062. *(reason + 4) = 1;
  3063. *(reason + 3) = 2;
  3064. *(reason + 2) = 2;
  3065. *(reason + 1) = 8;
  3066. *(reason + 0) = 8;
  3067. result = YES;
  3068. }
  3069. else if (ShmStatusCodeData->AlarmCode.AlarmEvents.bits.CcsGfdTrip == YES)
  3070. {
  3071. // 012235
  3072. *(reason + 5) = 0;
  3073. *(reason + 4) = 1;
  3074. *(reason + 3) = 2;
  3075. *(reason + 2) = 2;
  3076. *(reason + 1) = 3;
  3077. *(reason + 0) = 5;
  3078. result = YES;
  3079. }
  3080. }
  3081. return result;
  3082. }
  3083. void SendCommunicationOnly(byte index)
  3084. {
  3085. SetChargingPermission(index, COMMUNICATION,
  3086. _chargingData[index]->AvailableChargingPower,
  3087. 0,
  3088. 0,
  3089. _chargingData[index]->Evboard_id);
  3090. }
  3091. void SendStopOnly(byte index)
  3092. {
  3093. SetChargingPermission(index, STOP,
  3094. _chargingData[index]->AvailableChargingPower,
  3095. 0,
  3096. 0,
  3097. _chargingData[index]->Evboard_id);
  3098. }
  3099. int main(int argc, char *argv[])
  3100. {
  3101. if(InitShareMemory() == FAIL)
  3102. {
  3103. #ifdef SystemLogMessage
  3104. DEBUG_ERROR("InitShareMemory NG\n");
  3105. #endif
  3106. if(ShmStatusCodeData != NULL)
  3107. {
  3108. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory=1;
  3109. }
  3110. sleep(5);
  3111. return 0;
  3112. }
  3113. gun_count = ShmSysConfigAndInfo->SysConfig.TotalConnectorCount;
  3114. Initialization();
  3115. CanFd = InitCanBus();
  3116. CANReceiver();
  3117. byte priorityLow = 1;
  3118. time_t rtc = GetRtcInfoForEpoch();
  3119. while(CanFd)
  3120. {
  3121. for(byte _index = 0; _index < gun_count; _index++)
  3122. {
  3123. if (priorityLow == 1)
  3124. {
  3125. // 優先權較低 - 只要有回應即不會再詢問
  3126. if (_chargingData[_index]->Type == _Type_Chademo &&
  3127. ShmCHAdeMOData->evse[_chargingData[_index]->type_index].SelfTest_Comp != PASS)
  3128. {
  3129. SyncRtcInfo(_index, _chargingData[_index]->Evboard_id, (int)rtc);
  3130. GetFirmwareVersion(_index, _chargingData[_index]->Evboard_id);
  3131. }
  3132. else if (_chargingData[_index]->Type == _Type_GB &&
  3133. ShmGBTData->evse[_chargingData[_index]->type_index].SelfTest_Comp != PASS)
  3134. {
  3135. SyncRtcInfo(_index, _chargingData[_index]->Evboard_id, (int)rtc);
  3136. GetFirmwareVersion(_index, _chargingData[_index]->Evboard_id);
  3137. }
  3138. else if (_chargingData[_index]->Type == _Type_CCS_2)
  3139. {
  3140. if (ShmCcsData->CommProtocol == _CCS_COMM_V2GMessage_DIN70121 &&
  3141. ShmCcsData->V2GMessage_DIN70121[_chargingData[_index]->type_index].SelfTest_Comp != PASS)
  3142. {
  3143. SyncRtcInfo(_index, _chargingData[_index]->Evboard_id, (int)rtc);
  3144. GetFirmwareVersion(_index, _chargingData[_index]->Evboard_id);
  3145. }
  3146. }
  3147. // 固定要取得的資訊 : 1.槍鎖狀態, 2."Connector 1" 溫度, 3."Connector 2" 溫度, 4.Pilot Voltage
  3148. //PRINTF_FUNC("GetMiscellaneousInfo. index = %d, Eid = %d \n", _index, _chargingData[_index]->Evboard_id);
  3149. GetMiscellaneousInfo(_index,
  3150. _chargingData[_index]->RelayK1K2Status,
  3151. _chargingData[_index]->PresentChargedEnergy,
  3152. (_chargingData[_index]->PresentChargingVoltage * 10),
  3153. _chargingData[_index]->Evboard_id);
  3154. }
  3155. switch (_chargingData[_index]->SystemStatus)
  3156. {
  3157. case S_IDLE:
  3158. case S_RESERVATION:
  3159. if (_chargingData[_index]->Type == _Type_Chademo)
  3160. {
  3161. ClearAbnormalStatus_Chademo(_index);
  3162. if (ShmSysConfigAndInfo->SysInfo.PageIndex == _LCM_WAIT_FOR_PLUG)
  3163. {
  3164. if (!chkChademoPermission[_index])
  3165. {
  3166. chkChademoPermission[_index] = true;
  3167. gettimeofday(&_chk_chademo_permission_timeout[_index], NULL);
  3168. SendCommunicationOnly(_index);
  3169. }
  3170. else
  3171. {
  3172. if (GetTimeoutValue(_chk_chademo_permission_timeout[_index]) / 1000 > 10000)
  3173. {
  3174. SendCommunicationOnly(_index);
  3175. gettimeofday(&_chk_chademo_permission_timeout[_index], NULL);
  3176. }
  3177. }
  3178. }
  3179. else if (chkChademoPermission[_index])
  3180. {
  3181. chkChademoPermission[_index] = false;
  3182. SendStopOnly(_index);
  3183. }
  3184. }
  3185. else if (_chargingData[_index]->Type == _Type_GB)
  3186. {
  3187. ClearAbnormalStatus_GB(_index);
  3188. }
  3189. else if (_chargingData[_index]->Type == _Type_CCS_2)
  3190. {
  3191. ClearAbnormalStatus_CCS(_index);
  3192. }
  3193. if (priorityLow == 1)
  3194. {
  3195. _chargingData[_index]->PresentChargedEnergy = 0;
  3196. _chargingData[_index]->PresentChargingPower = 0;
  3197. _chargingData[_index]->GroundFaultStatus = GFD_WAIT;
  3198. _chargingData[_index]->RealRatingPower = 0;
  3199. _chargingData[_index]->StopChargeFlag = NO;
  3200. _chargingData[_index]->ChargingFee = 0.0;
  3201. _chargingData[_index]->EvBatterySoc = 0;
  3202. _chargingData[_index]->PresentChargingVoltage = 0;
  3203. _chargingData[_index]->PresentChargingCurrent = 0;
  3204. _chargingData[_index]->EvBatteryMaxVoltage = 0;
  3205. chargingTime[_index] = 0;
  3206. maxChargingPow = (ShmSysConfigAndInfo->SysConfig.MaxChargingPower * 10);
  3207. }
  3208. break;
  3209. case S_PREPARNING:
  3210. {
  3211. chkChademoPermission[_index] = false;
  3212. // 設定當前輸出
  3213. if (gun_count == 1)
  3214. SetPresentChargingOutputPower(_chargingData[0], _chargingData[0]);
  3215. else if (gun_count == 2)
  3216. SetPresentChargingOutputPower(_chargingData[0], _chargingData[1]);
  3217. _chargingData[_index]->PowerConsumption = 0;
  3218. }
  3219. break;
  3220. case S_PREPARING_FOR_EV:
  3221. {
  3222. // 開始確認車端是否同意開始充電 : 1.SOC, 2.Target Vol, 3.Target Cur, 4.Charging remaining time
  3223. GetOutputReq(_index, _chargingData[_index]->Evboard_id);
  3224. // PRINTF_FUNC("PresentChargingVoltage = %f \n", _chargingData[_index]->PresentChargingVoltage);
  3225. // PRINTF_FUNC("PresentChargingCurrent = %f \n", _chargingData[_index]->PresentChargingCurrent);
  3226. // PRINTF_FUNC("AvailableChargingPower = %f \n", _chargingData[_index]->AvailableChargingPower);
  3227. // PRINTF_FUNC("AvailableChargingCurrent = %f \n", _chargingData[_index]->AvailableChargingCurrent);
  3228. // PRINTF_FUNC("MaximumChargingVoltage = %f \n", _chargingData[_index]->MaximumChargingVoltage);
  3229. // 設定當前輸出
  3230. if (gun_count == 1)
  3231. SetPresentChargingOutputPower(_chargingData[0], _chargingData[0]);
  3232. else if (gun_count == 2)
  3233. SetPresentChargingOutputPower(_chargingData[0], _chargingData[1]);
  3234. if (priorityLow == 1)
  3235. {
  3236. float maxVol, maxCur;
  3237. // 樁端輸出能力
  3238. maxVol = _chargingData[_index]->MaximumChargingVoltage;
  3239. maxCur = _chargingData[_index]->AvailableChargingCurrent;
  3240. GetMaxVolAndCurMethod(_index, &maxVol, &maxCur);
  3241. PRINTF_FUNC("To EV_%d Max_Vol = %f, Cap_Cur = %f, Cap_Pow = %f \n",
  3242. _index, maxVol, maxCur, _chargingData[_index]->AvailableChargingPower);
  3243. _chargingData[_index]->RealMaxVoltage = maxVol;
  3244. SetChargingPermission(_index, START,
  3245. _chargingData[_index]->AvailableChargingPower,
  3246. maxCur,
  3247. maxVol,
  3248. _chargingData[_index]->Evboard_id);
  3249. // 取得車端電池資訊 : 1.AC or DC ? 2.Total battery cap, 3.Max battery vol, 4.Max battery cur
  3250. GetEvBatteryInfo(_index, _chargingData[_index]->Evboard_id);
  3251. }
  3252. gettimeofday(&_chk_ratingPower_timeout[_index], NULL);
  3253. }
  3254. break;
  3255. case S_PREPARING_FOR_EVSE:
  3256. case S_CCS_PRECHARGE_ST0:
  3257. case S_CCS_PRECHARGE_ST1:
  3258. {
  3259. // 開始確認車端是否同意開始充電
  3260. GetOutputReq(_index, _chargingData[_index]->Evboard_id);
  3261. // 設定當前輸出
  3262. if (gun_count == 1)
  3263. SetPresentChargingOutputPower(_chargingData[0], _chargingData[0]);
  3264. else if (gun_count == 2)
  3265. SetPresentChargingOutputPower(_chargingData[0], _chargingData[1]);
  3266. if (priorityLow % 5 == 1)
  3267. {
  3268. // 樁端輸出能力改變
  3269. if (gun_count == 1)
  3270. SetPresentChargingOutputCap(_chargingData[0], _chargingData[0]);
  3271. else if (gun_count == 2)
  3272. SetPresentChargingOutputCap(_chargingData[0], _chargingData[1]);
  3273. }
  3274. // 持續通知 Isolation 測試狀態
  3275. if (priorityLow == 1)
  3276. {
  3277. // 拉 500 V 如果在一秒鐘內 GFD 都符合則 PASS
  3278. // if (_chargingData[_index]->FireChargingVoltage >= 3500)
  3279. // _chargingData[_index]->GroundFaultStatus = GFD_PASS;
  3280. //PRINTF_FUNC("To EV_%d GFD = %d \n", _index, _chargingData[_index]->GroundFaultStatus);
  3281. unsigned char _result = _chargingData[_index]->GroundFaultStatus;
  3282. // GB & Chademo ~ Warning 也先算 Pass,因為 CCS 認證會驗 Warning 故不可更動
  3283. if(_chargingData[_index]->Type == _Type_Chademo ||
  3284. _chargingData[_index]->Type == _Type_GB)
  3285. {
  3286. if (_result == GFD_WARNING)
  3287. {
  3288. _result = GFD_PASS;
  3289. }
  3290. }
  3291. if(_result < GFD_WAIT &&
  3292. _result > GFD_WARNING)
  3293. {
  3294. PRINTF_FUNC("Unexpected GFD status : %d \n", _result);
  3295. _result = GFD_WAIT;
  3296. }
  3297. else if (_result == GFD_WARNING ||
  3298. _result == GFD_PASS)
  3299. {
  3300. if (((GetTimeoutValue(_chk_ratingPower_timeout[_index]) / 1000) > 12000 &&
  3301. _chargingData[_index]->RealRatingPower > 0) ||
  3302. (GetTimeoutValue(_chk_ratingPower_timeout[_index]) / 1000) > 14000)
  3303. {
  3304. PRINTF_FUNC("**********EvComm : _index= %d, RealRatingPower = %d \n",
  3305. _index, _chargingData[_index]->RealRatingPower);
  3306. }
  3307. else
  3308. _result = GFD_WAIT;
  3309. }
  3310. SetIsolationStatus(_index, _result, _chargingData[_index]->Evboard_id);
  3311. if(_chargingData[_index]->SystemStatus == S_CCS_PRECHARGE_ST0 &&
  3312. _chargingData[_index]->PrechargeStatus == PRECHARGE_READY)
  3313. {
  3314. SetEvsePrechargeInfo(_index, PRECHARGE_PRERELAY_PASS, _chargingData[_index]->Evboard_id);
  3315. }
  3316. }
  3317. }
  3318. break;
  3319. case S_CHARGING:
  3320. {
  3321. // 計算 Power
  3322. _chargingData[_index]->PresentChargingPower = ((float)((_chargingData[_index]->PresentChargingVoltage) * (_chargingData[_index]->PresentChargingCurrent)) / 1000);
  3323. if (chargingTime[_index] == 0 ||
  3324. chargingTime[_index] > _chargingData[_index]->PresentChargedDuration)
  3325. {
  3326. chargingTime[_index] = _chargingData[_index]->PresentChargedDuration;
  3327. }
  3328. else
  3329. {
  3330. int passTime = _chargingData[_index]->PresentChargedDuration - chargingTime[_index];
  3331. if (passTime > 0)
  3332. {
  3333. float changingPow = (_chargingData[_index]->PresentChargingPower) * passTime / 3600;
  3334. if (ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  3335. {
  3336. _chargingData[_index]->ChargingFee += changingPow * ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee;
  3337. }
  3338. _chargingData[_index]->PresentChargedEnergy += changingPow;
  3339. _chargingData[_index]->PowerConsumption += changingPow;
  3340. chargingTime[_index] = _chargingData[_index]->PresentChargedDuration;
  3341. }
  3342. }
  3343. // 開始確認車端是否同意開始充電
  3344. GetOutputReq(_index, _chargingData[_index]->Evboard_id);
  3345. // 設定當前輸出
  3346. if (gun_count == 1)
  3347. SetPresentChargingOutputPower(_chargingData[0], _chargingData[0]);
  3348. else if (gun_count == 2)
  3349. SetPresentChargingOutputPower(_chargingData[0], _chargingData[1]);
  3350. // for test end
  3351. if (priorityLow % 5 == 0)
  3352. {
  3353. // 樁端輸出能力改變
  3354. if (gun_count == 1)
  3355. SetPresentChargingOutputCap(_chargingData[0], _chargingData[0]);
  3356. else if (gun_count == 2)
  3357. SetPresentChargingOutputCap(_chargingData[0], _chargingData[1]);
  3358. }
  3359. if(_chargingData[_index]->GroundFaultStatus == GFD_FAIL)
  3360. {
  3361. SetIsolationStatus(_index, _chargingData[_index]->GroundFaultStatus, _chargingData[_index]->Evboard_id);
  3362. }
  3363. else if(_chargingData[_index]->Type == _Type_CCS_2)
  3364. {
  3365. SetIsolationStatus(_index, _chargingData[_index]->GroundFaultStatus, _chargingData[_index]->Evboard_id);
  3366. }
  3367. // GFD 失敗再通知
  3368. if (priorityLow == 1)
  3369. {
  3370. if(_chargingData[_index]->Type == _Type_CCS_2 &&
  3371. _chargingData[_index]->PrechargeStatus == PRECHARGE_READY)
  3372. {
  3373. SetEvsePrechargeInfo(_index, PRECHARGE_CHARELAY_PASS, _chargingData[_index]->Evboard_id);
  3374. }
  3375. }
  3376. }
  3377. break;
  3378. case S_TERMINATING:
  3379. {
  3380. // 設定當前輸出
  3381. if (gun_count == 1)
  3382. SetPresentChargingOutputPower(_chargingData[0], _chargingData[0]);
  3383. else if (gun_count == 2)
  3384. SetPresentChargingOutputPower(_chargingData[0], _chargingData[1]);
  3385. // 槍鎖還在,則代表是樁端要求的停止
  3386. if (_chargingData[_index]->GunLocked == START ||
  3387. _chargingData[_index]->Type == _Type_CCS_2)
  3388. {
  3389. byte normalStop = 0x01;
  3390. byte stopReason[6] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
  3391. if (GetStopChargingReasonByEvse(_index, stopReason))
  3392. {
  3393. normalStop = 0x02;
  3394. }
  3395. EvseStopChargingEvent(normalStop, stopReason, _chargingData[_index]->Evboard_id);
  3396. }
  3397. if(_chargingData[_index]->Type == _Type_CCS_2)
  3398. {
  3399. SetIsolationStatus(_index, _chargingData[_index]->GroundFaultStatus, _chargingData[_index]->Evboard_id);
  3400. }
  3401. GetOutputReq(_index, _chargingData[_index]->Evboard_id);
  3402. }
  3403. break;
  3404. case S_COMPLETE:
  3405. {
  3406. // 設定當前輸出
  3407. if (gun_count == 1)
  3408. SetPresentChargingOutputPower(_chargingData[0], _chargingData[0]);
  3409. else if (gun_count == 2)
  3410. SetPresentChargingOutputPower(_chargingData[0], _chargingData[1]);
  3411. if (priorityLow == 1)
  3412. {
  3413. float maxVol, maxCur;
  3414. // 樁端輸出能力
  3415. maxVol = _chargingData[_index]->MaximumChargingVoltage;
  3416. maxCur = _chargingData[_index]->AvailableChargingCurrent;
  3417. GetMaxVolAndCurMethod(_index, &maxVol, &maxCur);
  3418. SetChargingPermission(_index, STOP,
  3419. _chargingData[_index]->AvailableChargingPower,
  3420. maxCur,
  3421. maxVol,
  3422. _chargingData[_index]->Evboard_id);
  3423. }
  3424. }
  3425. break;
  3426. }
  3427. }
  3428. priorityLow >= 20 ? priorityLow = 1 : priorityLow++;
  3429. usleep(45000); //EV 小板通訊 (50 ms)
  3430. }
  3431. DEBUG_INFO("Module_EvComm : Can-bus port = %d \n", CanFd);
  3432. return FAIL;
  3433. }