Module_LcmControl.c 140 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363
  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-11-07", "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. else
  3856. {
  3857. page_authorizing(ShmCharger->gun_selectd);
  3858. }
  3859. }
  3860. else
  3861. {
  3862. refreshStartTimer(&startTime[ShmCharger->gun_selectd][TMR_IDX_SHOW_AUTH_RESULT]);
  3863. ShmCharger->gun_info[ShmCharger->gun_selectd].isHandshakeTimerRefresh = NO;
  3864. switch(ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus)
  3865. {
  3866. case SYS_MODE_BOOTING:
  3867. page_booting();
  3868. break;
  3869. case SYS_MODE_IDLE:
  3870. page_idle(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3871. break;
  3872. case SYS_MODE_AUTHORIZING:
  3873. if(ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].StartMethod == START_METHOD_EVCCID)
  3874. page_authorizing(ShmCharger->gun_selectd);
  3875. break;
  3876. case SYS_MODE_PREPARING:
  3877. page_preparing(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3878. break;
  3879. case SYS_MODE_CHARGING:
  3880. page_charging(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3881. break;
  3882. case SYS_MODE_TERMINATING:
  3883. page_terminating(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3884. break;
  3885. case SYS_MODE_COMPLETE:
  3886. page_complete(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3887. break;
  3888. case SYS_MODE_ALARM:
  3889. page_alarm();
  3890. break;
  3891. case SYS_MODE_FAULT:
  3892. page_fault();
  3893. break;
  3894. case SYS_MODE_MAINTAIN:
  3895. page_maintain();
  3896. break;
  3897. case SYS_MODE_UPDATE:
  3898. page_update();
  3899. break;
  3900. case SYS_MODE_RESERVATION:
  3901. //page_reservation();
  3902. page_idle(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3903. break;
  3904. case SYS_MODE_BOOKING:
  3905. page_booking();
  3906. break;
  3907. case SYS_MODE_DEBUG:
  3908. page_debug();
  3909. break;
  3910. default:
  3911. page_unknown();
  3912. break;
  3913. }
  3914. }
  3915. page_header(ShmCharger->gun_selectd, ShmSysConfigAndInfo->SysInfo.AcChargingData[ShmCharger->gun_selectd].SystemStatus);
  3916. page_footer();
  3917. }
  3918. usleep(100000);
  3919. }
  3920. return FAIL;
  3921. }