Module_LcmControl.c 109 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582
  1. /*
  2. * Module_LcmControl.c
  3. *
  4. * Created on : 2020-10-20
  5. * Update on : 2022-10-13
  6. * Author : Folus Wen, Eason Yang
  7. * Version : V0.31
  8. *
  9. */
  10. #include <sys/time.h>
  11. #include "define.h"
  12. #include "main.h"
  13. #include "lcmComm_dgus.h"
  14. #include "cbmp.h"
  15. //=======================================
  16. // Declare share memory
  17. //=======================================
  18. struct SysConfigAndInfo *ShmSysConfigAndInfo;
  19. struct StatusCodeData *ShmStatusCodeData;
  20. struct OCPP16Data *ShmOCPP16Data;
  21. struct OCPP20Data *ShmOCPP20Data;
  22. struct Charger *ShmCharger;
  23. //=======================================
  24. // Declare Basic function
  25. //=======================================
  26. void trim(char *s);
  27. int mystrcmp(char *p1,char *p2);
  28. void substr(char *dest, const char* src, unsigned int start, unsigned int cnt);
  29. uint8_t split(char **arr, char *str, const char *del);
  30. void string2ByteArray(uint8_t *input, uint8_t *output);
  31. //=======================================
  32. // Declare Control panel function
  33. //=======================================
  34. void setRTC();
  35. void setRfidIcon();
  36. void setWifi4GIcon();
  37. void setQRCodeIcon();
  38. void setBackendIcon();
  39. void setQRCodeAlarm();
  40. void setEthernetIcon();
  41. void setCsuRootFsFwRev();
  42. uint8_t getCurrentPage();
  43. void setAlarmCodeAndIcon();
  44. void setPresentSessionFee();
  45. void setPresentParkingFee();
  46. void setBillingFromWebsite();
  47. int isEthConnected(char *eth);
  48. void setUserPrice(uint8_t type);
  49. void setTimeTitle(uint8_t isOn);
  50. void setEnergyTitle(uint8_t isOn);
  51. void setCurrentPage(uint8_t page);
  52. void setPresentFinalCost(float cost);
  53. void setFinalCostTitle(uint8_t isOn);
  54. void setSessionFeeTitle(uint8_t isOn);
  55. void setParkingFeeTitle(uint8_t isOn);
  56. void setTextToEmpty(uint8_t gun_index);
  57. void setWarningStatus(uint8_t gun_index);
  58. void setQRCodeReceipt(uint8_t gun_index);
  59. void setCurrencyFromWebsite(uint8_t unit);
  60. void setPriceFromWebsite(float monry_rate);
  61. void setAuthorizationPage(uint8_t gun_index);
  62. float getPresentFinalCost(uint8_t gun_index);
  63. void setGunPluginAnimation(uint8_t gun_index);
  64. void setPresentChargedPower(uint8_t gun_index);
  65. void setPlugAndChargeAnimation(uint8_t gun_index);
  66. void setPresentChargedDuration(uint8_t gun_index);
  67. void setPresentPowerConsumption(uint8_t gun_index);
  68. void setFinalCost(uint8_t gun_index, uint8_t type);
  69. void setPresentConnectionTimeout(uint8_t gun_index);
  70. void setRunningCost(uint8_t gun_index, uint8_t type);
  71. void setPressStartButtonAnimation(uint8_t gun_index);
  72. void setDisplayValue(uint16_t address, uint8_t value);
  73. void setDisplayValue2(uint16_t address, uint8_t value);
  74. void setDefaultValue(uint8_t gun_index, uint8_t system_mode);
  75. void setQRCodeContent(char *input, int length, uint8_t mode);
  76. void setBillingFromBackend(uint8_t gun_index, uint8_t system_mode);
  77. void setConnectionAnimation(uint8_t gun_index, uint8_t system_mode);
  78. void setPresentChargedEnergy(uint8_t gun_index, uint8_t system_mode);
  79. void setMarqueeControl(uint16_t address, uint8_t gun_index, uint8_t type);
  80. void setPrechargingTimerToDefault();
  81. void setPrechargingEnergyToDefault();
  82. void setPrechargingSessionFeeToDefault();
  83. void setPrechargingParkingFeeToDefault();
  84. void setPrechargingCostToDefault();
  85. void setPrechargingPowerToDefault();
  86. void setClearPrechargingValueToEmpty();
  87. //=======================================
  88. // Declare Timer
  89. //=======================================
  90. enum TMR_IDX
  91. {
  92. TMR_IDX_0=0,
  93. TMR_IDX_CONNECTION,
  94. TMR_IDX_PLUGIN,
  95. TMR_IDX_ALARM,
  96. TMR_IDX_PRICE,
  97. TMR_IDX_REFRESH_INFO,
  98. TMR_IDX_STARTBUTTON,
  99. TMR_IDX_7,
  100. TMR_IDX_8,
  101. TMR_IDX_SHOW_AUTH_RESULT,
  102. TMR_IDX_FINAL_COUNTER
  103. };
  104. struct timespec startTime[AC_QUANTITY][TMR_IDX_FINAL_COUNTER];
  105. #define TIME_ANIMATION_PLUGIN 1 // Unit: Second
  106. #define TIME_ANIMATION_BATTERY 1 // Unit: Second
  107. #define TIME_ANIMATION_CONNECTION 1 // Unit: Second
  108. #define TIME_ANIMATION_START_PRESS 1 // Unit: Second
  109. #define TIME_ANIMATION_ALARM 5 // Unit: Second
  110. #define TIME_REFRESH_TIME 5 // Unit: Second
  111. #define TIME_AUTH_RESULT_TIME 5 // Unit: Second
  112. #define TIME_REFRESH_INFO 3 // Unit: Second
  113. #define is_error(ptr) ((unsigned long)ptr > (unsigned long)-4000L)
  114. //=======================================
  115. // Declare Variable
  116. //=======================================
  117. uint8_t CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  118. uint8_t GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_0;
  119. uint8_t START_PRESS_LEVEL_STATIS = PRESS_START_LEVEL_0;
  120. uint8_t WarningCount = 255;
  121. int Uart1Fd;
  122. int GettingCurrentPage = 255;
  123. int SettingCurrentPage = 255;
  124. int CheckCurrentPageCounter = 0;
  125. //=======================================
  126. // Record version and date
  127. //=======================================
  128. char *FIRMWARE_UPDATE_IMAGE[3] = {"V0.31", "2022-10-13", "REV.03.00"};
  129. //=======================================
  130. // Common routine
  131. //=======================================
  132. int StoreLogMsg(const char *fmt, ...)
  133. {
  134. char Buf[4096+256];
  135. char buffer[4096];
  136. time_t CurrentTime;
  137. struct tm *tm;
  138. struct timeval tv;
  139. va_list args;
  140. va_start(args, fmt);
  141. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  142. va_end(args);
  143. memset(Buf,0,sizeof(Buf));
  144. CurrentTime = time(NULL);
  145. tm=localtime(&CurrentTime);
  146. gettimeofday(&tv, NULL); // get microseconds, 10^-6
  147. sprintf(Buf,"echo -n \'[%04d.%02d.%02d %02d:%02d:%02d.%06ld]%s\' >> /Storage/SystemLog/[%04d.%02d]Module_LcmControlLog",
  148. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,tv.tv_usec,
  149. buffer,
  150. tm->tm_year+1900,tm->tm_mon+1);
  151. #ifdef SystemLogMessage
  152. system(Buf);
  153. #endif
  154. #ifdef ConsloePrintLog
  155. printf("[%04d.%02d.%02d %02d:%02d:%02d.%06ld]%s", tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,tv.tv_usec, buffer);
  156. #endif
  157. return rc;
  158. }
  159. void refreshStartTimer(struct timespec *timer)
  160. {
  161. clock_gettime(CLOCK_MONOTONIC, timer);
  162. }
  163. int getDiffSecNow(struct timespec timer)
  164. {
  165. struct timespec timerNow;
  166. clock_gettime(CLOCK_MONOTONIC, &timerNow);
  167. return (int)((((unsigned long)(timerNow.tv_sec - timer.tv_sec) * 1000) + ((unsigned long)((timerNow.tv_nsec / 1000000) - (timer.tv_nsec / 1000000))))/1000);
  168. }
  169. int getDiffSecBetween(struct timespec start, struct timespec end)
  170. {
  171. return (int)((((unsigned long)(end.tv_sec - start.tv_sec) * 1000) + ((unsigned long)((end.tv_nsec / 1000000) - (start.tv_nsec / 1000000))))/1000);
  172. }
  173. long long DiffTimebWithNow(struct timeb ST)
  174. {
  175. //return milli-second
  176. struct timeb ET;
  177. long long StartTime,StopTime;
  178. ftime(&ET);
  179. StartTime=(long long)ST.time;
  180. StopTime=(long long)ET.time;
  181. return ((StopTime-StartTime)*1000) + (ET.millitm-ST.millitm);
  182. }
  183. int DiffTimeb(struct timeb ST, struct timeb ET)
  184. {
  185. //return milli-second
  186. unsigned int StartTime,StopTime;
  187. StartTime=(unsigned int)ST.time;
  188. StopTime=(unsigned int)ET.time;
  189. return (StopTime-StartTime)*1000+ET.millitm-ST.millitm;
  190. }
  191. void trim(char *s)
  192. {
  193. int i=0, j, k, l=0;
  194. while((s[i]==' ')||(s[i]=='\t')||(s[i]=='\n'))
  195. i++;
  196. j = strlen(s)-1;
  197. while((s[j]==' ')||(s[j]=='\t')||(s[j]=='\n'))
  198. j--;
  199. if(i==0 && j==strlen(s)-1) { }
  200. else if(i==0) s[j+1] = '\0';
  201. else {
  202. for(k=i; k<=j; k++) s[l++] = s[k];
  203. s[l] = '\0';
  204. }
  205. }
  206. void trim_string(char *s, unsigned char len)
  207. {
  208. for(unsigned char i = 0 ; i < len; i++)
  209. {
  210. if (!(s[i] =='.')&& !((s[i]>='0') && (s[i]<='9')))
  211. {
  212. s[i] = s[i + 1];
  213. strncpy(s + i, s + i + 1, len);
  214. i -= 1;
  215. len -= 1;
  216. }
  217. }
  218. s[len + 1] = '\0';
  219. }
  220. int mystrcmp(char *p1,char *p2)
  221. {
  222. while(*p1==*p2)
  223. {
  224. if(*p1=='\0' || *p2=='\0')
  225. break;
  226. p1++;
  227. p2++;
  228. }
  229. if(*p1=='\0' && *p2=='\0')
  230. return(PASS);
  231. else
  232. return(FAIL);
  233. }
  234. void substr(char *dest, const char* src, unsigned int start, unsigned int cnt)
  235. {
  236. strncpy(dest, src + start, cnt);
  237. dest[cnt] = 0;
  238. }
  239. uint8_t split(char **arr, char *str, const char *del)
  240. {
  241. uint8_t result = 0;
  242. char *s = strtok(str, del);
  243. while(s != NULL)
  244. {
  245. *arr++ = s;
  246. result += 1;
  247. s = strtok(NULL, del);
  248. }
  249. return result;
  250. }
  251. void getDateTimeString(char* result)
  252. {
  253. struct ParsingResult
  254. {
  255. int scanedElement;
  256. int tz_hour;
  257. int tz_min;
  258. }timeOffset;
  259. time_t CurrentTime;
  260. struct tm *tmOrg;
  261. struct tm *tmTarget;
  262. struct timeb tbTarget;
  263. CurrentTime = time(NULL);
  264. tmOrg=localtime(&CurrentTime);
  265. tmOrg->tm_gmtoff = 0;
  266. tbTarget.time = mktime(tmOrg);
  267. tbTarget.timezone = 0;
  268. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  269. {
  270. if((timeOffset.scanedElement = sscanf((char*)ShmOCPP16Data->ConfigurationTable.CoreProfile[TimeOffset].ItemData, "%d:%d", &timeOffset.tz_hour, &timeOffset.tz_min)) == 2)
  271. {
  272. tbTarget.time += (timeOffset.tz_hour*3600) + (timeOffset.tz_min*60*(timeOffset.tz_hour>=0?1:-1));
  273. }
  274. }
  275. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  276. {
  277. // OCPP 2.0.1
  278. }
  279. tmTarget = gmtime(&tbTarget.time);
  280. //sprintf(result, "%04d/%02d/%02d %02d:%02d", tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min);
  281. //sprintf(result, "%04d/%02d/%02d %02d:%02d %s", tmTarget->tm_year+1900,tmTarget->tm_mon+1,tmTarget->tm_mday,(tmTarget->tm_hour%12),tmTarget->tm_min,((tmTarget->tm_hour/12)>0?"p.m":"a.m"));
  282. if((tmTarget->tm_hour%12) == 0)
  283. sprintf(result, "%04d/%02d/%02d %02d:%02d %s", tmTarget->tm_year+1900,tmTarget->tm_mon+1,tmTarget->tm_mday,((tmTarget->tm_hour%12)==0?12:(tmTarget->tm_hour%12)),tmTarget->tm_min,((tmTarget->tm_hour/12)==1?"p.m.":"a.m."));
  284. else
  285. sprintf(result, "%04d/%02d/%02d %02d:%02d %s", tmTarget->tm_year+1900,tmTarget->tm_mon+1,tmTarget->tm_mday,(tmTarget->tm_hour%12),tmTarget->tm_min,((tmTarget->tm_hour/12)>0?"p.m.":"a.m."));
  286. }
  287. //======================================================
  288. // OCPP routine
  289. //======================================================
  290. uint8_t ocpp_get_isRemoteStartWait()
  291. {
  292. uint8_t result = OFF;
  293. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  294. {
  295. result = ShmOCPP16Data->MsMsg.bits.isRemoteStartWaitReq;
  296. }
  297. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  298. {
  299. result = ShmOCPP20Data->MsMsg.bits.isRemoteStartWaitReq;
  300. }
  301. return result;
  302. }
  303. uint8_t ocpp_compare_reserve_id_with_user(uint8_t gun_index)
  304. {
  305. uint8_t result = OFF;
  306. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  307. {
  308. if(strcmp((char*)ShmSysConfigAndInfo->SysConfig.UserId, (char*)ShmOCPP16Data->ReserveNow[gun_index].IdTag) == 0)
  309. result = ON;
  310. }
  311. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  312. {
  313. if(strcmp((char*)ShmSysConfigAndInfo->SysConfig.UserId, (char*)ShmOCPP20Data->ReserveNow[gun_index].idToken.idToken) == 0)
  314. result = ON;
  315. }
  316. return result;
  317. }
  318. uint8_t ocpp_compare_reserve_id_with_remote_user(uint8_t gun_index)
  319. {
  320. uint8_t result = OFF;
  321. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  322. {
  323. if(strcmp((char*)ShmOCPP16Data->RemoteStartTransaction[gun_index].IdTag, (char*)ShmOCPP16Data->ReserveNow[gun_index].IdTag) == 0)
  324. {
  325. result = ON;
  326. memcpy(ShmSysConfigAndInfo->SysConfig.UserId, ShmOCPP16Data->RemoteStartTransaction[gun_index].IdTag, ARRAY_SIZE(ShmOCPP16Data->RemoteStartTransaction[gun_index].IdTag));
  327. }
  328. }
  329. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  330. {
  331. if(strcmp((char*)ShmOCPP20Data->RequestStartTransaction[gun_index].idToken.idToken, (char*)ShmOCPP20Data->ReserveNow[gun_index].idToken.idToken) == 0)
  332. {
  333. result = ON;
  334. memcpy(ShmSysConfigAndInfo->SysConfig.UserId, ShmOCPP20Data->RequestStartTransaction[gun_index].idToken.idToken, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.UserId));
  335. }
  336. }
  337. return result;
  338. }
  339. //=======================================
  340. // Function to page routine
  341. //=======================================
  342. void page_booting()
  343. {
  344. if(getCurrentPage() != SYSTEM_SCREEN_BOOTING)
  345. {
  346. setCurrentPage(SYSTEM_SCREEN_BOOTING);
  347. }
  348. else
  349. {
  350. setClearPrechargingValueToEmpty();
  351. }
  352. }
  353. void page_idle(uint8_t gun_index, uint8_t system_mode)
  354. {
  355. setPrechargingTimerToDefault();
  356. setPrechargingEnergyToDefault();
  357. setPrechargingSessionFeeToDefault();
  358. setPrechargingParkingFeeToDefault();
  359. setPrechargingCostToDefault();
  360. setPrechargingPowerToDefault();
  361. if(ocpp_get_isRemoteStartWait())
  362. {
  363. if((getCurrentPage() != SYSTEM_SCREEN_PREPARING))
  364. {
  365. setCurrentPage(SYSTEM_SCREEN_PREPARING);
  366. }
  367. else
  368. {
  369. setPresentConnectionTimeout(gun_index);
  370. setConnectionAnimation(gun_index, system_mode);
  371. setGunPluginAnimation(gun_index);
  372. }
  373. }
  374. else
  375. {
  376. if(ShmCharger->gun_info[gun_index].isSleepOn == YES)
  377. {
  378. if((getCurrentPage() != SYSTEM_SCREEN_SLEEP))
  379. {
  380. setCurrentPage(SYSTEM_SCREEN_SLEEP);
  381. setPressStartButtonAnimation(gun_index);
  382. START_PRESS_LEVEL_STATIS = PRESS_START_LEVEL_0;
  383. }
  384. else
  385. {
  386. setPressStartButtonAnimation(gun_index);
  387. }
  388. }
  389. else
  390. {
  391. if(ShmCharger->gun_info[gun_index].isCheckPowerConsumption == YES)
  392. {
  393. setCurrentPage(SYSTEM_SCREEN_POWER_CONSUMPTION);
  394. setDisplayValue(ICON_POWER_CONSUMPTION, APPEAR);
  395. setPresentPowerConsumption(gun_index);
  396. setCsuRootFsFwRev();
  397. }
  398. else
  399. {
  400. if(ShmSysConfigAndInfo->SysConfig.AuthorisationMode == AUTH_MODE_DISABLE)
  401. {
  402. if((getCurrentPage() != SYSTEM_SCREEN_PLUG_AND_CHARGE))
  403. {
  404. setCurrentPage(SYSTEM_SCREEN_PLUG_AND_CHARGE);
  405. setDefaultValue(gun_index, system_mode);
  406. }
  407. else
  408. {
  409. setPlugAndChargeAnimation(gun_index);
  410. }
  411. }
  412. else
  413. {
  414. if((ShmSysConfigAndInfo->SysConfig.isAuthrizeByEVCCID && (ShmSysConfigAndInfo->SysConfig.AuthorisationMode == AUTH_MODE_ENABLE)) &&
  415. (ShmCharger->isCcsEnable) &&
  416. (ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PilotState == CP_STATE_B) &&
  417. (ShmCharger->gun_info[gun_index].isGetEvCCIDTimeout == OFF) &&
  418. (ShmCharger->gun_info[gun_index].resultAuthorization != VALIDATED_RFID) &&
  419. (ShmCharger->gun_info[gun_index].isRemoteStartWait != ON) &&
  420. (ShmCharger->gun_info[gun_index].isEvCCIDAuthorizeFail != YES))
  421. {
  422. if((getCurrentPage() != SYSTEM_SCREEN_PREPARE_FOR_EVSE))
  423. {
  424. setCurrentPage(SYSTEM_SCREEN_PREPARE_FOR_EVSE);
  425. }
  426. else
  427. {
  428. setConnectionAnimation(gun_index, system_mode);
  429. }
  430. }
  431. else
  432. {
  433. if((getCurrentPage() != SYSTEM_SCREEN_IDLE) && (ShmCharger->gun_info[gun_index].resultAuthorization != VALIDATED_RFID))
  434. {
  435. setCurrentPage(SYSTEM_SCREEN_IDLE);
  436. setDefaultValue(gun_index, system_mode);
  437. }
  438. else
  439. {
  440. setRfidIcon();
  441. setQRCodeIcon();
  442. setConnectionAnimation(gun_index, system_mode);
  443. }
  444. }
  445. }
  446. }
  447. }
  448. }
  449. }
  450. void page_authorizing(uint8_t gun_index)
  451. {
  452. setAuthorizationPage(gun_index);
  453. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
  454. {
  455. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  456. {
  457. if((strcmp((char*)ShmSysConfigAndInfo->SysConfig.UserId, (char *)ShmOCPP16Data->Cost.SetUserPrice.idToken) == 0) && ((strcmp((char *)ShmOCPP16Data->Cost.SetUserPrice.idToken,"") != 0)))
  458. {
  459. setUserPrice(ACCOUNT_BALANCE);
  460. }
  461. else
  462. {
  463. setDisplayValue(ICON_USER_ACCOUNT_BALANCE, DISAPPEAR);
  464. setDisplayValue(TEXT_USER_ACCOUNT_BALANCE, DISAPPEAR);
  465. }
  466. }
  467. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  468. {
  469. // DISPLAY BY OCPP 2.0.1
  470. }
  471. }
  472. else
  473. {
  474. setDisplayValue(ICON_USER_ACCOUNT_BALANCE, DISAPPEAR);
  475. setDisplayValue(TEXT_USER_ACCOUNT_BALANCE, DISAPPEAR);
  476. }
  477. }
  478. void page_preparing(uint8_t gun_index, uint8_t system_mode)
  479. {
  480. if(ShmCharger->gun_info[gun_index].chargingMode == CHARGING_MODE_HLC)
  481. {
  482. if((getCurrentPage() != SYSTEM_SCREEN_PREPARE_FOR_EVSE))
  483. {
  484. setCurrentPage(SYSTEM_SCREEN_PREPARE_FOR_EVSE);
  485. setDefaultValue(gun_index, system_mode);
  486. }
  487. else
  488. {
  489. setPrechargingTimerToDefault();
  490. setPrechargingEnergyToDefault();
  491. setPrechargingSessionFeeToDefault();
  492. setPrechargingParkingFeeToDefault();
  493. setPrechargingCostToDefault();
  494. setPrechargingPowerToDefault();
  495. setConnectionAnimation(gun_index, system_mode);
  496. setPresentChargedEnergy(gun_index, system_mode);
  497. }
  498. }
  499. else
  500. {
  501. if((getCurrentPage() != SYSTEM_SCREEN_PREPARING))
  502. {
  503. setCurrentPage(SYSTEM_SCREEN_PREPARING);
  504. setDefaultValue(gun_index, system_mode);
  505. }
  506. else
  507. {
  508. setPresentConnectionTimeout(gun_index);
  509. setConnectionAnimation(gun_index, system_mode);
  510. setGunPluginAnimation(gun_index);
  511. setPresentChargedEnergy(gun_index, system_mode);
  512. }
  513. }
  514. }
  515. void page_charging(uint8_t gun_index, uint8_t system_mode)
  516. {
  517. static char runningCost[1024] = {0};
  518. if((getCurrentPage() != SYSTEM_SCREEN_CHARGING) && (!ShmCharger->isAuthrizing && !ShmCharger->isGetAuthResult))
  519. {
  520. setCurrentPage(SYSTEM_SCREEN_CHARGING);
  521. setDefaultValue(gun_index, system_mode);
  522. }
  523. else
  524. {
  525. setConnectionAnimation(gun_index, system_mode);
  526. setPresentChargedDuration(gun_index);
  527. setPresentChargedPower(gun_index);
  528. setTimeTitle(ON);
  529. setEnergyTitle(ON);
  530. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
  531. {
  532. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  533. {
  534. // Title appear
  535. setSessionFeeTitle(ON);
  536. setParkingFeeTitle(ON);
  537. setFinalCostTitle(ON);
  538. }
  539. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  540. {
  541. // DISPLAY BY OCPP 2.0.1
  542. }
  543. }
  544. else
  545. {
  546. if(ShmSysConfigAndInfo->SysConfig.BillingData.isBilling == ON)
  547. {
  548. // Title appear
  549. setSessionFeeTitle(ON);
  550. setParkingFeeTitle(ON);
  551. setFinalCostTitle(ON);
  552. }
  553. else
  554. {
  555. // Title disappear
  556. setSessionFeeTitle(OFF);
  557. setParkingFeeTitle(OFF);
  558. setFinalCostTitle(OFF);
  559. }
  560. }
  561. if((getDiffSecNow(startTime[gun_index][TMR_IDX_REFRESH_INFO]) >= TIME_REFRESH_INFO) || (ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16?(strcmp((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description, runningCost) != 0):YES))
  562. {
  563. setPresentChargedEnergy(gun_index, system_mode);
  564. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  565. {
  566. memcpy((char*) runningCost,(char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description,ARRAY_SIZE(ShmOCPP16Data->Cost.RunningCost[gun_index].description));
  567. }
  568. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  569. {
  570. // OCPP 2.0.1
  571. }
  572. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
  573. {
  574. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  575. {
  576. setRunningCost(gun_index, TOTAL_COST);
  577. setRunningCost(gun_index, SESSION_FEE);
  578. setRunningCost(gun_index, OCCUPANCY_FEE);
  579. }
  580. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  581. {
  582. // DISPLAY BY OCPP 2.0.1
  583. }
  584. }
  585. else
  586. {
  587. if(ShmSysConfigAndInfo->SysConfig.BillingData.isBilling == ON)
  588. {
  589. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  590. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  591. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  592. setPresentFinalCost(getPresentFinalCost(gun_index));
  593. //setPresentSessionFee();
  594. setPresentParkingFee();
  595. }
  596. else
  597. {
  598. // Total cost disappear
  599. setDisplayValue(ICON_CHARGING_TOTAL_COST, DISAPPEAR);
  600. setDisplayValue(TEXT_CHARGING_TOTAL_COST, DISAPPEAR);
  601. // Session fee disappear
  602. setDisplayValue(ICON_CHARGING_SESSION_FEE, DISAPPEAR);
  603. setDisplayValue(TEXT_CHARGING_SESSION_FEE, DISAPPEAR);
  604. // Parking fee disappear
  605. setDisplayValue(ICON_CHARGING_PARKING_FEE, DISAPPEAR);
  606. setDisplayValue(TEXT_CHARGING_PARKING_FEE, DISAPPEAR);
  607. // User account balance disappear
  608. setDisplayValue(ICON_COMPLETE_WALLET, DISAPPEAR);
  609. setDisplayValue(TEXT_REMAINING_ACCOUNT_BALANCE, DISAPPEAR);
  610. }
  611. }
  612. refreshStartTimer(&startTime[gun_index][TMR_IDX_REFRESH_INFO]);
  613. }
  614. }
  615. }
  616. void page_complete(uint8_t gun_index, uint8_t system_mode)
  617. {
  618. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus != ON))
  619. {
  620. if(getCurrentPage() != SYSTEM_SCREEN_COMPLETE)
  621. {
  622. setCurrentPage(SYSTEM_SCREEN_COMPLETE);
  623. }
  624. else
  625. {}
  626. }
  627. else
  628. {
  629. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  630. {
  631. if(ShmOCPP16Data->StopTransaction[gun_index].TransactionId != ShmOCPP16Data->Cost.FinalCost[gun_index].txId)
  632. {
  633. if(getCurrentPage() != SYSTEM_SCREEN_COMPLETE)
  634. {
  635. setCurrentPage(SYSTEM_SCREEN_COMPLETE);
  636. }
  637. else
  638. {}
  639. }
  640. else
  641. {
  642. if((strcmp((char *)ShmOCPP16Data->Cost.FinalCost[gun_index].qrCodeText,"") != 0))
  643. {
  644. if(getCurrentPage() != SYSTEM_SCREEN_COMPLETE_WITH_QRCODE)
  645. {
  646. setCurrentPage(SYSTEM_SCREEN_COMPLETE_WITH_QRCODE);
  647. setQRCodeReceipt(gun_index);
  648. DEBUG_INFO("[CDFA 2.0].\n");
  649. }
  650. else
  651. {
  652. setQRCodeReceipt(gun_index);
  653. }
  654. }
  655. else
  656. {
  657. if((strcmp((char *)&ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL,"") != 0))
  658. {
  659. if(getCurrentPage() != SYSTEM_SCREEN_COMPLETE_WITH_QRCODE)
  660. {
  661. setCurrentPage(SYSTEM_SCREEN_COMPLETE_WITH_QRCODE);
  662. setQRCodeReceipt(gun_index);
  663. DEBUG_INFO("[CDFA 1.0].\n");
  664. }
  665. else
  666. {
  667. setQRCodeReceipt(gun_index);
  668. }
  669. }
  670. else
  671. {
  672. if(getCurrentPage() != SYSTEM_SCREEN_COMPLETE)
  673. {
  674. setCurrentPage(SYSTEM_SCREEN_COMPLETE);
  675. }
  676. else
  677. {}
  678. }
  679. }
  680. }
  681. }
  682. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  683. {
  684. // DISPLAY BY OCPP 2.0.1
  685. }
  686. else
  687. {}
  688. }
  689. setPresentChargedDuration(gun_index);
  690. setPresentChargedEnergy(gun_index, system_mode);
  691. setTimeTitle(ON);
  692. setEnergyTitle(ON);
  693. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
  694. {
  695. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  696. {
  697. setFinalCost(gun_index, TOTAL_COST);
  698. setFinalCost(gun_index, SESSION_FEE);
  699. setFinalCost(gun_index, OCCUPANCY_FEE);
  700. setFinalCost(gun_index, ACCOUNT_BALANCE);
  701. // Title appear
  702. setSessionFeeTitle(ON);
  703. setParkingFeeTitle(ON);
  704. setFinalCostTitle(ON);
  705. }
  706. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  707. {
  708. // DISPLAY BY OCPP 2.0.1
  709. }
  710. }
  711. else
  712. {
  713. if(ShmSysConfigAndInfo->SysConfig.BillingData.isBilling == ON)
  714. {
  715. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  716. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  717. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  718. setPresentFinalCost(getPresentFinalCost(gun_index));
  719. //setPresentSessionFee();
  720. setPresentParkingFee();
  721. setDisplayValue(ICON_COMPLETE_WALLET, DISAPPEAR);
  722. setDisplayValue(TEXT_REMAINING_ACCOUNT_BALANCE, DISAPPEAR);
  723. // Title appear
  724. setSessionFeeTitle(ON);
  725. setParkingFeeTitle(ON);
  726. setFinalCostTitle(ON);
  727. }
  728. else
  729. {
  730. // Total cost disappear
  731. setDisplayValue(ICON_CHARGING_TOTAL_COST, DISAPPEAR);
  732. setDisplayValue(TEXT_CHARGING_TOTAL_COST, DISAPPEAR);
  733. // Session fee disappear
  734. setDisplayValue(ICON_CHARGING_SESSION_FEE, DISAPPEAR);
  735. setDisplayValue(TEXT_CHARGING_SESSION_FEE, DISAPPEAR);
  736. // Parking fee disappear
  737. setDisplayValue(ICON_CHARGING_PARKING_FEE, DISAPPEAR);
  738. setDisplayValue(TEXT_CHARGING_PARKING_FEE, DISAPPEAR);
  739. // User account balance disappear
  740. setDisplayValue(ICON_COMPLETE_WALLET, DISAPPEAR);
  741. setDisplayValue(TEXT_REMAINING_ACCOUNT_BALANCE, DISAPPEAR);
  742. // Title disappear
  743. setSessionFeeTitle(OFF);
  744. setParkingFeeTitle(OFF);
  745. setFinalCostTitle(OFF);
  746. }
  747. }
  748. }
  749. void page_terminating(uint8_t gun_index, uint8_t system_mode)
  750. {
  751. if((getCurrentPage() != SYSTEM_SCREEN_TERMINATING) && (!ShmCharger->isAuthrizing && !ShmCharger->isGetAuthResult))
  752. {
  753. setCurrentPage(SYSTEM_SCREEN_TERMINATING);
  754. setDefaultValue(gun_index, system_mode);
  755. }
  756. else
  757. {
  758. setPresentChargedDuration(gun_index);
  759. setPresentChargedEnergy(gun_index, system_mode);
  760. setPresentChargedPower(gun_index);
  761. setTimeTitle(ON);
  762. setEnergyTitle(ON);
  763. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
  764. {
  765. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  766. {
  767. setRunningCost(gun_index, TOTAL_COST);
  768. setRunningCost(gun_index, SESSION_FEE);
  769. setRunningCost(gun_index, OCCUPANCY_FEE);
  770. // Title appear
  771. setSessionFeeTitle(ON);
  772. setParkingFeeTitle(ON);
  773. setFinalCostTitle(ON);
  774. }
  775. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  776. {
  777. // DISPLAY BY OCPP 2.0.1
  778. }
  779. }
  780. else
  781. {
  782. if(ShmSysConfigAndInfo->SysConfig.BillingData.isBilling == ON)
  783. {
  784. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  785. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  786. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  787. setPresentFinalCost(getPresentFinalCost(gun_index));
  788. //setPresentSessionFee();
  789. setPresentParkingFee();
  790. // Title appear
  791. setSessionFeeTitle(ON);
  792. setParkingFeeTitle(ON);
  793. setFinalCostTitle(ON);
  794. }
  795. else
  796. {
  797. // Total cost disappear
  798. setDisplayValue(ICON_CHARGING_TOTAL_COST, DISAPPEAR);
  799. setDisplayValue(TEXT_CHARGING_TOTAL_COST, DISAPPEAR);
  800. // Session fee disappear
  801. setDisplayValue(ICON_CHARGING_SESSION_FEE, DISAPPEAR);
  802. setDisplayValue(TEXT_CHARGING_SESSION_FEE, DISAPPEAR);
  803. // Parking fee disappear
  804. setDisplayValue(ICON_CHARGING_PARKING_FEE, DISAPPEAR);
  805. setDisplayValue(TEXT_CHARGING_PARKING_FEE, DISAPPEAR);
  806. // User account balance disappear
  807. setDisplayValue(ICON_COMPLETE_WALLET, DISAPPEAR);
  808. setDisplayValue(TEXT_REMAINING_ACCOUNT_BALANCE, DISAPPEAR);
  809. // Title disappear
  810. setSessionFeeTitle(OFF);
  811. setParkingFeeTitle(OFF);
  812. setFinalCostTitle(OFF);
  813. }
  814. }
  815. }
  816. }
  817. void page_alarm()
  818. {
  819. if(ShmStatusCodeData->AlarmCode.AlarmEvents.bits.EmergencyStopTrip != ON)
  820. {
  821. if(getCurrentPage() != SYSTEM_SCREEN_ALARM)
  822. {
  823. setCurrentPage(SYSTEM_SCREEN_ALARM);
  824. setQRCodeAlarm();
  825. }
  826. else
  827. {
  828. setQRCodeAlarm();
  829. }
  830. }
  831. else
  832. {
  833. if(getCurrentPage() != SYSTEM_SCREEN_EMERGENCY)
  834. {
  835. setCurrentPage(SYSTEM_SCREEN_EMERGENCY);
  836. }
  837. else
  838. {}
  839. }
  840. }
  841. void page_maintain()
  842. {
  843. if(getCurrentPage() != SYSTEM_SCREEN_MAINTENANCE)
  844. {
  845. setCurrentPage(SYSTEM_SCREEN_MAINTENANCE);
  846. }
  847. else
  848. {}
  849. }
  850. void page_update()
  851. {
  852. if(getCurrentPage() != SYSTEM_SCREEN_MAINTENANCE)
  853. {
  854. setCurrentPage(SYSTEM_SCREEN_MAINTENANCE);
  855. }
  856. else
  857. {}
  858. }
  859. void page_debug()
  860. {
  861. if(getCurrentPage() != SYSTEM_SCREEN_MAINTENANCE)
  862. {
  863. setCurrentPage(SYSTEM_SCREEN_MAINTENANCE);
  864. }
  865. else
  866. {}
  867. }
  868. void page_reservation(){}
  869. void page_booking(){}
  870. void page_fault(){}
  871. void page_unknown(){}
  872. void page_header(uint8_t gun_index, uint8_t system_mode)
  873. {
  874. setEthernetIcon();
  875. setBackendIcon();
  876. setWifi4GIcon();
  877. setWarningStatus(gun_index);
  878. // CHANGE LCD BRIGHNESS ( POWER SAVING MODE )
  879. if((ShmCharger->isLcdOn == ON))
  880. setDisplayValue(REG_ADDRESS_WRITE_BRIGHTNESS,BRIGHTNESS_100);
  881. else
  882. setDisplayValue(REG_ADDRESS_WRITE_BRIGHTNESS,BRIGHTNESS_10);
  883. // SET BILLING
  884. if((ShmSysConfigAndInfo->SysConfig.BillingData.isBilling == ON) && (ShmSysConfigAndInfo->SysInfo.OcppConnStatus != ON))
  885. {
  886. setBillingFromWebsite();
  887. setDisplayValue2(MARQUEES_DEFAULT_PRICE, DISAPPEAR);
  888. }
  889. else
  890. {
  891. // EVERY 5 SECONDS TO UPDATE PRICE
  892. if(getDiffSecNow(startTime[gun_index][TMR_IDX_PRICE]) > (TIME_REFRESH_TIME))
  893. {
  894. refreshStartTimer(&startTime[gun_index][TMR_IDX_PRICE]);
  895. setBillingFromBackend(gun_index, system_mode);
  896. }
  897. }
  898. }
  899. void page_footer()
  900. {
  901. setRTC();
  902. }
  903. //=======================================
  904. // SETTING ICON DISPLAY VALUE
  905. //=======================================
  906. void setDisplayValue(uint16_t address, uint8_t value)
  907. {
  908. uint8_t data[2];
  909. data[0] = value >> 8;
  910. data[1] = value & 0X00FF;
  911. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, address, data, ARRAY_SIZE(data));
  912. }
  913. //=======================================
  914. // SETTING MARQUEE CONTROL DISPLAY VALUE
  915. //=======================================
  916. void setDisplayValue2(uint16_t address, uint8_t value)
  917. {
  918. uint8_t data[4];
  919. data[0] = value >> 8;
  920. data[1] = value & 0X00FF;
  921. data[2] = 0xFF;
  922. data[3] = 0xFF;
  923. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, (address+3), data, ARRAY_SIZE(data));
  924. }
  925. //=======================================
  926. // PRINT OUT SCREEN MODE
  927. //=======================================
  928. char* getDisplayModeName(unsigned char mode)
  929. {
  930. char* result;
  931. switch(mode)
  932. {
  933. case SYSTEM_SCREEN_BOOTING:
  934. result = "BOOTING";
  935. break;
  936. case SYSTEM_SCREEN_IDLE:
  937. result = "IDLE";
  938. break;
  939. case SYSTEM_SCREEN_PREPARING:
  940. result = "PREPARING";
  941. break;
  942. case SYSTEM_SCREEN_PREPARE_FOR_EVSE:
  943. result = "PREPARE_FOR_EVSE";
  944. break;
  945. case SYSTEM_SCREEN_CHARGING:
  946. result = "CHARGING";
  947. break;
  948. case SYSTEM_SCREEN_COMPLETE:
  949. result = "COMPLETE";
  950. break;
  951. case SYSTEM_SCREEN_MAINTENANCE:
  952. result = "MAINTENANCE";
  953. break;
  954. case SYSTEM_SCREEN_AUTH_PASS:
  955. result = "AUTH_PASS";
  956. break;
  957. case SYSTEM_SCREEN_AUTH_FAIL:
  958. result = "AUTH_FAIL";
  959. break;
  960. case SYSTEM_SCREEN_AUTH_UNKNOWN:
  961. result = "AUTH_UNKNOWN";
  962. break;
  963. case SYSTEM_SCREEN_TERMINATING:
  964. result = "TERMINATING";
  965. break;
  966. case SYSTEM_SCREEN_EMERGENCY:
  967. result = "EMERGENCY";
  968. break;
  969. case SYSTEM_SCREEN_SLEEP:
  970. result = "SLEEP";
  971. break;
  972. case SYSTEM_SCREEN_SLEEP2:
  973. result = "SLEEP2";
  974. break;
  975. case SYSTEM_SCREEN_ALARM:
  976. result = "ALARM";
  977. break;
  978. case SYSTEM_SCREEN_PLUG_AND_CHARGE:
  979. result = "PLUG_AND_CHARGE";
  980. break;
  981. case SYSTEM_SCREEN_COMPLETE_WITH_QRCODE:
  982. result = "COMPLETE_WITH_QRCODE";
  983. break;
  984. case SYSTEM_SCREEN_POWER_CONSUMPTION:
  985. result = "POWER_CONSUMPTION";
  986. break;
  987. default:
  988. result = "UNKNOWN";
  989. break;
  990. }
  991. return result;
  992. }
  993. //=======================================
  994. // GETTING CURRENT SCREEN PAGE
  995. //=======================================
  996. uint8_t getCurrentPage()
  997. {
  998. uint8_t currentPage[2];
  999. uint8_t result = 255;
  1000. if(lcdRegisterRead(Uart1Fd, REG_TYPE_CONTROL, REG_ADDRESS_READ_PAGE_ID, currentPage, ARRAY_SIZE(currentPage)))
  1001. {
  1002. result = currentPage[1];
  1003. /*
  1004. if((GettingCurrentPage != result))
  1005. {
  1006. if(CheckCurrentPageCounter >= 3)
  1007. {
  1008. GettingCurrentPage = result;
  1009. DEBUG_INFO("Getting current page: [%s].\n", getDisplayModeName((unsigned char)GettingCurrentPage));
  1010. }
  1011. CheckCurrentPageCounter++;
  1012. }
  1013. else
  1014. {
  1015. CheckCurrentPageCounter = 0;
  1016. }
  1017. */
  1018. }
  1019. else
  1020. {
  1021. DEBUG_INFO("Getting current page: [Fail].\n");
  1022. }
  1023. return result;
  1024. }
  1025. //=======================================
  1026. // SETTING CURRENT SCREEN PAGE
  1027. //=======================================
  1028. void setCurrentPage(uint8_t page)
  1029. {
  1030. uint8_t settingPage[2];
  1031. settingPage[0] = 0x00;
  1032. settingPage[1] = page;
  1033. if(lcdRegisterWrite(Uart1Fd, REG_TYPE_CONTROL, REG_ADDRESS_SET_PAGE_ID, settingPage, ARRAY_SIZE(settingPage)))
  1034. {
  1035. if(SettingCurrentPage != page)
  1036. {
  1037. SettingCurrentPage = page;
  1038. DEBUG_INFO("Setting current page: [%s].\n", getDisplayModeName((unsigned char)SettingCurrentPage), SettingCurrentPage);
  1039. if(ocpp_get_isRemoteStartWait())
  1040. {
  1041. DEBUG_INFO("[Remote to start without the connector id].\n");
  1042. }
  1043. else
  1044. {}
  1045. }
  1046. }
  1047. else
  1048. {
  1049. DEBUG_INFO("Setting current page: [Fail].\n");
  1050. }
  1051. }
  1052. //=======================================
  1053. // CONVERT STRING TO BYTE ARRAY
  1054. //=======================================
  1055. void string2ByteArray(uint8_t *input, uint8_t *output)
  1056. {
  1057. int loop;
  1058. int i;
  1059. loop = 0;
  1060. i = 0;
  1061. while(input[loop] != '\0')
  1062. {
  1063. output[i++] = input[loop++];
  1064. }
  1065. output[loop] = '\0';
  1066. }
  1067. //=======================================
  1068. // SETTING ICON [RFID]
  1069. //=======================================
  1070. void setRfidIcon()
  1071. {
  1072. if(ShmSysConfigAndInfo->SysConfig.isRFID == ON)
  1073. setDisplayValue(ICON_RFID, RFID_ENABLE);
  1074. else
  1075. setDisplayValue(ICON_RFID, RFID_DISABLE);
  1076. }
  1077. //========================================
  1078. // SETTING ICON [BACKEND]
  1079. //========================================
  1080. void setBackendIcon()
  1081. {
  1082. if(ShmSysConfigAndInfo->SysInfo.OcppConnStatus != ON)
  1083. setDisplayValue(ICON_BACKEND_CONNECTION,BACKEND_OFFLINE);
  1084. else
  1085. setDisplayValue(ICON_BACKEND_CONNECTION,BACKEND_ONLINE);
  1086. }
  1087. //========================================
  1088. // SETTING ICON [ETHERNET]
  1089. //========================================
  1090. void setEthernetIcon()
  1091. {
  1092. char ethernet [16];
  1093. strcpy((char*)ethernet, "eth0");
  1094. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.InternetDisconnectViaEthernet == ON)
  1095. {
  1096. if(isEthConnected(ethernet) == YES)
  1097. setDisplayValue(ICON_ETHERENT_CONNECTION, ETHERNET_CONNECTED_WITHOUT_INTERNET);
  1098. else
  1099. setDisplayValue(ICON_ETHERENT_CONNECTION, ETHERNET_DISCONNECTED_INTERNET);
  1100. }
  1101. else
  1102. {
  1103. setDisplayValue(ICON_ETHERENT_CONNECTION, ETHERNET_CONNECTED_INTERNET);
  1104. }
  1105. }
  1106. //=======================================
  1107. // SETTING ICON [WIFI/4G]
  1108. //=======================================
  1109. void setWifi4GIcon()
  1110. {
  1111. // SET WIFI + 4G ICON STATUS ( ONLINE OR OFFLINE )
  1112. if(ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'D')
  1113. {
  1114. if(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode == DISABLE_WIFI)
  1115. {
  1116. if(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomEnabled == DISABLE_4G)
  1117. {
  1118. setDisplayValue(ICON_WIFI_CONNECTION, DISAPPEAR);
  1119. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1120. }
  1121. else
  1122. {
  1123. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1124. // 4G Internet connection status: Connected: OFF / Disconnected: ON
  1125. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.InternetDisconnectVia4Gi == ON)
  1126. {
  1127. // 4G APN connection status: Connected: OFF / Disconnected: ON
  1128. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.ApnDisconnectVia4Gi == ON)
  1129. setDisplayValue(ICON_WIFI_CONNECTION, TELECOM_DISCONNECTED_INTERNET);
  1130. else
  1131. setDisplayValue(ICON_WIFI_CONNECTION, TELECOM_CONNECTED_WITHOUT_INTERNET);
  1132. }
  1133. else
  1134. setDisplayValue(ICON_WIFI_CONNECTION, TELECOM_CONNECTED_INTERNET);
  1135. }
  1136. }
  1137. else
  1138. {
  1139. if(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode == WIFI_STATION)
  1140. {
  1141. // Wifi Internet connection status: Connected = OFF / Disconnected = ON
  1142. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.InternetDisconnectViaWiFi == ON)
  1143. {
  1144. // Wifi Access point connection status: Connected = OFF / Disconnected = ON
  1145. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.ApDisconnectViaWiFi == ON)
  1146. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_DISCONNECTED_INTERNET);
  1147. else
  1148. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_CONNECTED_WITHOUT_INTERNET);
  1149. }
  1150. else
  1151. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_CONNECTED_INTERNET);
  1152. }
  1153. else if(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode == WIFI_ACCESS_POINT)
  1154. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_CONNECTED_WITHOUT_INTERNET);
  1155. else
  1156. setDisplayValue(ICON_WIFI_CONNECTION, DISAPPEAR);
  1157. if(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomEnabled == DISABLE_4G)
  1158. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1159. else
  1160. {
  1161. // 4G Internet connection status: Connected: OFF / Disconnected: ON
  1162. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.InternetDisconnectVia4Gi == ON)
  1163. {
  1164. // 4G APN connection status: Connected: OFF / Disconnected: ON
  1165. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.ApnDisconnectVia4Gi == ON)
  1166. setDisplayValue(ICON_4G_CONNECTION, TELECOM_DISCONNECTED_INTERNET);
  1167. else
  1168. setDisplayValue(ICON_4G_CONNECTION, TELECOM_CONNECTED_WITHOUT_INTERNET);
  1169. }
  1170. else
  1171. setDisplayValue(ICON_4G_CONNECTION, TELECOM_CONNECTED_INTERNET);
  1172. }
  1173. }
  1174. }
  1175. else if(ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'E')
  1176. {
  1177. setDisplayValue(ICON_WIFI_CONNECTION, DISAPPEAR);
  1178. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1179. }
  1180. else
  1181. {
  1182. // SET 4G ICON STATUS ( ONLINE OR OFFLINE )
  1183. if(ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'T')
  1184. {
  1185. switch(ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomEnabled)
  1186. {
  1187. case DISABLE_4G:
  1188. setDisplayValue(ICON_WIFI_CONNECTION, DISAPPEAR);
  1189. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1190. break;
  1191. case ENABLE_4G:
  1192. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1193. // 4G Internet connection status: Connected: OFF / Disconnected: ON
  1194. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.InternetDisconnectVia4Gi == ON)
  1195. {
  1196. // 4G APN connection status: Connected: OFF / Disconnected: ON
  1197. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.ApnDisconnectVia4Gi == ON)
  1198. setDisplayValue(ICON_WIFI_CONNECTION, TELECOM_DISCONNECTED_INTERNET);
  1199. else
  1200. setDisplayValue(ICON_WIFI_CONNECTION, TELECOM_CONNECTED_WITHOUT_INTERNET);
  1201. }
  1202. else
  1203. setDisplayValue(ICON_WIFI_CONNECTION, TELECOM_CONNECTED_INTERNET);
  1204. break;
  1205. default:
  1206. break;
  1207. }
  1208. }
  1209. // SET WIFI ICON STATUS ( ONLINE OR OFFLINE)
  1210. if(ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'W')
  1211. {
  1212. switch(ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode)
  1213. {
  1214. case DISABLE_WIFI:
  1215. setDisplayValue(ICON_WIFI_CONNECTION, DISAPPEAR);
  1216. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1217. break;
  1218. case WIFI_STATION:
  1219. setDisplayValue(ICON_4G_CONNECTION, DISAPPEAR);
  1220. // Wifi Internet connection status: Connected = OFF / Disconnected = ON
  1221. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.InternetDisconnectViaWiFi == ON)
  1222. {
  1223. // Wifi Access point connection status: Connected = OFF / Disconnected = ON
  1224. if(ShmStatusCodeData->InfoCode.InfoEvents.bits.ApDisconnectViaWiFi == ON)
  1225. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_DISCONNECTED_INTERNET);
  1226. else
  1227. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_CONNECTED_WITHOUT_INTERNET);
  1228. }
  1229. else
  1230. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_CONNECTED_INTERNET);
  1231. break;
  1232. case WIFI_ACCESS_POINT:
  1233. setDisplayValue(ICON_WIFI_CONNECTION, WIFI_CONNECTED_WITHOUT_INTERNET);
  1234. break;
  1235. default:
  1236. break;
  1237. }
  1238. }
  1239. }
  1240. }
  1241. //========================================
  1242. // SETTING CONTENT [RTC]
  1243. //========================================
  1244. void setRTC()
  1245. {
  1246. uint8_t data[32];
  1247. uint8_t rtc[32];
  1248. memset(data, 0x00, ARRAY_SIZE(data));
  1249. memset(rtc, 0x00, ARRAY_SIZE(rtc));
  1250. getDateTimeString((char*)rtc);
  1251. string2ByteArray(rtc, data);
  1252. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_RTC, data, ARRAY_SIZE(data));
  1253. }
  1254. //=======================================
  1255. // SETTING CONTENT [BILLING] WEB PAGE
  1256. //=======================================
  1257. void setBillingFromWebsite()
  1258. {
  1259. struct timeb csuTime;
  1260. struct tm *tmCSU;
  1261. ftime(&csuTime);
  1262. tmCSU = localtime(&csuTime.time);
  1263. setDisplayValue(ICON_PRICE, APPEAR);
  1264. if(tmCSU->tm_hour <= 23)
  1265. {
  1266. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = ShmSysConfigAndInfo->SysConfig.BillingData.Fee[tmCSU->tm_hour];
  1267. setPriceFromWebsite(ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee);
  1268. }
  1269. // CURRENCY UNIT ( 53 COUNTRIES )
  1270. if(ShmSysConfigAndInfo->SysConfig.BillingData.Currency <= 53)
  1271. {
  1272. setCurrencyFromWebsite(ShmSysConfigAndInfo->SysConfig.BillingData.Currency);
  1273. }
  1274. }
  1275. //=======================================
  1276. // SETTING CONTNET [CURRENCY] WEB PAGE
  1277. //=======================================
  1278. void setCurrencyFromWebsite(uint8_t unit)
  1279. {
  1280. uint8_t data[16];
  1281. uint8_t currency[16];
  1282. unsigned char kWh [16];
  1283. uint8_t final_currency[16];
  1284. memset(data, 0x00, ARRAY_SIZE(data));
  1285. memset(currency, 0x00, ARRAY_SIZE(currency));
  1286. memset(final_currency, 0x00, ARRAY_SIZE(final_currency));
  1287. strcpy((char*)kWh, "/kWh");
  1288. memcpy((char*)currency, Currency[unit], 3);
  1289. sprintf((char *)final_currency, "%s%s", currency,kWh);
  1290. string2ByteArray(final_currency, data);
  1291. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CURRENCY_UNIT, data, ARRAY_SIZE(data));
  1292. }
  1293. //=======================================
  1294. // SETTING CONTENT [PRICE] WEB PAGE
  1295. //=======================================
  1296. void setPriceFromWebsite(float monry_rate)
  1297. {
  1298. uint8_t data[16];
  1299. uint8_t price[16];
  1300. memset(data, 0x00, ARRAY_SIZE(data));
  1301. memset(price, 0x00, ARRAY_SIZE(price));
  1302. sprintf((char *)price, "%.2f", monry_rate);
  1303. string2ByteArray(price, data);
  1304. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRICE, data, ARRAY_SIZE(data));
  1305. }
  1306. //=======================================
  1307. // SETTING CONTENT [FINAL COST] WEB PAGE
  1308. //=======================================
  1309. void setPresentFinalCost(float cost)
  1310. {
  1311. uint8_t data[32];
  1312. uint8_t finalCost[32];
  1313. memset(data, 0x00, ARRAY_SIZE(data));
  1314. memset(finalCost, 0x00, ARRAY_SIZE(finalCost));
  1315. sprintf((char *)finalCost, "$ %.2f", cost);
  1316. string2ByteArray(finalCost, data);
  1317. // Total Cost
  1318. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TOTAL_COST, data, ARRAY_SIZE(data));
  1319. // Session Fee
  1320. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, data, ARRAY_SIZE(data));
  1321. }
  1322. //=======================================
  1323. // SETTING CONTENT [SESSION FEE] WEB PAGE
  1324. //=======================================
  1325. void setPresentSessionFee()
  1326. {
  1327. uint8_t data[32];
  1328. uint8_t sessionFee[32];
  1329. memset(data, 0x00, ARRAY_SIZE(data));
  1330. memset(sessionFee, 0x00, ARRAY_SIZE(sessionFee));
  1331. strcpy((char*)sessionFee, "$ -----");
  1332. string2ByteArray(sessionFee, data);
  1333. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, data, ARRAY_SIZE(data));
  1334. }
  1335. //=======================================
  1336. // SETTING CONTENT [PARKING FEE] WEB PAGE
  1337. //=======================================
  1338. void setPresentParkingFee()
  1339. {
  1340. uint8_t data[32];
  1341. uint8_t parkingFee[32];
  1342. memset(data, 0x00, ARRAY_SIZE(data));
  1343. memset(parkingFee, 0x00, ARRAY_SIZE(parkingFee));
  1344. strcpy((char*)parkingFee, "$ -----");
  1345. string2ByteArray(parkingFee, data);
  1346. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_PARKING_FEE, data, ARRAY_SIZE(data));
  1347. }
  1348. //=======================================
  1349. // GETTING VALUE [FINAL COST] WEB PAGE
  1350. //=======================================
  1351. float getPresentFinalCost(uint8_t gun_index)
  1352. {
  1353. float result = 0.0f;
  1354. for(int idx=0;idx<ARRAY_SIZE(ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].presentChargedEnergyPeriod);idx++)
  1355. {
  1356. result += ((ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].presentChargedEnergyPeriod[idx]) * ShmSysConfigAndInfo->SysConfig.BillingData.Fee[idx]);
  1357. }
  1358. return result;
  1359. }
  1360. //=======================================
  1361. // Setting [ Billing ] ( BACKEND )
  1362. //=======================================
  1363. void setBillingFromBackend(uint8_t gun_index, uint8_t system_mode)
  1364. {
  1365. if((system("pidof -s OcppBackend > /dev/null") != 0))
  1366. {
  1367. setDisplayValue(ICON_PRICE, DISAPPEAR);
  1368. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1369. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1370. setDisplayValue2(MARQUEES_DEFAULT_PRICE, DISAPPEAR);
  1371. }
  1372. else
  1373. {
  1374. if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
  1375. {
  1376. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1377. {
  1378. if((strcmp((char *)ShmOCPP16Data->ConfigurationTable.CoreProfile[DefaultPrice].ItemData,"") != 0))
  1379. {
  1380. if(system_mode == SYS_MODE_IDLE)
  1381. {
  1382. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1383. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1384. setDisplayValue(ICON_PRICE, APPEAR);
  1385. setMarqueeControl(MARQUEES_DEFAULT_PRICE, gun_index, DEFAULE_PRICE);
  1386. }
  1387. else
  1388. {
  1389. /*
  1390. * 1. IF STARTUSERID IS NOT MATCH WITH IDTOKEN ALSO VALUE CAN'T BE NULL, OTHERWISE THE SYSTEM MUST USE DEFAULT PRICE
  1391. */
  1392. if((strcmp((char*)ShmSysConfigAndInfo->SysConfig.UserId, (char *)ShmOCPP16Data->Cost.SetUserPrice.idToken) == 0) && ((strcmp((char *)ShmOCPP16Data->Cost.SetUserPrice.idToken,"") != 0)))
  1393. {
  1394. setMarqueeControl(MARQUEES_DEFAULT_PRICE, gun_index, SET_USER_PRICE);
  1395. }
  1396. else
  1397. {
  1398. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1399. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1400. setDisplayValue(ICON_PRICE, APPEAR);
  1401. setMarqueeControl(MARQUEES_DEFAULT_PRICE, gun_index, DEFAULE_PRICE);
  1402. }
  1403. }
  1404. }
  1405. else
  1406. {
  1407. if(system_mode == SYS_MODE_IDLE)
  1408. {
  1409. setDisplayValue(ICON_PRICE, DISAPPEAR);
  1410. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1411. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1412. setDisplayValue2(MARQUEES_DEFAULT_PRICE, DISAPPEAR);
  1413. }
  1414. else
  1415. {
  1416. if((strcmp((char*)ShmSysConfigAndInfo->SysConfig.UserId, (char *)ShmOCPP16Data->Cost.SetUserPrice.idToken) == 0) && ((strcmp((char *)ShmOCPP16Data->Cost.SetUserPrice.idToken,"") != 0)))
  1417. {
  1418. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1419. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1420. setDisplayValue(ICON_PRICE, APPEAR);
  1421. setMarqueeControl(MARQUEES_DEFAULT_PRICE, gun_index, SET_USER_PRICE);
  1422. }
  1423. else
  1424. {
  1425. setDisplayValue(ICON_PRICE, DISAPPEAR);
  1426. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1427. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1428. setDisplayValue2(MARQUEES_DEFAULT_PRICE, DISAPPEAR);
  1429. }
  1430. }
  1431. }
  1432. }
  1433. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1434. {
  1435. // DISPLAY BY OCPP 2.0.1
  1436. }
  1437. }
  1438. else
  1439. {
  1440. setDisplayValue(ICON_PRICE, DISAPPEAR);
  1441. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1442. setDisplayValue(TEXT_CURRENCY_UNIT, DISAPPEAR);
  1443. setDisplayValue2(MARQUEES_DEFAULT_PRICE, DISAPPEAR);
  1444. }
  1445. }
  1446. }
  1447. //=======================================
  1448. // Setting [ UserPrice ] ( BACKEND )
  1449. //=======================================
  1450. void setUserPrice(uint8_t type)
  1451. {
  1452. uint8_t length;
  1453. uint8_t output_data[32];
  1454. char input_data[32];
  1455. char tmp[256];
  1456. char *splitString[10];
  1457. const char *Symbol = ";";
  1458. memset(tmp, 0, ARRAY_SIZE(tmp));
  1459. memset(input_data, 0x00, ARRAY_SIZE(input_data));
  1460. memset(output_data, 0x00, ARRAY_SIZE(output_data));
  1461. switch(type)
  1462. {
  1463. case CONNECTION_FEE:
  1464. break;
  1465. case CURRENT_RATE:
  1466. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1467. {
  1468. if(strstr((char *)ShmOCPP16Data->Cost.SetUserPrice.price, "Current Rate:") > 0)
  1469. {
  1470. // APPEAR PRICE ICON
  1471. setDisplayValue(ICON_PRICE, APPEAR);
  1472. // APPEAR PRICE TEXT
  1473. strcpy((char*)tmp,(char *)ShmOCPP16Data->Cost.SetUserPrice.price);
  1474. split((char**)splitString, tmp, Symbol);
  1475. memcpy(input_data, splitString[1], strlen(splitString[1]));
  1476. length = strlen(input_data);
  1477. trim_string(input_data,length);
  1478. memcpy(output_data ,input_data, strlen(input_data));
  1479. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRICE, output_data, ARRAY_SIZE(output_data));
  1480. }
  1481. else
  1482. {
  1483. // DISAPPEAR PRICE ICON AND PRICE TEXT
  1484. setDisplayValue(ICON_PRICE, DISAPPEAR);
  1485. setDisplayValue(TEXT_PRICE, DISAPPEAR);
  1486. }
  1487. }
  1488. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1489. {
  1490. // OCPP 2.0.1
  1491. }
  1492. break;
  1493. case OCCUPANCY_FEE:
  1494. break;
  1495. case ACCOUNT_BALANCE:
  1496. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1497. {
  1498. if(strstr((char *)ShmOCPP16Data->Cost.SetUserPrice.price, "Account Balance:") > 0)
  1499. {
  1500. // APPEAR ACCOUNT BALANCE ICON
  1501. setDisplayValue(ICON_USER_ACCOUNT_BALANCE, APPEAR);
  1502. // APPEAR ACCOUNT BALANCE TEXT
  1503. strcpy((char*)tmp,(char *)ShmOCPP16Data->Cost.SetUserPrice.price);
  1504. split((char**)splitString, tmp, Symbol);
  1505. memcpy(input_data, splitString[3], strlen(splitString[3]));
  1506. length = strlen(input_data);
  1507. trim_string(input_data,length);
  1508. memcpy(output_data ,input_data, strlen(input_data));
  1509. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_USER_ACCOUNT_BALANCE, output_data, ARRAY_SIZE(output_data));
  1510. }
  1511. else
  1512. {
  1513. // DISAPPEAR BALANCE ICON AND BALANCE TEXT
  1514. setDisplayValue(ICON_USER_ACCOUNT_BALANCE, DISAPPEAR);
  1515. setDisplayValue(TEXT_USER_ACCOUNT_BALANCE, DISAPPEAR);
  1516. }
  1517. }
  1518. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1519. {
  1520. // OCPP 2.0.1
  1521. }
  1522. break;
  1523. default:
  1524. break;
  1525. }
  1526. }
  1527. //=======================================
  1528. // Setting [ FinalCost ] ( BACKEND )
  1529. //=======================================
  1530. void setFinalCost(uint8_t gun_index, uint8_t type)
  1531. {
  1532. uint8_t output_data[32];
  1533. unsigned char cost_empty[32];
  1534. unsigned char balance_empty[32];
  1535. unsigned char session_empty[32];
  1536. unsigned char occupancy_empty[32];
  1537. json_object *jsonDescription;
  1538. memset(output_data, 0x00, ARRAY_SIZE(output_data));
  1539. memset(balance_empty, 0x00, ARRAY_SIZE(balance_empty));
  1540. memset(cost_empty, 0x00, ARRAY_SIZE(cost_empty));
  1541. memset(session_empty, 0x00, ARRAY_SIZE(session_empty));
  1542. memset(occupancy_empty, 0x00, ARRAY_SIZE(occupancy_empty));
  1543. switch(type)
  1544. {
  1545. case CONNECTION_FEE:
  1546. break;
  1547. case SESSION_FEE:
  1548. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1549. {
  1550. if(ShmOCPP16Data->StopTransaction[gun_index].TransactionId != ShmOCPP16Data->Cost.FinalCost[gun_index].txId)
  1551. {
  1552. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  1553. strcpy((char*)session_empty, "$ -----");
  1554. string2ByteArray(session_empty, output_data);
  1555. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, output_data, ARRAY_SIZE(output_data));
  1556. }
  1557. else
  1558. {
  1559. double chargingCost = 0;
  1560. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.FinalCost[gun_index].description);
  1561. if(!is_error(jsonDescription))
  1562. {
  1563. if(json_object_object_get(jsonDescription,"chargingFee") != NULL)
  1564. {
  1565. chargingCost += json_object_get_double(json_object_object_get(jsonDescription,"chargingFee"));
  1566. }
  1567. if(chargingCost> 0)
  1568. sprintf((char*)output_data, "$ %.2f", chargingCost);
  1569. else
  1570. sprintf((char*)output_data, "$ -----");
  1571. // APPEAR COST ICON
  1572. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  1573. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, output_data, ARRAY_SIZE(output_data));
  1574. }
  1575. json_object_put(jsonDescription);
  1576. }
  1577. }
  1578. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1579. {
  1580. // OCPP 2.0.1
  1581. }
  1582. break;
  1583. case OCCUPANCY_FEE:
  1584. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1585. {
  1586. if(ShmOCPP16Data->StopTransaction[gun_index].TransactionId != ShmOCPP16Data->Cost.FinalCost[gun_index].txId)
  1587. {
  1588. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  1589. strcpy((char*)occupancy_empty, "$ -----");
  1590. string2ByteArray(occupancy_empty, output_data);
  1591. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_PARKING_FEE, output_data, ARRAY_SIZE(output_data));
  1592. }
  1593. else
  1594. {
  1595. double parkingCost = 0;
  1596. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.FinalCost[gun_index].description);
  1597. if(!is_error(jsonDescription))
  1598. {
  1599. if(json_object_object_get(jsonDescription,"parkingFee") != NULL)
  1600. {
  1601. parkingCost += json_object_get_double(json_object_object_get(jsonDescription,"parkingFee"));
  1602. }
  1603. if(parkingCost > 0)
  1604. sprintf((char*)output_data, "$ %.2f", parkingCost);
  1605. else
  1606. sprintf((char*)output_data, "$ -----");
  1607. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  1608. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_PARKING_FEE, output_data, ARRAY_SIZE(output_data));
  1609. }
  1610. json_object_put(jsonDescription);
  1611. }
  1612. }
  1613. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1614. {
  1615. // OCPP 2.0.1
  1616. }
  1617. break;
  1618. case TOTAL_COST:
  1619. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1620. {
  1621. if(ShmOCPP16Data->StopTransaction[gun_index].TransactionId != ShmOCPP16Data->Cost.FinalCost[gun_index].txId)
  1622. {
  1623. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  1624. strcpy((char*)cost_empty, "$ -----");
  1625. string2ByteArray(cost_empty, output_data);
  1626. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TOTAL_COST, output_data, ARRAY_SIZE(output_data));
  1627. }
  1628. else
  1629. {
  1630. double chargingCost = 0;
  1631. double parkingCost = 0;
  1632. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.FinalCost[gun_index].description);
  1633. if(!is_error(jsonDescription))
  1634. {
  1635. if(json_object_object_get(jsonDescription,"chargingFee") != NULL)
  1636. {
  1637. chargingCost += json_object_get_double(json_object_object_get(jsonDescription,"chargingFee"));
  1638. }
  1639. if(json_object_object_get(jsonDescription,"parkingFee") != NULL)
  1640. {
  1641. parkingCost += json_object_get_double(json_object_object_get(jsonDescription,"parkingFee"));
  1642. }
  1643. if((chargingCost + parkingCost) > 0)
  1644. sprintf((char*)output_data, "$ %.2f", (chargingCost + parkingCost));
  1645. else
  1646. sprintf((char*)output_data, "$ -----");
  1647. // APPEAR COST ICON
  1648. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  1649. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TOTAL_COST, output_data, ARRAY_SIZE(output_data));
  1650. }
  1651. json_object_put(jsonDescription);
  1652. }
  1653. }
  1654. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1655. {
  1656. // OCPP 2.0.1
  1657. }
  1658. break;
  1659. case ACCOUNT_BALANCE:
  1660. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1661. {
  1662. if(ShmOCPP16Data->StopTransaction[gun_index].TransactionId != ShmOCPP16Data->Cost.FinalCost[gun_index].txId)
  1663. {
  1664. setDisplayValue(ICON_COMPLETE_WALLET, APPEAR);
  1665. strcpy((char*)balance_empty, "$ -----");
  1666. string2ByteArray(balance_empty, output_data);
  1667. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_REMAINING_ACCOUNT_BALANCE, output_data, ARRAY_SIZE(output_data));
  1668. }
  1669. else
  1670. {
  1671. double accountBalance = 0;
  1672. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.FinalCost[gun_index].description);
  1673. if(!is_error(jsonDescription))
  1674. {
  1675. if(json_object_object_get(jsonDescription,"accountBalance") != NULL)
  1676. {
  1677. accountBalance += json_object_get_double(json_object_object_get(jsonDescription,"accountBalance"));
  1678. }
  1679. if(accountBalance > 0)
  1680. sprintf((char*)output_data, "$ %.2f", accountBalance);
  1681. else
  1682. sprintf((char*)output_data, "$ -----");
  1683. // APPEAR COST ICON
  1684. setDisplayValue(ICON_COMPLETE_WALLET, APPEAR);
  1685. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_REMAINING_ACCOUNT_BALANCE, output_data, ARRAY_SIZE(output_data));
  1686. }
  1687. json_object_put(jsonDescription);
  1688. }
  1689. }
  1690. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1691. {
  1692. // OCPP 2.0.1
  1693. }
  1694. break;
  1695. default:
  1696. break;
  1697. }
  1698. }
  1699. //=======================================
  1700. // Setting [ RunningCost ] ( BACKEND )
  1701. //=======================================
  1702. void setRunningCost(uint8_t gun_index, uint8_t type)
  1703. {
  1704. uint8_t output_data[32];
  1705. unsigned char cost_empty[32];
  1706. unsigned char session_empty[32];
  1707. unsigned char occupancy_empty[32];
  1708. json_object *jsonDescription;
  1709. memset(output_data, 0x00, ARRAY_SIZE(output_data));
  1710. memset(cost_empty, 0x00, ARRAY_SIZE(cost_empty));
  1711. memset(session_empty, 0x00, ARRAY_SIZE(session_empty));
  1712. memset(occupancy_empty, 0x00, ARRAY_SIZE(occupancy_empty));
  1713. switch(type)
  1714. {
  1715. case CONNECTION_FEE:
  1716. break;
  1717. case SESSION_FEE:
  1718. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1719. {
  1720. if(ShmOCPP16Data->StartTransaction[gun_index].ResponseTransactionId != ShmOCPP16Data->Cost.RunningCost[gun_index].txId)
  1721. {
  1722. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  1723. strcpy((char*)session_empty, "$ -----");
  1724. string2ByteArray(session_empty, output_data);
  1725. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, output_data, ARRAY_SIZE(output_data));
  1726. }
  1727. else
  1728. {
  1729. double chargingCost = 0;
  1730. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description);
  1731. if(!is_error(jsonDescription))
  1732. {
  1733. if(json_object_object_get(jsonDescription,"chargingFee") != NULL)
  1734. {
  1735. chargingCost += json_object_get_double(json_object_object_get(jsonDescription,"chargingFee"));
  1736. }
  1737. if(chargingCost> 0)
  1738. sprintf((char*)output_data, "$ %.2f", chargingCost);
  1739. else
  1740. sprintf((char*)output_data, "$ -----");
  1741. // APPEAR COST ICON
  1742. setDisplayValue(ICON_CHARGING_SESSION_FEE, APPEAR);
  1743. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, output_data, ARRAY_SIZE(output_data));
  1744. }
  1745. json_object_put(jsonDescription);
  1746. }
  1747. }
  1748. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1749. {
  1750. // OCPP 2.0.1
  1751. }
  1752. break;
  1753. case OCCUPANCY_FEE:
  1754. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1755. {
  1756. if(ShmOCPP16Data->StartTransaction[gun_index].ResponseTransactionId != ShmOCPP16Data->Cost.RunningCost[gun_index].txId)
  1757. {
  1758. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  1759. strcpy((char*)occupancy_empty, "$ -----");
  1760. string2ByteArray(occupancy_empty, output_data);
  1761. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_PARKING_FEE, output_data, ARRAY_SIZE(output_data));
  1762. }
  1763. else
  1764. {
  1765. double parkingCost = 0;
  1766. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description);
  1767. if(!is_error(jsonDescription))
  1768. {
  1769. if(json_object_object_get(jsonDescription,"parkingFee") != NULL)
  1770. {
  1771. parkingCost += json_object_get_double(json_object_object_get(jsonDescription,"parkingFee"));
  1772. }
  1773. if(parkingCost > 0)
  1774. sprintf((char*)output_data, "$ %.2f", parkingCost);
  1775. else
  1776. sprintf((char*)output_data, "$ -----");
  1777. setDisplayValue(ICON_CHARGING_PARKING_FEE, APPEAR);
  1778. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_PARKING_FEE, output_data, ARRAY_SIZE(output_data));
  1779. }
  1780. json_object_put(jsonDescription);
  1781. }
  1782. }
  1783. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1784. {
  1785. // OCPP 2.0.1
  1786. }
  1787. break;
  1788. case TOTAL_COST:
  1789. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1790. {
  1791. if(ShmOCPP16Data->StartTransaction[gun_index].ResponseTransactionId != ShmOCPP16Data->Cost.RunningCost[gun_index].txId)
  1792. {
  1793. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  1794. strcpy((char*)cost_empty, "$ -----");
  1795. string2ByteArray(cost_empty, output_data);
  1796. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TOTAL_COST, output_data, ARRAY_SIZE(output_data));
  1797. }
  1798. else
  1799. {
  1800. double chargingCost = 0;
  1801. double parkingCost = 0;
  1802. jsonDescription = json_tokener_parse((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description);
  1803. if(!is_error(jsonDescription))
  1804. {
  1805. if(json_object_object_get(jsonDescription,"chargingFee") != NULL)
  1806. {
  1807. chargingCost += json_object_get_double(json_object_object_get(jsonDescription,"chargingFee"));
  1808. }
  1809. if(json_object_object_get(jsonDescription,"parkingFee") != NULL)
  1810. {
  1811. parkingCost += json_object_get_double(json_object_object_get(jsonDescription,"parkingFee"));
  1812. }
  1813. if((chargingCost + parkingCost) > 0)
  1814. sprintf((char*)output_data, "$ %.2f", (chargingCost + parkingCost));
  1815. else
  1816. sprintf((char*)output_data, "$ -----");
  1817. // APPEAR COST ICON
  1818. setDisplayValue(ICON_CHARGING_TOTAL_COST, APPEAR);
  1819. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TOTAL_COST, output_data, ARRAY_SIZE(output_data));
  1820. }
  1821. json_object_put(jsonDescription);
  1822. }
  1823. }
  1824. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1825. {
  1826. // OCPP 2.0.1
  1827. }
  1828. break;
  1829. case ACCOUNT_BALANCE:
  1830. break;
  1831. default:
  1832. break;
  1833. }
  1834. }
  1835. //=======================================
  1836. // SETTING CONTENT [QR CODE CUSTOMIZED]
  1837. //=======================================
  1838. void setQRCodeIcon()
  1839. {
  1840. int LENGTH = 0;
  1841. if(ShmSysConfigAndInfo->SysConfig.isQRCode == ON)
  1842. {
  1843. setDisplayValue(ICON_QR_CODE,QRCODE_ENABLE);
  1844. if(ShmSysConfigAndInfo->SysConfig.QRCodeMadeMode == NO)
  1845. {
  1846. LENGTH = strlen((char *)ShmSysConfigAndInfo->SysConfig.SystemId);
  1847. setQRCodeContent((char *)ShmSysConfigAndInfo->SysConfig.SystemId, LENGTH, QRCODE_FOR_IDLE);
  1848. }
  1849. else
  1850. {
  1851. LENGTH = strlen((char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent);
  1852. setQRCodeContent((char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent, LENGTH, QRCODE_FOR_IDLE);
  1853. }
  1854. }
  1855. else
  1856. {
  1857. setDisplayValue(TEXT_QRCODE_CONTENT, DISAPPEAR);
  1858. setDisplayValue(ICON_QR_CODE,QRCODE_DISABLE);
  1859. }
  1860. }
  1861. //=======================================
  1862. // SETTING CONTENT [QR CODE RECEIPT]
  1863. //=======================================
  1864. void setQRCodeReceipt(uint8_t gun_index)
  1865. {
  1866. int LENGTH = 0;
  1867. int TRANSACTION_ID;
  1868. uint8_t DISPLAY_DATA[512];
  1869. uint8_t QR_CODE_CONTENT[512];
  1870. uint8_t QR_CODE_RECEIPT[512];
  1871. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  1872. memset(QR_CODE_CONTENT, 0x00, ARRAY_SIZE(QR_CODE_CONTENT));
  1873. memset(QR_CODE_RECEIPT, 0x00, ARRAY_SIZE(QR_CODE_RECEIPT));
  1874. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  1875. {
  1876. if((strcmp((char *)ShmOCPP16Data->Cost.FinalCost[gun_index].qrCodeText,"") != 0))
  1877. {
  1878. // QR CODE RECEIPT FOR CDFA 2.0 STRUCTURE
  1879. memcpy((char*)QR_CODE_CONTENT, (char*)ShmOCPP16Data->Cost.FinalCost[gun_index].qrCodeText, ARRAY_SIZE(QR_CODE_CONTENT));
  1880. sprintf((char *)QR_CODE_RECEIPT, "%s", QR_CODE_CONTENT);
  1881. string2ByteArray(QR_CODE_RECEIPT, DISPLAY_DATA);
  1882. }
  1883. else
  1884. {
  1885. if((strcmp((char *)ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL,"") != 0))
  1886. {
  1887. // QR CODE RECEIPT FOR CDFA 1.0 STRUCTURE
  1888. memcpy((char*)QR_CODE_CONTENT, (char*)ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL, ARRAY_SIZE(ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL));
  1889. TRANSACTION_ID = ShmOCPP16Data->StopTransaction[gun_index].TransactionId;
  1890. sprintf((char *)QR_CODE_RECEIPT, "%s%d", QR_CODE_CONTENT,TRANSACTION_ID);
  1891. string2ByteArray(QR_CODE_RECEIPT, DISPLAY_DATA);
  1892. }
  1893. else
  1894. {}
  1895. }
  1896. }
  1897. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  1898. {
  1899. // TO DO OCPP 2.0
  1900. }
  1901. else
  1902. {}
  1903. LENGTH = strlen((char *)DISPLAY_DATA);
  1904. setQRCodeContent((char *)DISPLAY_DATA, LENGTH, QRCODE_FOR_COMPLETE);
  1905. }
  1906. //=======================================
  1907. // SETTING CONTENT [QR CODE ALARM]
  1908. //=======================================
  1909. void setQRCodeAlarm()
  1910. {
  1911. int LENGTH = 0;
  1912. uint8_t DISPLAY_DATA[512];
  1913. uint8_t QR_CODE_ALARM[512];
  1914. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  1915. memset(QR_CODE_ALARM, 0x00, ARRAY_SIZE(QR_CODE_ALARM));
  1916. sprintf((char *)QR_CODE_ALARM, "%s", "https://evsc.phihong.com.tw/");
  1917. string2ByteArray(QR_CODE_ALARM, DISPLAY_DATA);
  1918. LENGTH = strlen((char *)DISPLAY_DATA);
  1919. setQRCodeContent((char *)DISPLAY_DATA, LENGTH, QRCODE_FOR_ALARM);
  1920. }
  1921. //=======================================
  1922. // SETTING CONTENT [QR CODE]
  1923. //=======================================
  1924. void setQRCodeContent(char *input, int length, uint8_t mode)
  1925. {
  1926. int loop = 0;
  1927. uint8_t output[length];
  1928. input[length] = '\0';
  1929. output[length] = '\0';
  1930. while(input[loop] != '\0')
  1931. {
  1932. output[loop] = input[loop];
  1933. loop++;
  1934. }
  1935. switch(mode)
  1936. {
  1937. case QRCODE_FOR_IDLE:
  1938. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_QRCODE_CONTENT, output, ARRAY_SIZE(output)+1);
  1939. break;
  1940. case QRCODE_FOR_COMPLETE:
  1941. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_QRCODE_RECEIPT, output, ARRAY_SIZE(output)+1);
  1942. break;
  1943. case QRCODE_FOR_ALARM:
  1944. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_QRCODE_ALARM, output, ARRAY_SIZE(output)+1);
  1945. break;
  1946. default:
  1947. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_QRCODE_CONTENT, output, ARRAY_SIZE(output)+1);
  1948. break;
  1949. }
  1950. }
  1951. //=======================================
  1952. // SETTING SWITCH [WARNING PAGE]
  1953. //=======================================
  1954. void setWarningStatus(uint8_t gun_index)
  1955. {
  1956. /*
  1957. * 1. WARNING COUNT IS DIFFERENT BETWEEN BEGINNING CHANGE DISPLAY
  1958. * 2. WARNING COUNT BIGGER THAN 4 AND EVERY 5 SECONDS CHANGE NEXT PAGE
  1959. */
  1960. if(WarningCount != ShmSysConfigAndInfo->SysWarningInfo.WarningCount)
  1961. {
  1962. WarningCount = ShmSysConfigAndInfo->SysWarningInfo.WarningCount;
  1963. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  1964. setAlarmCodeAndIcon();
  1965. }
  1966. else if((ShmSysConfigAndInfo->SysWarningInfo.WarningCount > 4) && (getDiffSecNow(startTime[gun_index][TMR_IDX_ALARM]) > (TIME_ANIMATION_ALARM)))
  1967. {
  1968. refreshStartTimer(&startTime[gun_index][TMR_IDX_ALARM]);
  1969. if(ShmSysConfigAndInfo->SysWarningInfo.PageIndex == 0)
  1970. {
  1971. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 1;
  1972. }
  1973. else
  1974. {
  1975. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  1976. }
  1977. setAlarmCodeAndIcon();
  1978. }
  1979. }
  1980. //=======================================
  1981. // SETTING ICON [ALARM CODE]
  1982. //=======================================
  1983. void setAlarmCodeAndIcon()
  1984. {
  1985. uint8_t cmd[7];
  1986. uint8_t index = 0;
  1987. for(index = 0; (index + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 4) < ShmSysConfigAndInfo->SysWarningInfo.WarningCount; index++)
  1988. {
  1989. memset(cmd, 0x00, sizeof(cmd));
  1990. if(index >= 4)
  1991. {
  1992. break;
  1993. }
  1994. // ALARM CODE TEXT (XXXXXX)
  1995. string2ByteArray(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[index + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 4][0], cmd);
  1996. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_ALARM_CODE_1 + (index * 6), cmd, ARRAY_SIZE(cmd));
  1997. // ALARM CODE ICON STATUS (!)
  1998. memset(cmd, 0x00, sizeof(cmd));
  1999. cmd[0] = 0x00;
  2000. cmd[1] = 0x01;
  2001. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, ICON_ALARM_1 + index, cmd, 2);
  2002. }
  2003. memset(cmd, 0x00, sizeof(cmd));
  2004. for(; index < 4; index++)
  2005. {
  2006. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_ALARM_CODE_1 + (index * 6), cmd, ARRAY_SIZE(cmd));
  2007. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, ICON_ALARM_1 + index, cmd, 2);
  2008. }
  2009. }
  2010. //=======================================
  2011. // SETTING ANIMATION CONNECTION
  2012. //=======================================
  2013. void setConnectionAnimation(uint8_t gun_index, uint8_t system_mode)
  2014. {
  2015. switch(system_mode)
  2016. {
  2017. case SYS_MODE_IDLE:
  2018. if(ShmCharger->gun_info[gun_index].chargingMode == CHARGING_MODE_HLC)
  2019. {
  2020. if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION)))
  2021. {
  2022. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2023. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_1;
  2024. }
  2025. else if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION*2)))
  2026. {
  2027. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_2);
  2028. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2029. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2030. }
  2031. }
  2032. else
  2033. {
  2034. if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION)))
  2035. {
  2036. setDisplayValue(ICON_PREPARING_ANIMATION, CONNECTION_FLASHING_1);
  2037. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2038. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_1;
  2039. }
  2040. else if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION*2)))
  2041. {
  2042. setDisplayValue(ICON_PREPARING_ANIMATION, CONNECTION_FLASHING_2);
  2043. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_2);
  2044. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2045. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2046. }
  2047. }
  2048. break;
  2049. case SYS_MODE_PREPARING:
  2050. if(ShmCharger->gun_info[gun_index].chargingMode == CHARGING_MODE_HLC)
  2051. {
  2052. if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION)))
  2053. {
  2054. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2055. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_1;
  2056. }
  2057. else if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION*2)))
  2058. {
  2059. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_2);
  2060. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2061. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2062. }
  2063. }
  2064. else
  2065. {
  2066. if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION)))
  2067. {
  2068. setDisplayValue(ICON_PREPARING_ANIMATION, CONNECTION_FLASHING_1);
  2069. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_1;
  2070. }
  2071. else if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION*2)))
  2072. {
  2073. setDisplayValue(ICON_PREPARING_ANIMATION, CONNECTION_FLASHING_2);
  2074. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2075. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2076. }
  2077. }
  2078. break;
  2079. case SYS_MODE_CHARGING:
  2080. if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION)))
  2081. {
  2082. setDisplayValue(ICON_CHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2083. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_1;
  2084. }
  2085. else if((CONNECTION_LEVEL_STATUS == CONNECTION_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_CONNECTION]) > (TIME_ANIMATION_CONNECTION*2)))
  2086. {
  2087. setDisplayValue(ICON_CHARGING_ANIMATION, CONNECTION_FLASHING_2);
  2088. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2089. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2090. }
  2091. break;
  2092. case SYS_MODE_TERMINATING:
  2093. break;
  2094. default:
  2095. break;
  2096. }
  2097. }
  2098. //=======================================
  2099. // SETTING ANIMATION [CONNECTOR PLUG-IN]
  2100. //=======================================
  2101. void setGunPluginAnimation(uint8_t gun_index)
  2102. {
  2103. if((ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PilotState == CP_STATE_B) ||
  2104. (ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PilotState == CP_STATE_C) ||
  2105. (ShmCharger->gun_info[gun_index].primaryMcuState.socket_e.isSocketEPinOn == ON))
  2106. {
  2107. setDisplayValue(ICON_PREPARING_PLUG_ARROW, PLUGIN_ARROW_2);
  2108. }
  2109. else
  2110. {
  2111. if((GUN_PLUGING_LEVEL_STATUS == GUN_PLUGING_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_PLUGIN]) > (TIME_ANIMATION_PLUGIN)))
  2112. {
  2113. setDisplayValue(ICON_PREPARING_PLUG_ARROW, PLUGIN_ARROW_1);
  2114. GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_1;
  2115. }
  2116. else if((GUN_PLUGING_LEVEL_STATUS == GUN_PLUGING_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_PLUGIN]) > (TIME_ANIMATION_PLUGIN*2)))
  2117. {
  2118. setDisplayValue(ICON_PREPARING_PLUG_ARROW, PLUGIN_ARROW_2);
  2119. GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_0;
  2120. refreshStartTimer(&startTime[gun_index][TMR_IDX_PLUGIN]);
  2121. }
  2122. }
  2123. }
  2124. //=======================================
  2125. // SETTING ANIMATION [PLUG & CHARGE]
  2126. //=======================================
  2127. void setPlugAndChargeAnimation(uint8_t gun_index)
  2128. {
  2129. if((GUN_PLUGING_LEVEL_STATUS == GUN_PLUGING_LEVEL_0) && (getDiffSecNow(startTime[gun_index][TMR_IDX_PLUGIN]) > (TIME_ANIMATION_PLUGIN)))
  2130. {
  2131. setDisplayValue(ICON_PLUG_AND_CHARGE_ARROW, PLUGIN_ARROW_1);
  2132. GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_1;
  2133. }
  2134. else if((GUN_PLUGING_LEVEL_STATUS == GUN_PLUGING_LEVEL_1) && (getDiffSecNow(startTime[gun_index][TMR_IDX_PLUGIN]) > (TIME_ANIMATION_PLUGIN*2)))
  2135. {
  2136. setDisplayValue(ICON_PLUG_AND_CHARGE_ARROW, PLUGIN_ARROW_2);
  2137. GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_0;
  2138. refreshStartTimer(&startTime[gun_index][TMR_IDX_PLUGIN]);
  2139. }
  2140. }
  2141. //=======================================
  2142. // SETTING ANIMATION [PRESS START BUTTON]
  2143. //=======================================
  2144. void setPressStartButtonAnimation(uint8_t gun_index)
  2145. {
  2146. if((START_PRESS_LEVEL_STATIS == PRESS_START_LEVEL_0) && ((getDiffSecNow(startTime[gun_index][TMR_IDX_STARTBUTTON]))> (TIME_ANIMATION_START_PRESS)))
  2147. {
  2148. setDisplayValue(ICON_PRESS_START_BUTTON, PRESS_START_1);
  2149. START_PRESS_LEVEL_STATIS = PRESS_START_LEVEL_1;
  2150. }
  2151. else if((START_PRESS_LEVEL_STATIS == PRESS_START_LEVEL_1) && ((getDiffSecNow(startTime[gun_index][TMR_IDX_STARTBUTTON]))> (TIME_ANIMATION_START_PRESS*2)))
  2152. {
  2153. setDisplayValue(ICON_PRESS_START_BUTTON, PRESS_START_2);
  2154. START_PRESS_LEVEL_STATIS = PRESS_START_LEVEL_0;
  2155. refreshStartTimer(&startTime[gun_index][TMR_IDX_STARTBUTTON]);
  2156. }
  2157. }
  2158. //=======================================
  2159. // SETTING CONNECTION TIMEOUT
  2160. //=======================================
  2161. void setPresentConnectionTimeout(uint8_t gun_index)
  2162. {
  2163. int TIME;
  2164. uint8_t DISPLAY_DATA[16];
  2165. uint8_t CONNECTION_TIMEOUT[16];
  2166. unsigned char NOT_COUNTING[16];
  2167. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2168. memset(CONNECTION_TIMEOUT, 0x00, ARRAY_SIZE(CONNECTION_TIMEOUT));
  2169. memset(NOT_COUNTING, 0x00, ARRAY_SIZE(NOT_COUNTING));
  2170. if((ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PilotState == CP_STATE_B) ||
  2171. (ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PilotState == CP_STATE_C) ||
  2172. (ShmCharger->gun_info[gun_index].primaryMcuState.socket_e.isSocketEPinOn == ON))
  2173. {
  2174. strcpy((char*)NOT_COUNTING, "-----");
  2175. string2ByteArray(NOT_COUNTING, DISPLAY_DATA);
  2176. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_CONNECTION_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2177. }
  2178. else
  2179. {
  2180. if((ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PilotState == CP_STATE_A))
  2181. {
  2182. TIME = ShmCharger->timeoutSpec.Handshake_Timeout;
  2183. if(TIME <= 0)
  2184. {
  2185. strcpy((char*)NOT_COUNTING, "000");
  2186. string2ByteArray(NOT_COUNTING, DISPLAY_DATA);
  2187. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_CONNECTION_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2188. }
  2189. else
  2190. {
  2191. sprintf((char *)CONNECTION_TIMEOUT, "%03d ", TIME);
  2192. string2ByteArray(CONNECTION_TIMEOUT, DISPLAY_DATA);
  2193. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_CONNECTION_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2194. }
  2195. }
  2196. else
  2197. {
  2198. strcpy((char*)NOT_COUNTING, "-----");
  2199. string2ByteArray(NOT_COUNTING, DISPLAY_DATA);
  2200. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_CONNECTION_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2201. }
  2202. }
  2203. }
  2204. //=======================================
  2205. // SETTING PRESENT [POWER]
  2206. //=======================================
  2207. void setPresentChargedPower(uint8_t gun_index)
  2208. {
  2209. uint8_t DISPLAY_DATA[16];
  2210. uint8_t POWER[16];
  2211. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2212. memset(POWER, 0x00, ARRAY_SIZE(POWER));
  2213. sprintf((char *)POWER, "%.2f kW", ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PresentChargingPower);
  2214. string2ByteArray(POWER, DISPLAY_DATA);
  2215. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_POWER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2216. }
  2217. //=======================================
  2218. // SETTING PRESENT [ENERGY]
  2219. //=======================================
  2220. void setPresentChargedEnergy(uint8_t gun_index, uint8_t system_mode)
  2221. {
  2222. uint8_t DISPLAY_DATA[16];
  2223. uint8_t ENERGY[16];
  2224. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2225. memset(ENERGY, 0x00, ARRAY_SIZE(ENERGY));
  2226. switch(system_mode)
  2227. {
  2228. case SYS_MODE_PREPARING:
  2229. sprintf((char *)ENERGY, "%s kWh", "0.0000");
  2230. string2ByteArray(ENERGY, DISPLAY_DATA);
  2231. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2232. break;
  2233. case SYS_MODE_CHARGING:
  2234. case SYS_MODE_TERMINATING:
  2235. case SYS_MODE_COMPLETE:
  2236. default:
  2237. sprintf((char *)ENERGY, "%.4f kWh", ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PresentChargedEnergy);
  2238. string2ByteArray(ENERGY, DISPLAY_DATA);
  2239. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2240. break;
  2241. }
  2242. }
  2243. //=======================================
  2244. // SETTING PRESENT [DURATION]
  2245. //=======================================
  2246. void setPresentChargedDuration(uint8_t gun_index)
  2247. {
  2248. uint8_t DISPLAY_DATA[16];
  2249. uint8_t TIME[16];
  2250. uint16_t HOUR;
  2251. uint16_t MINUTE;
  2252. uint16_t SECOND;
  2253. uint32_t PRESENT_CHARGED_DURATION = ShmSysConfigAndInfo->SysInfo.AcChargingData[gun_index].PresentChargedDuration;
  2254. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2255. memset(TIME, 0x00, ARRAY_SIZE(TIME));
  2256. HOUR = (PRESENT_CHARGED_DURATION / 3600);
  2257. MINUTE = (PRESENT_CHARGED_DURATION - (3600 * HOUR)) / 60;
  2258. SECOND = (PRESENT_CHARGED_DURATION - (3600 * HOUR) - (MINUTE * 60));
  2259. sprintf((char *)TIME, "%02d:%02d:%02d", HOUR, MINUTE, SECOND);
  2260. string2ByteArray(TIME, DISPLAY_DATA);
  2261. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2262. }
  2263. //=======================================
  2264. // SETTING PRESENT [POWER CONSUMPTION]
  2265. //=======================================
  2266. void setPresentPowerConsumption(uint8_t gun_index)
  2267. {
  2268. uint8_t DISPLAY_DATA[32];
  2269. uint8_t POWER_CONSUMPTION[32];
  2270. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2271. memset(POWER_CONSUMPTION, 0x00, ARRAY_SIZE(POWER_CONSUMPTION));
  2272. sprintf((char *)POWER_CONSUMPTION, "%.4f kWh", ((float)ShmCharger->gun_info[gun_index].powerConsumptionTotal.power_consumption/10000.0));
  2273. string2ByteArray(POWER_CONSUMPTION, DISPLAY_DATA);
  2274. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_POWER_CONSUMPTION, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2275. }
  2276. //=======================================
  2277. // SETTING AUTHORIZATION PAGE
  2278. //=======================================
  2279. void setAuthorizationPage(uint8_t gun_index)
  2280. {
  2281. switch(ShmCharger->gun_info[gun_index].resultAuthorization)
  2282. {
  2283. case VALIDATED_RFID:
  2284. if(getCurrentPage() != SYSTEM_SCREEN_AUTH_PASS)
  2285. {
  2286. setCurrentPage(SYSTEM_SCREEN_AUTH_PASS);
  2287. }
  2288. else
  2289. {}
  2290. break;
  2291. case UNVALIDATED_RFID:
  2292. if(getCurrentPage() != SYSTEM_SCREEN_AUTH_FAIL)
  2293. {
  2294. setCurrentPage(SYSTEM_SCREEN_AUTH_FAIL);
  2295. }
  2296. else
  2297. {}
  2298. break;
  2299. case UNKNOW_RFID:
  2300. if(getCurrentPage() != SYSTEM_SCREEN_AUTH_UNKNOWN)
  2301. {
  2302. setCurrentPage(SYSTEM_SCREEN_AUTH_UNKNOWN);
  2303. }
  2304. else
  2305. {}
  2306. break;
  2307. case DEFAULT_RFID:
  2308. break;
  2309. default:
  2310. break;
  2311. }
  2312. }
  2313. //=======================================
  2314. // SETTING DEFAULT VALUE
  2315. //=======================================
  2316. void setDefaultValue(uint8_t gun_index, uint8_t system_mode)
  2317. {
  2318. switch(system_mode)
  2319. {
  2320. case SYS_MODE_BOOTING:
  2321. break;
  2322. case SYS_MODE_IDLE:
  2323. setTextToEmpty(gun_index);
  2324. setTimeTitle(ON);
  2325. setEnergyTitle(ON);
  2326. setSessionFeeTitle(ON);
  2327. setParkingFeeTitle(ON);
  2328. setFinalCostTitle(ON);
  2329. if(ShmCharger->gun_info[gun_index].chargingMode == CHARGING_MODE_HLC)
  2330. {
  2331. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2332. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2333. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2334. }
  2335. else
  2336. {
  2337. setDisplayValue(ICON_PREPARING_PLUG_ARROW, PLUGIN_ARROW_1);
  2338. GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_0;
  2339. refreshStartTimer(&startTime[gun_index][TMR_IDX_PLUGIN]);
  2340. }
  2341. break;
  2342. case SYS_MODE_AUTHORIZING:
  2343. setTimeTitle(ON);
  2344. setEnergyTitle(ON);
  2345. setSessionFeeTitle(ON);
  2346. setParkingFeeTitle(ON);
  2347. setFinalCostTitle(ON);
  2348. break;
  2349. case SYS_MODE_PREPARING:
  2350. setTimeTitle(ON);
  2351. setEnergyTitle(ON);
  2352. setSessionFeeTitle(ON);
  2353. setParkingFeeTitle(ON);
  2354. setFinalCostTitle(ON);
  2355. if(ShmCharger->gun_info[gun_index].chargingMode == CHARGING_MODE_HLC)
  2356. {
  2357. setDisplayValue(ICON_PRECHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2358. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2359. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2360. refreshStartTimer(&startTime[gun_index][TMR_IDX_REFRESH_INFO]);
  2361. }
  2362. else
  2363. {
  2364. setDisplayValue(ICON_PREPARING_PLUG_ARROW, PLUGIN_ARROW_1);
  2365. GUN_PLUGING_LEVEL_STATUS = GUN_PLUGING_LEVEL_0;
  2366. refreshStartTimer(&startTime[gun_index][TMR_IDX_PLUGIN]);
  2367. refreshStartTimer(&startTime[gun_index][TMR_IDX_REFRESH_INFO]);
  2368. }
  2369. break;
  2370. case SYS_MODE_CHARGING:
  2371. break;
  2372. case SYS_MODE_TERMINATING:
  2373. setDisplayValue(ICON_CHARGING_ANIMATION, CONNECTION_FLASHING_1);
  2374. refreshStartTimer(&startTime[gun_index][TMR_IDX_CONNECTION]);
  2375. refreshStartTimer(&startTime[gun_index][TMR_IDX_REFRESH_INFO]);
  2376. CONNECTION_LEVEL_STATUS = CONNECTION_LEVEL_0;
  2377. break;
  2378. case SYS_MODE_COMPLETE:
  2379. break;
  2380. case SYS_MODE_ALARM:
  2381. break;
  2382. case SYS_MODE_FAULT:
  2383. break;
  2384. case SYS_MODE_MAINTAIN:
  2385. break;
  2386. case SYS_MODE_UPDATE:
  2387. break;
  2388. case SYS_MODE_RESERVATION:
  2389. break;
  2390. case SYS_MODE_BOOKING:
  2391. break;
  2392. case SYS_MODE_DEBUG:
  2393. break;
  2394. default:
  2395. break;
  2396. }
  2397. }
  2398. //=======================================
  2399. // SETTING CONTENT EMPTY
  2400. //=======================================
  2401. void setTextToEmpty(uint8_t gun_index)
  2402. {
  2403. uint8_t DISPLAY_DATA[16];
  2404. uint8_t TEXT_DATA[16];
  2405. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2406. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2407. strcpy((char*)TEXT_DATA, " ");
  2408. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2409. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TOTAL_COST, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2410. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_SESSION_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2411. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_PARKING_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2412. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_USER_ACCOUNT_BALANCE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2413. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_REMAINING_ACCOUNT_BALANCE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2414. }
  2415. //=======================================
  2416. // Setting marquee control
  2417. //=======================================
  2418. void setMarqueeControl(uint16_t address, uint8_t gun_index, uint8_t type)
  2419. {
  2420. uint8_t data[250];
  2421. unsigned char Content[250];
  2422. memset(Content, 0xFF, ARRAY_SIZE(Content));
  2423. memset(data, 0xFF, ARRAY_SIZE(data));
  2424. switch(type)
  2425. {
  2426. case DEFAULE_PRICE:
  2427. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  2428. {
  2429. sprintf((char *)Content, "%s", (char *)ShmOCPP16Data->ConfigurationTable.CoreProfile[DefaultPrice].ItemData);
  2430. string2ByteArray(Content,data);
  2431. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, (address+3), data, ARRAY_SIZE(data));
  2432. }
  2433. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  2434. {
  2435. // OCPP 2.0.1
  2436. }
  2437. break;
  2438. case SET_USER_PRICE:
  2439. if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_16)
  2440. {
  2441. sprintf((char *)Content, "%s", (char *)ShmOCPP16Data->Cost.SetUserPrice.price);
  2442. string2ByteArray(Content,data);
  2443. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, (address+3), data, ARRAY_SIZE(data));
  2444. }
  2445. else if(ShmSysConfigAndInfo->SysInfo.OcppRunningVer == OCPP_RUNNING_VERSION_20)
  2446. {
  2447. // OCPP 2.0.1
  2448. }
  2449. break;
  2450. case FINAL_COST:
  2451. break;
  2452. case RUNNING_COST:
  2453. break;
  2454. default:
  2455. break;
  2456. }
  2457. }
  2458. //=======================================
  2459. // SETTING TITLE [BY MODEL NAME]
  2460. //=======================================
  2461. int isAmericaType()
  2462. {
  2463. int result = NO;
  2464. if(ShmSysConfigAndInfo->SysConfig.ModelName[3] == 'U')
  2465. result = YES;
  2466. else
  2467. result = NO;
  2468. return result;
  2469. }
  2470. //=======================================
  2471. // SETTING TITLE [TIME]
  2472. //=======================================
  2473. void setTimeTitle(uint8_t isOn)
  2474. {
  2475. uint8_t DISPLAY_DATA[32];
  2476. uint8_t TEXT_DATA[32];
  2477. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2478. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2479. if(isAmericaType() == YES)
  2480. {
  2481. if(isOn == ON)
  2482. {
  2483. strcpy((char*)TEXT_DATA, "(hrs: mins: secs)");
  2484. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2485. }
  2486. else
  2487. {
  2488. strcpy((char*)TEXT_DATA, " ");
  2489. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2490. }
  2491. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TITLE_TIME, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2492. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_TITLE_TIME, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2493. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TITLE_TIME, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2494. }
  2495. else
  2496. {
  2497. setDisplayValue(TEXT_CHARGING_TITLE_TIME, DISAPPEAR);
  2498. setDisplayValue(TEXT_PREPARING_TITLE_TIME, DISAPPEAR);
  2499. setDisplayValue(TEXT_PRECHARGING_TITLE_TIME, DISAPPEAR);
  2500. }
  2501. }
  2502. //=======================================
  2503. // SETTING TITLE [ENERGY]
  2504. //=======================================
  2505. void setEnergyTitle(uint8_t isOn)
  2506. {
  2507. uint8_t DISPLAY_DATA[32];
  2508. uint8_t TEXT_DATA[32];
  2509. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2510. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2511. if(isAmericaType() == YES)
  2512. {
  2513. if(isOn == ON)
  2514. {
  2515. strcpy((char*)TEXT_DATA, "(Energy)");
  2516. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2517. }
  2518. else
  2519. {
  2520. strcpy((char*)TEXT_DATA, " ");
  2521. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2522. }
  2523. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TITLE_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2524. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_TITLE_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2525. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TITLE_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2526. }
  2527. else
  2528. {
  2529. setDisplayValue(TEXT_CHARGING_TITLE_ENERGY, DISAPPEAR);
  2530. setDisplayValue(TEXT_PREPARING_TITLE_ENERGY, DISAPPEAR);
  2531. setDisplayValue(TEXT_PRECHARGING_TITLE_ENERGY, DISAPPEAR);
  2532. }
  2533. }
  2534. //=======================================
  2535. // SETTING TITLE [SESSION FEE]
  2536. //=======================================
  2537. void setSessionFeeTitle(uint8_t isOn)
  2538. {
  2539. uint8_t DISPLAY_DATA[32];
  2540. uint8_t TEXT_DATA[32];
  2541. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2542. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2543. if(isAmericaType() == YES)
  2544. {
  2545. if(isOn == ON)
  2546. {
  2547. strcpy((char*)TEXT_DATA, "(Energy Cost)");
  2548. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2549. }
  2550. else
  2551. {
  2552. strcpy((char*)TEXT_DATA, " ");
  2553. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2554. }
  2555. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TITLE_SESSION_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2556. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_TITLE_SESSION_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2557. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TITLE_SESSION_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2558. }
  2559. else
  2560. {
  2561. setDisplayValue(TEXT_CHARGING_TITLE_SESSION_FEE, DISAPPEAR);
  2562. setDisplayValue(TEXT_PREPARING_TITLE_SESSION_FEE, DISAPPEAR);
  2563. setDisplayValue(TEXT_PRECHARGING_TITLE_SESSION_FEE, DISAPPEAR);
  2564. }
  2565. }
  2566. //=======================================
  2567. // SETTING TITLE [PARKING FEE]
  2568. //=======================================
  2569. void setParkingFeeTitle(uint8_t isOn)
  2570. {
  2571. uint8_t DISPLAY_DATA[32];
  2572. uint8_t TEXT_DATA[32];
  2573. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2574. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2575. if(isAmericaType() == YES)
  2576. {
  2577. if(isOn == ON)
  2578. {
  2579. strcpy((char*)TEXT_DATA, "(Parking Fee)");
  2580. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2581. }
  2582. else
  2583. {
  2584. strcpy((char*)TEXT_DATA, " ");
  2585. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2586. }
  2587. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TITLE_PARKING_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2588. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_TITLE_PARKING_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2589. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TITLE_PARKING_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2590. }
  2591. else
  2592. {
  2593. setDisplayValue(TEXT_CHARGING_TITLE_PARKING_FEE, DISAPPEAR);
  2594. setDisplayValue(TEXT_PREPARING_TITLE_PARKING_FEE, DISAPPEAR);
  2595. setDisplayValue(TEXT_PRECHARGING_TITLE_PARKING_FEE, DISAPPEAR);
  2596. }
  2597. }
  2598. //=======================================
  2599. // SETTING TITLE [FINAL COST]
  2600. //=======================================
  2601. void setFinalCostTitle(uint8_t isOn)
  2602. {
  2603. uint8_t DISPLAY_DATA[32];
  2604. uint8_t TEXT_DATA[32];
  2605. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2606. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2607. if(isAmericaType() == YES)
  2608. {
  2609. if(isOn == ON)
  2610. {
  2611. strcpy((char*)TEXT_DATA, "(Total Cost)");
  2612. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2613. }
  2614. else
  2615. {
  2616. strcpy((char*)TEXT_DATA, " ");
  2617. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2618. }
  2619. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_TITLE_FINAL_COST, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2620. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PREPARING_TITLE_FINAL_COST, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2621. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TITLE_FINAL_COST, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2622. }
  2623. else
  2624. {
  2625. setDisplayValue(TEXT_CHARGING_TITLE_FINAL_COST, DISAPPEAR);
  2626. setDisplayValue(TEXT_PREPARING_TITLE_FINAL_COST, DISAPPEAR);
  2627. setDisplayValue(TEXT_PRECHARGING_TITLE_FINAL_COST, DISAPPEAR);
  2628. }
  2629. }
  2630. //=======================================
  2631. // SETTING CSU FIRMWARE VERSION
  2632. //=======================================
  2633. void setCsuRootFsFwRev()
  2634. {
  2635. uint8_t DISPLAY_DATA[64];
  2636. uint8_t TEXT_DATA[64];
  2637. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2638. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2639. sprintf((char *)TEXT_DATA, "%s%s", " CSU Software Version: ",(char*)ShmSysConfigAndInfo->SysInfo.CsuRootFsFwRev);
  2640. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2641. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CSU_ROOT_FS_FW_REV, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2642. }
  2643. //=======================================
  2644. // SETTING PRECHARGING VALUE EMPTY
  2645. //=======================================
  2646. void setClearPrechargingValueToEmpty()
  2647. {
  2648. uint8_t DISPLAY_DATA[16];
  2649. uint8_t TEXT_DATA[16];
  2650. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2651. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2652. strcpy((char*)TEXT_DATA, " ");
  2653. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2654. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2655. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2656. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_SESSION_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2657. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_PARKING_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2658. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_COST, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2659. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_POWER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2660. }
  2661. //=======================================
  2662. // SETTING PRECHARGING TIMER DEFAULT
  2663. //=======================================
  2664. void setPrechargingTimerToDefault()
  2665. {
  2666. uint8_t DISPLAY_DATA[16];
  2667. uint8_t TEXT_DATA[16];
  2668. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2669. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2670. sprintf((char *)TEXT_DATA, "%s", "00:00:00");
  2671. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2672. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_TIMER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2673. }
  2674. //=======================================
  2675. // SETTING PRECHARGING ENERGY DEFAULT
  2676. //=======================================
  2677. void setPrechargingEnergyToDefault()
  2678. {
  2679. uint8_t DISPLAY_DATA[16];
  2680. uint8_t TEXT_DATA[16];
  2681. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2682. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2683. sprintf((char *)TEXT_DATA, "%s kWh", "0000.0000");
  2684. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2685. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_ENERGY, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2686. }
  2687. //=======================================
  2688. // SETTING PRECHARGING SESSION FEE DEFAULT
  2689. //=======================================
  2690. void setPrechargingSessionFeeToDefault()
  2691. {
  2692. uint8_t DISPLAY_DATA[16];
  2693. uint8_t TEXT_DATA[16];
  2694. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2695. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2696. sprintf((char *)TEXT_DATA, "%s", "000.00");
  2697. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2698. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_SESSION_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2699. }
  2700. //=======================================
  2701. // SETTING PRECHARGING PARKING FEE DEFAULT
  2702. //=======================================
  2703. void setPrechargingParkingFeeToDefault()
  2704. {
  2705. uint8_t DISPLAY_DATA[16];
  2706. uint8_t TEXT_DATA[16];
  2707. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2708. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2709. sprintf((char *)TEXT_DATA, "%s", "000.00");
  2710. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2711. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_PARKING_FEE, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2712. }
  2713. //=======================================
  2714. // SETTING PRECHARGING COST DEFAULT
  2715. //=======================================
  2716. void setPrechargingCostToDefault()
  2717. {
  2718. uint8_t DISPLAY_DATA[16];
  2719. uint8_t TEXT_DATA[16];
  2720. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2721. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2722. sprintf((char *)TEXT_DATA, "%s", "000.00");
  2723. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2724. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_COST, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2725. }
  2726. //=======================================
  2727. // SETTING PRECHARGING POWER DEFUALT
  2728. //=======================================
  2729. void setPrechargingPowerToDefault()
  2730. {
  2731. uint8_t DISPLAY_DATA[16];
  2732. uint8_t TEXT_DATA[16];
  2733. memset(DISPLAY_DATA, 0x00, ARRAY_SIZE(DISPLAY_DATA));
  2734. memset(TEXT_DATA, 0x00, ARRAY_SIZE(TEXT_DATA));
  2735. sprintf((char *)TEXT_DATA, "%s kW", "0.00");
  2736. string2ByteArray(TEXT_DATA, DISPLAY_DATA);
  2737. lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_PRECHARGING_POWER, DISPLAY_DATA, ARRAY_SIZE(DISPLAY_DATA));
  2738. }
  2739. //=======================================
  2740. // Initial all share memory
  2741. //=======================================
  2742. int InitShareMemory()
  2743. {
  2744. int result = PASS;
  2745. int MeterSMId;
  2746. // Initial ShmSysConfigAndInfo
  2747. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0)
  2748. {
  2749. DEBUG_ERROR("shmget ShmSysConfigAndInfo NG\n");
  2750. result = FAIL;
  2751. }
  2752. else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  2753. {
  2754. DEBUG_ERROR("shmat ShmSysConfigAndInfo NG\n");
  2755. result = FAIL;
  2756. }
  2757. else
  2758. {}
  2759. // Initial ShmStatusCodeData
  2760. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0)
  2761. {
  2762. DEBUG_ERROR("shmget ShmStatusCodeData NG\n");
  2763. result = FAIL;
  2764. }
  2765. else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  2766. {
  2767. DEBUG_ERROR("shmat ShmStatusCodeData NG\n");
  2768. result = FAIL;
  2769. }
  2770. else
  2771. {}
  2772. // Initial ShmCharger
  2773. if ((MeterSMId = shmget(ShmChargerKey, sizeof(struct Charger), 0777)) < 0)
  2774. {
  2775. DEBUG_ERROR("shmget ShmChargerKey NG\n");
  2776. result = FAIL;
  2777. }
  2778. else if ((ShmCharger = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  2779. {
  2780. DEBUG_ERROR("shmat ShmChargerKey NG\n");
  2781. result = FAIL;
  2782. }
  2783. // Initial ShmOCPP16Data
  2784. if ((MeterSMId = shmget(ShmOcppModuleKey, sizeof(struct OCPP16Data), 0777)) < 0)
  2785. {
  2786. DEBUG_ERROR("shmget ShmOCPP16Data NG\n");
  2787. result = FAIL;
  2788. }
  2789. else if ((ShmOCPP16Data = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  2790. {
  2791. DEBUG_ERROR("shmat ShmOCPP16Data NG\n");
  2792. result = FAIL;
  2793. }
  2794. // Initial ShmOCPP20Data
  2795. if ((MeterSMId = shmget(ShmOcpp20ModuleKey, sizeof(struct OCPP20Data), 0777)) < 0)
  2796. {
  2797. DEBUG_ERROR("shmget ShmOCPP20Data NG\n");
  2798. result = FAIL;
  2799. }
  2800. else if ((ShmOCPP20Data = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  2801. {
  2802. DEBUG_ERROR("shmat ShmOCPP20Data NG\n");
  2803. result = FAIL;
  2804. }
  2805. return result;
  2806. }
  2807. //=======================================
  2808. // Initial communication port
  2809. //=======================================
  2810. int InitComPort()
  2811. {
  2812. int fd;
  2813. struct termios tios;
  2814. fd = open("/dev/ttyS3", O_RDWR);
  2815. if(fd<=0)
  2816. {
  2817. DEBUG_ERROR("open /dev/ttyS3 NG\n");
  2818. return -1;
  2819. }
  2820. ioctl (fd, TCGETS, &tios);
  2821. tios.c_cflag = B115200| CS8 | CLOCAL | CREAD;
  2822. tios.c_lflag = 0;
  2823. tios.c_iflag = 0;
  2824. tios.c_oflag = 0;
  2825. tios.c_cc[VMIN]=0;
  2826. tios.c_cc[VTIME]=(unsigned char)5; // timeout 500ms
  2827. tios.c_lflag=0;
  2828. tcflush(fd, TCIFLUSH);
  2829. ioctl (fd, TCSETS, &tios);
  2830. return fd;
  2831. }
  2832. //=======================================
  2833. // Download image
  2834. //=======================================
  2835. int downloadBMP(uint8_t picIdx, char *filename)
  2836. {
  2837. int result = PASS;
  2838. BMP *bmp;
  2839. struct stat fileSt;
  2840. uint32_t pageSize = 0xf0;
  2841. uint32_t pixelSize;
  2842. uint32_t transferedByte=0;
  2843. uint16_t bufferRamAddr = 0x8000;
  2844. uint32_t dataLen = 0;
  2845. uint32_t startAddr=0;
  2846. // Reset LCD
  2847. uint8_t cmd_reset[] = {0x55, 0xaa, 0x5a, 0xa5};
  2848. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, 0x04, cmd_reset, ARRAY_SIZE(cmd_reset)) != PASS)
  2849. {
  2850. DEBUG_INFO("LCD reset fail.\n");
  2851. }
  2852. sleep(1);
  2853. // Get image file size
  2854. stat(filename, &fileSt);
  2855. bmp = bopen(filename);
  2856. uint8_t buf[bmp->width*bmp->height*2];
  2857. DEBUG_INFO("Target address: %d\n", picIdx);
  2858. DEBUG_INFO("Image filename: %s\n", filename);
  2859. DEBUG_INFO("Image width: %d height: %d\n", bmp->width, bmp->height);
  2860. DEBUG_INFO("Image data size: %d\n", ARRAY_SIZE(buf));
  2861. // Get bmp pixel data and convert to 16 bit color
  2862. for(uint16_t idxY=0 ; idxY<bmp->height ; idxY++)
  2863. {
  2864. for(uint16_t idxX=0 ; idxX<bmp->width ; idxX++)
  2865. {
  2866. uint8_t r, g, b;
  2867. get_pixel_rgb(bmp, idxX, (bmp->height-idxY-1), &r, &g, &b);
  2868. buf[(2*((idxY*bmp->width) + idxX)) + 0] = ((((r>>3)<<11) | ((g>>2)<<5) | (b>>3)) >> 8) & 0xff;
  2869. buf[(2*((idxY*bmp->width) + idxX)) + 1] = ((((r>>3)<<11) | ((g>>2)<<5) | (b>>3)) >> 0) & 0xff;
  2870. }
  2871. }
  2872. bclose(bmp);
  2873. // Transfer pixel to screen page
  2874. pixelSize = ARRAY_SIZE(buf);
  2875. for(uint16_t idxSrcData=0;idxSrcData<(((pixelSize%pageSize)==0)?(pixelSize/pageSize):(pixelSize/pageSize)+1);idxSrcData++)
  2876. {
  2877. //DEBUG_INFO("Buffer start data address: 0x%08X\n", (idxSrcData*pageSize));
  2878. //DEBUG_INFO(" Image start ram address: 0x%08X\n", ((idxSrcData*pageSize) >> 1));
  2879. uint8_t display_cmd[] ={0x5a, (bufferRamAddr>>8)&0xff, (bufferRamAddr>>0)&0xff, 0x00, 0x00, 0x00, 0x00, 0x00};
  2880. if((idxSrcData+1) != (((pixelSize%pageSize)==0)?(pixelSize/pageSize):(pixelSize/pageSize)+1))
  2881. {
  2882. // Data transfer
  2883. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, (bufferRamAddr+(dataLen>>1)), &buf[(idxSrcData*pageSize)], pageSize) != PASS)
  2884. {
  2885. DEBUG_INFO("Transfer data to ram 0x%04X fail.\n", transferedByte);
  2886. }
  2887. transferedByte += pageSize;
  2888. dataLen += pageSize;
  2889. }
  2890. else
  2891. {
  2892. // Last data transfer
  2893. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, (bufferRamAddr+(dataLen>>1)), &buf[(idxSrcData*pageSize)], (pixelSize-(idxSrcData*pageSize))) != PASS)
  2894. {
  2895. DEBUG_INFO("Transfer data to ram 0x%04X fail.\n", transferedByte);
  2896. }
  2897. transferedByte += (pixelSize-(idxSrcData*pageSize));
  2898. dataLen += (pixelSize-(idxSrcData*pageSize));
  2899. }
  2900. // Move data from ram to flash
  2901. if((dataLen >= (pageSize*10)) || (idxSrcData == (((pixelSize%pageSize)==0)?(pixelSize/pageSize):(pixelSize/pageSize)+1)-1))
  2902. {
  2903. display_cmd[3] = ((dataLen>>1) >> 8) & 0xff; // Data length high byte
  2904. display_cmd[4] = ((dataLen>>1) >> 0) & 0xff; // Data length low byte
  2905. display_cmd[5] = (((startAddr)>>1) >> 16) & 0xff; // Screen on ram address 1st byte
  2906. display_cmd[6] = (((startAddr)>>1) >> 8) & 0xff; // Screen on ram address 2nd byte
  2907. display_cmd[7] = (((startAddr)>>1) >> 0) & 0xff; // Screen on ram address 3th byte
  2908. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, 0xa2, display_cmd, ARRAY_SIZE(display_cmd)) != PASS)
  2909. {
  2910. DEBUG_INFO("Write data to display buffer 0x%04X fail.\n", transferedByte);
  2911. }
  2912. startAddr += dataLen;
  2913. dataLen = 0;
  2914. }
  2915. }
  2916. // Save image to target address
  2917. uint8_t save_cmd[] ={0x5a, 0x02, ((picIdx>>8)&0xff), (picIdx&0xff)};
  2918. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, 0x84, save_cmd, ARRAY_SIZE(save_cmd)) != PASS)
  2919. {
  2920. DEBUG_INFO("Save image fail.\n");
  2921. }
  2922. DEBUG_INFO("Save image success.\n");
  2923. sleep(1);
  2924. return result;
  2925. }
  2926. //=======================================
  2927. // Download image
  2928. //=======================================
  2929. int downloadBIN(uint8_t targetAddr, char *filename)
  2930. {
  2931. int result = PASS;
  2932. int fd;
  2933. struct stat fileSt;
  2934. uint32_t pageSize = 128;
  2935. uint32_t blocklSize = 32768;
  2936. uint32_t transferedByte=0;
  2937. uint16_t bufferRamAddr = 0x8000;
  2938. // Reset LCD
  2939. uint8_t cmd_reset[] = {0x55, 0xaa, 0x5a, 0xa5};
  2940. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, 0x04, cmd_reset, ARRAY_SIZE(cmd_reset)) != PASS)
  2941. {
  2942. DEBUG_INFO("LCD reset fail.\n");
  2943. }
  2944. sleep(1);
  2945. // Get image file size
  2946. stat(filename, &fileSt);
  2947. uint8_t buf[(fileSt.st_size%32768==0?(fileSt.st_size/32768)*32768:(fileSt.st_size/32768)+1)*32768];
  2948. DEBUG_INFO("Target address: %d\n", targetAddr);
  2949. DEBUG_INFO("Bin filename: %s\n", filename);
  2950. DEBUG_INFO("Bin data size: %d\n", fileSt.st_size);
  2951. fd = open(filename, O_RDWR);
  2952. if (fd < 0)
  2953. {
  2954. DEBUG_WARN("Bin can not be open.\n");
  2955. result = FAIL;
  2956. }
  2957. else
  2958. {
  2959. // Read data from bin file
  2960. memset(buf, 0x00, ARRAY_SIZE(buf));
  2961. read(fd, buf, ARRAY_SIZE(buf));
  2962. close(fd);
  2963. for(uint8_t idxBinSrc=0;idxBinSrc<(fileSt.st_size%32768==0?fileSt.st_size/32768:(fileSt.st_size/32768)+1);idxBinSrc++)
  2964. {
  2965. // Transfer data to ram
  2966. for(uint16_t idxSrcData=0;idxSrcData<(((blocklSize%pageSize)==0)?(blocklSize/pageSize):(blocklSize/pageSize)+1);idxSrcData++)
  2967. {
  2968. //DEBUG_INFO("Buffer start data address: 0x%08X\n", (idxBinSrc*blocklSize)+(idxSrcData*pageSize));
  2969. //DEBUG_INFO(" Image start ram address: 0x%08X\n", ((idxSrcData*pageSize) >> 1));
  2970. if((idxSrcData+1) != (((blocklSize%pageSize)==0)?(blocklSize/pageSize):(blocklSize/pageSize)+1))
  2971. {
  2972. // Data transfer
  2973. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, bufferRamAddr+((idxSrcData*pageSize)>>1), &buf[(idxBinSrc*blocklSize)+(idxSrcData*pageSize)], pageSize) != PASS)
  2974. {
  2975. DEBUG_INFO("Transfer data to ram 0x%04X fail.\n", transferedByte);
  2976. }
  2977. transferedByte += pageSize;
  2978. }
  2979. else
  2980. {
  2981. // Last data transfer
  2982. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, bufferRamAddr+((idxSrcData*pageSize)>>1), &buf[(idxBinSrc*blocklSize)+(idxSrcData*pageSize)], (blocklSize-(idxSrcData*pageSize)))!= PASS)
  2983. {
  2984. DEBUG_INFO("Transfer data to ram 0x%04X fail.\n", transferedByte);
  2985. }
  2986. transferedByte += (blocklSize-(idxSrcData*pageSize));
  2987. }
  2988. }
  2989. // Move data from ram to flash
  2990. uint8_t save_cmd[] ={0x5a, 0x02, ((((targetAddr*8)+idxBinSrc)>>8)&0xff), ((((targetAddr*8)+idxBinSrc)>>0)&0xff), ((bufferRamAddr>>8)&0xff), ((bufferRamAddr>>0)&0xff), 0x00, 0x01, 0x00, 0x00, 0x00, 0x00};
  2991. while(lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, 0xaa, save_cmd, ARRAY_SIZE(save_cmd)) != PASS)
  2992. {
  2993. DEBUG_INFO("Save bin file to 0x%04X fail.\n", ((targetAddr*8)+idxBinSrc));
  2994. }
  2995. DEBUG_INFO("Save bin file on 0x%04X success.\n", ((targetAddr*8)+idxBinSrc));
  2996. sleep(1);
  2997. }
  2998. }
  2999. return result;
  3000. }
  3001. //=======================================
  3002. // LCD upgrade
  3003. //=======================================
  3004. int lcdUpgrade(char *forlder)
  3005. {
  3006. int result = PASS;
  3007. DIR *dir;
  3008. struct dirent *file;
  3009. struct stat fileSt;
  3010. if ((dir = opendir (forlder)) != NULL)
  3011. {
  3012. /* print all the files and directories within directory */
  3013. while ((file = readdir (dir)) != NULL)
  3014. {
  3015. if((strlen(file->d_name)>2))
  3016. {
  3017. int targetAddr;
  3018. stat(file->d_name, &fileSt);
  3019. if(sscanf(file->d_name, "%d", &targetAddr) == 1)
  3020. {
  3021. char targetFile[384];
  3022. sprintf(targetFile, "/mnt/lcd/%s", file->d_name);
  3023. if(strstr(file->d_name, ".bmp") != NULL)
  3024. {
  3025. downloadBMP(targetAddr, targetFile);
  3026. }
  3027. else
  3028. {
  3029. downloadBIN(targetAddr, targetFile);
  3030. }
  3031. }
  3032. else
  3033. {
  3034. DEBUG_WARN("%s can not parse target address.\n", file->d_name);
  3035. }
  3036. }
  3037. else
  3038. {
  3039. if(strlen(file->d_name) >= 3)
  3040. {
  3041. DEBUG_ERROR("File name error.\n");
  3042. result = FAIL;
  3043. }
  3044. else
  3045. {
  3046. DEBUG_INFO("Searching file.\n");
  3047. }
  3048. }
  3049. sleep(1);
  3050. }
  3051. closedir (dir);
  3052. }
  3053. else
  3054. {
  3055. DEBUG_ERROR("%s does not valid.\n", forlder);
  3056. result = FAIL;
  3057. }
  3058. return result;
  3059. }
  3060. //=======================================
  3061. // Ethernet connection status
  3062. //=======================================
  3063. int isEthConnected(char *eth)
  3064. {
  3065. int result = NO;
  3066. FILE *fp;
  3067. char buf[512];
  3068. sprintf(buf, "/sbin/ethtool %s", eth);
  3069. fp = popen(buf, "r");
  3070. if(fp != NULL)
  3071. {
  3072. while(fgets(buf, sizeof(buf), fp) != NULL)
  3073. {
  3074. if((strstr(buf, "Link detected") != NULL) && (strstr(buf, "yes") != NULL))
  3075. {
  3076. result = YES;
  3077. }
  3078. }
  3079. }
  3080. pclose(fp);
  3081. return result;
  3082. }
  3083. //=======================================
  3084. // Main process
  3085. //=======================================
  3086. int main(void)
  3087. {
  3088. uint8_t previousMode = 0xff;
  3089. if(InitShareMemory() == FAIL)
  3090. {
  3091. #ifdef SystemLogMessage
  3092. DEBUG_ERROR("InitShareMemory NG\n");
  3093. #endif
  3094. if(ShmStatusCodeData!=NULL)
  3095. {
  3096. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory = 1;
  3097. }
  3098. sleep(5);
  3099. return FAIL;
  3100. }
  3101. Uart1Fd=InitComPort();
  3102. if(Uart1Fd<0)
  3103. {
  3104. #ifdef SystemLogMessage
  3105. DEBUG_ERROR("InitComPort NG\n");
  3106. #endif
  3107. if(ShmStatusCodeData!=NULL)
  3108. {
  3109. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.CsuInitFailed = 1;
  3110. }
  3111. sleep(5);
  3112. return FAIL;
  3113. }
  3114. else
  3115. {}
  3116. DEBUG_INFO("Initial completed\n");
  3117. DEBUG_INFO("Latest Firmware Version : [%s] \n", FIRMWARE_UPDATE_IMAGE[0]);
  3118. DEBUG_INFO("Latest Upgrade Date : [%s]. \n", FIRMWARE_UPDATE_IMAGE[1]);
  3119. DEBUG_INFO("Latest Image Version : [%s]. \n", FIRMWARE_UPDATE_IMAGE[2]);
  3120. for(;;)
  3121. {
  3122. if(ShmCharger->isUpgradeLcmReq)
  3123. {
  3124. ShmCharger->isUpgradeLcmSuccess = ((lcdUpgrade("/mnt/lcd") == PASS) ? YES : NO);
  3125. ShmCharger->isUpgradeLcmReq = OFF;
  3126. }
  3127. else
  3128. {
  3129. if(previousMode != ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus)
  3130. {
  3131. previousMode = ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus;
  3132. }
  3133. if(ShmCharger->isAuthrizing || ShmCharger->isGetAuthResult)
  3134. {
  3135. if(getDiffSecNow(startTime[ShmCharger->gun_selectd][TMR_IDX_SHOW_AUTH_RESULT]) >= TIME_AUTH_RESULT_TIME)
  3136. ShmCharger->isGetAuthResult = FALSE;
  3137. if(getDiffSecNow(startTime[ShmCharger->gun_selectd][TMR_IDX_SHOW_AUTH_RESULT]) < TIME_AUTH_RESULT_TIME)
  3138. {
  3139. page_authorizing(ShmCharger->gun_selectd);
  3140. ShmCharger->gun_info[ShmCharger->gun_selectd].isHandshakeTimerRefresh = YES;
  3141. }
  3142. else if(((ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus == SYS_MODE_IDLE) || (ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus == SYS_MODE_RESERVATION)) && (ShmCharger->gun_info[ShmCharger->gun_selectd].resultAuthorization == VALIDATED_RFID))
  3143. {
  3144. if((ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus == SYS_MODE_RESERVATION) && (ocpp_compare_reserve_id_with_user(ShmCharger->gun_selectd) != YES))
  3145. {
  3146. page_idle(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3147. }
  3148. else
  3149. {
  3150. page_preparing(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3151. }
  3152. ShmCharger->gun_info[ShmCharger->gun_selectd].isHandshakeTimerRefresh = NO;
  3153. }
  3154. }
  3155. else
  3156. {
  3157. refreshStartTimer(&startTime[ShmCharger->gun_selectd][TMR_IDX_SHOW_AUTH_RESULT]);
  3158. ShmCharger->gun_info[ShmCharger->gun_selectd].isHandshakeTimerRefresh = NO;
  3159. switch(ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus)
  3160. {
  3161. case SYS_MODE_BOOTING:
  3162. page_booting();
  3163. break;
  3164. case SYS_MODE_IDLE:
  3165. page_idle(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3166. break;
  3167. case SYS_MODE_AUTHORIZING:
  3168. if(ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].StartMethod == START_METHOD_EVCCID)
  3169. page_authorizing(ShmCharger->gun_selectd);
  3170. break;
  3171. case SYS_MODE_PREPARING:
  3172. page_preparing(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3173. break;
  3174. case SYS_MODE_CHARGING:
  3175. page_charging(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3176. break;
  3177. case SYS_MODE_TERMINATING:
  3178. page_terminating(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3179. break;
  3180. case SYS_MODE_COMPLETE:
  3181. page_complete(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3182. break;
  3183. case SYS_MODE_ALARM:
  3184. page_alarm();
  3185. break;
  3186. case SYS_MODE_FAULT:
  3187. page_fault();
  3188. break;
  3189. case SYS_MODE_MAINTAIN:
  3190. page_maintain();
  3191. break;
  3192. case SYS_MODE_UPDATE:
  3193. page_update();
  3194. break;
  3195. case SYS_MODE_RESERVATION:
  3196. //page_reservation();
  3197. page_idle(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3198. break;
  3199. case SYS_MODE_BOOKING:
  3200. page_booking();
  3201. break;
  3202. case SYS_MODE_DEBUG:
  3203. page_debug();
  3204. break;
  3205. default:
  3206. page_unknown();
  3207. break;
  3208. }
  3209. }
  3210. page_header(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3211. page_footer();
  3212. }
  3213. usleep(100000);
  3214. }
  3215. return FAIL;
  3216. }