Module_LcmControl.c 140 KB

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