main_service.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708
  1. /*
  2. * Copyright (C) 2007-2011 Siemens AG
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU Lesser General Public License as published
  6. * by the Free Software Foundation, either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. /*******************************************************************
  18. *
  19. * @author Sebastian.Kaebisch.EXT@siemens.com
  20. * @version 0.4
  21. * @contact Joerg.Heuer@siemens.com
  22. *
  23. ********************************************************************/
  24. #include "v2g_service.h"
  25. #include "v2g_serviceDataTypes.h"
  26. #include "v2g_serviceClientStubs.h"
  27. #include "EXITypes.h"
  28. #include "doIP.h"
  29. #include <stdio.h>
  30. #define MAX_BYTE_SIZE 128
  31. #define MAX_STRING_SIZE 256
  32. #define MAX_STREAM_SIZE 60
  33. static uint8_t byte_array[MAX_BYTE_SIZE]; /* define MAX_BYTE_SIZE before*/
  34. static uint32_t string_array[MAX_STRING_SIZE]; /* define MAX_STRING_SIZE before*/
  35. static void printEVSEStatus(struct EVSEStatusType* status);
  36. static void printErrorMessage(struct EXIService* service);
  37. static int ac_charging()
  38. {
  39. /* define in and out byte stream */
  40. uint8_t inStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
  41. uint8_t outStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
  42. /* define offset variable for transport header data */
  43. uint16_t transportHeaderOffset;
  44. /* service data structure */
  45. struct EXIService service;
  46. struct HeaderType v2gHeader;
  47. struct SessionSetupReqType sessionSetup;
  48. struct SessionSetupResType resultSessionSetup;
  49. struct ChargeParameterDiscoveryReqType powerDiscovery;
  50. struct ChargeParameterDiscoveryResType resultPowerDiscovery;
  51. struct LineLockReqType lineLock;
  52. struct LineLockResType resultLineLock;
  53. struct PowerDeliveryReqType powerDelivery;
  54. struct PowerDeliveryResType resultPowerDelivery;
  55. struct MeteringStatusResType resultMeteringStatus;
  56. struct MeteringReceiptReqType meteringReceipt;
  57. struct MeteringReceiptResType resultMeteringReceipt;
  58. struct FloatingValueType float_type; /* test float type*/
  59. /* BINARY memory setup */
  60. bytes_t bytes = { MAX_BYTE_SIZE, byte_array, 0 };
  61. /* STRING memory setup */
  62. string_ucs_t string = { MAX_STRING_SIZE, string_array, 0 };
  63. /* setup offset for DoIP header (otherwise set
  64. * transportHeaderOffset=0 if no transfer protocol is used)*/
  65. transportHeaderOffset = DOIP_HEADER_LENGTH;
  66. /*******************
  67. * Init V2G Client *
  68. *******************/
  69. init_v2gServiceClient(&service,bytes,string,inStream,MAX_STREAM_SIZE, outStream, MAX_STREAM_SIZE, transportHeaderOffset);
  70. /*******************************
  71. * Setup data for sessionSetup *
  72. *******************************/
  73. /* setup header information */
  74. v2gHeader.SessionInformation.SessionID.arraylen.data = 0; /* no session id in the initial message -> array length = 0*/
  75. v2gHeader.SessionInformation.ProtocolVersion.data[0]='1'; /* assign protocol version number*/
  76. v2gHeader.SessionInformation.ProtocolVersion.arraylen.data=1; /* array string length =1 of protocol version */
  77. v2gHeader.SessionInformation.isused.ProtocolVersion = 1; /* important: optional elements have to be set used (=1) or not used (=0) */
  78. v2gHeader.SessionInformation.isused.ServiceSessionID = 0; /* service session is not used */
  79. v2gHeader.isused.Notification=0; /* no notification */
  80. /* setup sessionSetup parameter */
  81. sessionSetup.isused.PEVID=1; /* PEVID is transported */
  82. sessionSetup.PEVID.arraylen.data=1;
  83. sessionSetup.PEVID.data[0]=10;
  84. sessionSetup.PEVStatus.ChargerStandby=0; /* charger standby = true */
  85. sessionSetup.PEVStatus.ConnectorLocked=0; /* connector locked = false */
  86. sessionSetup.PEVStatus.ReadyToCharge=0; /* ReadyToCharge = false */
  87. printf("PEV: call EVSE sessionSetup\n");
  88. /*********************
  89. * Call sessionSetup *
  90. *********************/
  91. if(call_sessionSetup(&service,&v2gHeader,&sessionSetup,&resultSessionSetup))
  92. {
  93. printErrorMessage(&service);
  94. }
  95. else
  96. {
  97. /* show result of the answer message of EVSE sessionSetup */
  98. printf("PEV: received response message from EVSE\n");
  99. printf("\tResponseCode=%d (OK)\n",resultSessionSetup.ResponseCode);
  100. printf("\tEVSEID=%d\n", resultSessionSetup.EVSEID.data[0]);
  101. printEVSEStatus(&resultSessionSetup.EVSEStatus);
  102. printf("\tTCurrent=%d\n",resultSessionSetup.TCurrent);
  103. }
  104. /*******************************************
  105. * Setup data for chargeParameterDiscovery *
  106. *******************************************/
  107. powerDiscovery.PEVStatus.ChargerStandby = 1;
  108. powerDiscovery.PEVStatus.ConnectorLocked = 0;
  109. powerDiscovery.PEVStatus.ReadyToCharge=0;
  110. powerDiscovery.ChargingMode = AC_charging_chargingModeType;
  111. powerDiscovery.EoC = 12345678;
  112. float_type.Multiplier = 0;
  113. float_type.Unit = J_unitSymbolType;
  114. float_type.Value = 100;
  115. powerDiscovery.EAmount = float_type;
  116. powerDiscovery.PEVMaxPhases = 3;
  117. float_type.Unit = W_unitSymbolType;
  118. float_type.Value = 600;
  119. powerDiscovery.PEVMaxPower = float_type;
  120. float_type.Unit = V_unitSymbolType;
  121. float_type.Value = 1000;
  122. powerDiscovery.PEVMaxVoltage = float_type;
  123. float_type.Value = 200;
  124. powerDiscovery.PEVMinVoltage = float_type;
  125. /* only required for DC */
  126. float_type.Unit = A_unitSymbolType;
  127. float_type.Value = 200;
  128. powerDiscovery.PEVMaxCurrent = float_type;
  129. powerDiscovery.PEVMinCurrent = float_type;
  130. /*********************************
  131. * Call chargeParameterDiscovery *
  132. *********************************/
  133. printf("\nPEV: call EVSE chargeParameterDiscovery\n");
  134. if(call_chargeParameterDiscovery(&service,&v2gHeader,&powerDiscovery,&resultPowerDiscovery))
  135. {
  136. printErrorMessage(&service);
  137. }
  138. else
  139. {
  140. /* show result of the answer message of EVSE sessionSetup*/
  141. printf("PEV: received response message from EVSE\n");
  142. printf("\tResponseCode=%d\n",resultPowerDiscovery.ResponseCode);
  143. printEVSEStatus(&resultPowerDiscovery.EVSEStatus);
  144. printf("\tEVSEMaxVoltage=%d\n",resultPowerDiscovery.EVSEMaxVoltage.Value);
  145. /*printf("\tEVSEMaxCurrent=%d\n",resultPowerDiscovery.EVSEMaxCurrent.Value);*/
  146. printf("\tEVSEMaxPhases=%d\n",resultPowerDiscovery.EVSEMaxPhases);
  147. /*printf("\tEnergyProvider=%d\n",resultPowerDiscovery.EnergyProvider.data[0]);*/
  148. }
  149. /*********************************
  150. * Setup data for lineLock *
  151. *********************************/
  152. lineLock.PEVStatus.ChargerStandby = 1;
  153. lineLock.PEVStatus.ConnectorLocked = 1;
  154. lineLock.PEVStatus.ReadyToCharge = 1;
  155. lineLock.ReqLockStatus = 1;
  156. /***********************
  157. * Call lineLock *
  158. ***********************/
  159. printf("\nPEV: call EVSE lineLock\n");
  160. if(call_lineLock(&service,&v2gHeader,&lineLock,&resultLineLock))
  161. {
  162. printErrorMessage(&service);
  163. }
  164. else
  165. {
  166. /* show result of the answer message of EVSE sessionSetup*/
  167. printf("PEV: received response message from EVSE\n");
  168. printf("\tResponseCode=%d\n",resultLineLock.ResponseCode);
  169. printEVSEStatus(&resultLineLock.EVSEStatus);
  170. }
  171. /*********************************
  172. * Setup data for powerDelivery *
  173. *********************************/
  174. powerDelivery.PEVStatus = lineLock.PEVStatus; /* PEV status, taken from lineLock */
  175. /*powerDelivery.isused.Tariff = 0;
  176. powerDelivery.Tariff = Green_charge_tariffIDType;*/
  177. /***********************
  178. * Call powerDelivery *
  179. ***********************/
  180. printf("\nPEV: call EVSE powerDelivery\n");
  181. if(call_powerDelivery(&service,&v2gHeader,&powerDelivery,&resultPowerDelivery))
  182. {
  183. printErrorMessage(&service);
  184. }
  185. else
  186. {
  187. /* show result of the answer message of EVSE sessionSetup*/
  188. printf("PEV: received response message from EVSE\n");
  189. printf("\tResponseCode=%d\n",resultPowerDelivery.ResponseCode);
  190. }
  191. /********************
  192. * Call meterStatus *
  193. ********************/
  194. printf("\nPEV: call EVSE meterStatus\n");
  195. if(call_meteringStatus(&service,&v2gHeader,&resultMeteringStatus))
  196. {
  197. printErrorMessage(&service);
  198. }
  199. else
  200. {
  201. printf("PEV: received response message from EVSE\n");
  202. printf("\tResponseCode=%d\n",resultPowerDiscovery.ResponseCode);
  203. printEVSEStatus(&resultPowerDiscovery.EVSEStatus);
  204. printf("\tEVSEID=%d\n",resultMeteringStatus.EVSEID.data[0]);
  205. printf("\tEVSEMaxPower=%d\n",resultMeteringStatus.EVSEMaxPower.Value);
  206. printf("\tisused.MeterInfo=%d\n", resultMeteringStatus.isused.MeterInfo);
  207. printf("\t\tMeterInfo.MeterID=%d\n", resultMeteringStatus.MeterInfo.MeterID.data[0]);
  208. printf("\t\tMeterInfo.MeterReading.Value=%d\n", resultMeteringStatus.MeterInfo.MeterReading.Value);
  209. printf("\t\tMeterInfo.MeterStatus=%d\n", resultMeteringStatus.MeterInfo.MeterStatus);
  210. /* printf("\t\tMeterInfo.TMeter=%d\n", resultMeteringStatus.MeterInfo.TMeter);*/
  211. /* printf("\t\tisused.PCurrent=%d\n", resultMeteringStatus.isused.PCurrent);
  212. printf("\t\tPCurrent=%d\n", resultMeteringStatus.PCurrent.Value);*/
  213. }
  214. /*********************************
  215. * Setup data for meteringReceipt *
  216. *********************************/
  217. meteringReceipt.PEVID.arraylen.data=1;
  218. meteringReceipt.PEVID.data[0]=10;
  219. meteringReceipt.isused.PEVID=1;
  220. meteringReceipt.PEVStatus = powerDelivery.PEVStatus; /* PEV status, taken from sessionSetup */
  221. meteringReceipt.TCurrent = 12345;
  222. meteringReceipt.isused.TCurrent = 1;
  223. meteringReceipt.Tariff = Green_charge_tariffIDType;
  224. meteringReceipt.MeterInfo.MeterStatus = 2;
  225. meteringReceipt.MeterInfo.isused.MeterStatus = 1;
  226. meteringReceipt.MeterInfo.MeterID.arraylen.data=1;
  227. meteringReceipt.MeterInfo.MeterID.data[0]=3;
  228. meteringReceipt.MeterInfo.isused.MeterID = 1;
  229. meteringReceipt.MeterInfo.MeterReading.Multiplier = 0;
  230. meteringReceipt.MeterInfo.MeterReading.Unit = A_unitSymbolType;
  231. meteringReceipt.MeterInfo.MeterReading.Value = 500;
  232. meteringReceipt.MeterInfo.isused.MeterReading = 1;
  233. meteringReceipt.MeterInfo.TMeter =123456789;
  234. meteringReceipt.MeterInfo.isused.TMeter = 1;
  235. /***********************
  236. * Call meteringReceipt *
  237. ***********************/
  238. printf("\nPEV: call EVSE meteringReceipt\n");
  239. if(call_meteringReceipt(&service,&v2gHeader,&meteringReceipt,&resultMeteringReceipt))
  240. {
  241. printErrorMessage(&service);
  242. }
  243. else
  244. {
  245. /* show result of the answer message of EVSE sessionSetup*/
  246. printf("PEV: received response message from EVSE\n");
  247. printf("\tResponseCode=%d\n",resultMeteringReceipt.ResponseCode);
  248. }
  249. return 0;
  250. }
  251. static int dc_charging()
  252. {
  253. static uint8_t byte_array[MAX_BYTE_SIZE]; /* define MAX_BYTE_SIZE before*/
  254. static uint32_t string_array[MAX_STRING_SIZE]; /* define MAX_STRING_SIZE before*/
  255. /* define in and out byte stream */
  256. uint8_t inStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
  257. uint8_t outStream[MAX_STREAM_SIZE]; /* define MAX_STREAM_SIZE before */
  258. /* define offset variable for transport header data */
  259. uint16_t transportHeaderOffset;
  260. /* service data structure */
  261. struct EXIService service;
  262. struct HeaderType v2gHeader;
  263. struct SessionSetupReqType sessionSetup;
  264. struct SessionSetupResType resultSessionSetup;
  265. struct ChargeParameterDiscoveryReqType powerDiscovery;
  266. struct ChargeParameterDiscoveryResType resultPowerDiscovery;
  267. struct CableCheckReqType cableCheck;
  268. struct CableCheckResType resultCableCheck;
  269. struct PowerDeliveryReqType powerDelivery;
  270. struct PowerDeliveryResType resultPowerDelivery;
  271. struct PreChargeReqType preCharge;
  272. struct PreChargeResType resultPreCharge;
  273. struct CurrentDemandReqType currentDemand;
  274. struct CurrentDemandResType resultCurrentDemand;
  275. struct WeldingDetectionReqType weldingDetection;
  276. struct WeldingDetectionResType resultWeldingDetection;
  277. struct TerminateChargingReqType terminateCharging;
  278. struct TerminateChargingResType resultTerminateCharging;
  279. struct FloatingValueType float_type; /* test float type*/
  280. /* BINARY memory setup */
  281. bytes_t bytes = { MAX_BYTE_SIZE, byte_array, 0 };
  282. /* STRING memory setup */
  283. string_ucs_t string = { MAX_STRING_SIZE, string_array, 0 };
  284. /* setup offset for DoIP header (otherwise set
  285. * transportHeaderOffset=0 if no transfer protocol is used)*/
  286. transportHeaderOffset = DOIP_HEADER_LENGTH;
  287. /*******************
  288. * Init V2G Client *
  289. *******************/
  290. init_v2gServiceClient(&service,bytes,string,inStream,MAX_STREAM_SIZE, outStream, MAX_STREAM_SIZE, transportHeaderOffset);
  291. /*******************************
  292. * Setup data for sessionSetup *
  293. *******************************/
  294. /* setup header information */
  295. v2gHeader.SessionInformation.SessionID.arraylen.data = 0; /* no session id in the initial message -> array length = 0*/
  296. v2gHeader.SessionInformation.ProtocolVersion.data[0]='1'; /* assign protocol version number*/
  297. v2gHeader.SessionInformation.ProtocolVersion.arraylen.data=1; /* array string length =1 of protocol version */
  298. v2gHeader.SessionInformation.isused.ProtocolVersion = 1; /* important: optional elements have to be set used (=1) or not used (=0) */
  299. v2gHeader.SessionInformation.isused.ServiceSessionID = 0; /* service session is not used */
  300. v2gHeader.isused.Notification=0; /* no notification */
  301. /* setup sessionSetup parameter */
  302. sessionSetup.isused.PEVID=1; /* no PEVID is transported */
  303. sessionSetup.PEVID.arraylen.data=1;
  304. sessionSetup.PEVID.data[0]=10;
  305. sessionSetup.PEVStatus.ChargerStandby=0; /* charger standby = true */
  306. sessionSetup.PEVStatus.ConnectorLocked=0; /* connector locked = false */
  307. printf("PEV: call EVSE sessionSetup\n");
  308. /*********************
  309. * Call sessionSetup *
  310. *********************/
  311. if(call_sessionSetup(&service,&v2gHeader,&sessionSetup,&resultSessionSetup))
  312. {
  313. printErrorMessage(&service);
  314. }
  315. else
  316. {
  317. /* show result of the answer message of EVSE sessionSetup */
  318. printf("PEV: received response message from EVSE\n");
  319. printf("\tResponseCode=%d\n",resultSessionSetup.ResponseCode);
  320. printf("\tEVSEID=%d\n", resultSessionSetup.EVSEID.data[0]);
  321. printEVSEStatus(&resultSessionSetup.EVSEStatus);
  322. printf("\tTCurrent=%d\n",resultSessionSetup.TCurrent);
  323. }
  324. /*******************************************
  325. * Setup data for chargeParameterDiscovery *
  326. *******************************************/
  327. powerDiscovery.PEVStatus = sessionSetup.PEVStatus; /* PEV status, taken from sessionSetup */
  328. powerDiscovery.EoC = 4321;
  329. powerDiscovery.ChargingMode = DC_charging_chargingModeType;
  330. float_type.Multiplier = 2;
  331. float_type.Unit = A_unitSymbolType;
  332. float_type.Value = 700;
  333. float_type.Multiplier = 0;
  334. float_type.Unit = J_unitSymbolType;
  335. float_type.Value = 100;
  336. powerDiscovery.EAmount = float_type;
  337. powerDiscovery.PEVMaxPhases = 3;
  338. float_type.Unit = W_unitSymbolType;
  339. float_type.Value = 600;
  340. powerDiscovery.PEVMaxPower = float_type;
  341. float_type.Unit = V_unitSymbolType;
  342. float_type.Value = 1000;
  343. powerDiscovery.PEVMaxVoltage = float_type;
  344. float_type.Value = 200;
  345. powerDiscovery.PEVMinVoltage = float_type;
  346. float_type.Unit = A_unitSymbolType;
  347. float_type.Value = 800;
  348. powerDiscovery.PEVMaxCurrent = float_type;
  349. float_type.Value = 150;
  350. powerDiscovery.PEVMinCurrent = float_type;
  351. /*********************************
  352. * Call chargeParameterDiscovery *
  353. *********************************/
  354. printf("\nPEV: call EVSE chargeParameterDiscovery\n");
  355. if(call_chargeParameterDiscovery(&service,&v2gHeader,&powerDiscovery,&resultPowerDiscovery))
  356. {
  357. printErrorMessage(&service);
  358. }
  359. else
  360. {
  361. /* show result of the answer message of EVSE sessionSetup*/
  362. printf("PEV: received response message from EVSE\n");
  363. printf("\tResponseCode=%d\n",resultPowerDiscovery.ResponseCode);
  364. printEVSEStatus(&resultPowerDiscovery.EVSEStatus);
  365. printf("\tEVSEMaxVoltage=%d\n",resultPowerDiscovery.EVSEMaxVoltage.Value);
  366. printf("\tEVSEMaxCurrent=%d\n",resultPowerDiscovery.EVSEMaxCurrent.Value);
  367. printf("\tEVSEMinCurrent=%d\n",resultPowerDiscovery.EVSEMinCurrent.Value);
  368. printf("\tEVSEMaxPhases=%d\n",resultPowerDiscovery.EVSEMaxPhases);
  369. /*printf("\tEnergyProvider=%d\n",resultPowerDiscovery.EnergyProvider.data[0]);*/
  370. }
  371. /***********************
  372. * Call cableCheck *
  373. ***********************/
  374. printf("\nPEV: call EVSE cableCheck\n");
  375. cableCheck.PEVStatus.ChargerStandby = 1;
  376. cableCheck.PEVStatus.ConnectorLocked = 1;
  377. cableCheck.PEVStatus.ReadyToCharge = 1;
  378. if(call_cableCheck(&service,&v2gHeader,&cableCheck,&resultCableCheck))
  379. {
  380. printErrorMessage(&service);
  381. }
  382. else
  383. {
  384. /* show result of the answer message of EVSE powerDiscovery*/
  385. printf("PEV: received response message from EVSE\n");
  386. printf("\tResponseCode=%d\n",resultCableCheck.ResponseCode);
  387. printEVSEStatus(&resultCableCheck.EVSEStatus);
  388. }
  389. /*********************************
  390. * Setup data for powerDelivery *
  391. *********************************/
  392. powerDelivery.PEVStatus = cableCheck.PEVStatus; /* PEV status, taken from sessionSetup */
  393. powerDelivery.isused.Tariff = 0;
  394. /*powerDelivery.Tariff = Green_charge_tariffIDType;*/
  395. /***********************
  396. * Call powerDelivery *
  397. ***********************/
  398. printf("\nPEV: call EVSE powerDelivery\n");
  399. if(call_powerDelivery(&service,&v2gHeader,&powerDelivery,&resultPowerDelivery))
  400. {
  401. printErrorMessage(&service);
  402. }
  403. else
  404. {
  405. /* show result of the answer message of EVSE sessionSetup*/
  406. printf("PEV: received response message from EVSE\n");
  407. printf("\tResponseCode=%d\n",resultPowerDelivery.ResponseCode);
  408. printEVSEStatus(&resultPowerDelivery.EVSEStatus);
  409. }
  410. /***********************
  411. * Call preCharge *
  412. ***********************/
  413. printf("\nPEV: call EVSE preCharge\n");
  414. preCharge.PEVStatus = cableCheck.PEVStatus;
  415. float_type.Unit = A_unitSymbolType;
  416. float_type.Value = 400;
  417. preCharge.PEVDemandCurrent = float_type;
  418. float_type.Unit = V_unitSymbolType;
  419. float_type.Value = 700;
  420. preCharge.PEVTargetVoltage = float_type;
  421. float_type.Value = 300;
  422. preCharge.VoltageDifferential = float_type;
  423. if(call_preCharge(&service,&v2gHeader,&preCharge,&resultPreCharge))
  424. {
  425. printErrorMessage(&service);
  426. }
  427. else
  428. {
  429. /* show result of the answer message of EVSE powerDiscovery*/
  430. printf("PEV: received response message from EVSE\n");
  431. printf("\tResponseCode=%d\n",resultPreCharge.ResponseCode);
  432. printEVSEStatus(&resultPreCharge.EVSEStatus);
  433. printf("\tEVSEPresentVoltage=%d\n",resultPreCharge.EVSEPresentVoltage.Value);
  434. }
  435. /***********************
  436. * Call currentDemand *
  437. ***********************/
  438. printf("\nPEV: call EVSE currentDemand\n");
  439. currentDemand.PEVStatus = powerDelivery.PEVStatus;
  440. float_type.Unit = A_unitSymbolType;
  441. float_type.Value = 44;
  442. currentDemand.CurrentDifferential = float_type;
  443. float_type.Value = 40;
  444. currentDemand.PEVDemandCurrent = float_type;
  445. float_type.Unit = V_unitSymbolType;
  446. float_type.Value = 300;
  447. currentDemand.VoltageDifferential = float_type;
  448. float_type.Value = 700;
  449. preCharge.PEVTargetVoltage = float_type;
  450. currentDemand.PEVTargetVoltage = float_type;
  451. if(call_currentDemand(&service,&v2gHeader,&currentDemand,&resultCurrentDemand))
  452. {
  453. printErrorMessage(&service);
  454. }
  455. else
  456. {
  457. /* show result of the answer message of EVSE powerDiscovery*/
  458. printf("PEV: received response message from EVSE\n");
  459. printf("\tResponseCode=%d\n",resultCurrentDemand.ResponseCode);
  460. printEVSEStatus(&resultCurrentDemand.EVSEStatus);
  461. printf("\tEVSEPresentVoltage.Value=%d\n",resultCurrentDemand.EVSEPresentVoltage.Value);
  462. printf("\tEVSEPresentCurrent.Value=%d\n",resultCurrentDemand.EVSEPresentCurrent.Value);
  463. }
  464. /***********************
  465. * Call weldingDetection *
  466. ***********************/
  467. printf("\nPEV: call EVSE weldingDetection\n");
  468. weldingDetection.PEVStatus = powerDelivery.PEVStatus;
  469. if(call_weldingDetection(&service,&v2gHeader,&weldingDetection,&resultWeldingDetection))
  470. {
  471. printErrorMessage(&service);
  472. }
  473. else
  474. {
  475. /* show result of the answer message of EVSE powerDiscovery*/
  476. printf("PEV: received response message from EVSE\n");
  477. printf("\tResponseCode=%d\n",resultWeldingDetection.ResponseCode);
  478. printEVSEStatus(&resultWeldingDetection.EVSEStatus);
  479. printf("\tEVSEPresentVoltage=%d\n",resultWeldingDetection.EVSEPresentVoltage.Value);
  480. }
  481. /*************************
  482. * Call terminateCharging*
  483. *************************/
  484. printf("\nPEV: call EVSE terminateCharging\n");
  485. terminateCharging.PEVStatus = sessionSetup.PEVStatus;
  486. if(call_terminateCharging(&service,&v2gHeader,&terminateCharging,&resultTerminateCharging))
  487. {
  488. printErrorMessage(&service);
  489. }
  490. else
  491. {
  492. /* show result of the answer message of EVSE powerDiscovery*/
  493. printf("PEV: received response message from EVSE\n");
  494. printf("\tResponseCode=%d\n",resultTerminateCharging.ResponseCode);
  495. printEVSEStatus(&resultWeldingDetection.EVSEStatus);
  496. printf("\tEVSEPresentVoltage.Value=%d\n",resultTerminateCharging.EVSEPresentVoltage.Value);
  497. }
  498. return 0;
  499. }
  500. int main_service()
  501. {
  502. printf("+++ Start V2G client / service example for AC charging +++\n\n");
  503. ac_charging();
  504. printf("\n+++Terminate V2G Client / Service example for AC charging +++\n");
  505. printf("Please press enter for DC charging!\n");
  506. fflush(stdout);
  507. getchar();
  508. printf("+++ Start V2G client / service example for DC charging +++\n\n");
  509. dc_charging();
  510. printf("\n+++Terminate V2G client / service example for DC charging +++");
  511. return 0;
  512. }
  513. static void printEVSEStatus(struct EVSEStatusType* status)
  514. {
  515. printf("\tEVSEStatus:\n\t\tConnectorLocked=%d\n",status->ConnectorLocked);
  516. printf("\t\tEVSEStandby=%d\n",status->EVSEStandby);
  517. printf("\t\tFatalError=%d\n",status->FatalError);
  518. printf("\t\tPowerSwitchClosed=%d\n",status->PowerSwitchClosed);
  519. printf("\t\tRCD=%d\n",status->RCD);
  520. printf("\t\tChargerStandby=%d\n",status->ChargerStandby);
  521. printf("\t\tEVSEMalfunction=%d\n",status->EVSEMalfunction);
  522. printf("\t\tShutDownTime=%d\n",status->ShutDownTime);
  523. }
  524. static void printErrorMessage(struct EXIService* service)
  525. {
  526. if(service->errorCode==EXI_NON_VALID_MESSAGE)
  527. {
  528. printf("PEV did not send a valid V2G message!\n");
  529. }
  530. else if(service->errorCode==EXI_SERIALIZATION_FAILED)
  531. {
  532. printf("EVSE error: Could not serialize the response message\n");
  533. }
  534. }