mirror of
https://github.com/uhi22/pyPLC.git
synced 2025-01-19 01:46:37 +00:00
added numbered checkpoints in docu, code and trace
This commit is contained in:
parent
0edea0bc25
commit
0980ced46b
4 changed files with 221 additions and 207 deletions
|
@ -105,6 +105,7 @@ class fsmPev():
|
|||
return
|
||||
evseIp = self.addressManager.getSeccIp() # the chargers IP address which was announced in SDP
|
||||
seccTcpPort = self.addressManager.getSeccTcpPort() # the chargers TCP port which was announced in SDP
|
||||
self.addToTrace("Checkpoint301: connecting")
|
||||
self.Tcp.connect(evseIp, seccTcpPort) # This is a blocking call. If we come back, we are connected, or not.
|
||||
if (not self.Tcp.isConnected):
|
||||
# Bad case: Connection did not work. May happen if we are too fast and the charger needs more
|
||||
|
@ -124,7 +125,7 @@ class fsmPev():
|
|||
def stateFunctionConnected(self):
|
||||
# We have a freshly established TCP channel. We start the V2GTP/EXI communication now.
|
||||
# We just use the initial request message from the Ioniq. It contains one entry: DIN.
|
||||
self.addToTrace("Sending the initial SupportedApplicationProtocolReq")
|
||||
self.addToTrace("Checkpoint400: Sending the initial SupportedApplicationProtocolReq")
|
||||
self.Tcp.transmit(addV2GTPHeader(exiHexToByteArray(exiHexDemoSupportedApplicationProtocolRequestIoniq)))
|
||||
self.hardwareInterface.resetSimulation()
|
||||
self.enterState(stateWaitForSupportedApplicationProtocolResponse)
|
||||
|
@ -139,7 +140,7 @@ class fsmPev():
|
|||
if (strConverterResult.find("supportedAppProtocolRes")>0):
|
||||
# todo: check the request content, and fill response parameters
|
||||
self.publishStatus("Schema negotiated")
|
||||
self.addToTrace("Will send SessionSetupReq")
|
||||
self.addToTrace("Checkpoint403: Schema negotiated. And Checkpoint500: Will send SessionSetupReq")
|
||||
msg = addV2GTPHeader(self.exiEncode("EDA")) # EDA for Encode, Din, SessionSetupReq
|
||||
self.addToTrace("responding " + prettyHexMessage(msg))
|
||||
self.Tcp.transmit(msg)
|
||||
|
@ -159,7 +160,7 @@ class fsmPev():
|
|||
try:
|
||||
y = json.loads(strConverterResult)
|
||||
strSessionId = y["header.SessionID"]
|
||||
self.addToTrace("The Evse decided for SessionId " + strSessionId)
|
||||
self.addToTrace("Checkpoint506: The Evse decided for SessionId " + strSessionId)
|
||||
self.publishStatus("Session established")
|
||||
self.sessionId = strSessionId
|
||||
except:
|
||||
|
@ -200,7 +201,7 @@ class fsmPev():
|
|||
if (strConverterResult.find("ServicePaymentSelectionRes")>0):
|
||||
# todo: check the request content, and fill response parameters
|
||||
self.publishStatus("ServPaySel done")
|
||||
self.addToTrace("Will send ContractAuthenticationReq")
|
||||
self.addToTrace("Checkpoint530: Will send ContractAuthenticationReq")
|
||||
msg = addV2GTPHeader(self.exiEncode("EDL_"+self.sessionId)) # EDL for Encode, Din, ContractAuthenticationReq.
|
||||
self.addToTrace("responding " + prettyHexMessage(msg))
|
||||
self.Tcp.transmit(msg)
|
||||
|
|
|
@ -637,7 +637,7 @@ class pyPlcHomeplug():
|
|||
|
||||
def evaluateSlacParamCnf(self):
|
||||
# As PEV, we receive the first response from the charger.
|
||||
self.addToTrace("received SLAC_PARAM.CNF")
|
||||
self.addToTrace("Checkpoint102: received SLAC_PARAM.CNF")
|
||||
if (self.iAmPev==1):
|
||||
if (self.pevSequenceState==STATE_WAITING_FOR_SLAC_PARAM_CNF): # we were waiting for the SlacParamCnf
|
||||
self.pevSequenceDelayCycles = 4 # original Ioniq is waiting 200ms
|
||||
|
@ -709,7 +709,7 @@ class pyPlcHomeplug():
|
|||
self.addToTrace("From SlacMatchCnf, got network membership key (NMK) " + s)
|
||||
# use the extracted NMK and NID to set the key in the adaptor:
|
||||
self.composeSetKey(0)
|
||||
self.addToTrace("transmitting CM_SET_KEY.REQ")
|
||||
self.addToTrace("Checkpoint170: transmitting CM_SET_KEY.REQ")
|
||||
self.sniffer.sendpacket(bytes(self.mytransmitbuffer))
|
||||
if (self.pevSequenceState==STATE_WAITING_FOR_SLAC_MATCH_CNF): # we were waiting for finishing the SLAC_MATCH.CNF and SET_KEY.REQ
|
||||
self.enterState(STATE_WAITING_FOR_RESTART2)
|
||||
|
@ -816,7 +816,7 @@ class pyPlcHomeplug():
|
|||
self.showStatus("NoModem, simuSLAC", "pevState")
|
||||
else:
|
||||
self.showStatus("Starting SLAC", "pevState")
|
||||
self.addToTrace("[PEVSLAC] Sending SLAC_PARAM.REQ...")
|
||||
self.addToTrace("[PEVSLAC] Checkpoint100: Sending SLAC_PARAM.REQ...")
|
||||
self.composeSlacParamReq()
|
||||
self.transmit(self.mytransmitbuffer)
|
||||
self.enterState(STATE_WAITING_FOR_SLAC_PARAM_CNF)
|
||||
|
@ -890,7 +890,7 @@ class pyPlcHomeplug():
|
|||
return
|
||||
self.composeSlacMatchReq()
|
||||
self.showStatus("SLAC match", "pevState")
|
||||
self.addToTrace("[PEVSLAC] transmitting SLAC_MATCH.REQ...")
|
||||
self.addToTrace("[PEVSLAC] Checkpoint150: transmitting SLAC_MATCH.REQ...")
|
||||
self.transmit(self.mytransmitbuffer)
|
||||
self.enterState(STATE_WAITING_FOR_SLAC_MATCH_CNF)
|
||||
return
|
||||
|
@ -967,7 +967,7 @@ class pyPlcHomeplug():
|
|||
return
|
||||
# SDP was not done yet. Now we start it.
|
||||
self.showStatus("SDP ongoing", "pevState")
|
||||
self.addToTrace("[PEVSLAC] SDP was not done yet. Now we start it.")
|
||||
self.addToTrace("[PEVSLAC] Checkpoint200: SDP was not done yet. Now we start it.")
|
||||
# Next step is to discover the chargers communication controller (SECC) using discovery protocol (SDP).
|
||||
self.pevSequenceDelayCycles=0
|
||||
self.SdpRepetitionCounter = 50 # prepare the number of retries for the SDP. The more the better.
|
||||
|
|
|
@ -181,7 +181,7 @@ class ipv6handler():
|
|||
v2gptPayloadLen = self.udpPayload[4] * 256 ** 3 + self.udpPayload[5] * 256 ** 2 + self.udpPayload[6] * 256 + self.udpPayload[7]
|
||||
if (v2gptPayloadLen == 20):
|
||||
# 20 is the only valid length for a SDP response.
|
||||
print("[PEV] Received SDP response")
|
||||
print("[PEV] Checkpoint203: Received SDP response")
|
||||
# at byte 8 of the UDP payload starts the IPv6 address of the charger.
|
||||
for i in range(0, 16):
|
||||
self.SeccIp[i] = self.udpPayload[8+i] # 16 bytes IP address of the charger
|
||||
|
|
407
readme.md
407
readme.md
|
@ -9,18 +9,118 @@ In this project, we call this mode *ListenMode*.
|
|||
2. Building a charger for CCS or for AC with digital communication. We call this *EvseMode*.
|
||||
3. Building a charging unit for a car which does not support powerline communication. Let's call it *PevMode*.
|
||||
|
||||
## References
|
||||
* [i] https://www.goingelectric.de/wiki/CCS-Technische-Details/ knowledge collection
|
||||
* [ii] https://openinverter.org/forum/viewtopic.php?p=37085#p37085 discussion of this project
|
||||
* [iii] https://github.com/qca/open-plc-utils utilities for configuring the PLC adaptor
|
||||
* [iv] https://github.com/karpierz/pcap-ct library for low-level-network-access
|
||||
* [v] https://github.com/FlUxIuS/V2Gdecoder demo for EXI decoder
|
||||
* [vi] https://github.com/SwitchEV/iso15118 another "nearly" open source CCS project
|
||||
* [vii] https://books.google.de/books?id=WYlmEAAAQBAJ&pg=PA99&lpg=PA99&dq=%22ampsnif%22&source=bl&ots=hqCjdFooZ-&sig=ACfU3U0EleLZQu0zWhHQZGktp8OytCMrLg&hl=de&sa=X&ved=2ahUKEwjT0Yq88P36AhWj_rsIHeGMA5MQ6AF6BAgKEAM#v=onepage&q=%22ampsnif%22&f=false How to enable sniffer mode.
|
||||
* [viii] https://www.mdpi.com/2076-3417/6/6/165/htm "Building an Interoperability Test System for Electric Vehicle Chargers Based on ISO/IEC 15118 and IEC 61850 Standards", including V2G message sequence chart
|
||||
* [ix] https://www.oppcharge.org/dok/ISO_15118-2_OpportunityCharging_Rev1.3.0.pdf Pantograph specific differences with some insight into ISO15118.
|
||||
* [x] https://assured-project.eu/storage/files/assured-10-interoperability-reference.pdf Fast and Smart Charging Solutions for
|
||||
Full Size Urban Heavy Duty Applications
|
||||
## News / Change History / Functional Status
|
||||
|
||||
### 2023-03-03 v0.6 Tea-Time on Alpitronics charger
|
||||
Made a tea, using the RaspberryPi3 and tpLink modem on Alpitronics hypercharger.
|
||||
|
||||
### 2023-02-27 PEV mode with OLED-display works on headless Raspberry
|
||||
- Charging status is shown on OLED display. Details in [hardware.md](doc/hardware.md)
|
||||
- RaspberryPi 3 configured to auto-start the PEV software as service. Startup time around 21 seconds from power-up until the SLAC starts. Details
|
||||
in [installation_on_raspberry.md](doc/installation_on_raspberry.md)
|
||||
|
||||
### 2022-12-21 v0.5 Light-bulb-demo-charging works on multiple chargers
|
||||
- On 3 of 4 tested charger models, the light-bulb-demo works: AlpitronicHPC, ABB HPC, ABB Triple. The Ionity Tritium overshoots the target voltage due to missing load, and aborts.
|
||||
- Welding detection gives negative or no answer.
|
||||
- Traces https://github.com/uhi22/pyPLC/blob/master/results/2022-12-21_westpark_alpi_charge_ok_with_bulb.pcapng and https://github.com/uhi22/pyPLC/blob/master/results/2022-12-21_alpi_ABBHPC_ABB_Ionity_lightbulb_3of4ok.decoded.txt
|
||||
- Pictures and discussion in https://openinverter.org/forum/viewtopic.php?p=50172#p50172
|
||||
|
||||
### 2022-12-20 Measurement of inlet voltage works
|
||||
- Tests ran on Alpitronics HPC.
|
||||
- Measuring the inlet voltage with Arduino "Dieter" works. During CableCheck and PreCharge, the inlet voltage is shown in the GUI.
|
||||
- The Alpi confirms the PowerDelivery (start), but rejects the CurrentDemandRequest with FAILED_SequenceError and EVSE_Shutdown.
|
||||
- Results (log file and pcap) are stored in https://github.com/uhi22/pyPLC/tree/master/results.
|
||||
|
||||
### 2022-12-13 v0.4 On Compleo, Light Bulb survives 400V cable check and PreCharge
|
||||
- SLAC issue is fixed on Compleo. Authorization works. Hardware interface "Dieter" controls the CP into state C.
|
||||
- The charger delivers power in the cable check, and a connected 230V bulb makes bright light and survives the 400V.
|
||||
- PreCharge starts, but terminates before full voltage is reached. Switching the load with power-relay is not yet implemented from
|
||||
hardware side. Without the load, we see the intended 230V precharge voltage, and run into timeout (to be investigated).
|
||||
|
||||
### 2022-12-02 v0.3 On Alpitonics until ChargeParameterDiscovery
|
||||
- TCP connection works now on Alpitronics charger
|
||||
- ContractAuthentication loop works
|
||||
|
||||
### 2022-11-25 v0.2 On ABB charger until ChargeParamDiscoveryRequest
|
||||
- With Win10 notebook in PevMode, tested on Alpitronics HPC and ABB Triple charger. On the Alpi, the SLAC and SDP works. The TCP connection fails. On ABB, the SLAC, SDP and TCP works. Also the protocol negotiation works. We come until ChargeParamDiscoveryReqest.
|
||||
- Log messages are sent via UDP port 514 as broadcast, like Syslog messages. The Wireshark shows them as readable text, so we have the actual communication between car and charger in the trace and also the debug log.
|
||||
- Example pcap in results/2022-11-25_v0.2_ABB_until_ChargeParamDiscovery.pcapng
|
||||
- With Win10 notebook in EvseMode, tested on the Ioniq car. It comes until the CurrentDemandRequest.
|
||||
- For using Raspberry in PevMode without display, there is now the pevNoGui.py, which can be auto-started by configuring a service which calls starter.sh, and this calls starter.py (this is still expermental).
|
||||
- The old Raspberry model B needs 90s from power-on until it sends the first log messages. Means, the boot is quite slow.
|
||||
- Raspberry in PevMode and Win10 notebook in EvseMode work well together until the PreCharge.
|
||||
- Known issues:
|
||||
- The TCP port, which is announced in the SDP response, is ignored. This can be the root cause of failing TCP connection on Alpitronics.
|
||||
- The SLAC timing includes too long wait times. This may be the root cause for failing SLAC on Supercharger and Compleo.
|
||||
|
||||
### 2022-11-15 [*PevMode*] Draft of SLAC sequencer
|
||||
In PevMode, the software runs through the SLAC sequence with a simulated Evse. After SLAC is finished, we send a software
|
||||
version request broadcast message, to find out, whether we have at least two homeplug modems in the network (one for the
|
||||
car and one for the charger). If this is fulfilled, we should use the SDP to discover the chargers IPv6 address. But this
|
||||
is not yet implemented.
|
||||
|
||||
### 2022-11-11 [*EvseMode*] Ioniq in the PreCharge loop
|
||||
The EVSE state machine, together with the EXI decoder/encoder, is able to talk to the Ioniq car until the PreCharge loop. The
|
||||
car terminates the loop after some seconds, because the intended voltage is not reached (no physical electricity connected to the
|
||||
charge port). Maybe it is possible to convince the car to close the relay, just by pretending "voltage is reached" in the
|
||||
PreCharge response. But maybe the car makes a plausibilization with the physical voltage, then further development would require
|
||||
a physical power supply.
|
||||
|
||||
### 2022-11-09 [*EvseMode*][*PevMode*] Exi decoder first steps working
|
||||
Using EXI decoder/encoder from basis https://github.com/Martin-P/OpenV2G and created fork https://github.com/uhi22/OpenV2Gx to
|
||||
provide a command-line interface, which can be used by the python script. The OpenV2G includes generated source code for four
|
||||
xml schemas (Handshake, DIN, ISO1, ISO2), provided by Siemens. Seems to be good maintained and is very efficient, because the
|
||||
decoder/encoder are directly available as C code, dedicated for each schema. This skips the slow process of reading the schema,
|
||||
parsing it, creating the grammer information. On Windows10 notebook, measured 15ms for decoder run from python via command line.
|
||||
The OpenV2G was compiled on Windows10 using the included makefile, using the `mingw32-make all`.
|
||||
The OpenV2G decoder/encoder code reveals some differences between the different schemas (DIN versus ISO). As starting point, only the
|
||||
DIN schema is considered in the command line interface and python part.
|
||||
|
||||
The python part now contains the charging state machines for car and charger, as draft.
|
||||
|
||||
Using the TPlink and Win10 laptop as evse, connected to Ioniq car, the python script successfully succeeds to SLAC, TCP connection,
|
||||
schema handshake, SessionSetup, ServiceDiscovery, ServicePaymentSelection. It stops on ChargeParameterDiscovery, most likely to
|
||||
missing or wrong implementation. Results (log file and pcap) are stored in
|
||||
https://github.com/uhi22/pyPLC/tree/master/results.
|
||||
|
||||
As summary, the concept with the python script together with the compiled EXI decoder works. Further efforts can be spent on
|
||||
completing the missing details of the V2G messages.
|
||||
|
||||
### 2022-10-26 [*ListenMode*] Network/AVLN is established
|
||||
Using the TPlink in EVSE mode and Win10 laptop, listening to a communication setup between real car and real alpitronics charger, the python script
|
||||
successfully extracts the NID and NMK from the SLAC_MATCH response, sets this information into the TPlink, and the TPlink turns three
|
||||
LEDs on. Means: Network established. When we send a broadcast software version request, we get three responses: One from the TPlink, one from the
|
||||
PLC modem of the car, and one from the PLC modem of the charger. This confirms, that the network is established.
|
||||
But: From the higher level communication (IPv6, UDP, TCP) we see only the broadcast neighbor solicitation at the beginning. The remaining traffic
|
||||
is hidden, most likely because the TPlink "too intelligent", it knows who has which MAC address and hides traffic which is not intended for the
|
||||
third participant in the network. Trace in results/2022-10-26_WP4_networkEstablishedButHiddenCommunication.pcapng
|
||||
|
||||
### 2022-10-21 [*EvseMode*] SLAC, SDP and ICMP are working
|
||||
Using the TPlink and Win10 laptop as evse, the python script runs successfully the SLAC and SDP (SECC discovery protocol). Afterwards, the car uses
|
||||
neighbor solicitation (ICMP) to confirm the IPv6 address, and the Win10 responds to it. The car tries to open the TCP on port 15118, this is failing
|
||||
because of missing implementation of the listener on PC side.
|
||||
|
||||
### 2022-10-19 [*ListenMode*] Sniffing mode not yet working with the TPlink adaptors
|
||||
* with a Devolo dLAN 200 AVplus, software INT6000-MAC-4-4-4405-00-4497-20101201-FINAL-B in original parametrization, it is possible
|
||||
to see the complete SLAC traffic (both directions) which sniffing the communication between a real charger and a real car. This does
|
||||
NOT work with the TPlink adaptors. They route only "their own" direction of the traffic to the ethernet. Means: The pev-configured device
|
||||
does not see the real car, and the evse-configured device does not see the real charger. This is bad for sniffing.
|
||||
|
||||
### 2022-10-19 [*EvseMode*] Communication/AVLN with Ioniq car established
|
||||
* Using a TPlink TL-PA4010P with firmware MAC-QCA7420-1.4.0.20-00-20171027-CS and the PIB configuration file patched for evse according to the open-plc-utils docu.
|
||||
* Python software running on Win10, Python 3.10.8
|
||||
* On control pilot, sending 5% PWM to initiate digital communication with the car
|
||||
* Since the TPlink is configured as coordinator, it sends "alive" messages, and the IONIQ starts sending the SLAC_PARAM.REQ.
|
||||
* Per keystroke, we trigger a SET_KEY before the car is connected. The TPlink responds with "rejected", but this is normal, the LEDs are turning off and on, key is accepted.
|
||||
* Python script interprets the relevant incoming messages (SLAC_PARAM.REQ, MNBC_SOUND.IND, SLAC_MATCH.REQ) and reacts accordingly.
|
||||
* After successfull SLAC sequence, all three LEDs on the TPlink are ON, means: Network (AVLN) is established.
|
||||
* In wireshark, we see that the car is sending UDP multicast messages to destination port 15118. This looks like a good sign, that it wants a ISO15118 compatible communication.
|
||||
![image](https://user-images.githubusercontent.com/98478946/196766285-1c3152f7-31db-4b5f-98b1-9f1216f9b9de.png)
|
||||
|
||||
|
||||
## Discussion
|
||||
See https://openinverter.org/forum/viewtopic.php?p=37085#p37085
|
||||
|
||||
|
||||
## Quick start / overview
|
||||
- Modify a PLC adaptor hardware, that it runs on battery
|
||||
|
@ -104,222 +204,122 @@ Pitfall: Pcap-ct does not work with Python 3.4. After update to Python 3.8, it w
|
|||
|
||||
See See [Raspberry installation manual](doc/installation_on_raspberry.md)
|
||||
|
||||
### Usage on Microcontrollers
|
||||
This python project is NOT intended for use on microcontrollers like ESP32 or STM32. But there is a variant ported to C for
|
||||
use in the Arduino IDE, with the ESP32-based WT32-ETH01 board. See here: https://github.com/uhi22/ccs32
|
||||
|
||||
## Example flow
|
||||
This chapter describes the start of a charging session, considering all layers. It is NOT the description of the currently
|
||||
implemented features, it is just a reference for understanding and further development.
|
||||
This chapter describes the start of a charging session, considering all layers. The checkpoint numbers can be used as reference in code and in the log files.
|
||||
(Todo: Only a few checkpoint numbers are referenced in the code. Adding more is work-in-progress.)
|
||||
|
||||
Precondition: On charger side, there is a homeplugGP-capable device present, which is configured as CentralCoordinator.
|
||||
1. The charger (Supply entity communication controller, SECC) creates a "random" value for NID (network ID) and
|
||||
* Checkpoint1: The charger (Supply entity communication controller, SECC) creates a "random" value for NID (network ID) and
|
||||
NMK (network membership key), and configures its homeplug modem with these values.
|
||||
2. The charger provides 12V on the control pilot (CP) line (State A).
|
||||
3. The user connects the plug into the car.
|
||||
4. The car pulls the 12V at CP line to 9V (State B).
|
||||
5. The charger sees the level change on CP and applies 5% PWM on CP.
|
||||
6. The car sees the 5%, and interprets it as request for digital communication. It wakes up its communication controller (electric vehicle
|
||||
* Checkpoint2: The charger provides 12V on the control pilot (CP) line (State A).
|
||||
* Checkpoint3: The user connects the plug into the car.
|
||||
* Checkpoint4: The car pulls the 12V at CP line to 9V (State B).
|
||||
* Checkpoint5: The charger sees the level change on CP and applies 5% PWM on CP.
|
||||
* Checkpoint6: The car sees the 5%, and interprets it as request for digital communication. It wakes up its communication controller (electric vehicle
|
||||
communication controller, EVCC) and homeplug modem.
|
||||
7. The car sees homeplug coordinator packets on the CP, and starts the SLAC sequence by sending SLAC_PARAM.REQ. Can be also two times.
|
||||
8. The charger receives the SLAC_PARAM.REQ and confirms it with SLAC_PARAM.CNF.
|
||||
9. The car sends START_ATTEN_CHAR.IND, to start the attenuation measurement. In total 3 times.
|
||||
10. The car sends MNBC_SOUND.IND, to provide different sounds (signals different frequency ranges). In total 10 times.
|
||||
11. The homeplug modem in the charger should measure the signal strength, and report the values to the SECC in an ethernet frame ATTEN_PROFILE.IND.
|
||||
However, the used homeplug adaptor with AR7420 seems not to support this feature. That's why we need to "guess" some attenuation values
|
||||
* Checkpoint7: The modem of the car sees homeplug coordinator packets on the CP. This is the precondition that it sends anything on HomePlug.
|
||||
* Checkpoint100: The car starts the SLAC sequence by sending SLAC_PARAM.REQ. Can be also two times.
|
||||
* Checkpoint101: The charger receives the SLAC_PARAM.REQ and confirms it with SLAC_PARAM.CNF.
|
||||
* Checkpoint102: The car receives the SLAC_PARAM.CNF.
|
||||
* Checkpoint103: The car sends START_ATTEN_CHAR.IND, to start the attenuation measurement. In total 3 times.
|
||||
* Checkpoint104: The car sends MNBC_SOUND.IND, to provide different sounds (signals different frequency ranges). In total 10 times.
|
||||
* Checkpoint110: The homeplug modem in the charger should measure the signal strength, and report the values to the SECC in an ethernet frame ATTEN_PROFILE.IND. However, the used homeplug adaptor with AR7420 seems not to support this feature. That's why we need to "guess" some attenuation values
|
||||
for the next step.
|
||||
12. The charger sends ATTEN_CHAR.IND, which contains the number of sounds and for each group the attenuation in dB. Pitfall: The car may ignore
|
||||
* Checkpoint120: The charger sends ATTEN_CHAR.IND, which contains the number of sounds and for each group the attenuation in dB. Pitfall: The car may ignore
|
||||
implausible values (e.g. all zero dB), and the process may be stuck.
|
||||
13. The car receives the ATTEN_CHAR.IND. If it would receive multiple of them from different chargers (due to cross-coupling), the car
|
||||
* Checkpoint130: The car receives the ATTEN_CHAR.IND. If it would receive multiple of them from different chargers (due to cross-coupling), the car
|
||||
decides based on the attenuation levels, which of the charges is the nearest.
|
||||
14. The car sends ATTEN_CHAR.RSP to the charger which reported the loudest signals.
|
||||
15. The car sends SLAC_MATCH.REQ to the charger. This means, it wants to pair with it.
|
||||
16. The charger responds with SLAC_MATCH.CNF. This contains the self-decided NID (network ID) and NMK (network membership key).
|
||||
17. The car receives the SLAC_MATCH.CNF, takes the NID and NMK from this message, and configures its homeplug modem with this data.
|
||||
18. Now, the homeplug modems of the car and of the charger have formed a "private" Homeplug network (AV local network, AVLN). The RF
|
||||
* Checkpoint140: The car sends ATTEN_CHAR.RSP to the charger which reported the loudest signals.
|
||||
* Checkpoint150: The car sends SLAC_MATCH.REQ to the charger. This means, it wants to pair with it.
|
||||
* Checkpoint155: The charger responds with SLAC_MATCH.CNF. This contains the self-decided NID (network ID) and NMK (network membership key).
|
||||
* Checkpoint160: The car receives the SLAC_MATCH.CNF, takes the NID and NMK from this message.
|
||||
* Checkpoint170: The car configures its homeplug modem with the received NID and NMK.
|
||||
* Checkpoint180: The homeplug modem of the car makes a restart to apply the new settings. This takes approx five seconds. The LEDs of the modem are going off and on again during this restart.
|
||||
* Checkpoint190: Now, the homeplug modems of the car and of the charger have formed a "private" Homeplug network (AV local network, AVLN). The RF
|
||||
traffic can only be decoded by participants who are using the same NID and NMK.
|
||||
19. The car wants to know the chargers IP address. In computer networks, a DHCP would be a usual way to do this. In the CCS world, a different
|
||||
approach is used: SDP, which is the SECC discovery protocol. The DHCP may be also supported as fallback.
|
||||
20. The car sends a broadcast message "Is here a charger in this network?". Technically, it is an IPv6.UDP.V2GTP.SDP message
|
||||
* Checkpoint200: The car wants to know the chargers IP address. In computer networks, a DHCP would be a usual way to do this. In the CCS world, a different
|
||||
approach is used: SDP, which is the SECC discovery protocol. The DHCP may be also supported as fallback. The car sends a broadcast message "Is here a charger in this network?". Technically, it is an IPv6.UDP.V2GTP.SDP message
|
||||
with 2 bytes payload, which defines the security level expected by the car. In usual case, the car says "I want unprotected TCP.".
|
||||
21. The charger receives the SDP request, and sends a SDP response "My IP address is xy, I will listen on port abc, and I support unprotected TCP."
|
||||
22. The car wants to make sure, that the IP addresses are unique and the relation between IP address and MAC address is clear. For
|
||||
* Checkpoint201: The charger receives the SDP request.
|
||||
* Checkpoint202: The charger sends a SDP response "My IP address is xy, I will listen on port abc, and I support unprotected TCP."
|
||||
* Checkpoint203: The car receives the SDP response, and takes the IPv6 address and the port from it, to be used later for the TCP connection.
|
||||
* Checkpoint204: The car wants to make sure, that the IP addresses are unique and the relation between IP address and MAC address is clear. For
|
||||
this, it sends a "Neighbour solicitation". (This looks a little bit oversized, because only two participants are in the local network, and
|
||||
their addresses have already been exchanged in the above steps. But ICMP is standard technology.)
|
||||
23. The charger responds to the neighbor solicitation request with a neighbor advertisement. This contains the MAC address of the charger.
|
||||
* Checkpoint205: The charger responds to the neighbor solicitation request with a neighbor advertisement. This contains the MAC address of the charger.
|
||||
In the case, we use this pyPLC project as charger (*EvseMode*), we rely on the operating system that it covers the ICMP. On Win10,
|
||||
this works perfectly, the only thing we must make sure, that the MAC and IPv6 of the ethernet port are correctly configured in the
|
||||
python script. Use `ipconfig -all` on Windows, to find out the addresses.
|
||||
24. Now, the car and the charger have a clear view about addressing (MAC adresses, IPv6 addresses).
|
||||
25. The car requests to open a TCP connection to charger at the port which was announced on the SDP response. This may be 15118 or may be a different port, depending on the chargers implementation.
|
||||
26. The charger, which was listening on that port, confirms the TCP channel.
|
||||
27. Now, the car and the charger have a reliable, bidirectional TCP channel.
|
||||
28. The car and the charger use the TCP channel, to exchange V2GTP messages, with EXI content.
|
||||
29. The charger is the "server" for the EXI, it is just waiting for requests from the car. The car is the "client", it actively
|
||||
initiates the EXI data exchange.
|
||||
30. The car walks through different states to negotiate, start and supervise the charging process. From communication point of view,
|
||||
the complete process uses XML data, which is packed in EXI frames, which in turn are transported in the TCP channel mentioned above. The overview over
|
||||
python script. Use `ipconfig -all` on Windows, to find out the addresses. Note: Each of the two participants (car and charger) may initiate
|
||||
the NeighborSolicitation, and the other side needs to respond with a NeighborAdvertisement.
|
||||
* Checkpoint210: Now, the car and the charger have a clear view about addressing (MAC adresses, IPv6 addresses).
|
||||
* Checkpoint300: The charger starts listening on the TCP port which it announced in the SDP response.
|
||||
* Checkpoint301: The car requests to open a TCP connection to charger at the port which was announced on the SDP response. This may be 15118 or may be a different port, depending on the chargers implementation. Technically, this is a TCP message with SYN.
|
||||
* Checkpoint302: The charger, which was listening on that port, confirms the TCP channel, by sending ACK+SYN.
|
||||
* Checkpoint303: The car finishes the TCP connection setup by sending ACK. This is the end of the "three-way-handshake". TCP state machines on both sides are in state "ESTABLISHED". The car and the charger have a reliable, bidirectional TCP channel.
|
||||
* Explanation: From now on, the car and the charger use the TCP channel, to exchange V2GTP messages, with EXI content. The charger is the "server" for the EXI, it is just waiting for requests from the car. The car is the "client", it actively
|
||||
initiates the EXI data exchange. The car walks through different states to negotiate, start and supervise the charging process. From communication point of view, the complete process uses XML data, which is packed in EXI frames, which in turn are transported in the TCP channel mentioned above. The overview over
|
||||
the various steps is visible in a sequence chart in [viii].
|
||||
31. The first request-response-pair decides about which XML schema is used for the later communication. This first communication uses
|
||||
* Checkpoint400: The first request-response-pair decides about which XML schema is used for the later communication. This first communication uses
|
||||
a special XML schema, the "application handshake" schema. Afterwards, one of the following three schemas will be used: DIN, ISO1, ISO2. These
|
||||
are different flavours of the DIN/ISO15118 specification, which have small but significant differences. This means, the negotiation of
|
||||
the exact schema is essential for the next step.
|
||||
31. The car announces the supported application protocols, e.g. DIN or ISO, using the SupportedApplicationProtocolRequest.
|
||||
32. The charger chooses the best application protocol from the list, and announces the decision with SupportedApplicationProtocolResponse.
|
||||
33. The car initiates the charging session with SessionSetupRequest. The SessionID in
|
||||
the exact schema is essential for the next step. The car announces the supported application protocols, e.g. DIN or ISO, using the SupportedApplicationProtocolRequest.
|
||||
* Checkpoint401: The charger receives SupportedApplicationProtocolRequest and chooses the best application protocol from the list.
|
||||
* Checkpoint402: The charger announces the decision with SupportedApplicationProtocolResponse.
|
||||
* Checkpoint403: The car receives SupportedApplicationProtocolResponse and knows now, whether the charger supports a compatible XML schema.
|
||||
* Checkpoint500: The car initiates the charging session with SessionSetupRequest. The SessionID in
|
||||
this first message is zero, which is the reserved number meaning "new session".
|
||||
34. The charger confirms the session with SessionSetupResponse. In this message, the charger sends for the first time
|
||||
* Checkpoint505: The charger confirms the session with SessionSetupResponse. In this message, the charger sends for the first time
|
||||
a new, non-zero SessionID. This SessionID is used in all the upcoming messages from both sides.
|
||||
35. The car sends ServiceDiscoveryRequest. Usually, this means it says "I want to charge" by setting serviceCathegory=EVCharging.
|
||||
36. The charger confirms with ServiceDiscoveryResponse. This contains the offered services and payment options. Usually it says which type
|
||||
* Checkpoint506: The car receives the SessionSetupResponse.
|
||||
* Checkpoint510: The car sends ServiceDiscoveryRequest. Usually, this means it says "I want to charge" by setting serviceCathegory=EVCharging.
|
||||
* Checkpoint515: The charger confirms with ServiceDiscoveryResponse. This contains the offered services and payment options. Usually it says which type
|
||||
of charging the charger supports (e.g. AC 1phase, AC 3phase, or DC according CCS https://en.wikipedia.org/wiki/IEC_62196#FF), and that
|
||||
the payment should be handled externally by the user, or by the car.
|
||||
37. The car sends ServicePaymentSelectionRequest. Usually (in non-plug-and-charge case), the car says "I cannot pay, something else should
|
||||
* Checkpoint520: The car sends ServicePaymentSelectionRequest. Usually (in non-plug-and-charge case), the car says "I cannot pay, something else should
|
||||
handle the payment", by setting paymentOption=ExternalPayment. Optionally it could announce other services than charging, e.g. internet access.
|
||||
38. The charger confirms with ServicePaymentSelectionResponse.
|
||||
39. The car sends ContractAuthenticationRequest. In non-plug-and-charge case this is most likely not containing relevant data.
|
||||
40. The charger confirms with ContractAuthenticationResponse. In case, the user needs to authenticate before charging, this
|
||||
* Checkpoint525: The charger confirms with ServicePaymentSelectionResponse.
|
||||
* Checkpoint530: The car sends ContractAuthenticationRequest. In non-plug-and-charge case this is most likely not containing relevant data.
|
||||
* Checkpoint535: The charger confirms with ContractAuthenticationResponse. In case, the user needs to authenticate before charging, this
|
||||
response does NOT yet say EVSEProcessing=Finished. The car repeats the request.
|
||||
41. The user authorizes, e.g. with RFID card or app or however.
|
||||
42. The charger sends ContractAuthenticationResponse with EVSEProcessing=Finished.
|
||||
41. The car sends ChargeParameterRequest. This contains the wanted RequestedEnergyTransferMode, e.g. to select
|
||||
* Checkpoint536: The user authorizes, e.g. with RFID card or app or however.
|
||||
* Checkpoint538: The charger sends ContractAuthenticationResponse with EVSEProcessing=Finished.
|
||||
* Checkpoint540: The car sends ChargeParameterRequest. This contains the wanted RequestedEnergyTransferMode, e.g. to select
|
||||
DC or AC and which power pins are used. The car announces the maximum current limit and the maximum voltage limit.
|
||||
42. The charger confirms with ChargeParameterResponse. The contains the limits from charger side, e.g. min and max voltage,
|
||||
* Checkpoint545: The charger confirms with ChargeParameterResponse. The contains the limits from charger side, e.g. min and max voltage,
|
||||
min and max current. Now, the initialization phase of the charging session is finished.
|
||||
43. The car changes to CP State to C or D, by applying an additional resistor between CP and ground.
|
||||
44. The car sends CableCheckRequest. This contains the information, whether the connector is locked.
|
||||
45. The charger applies voltage to the cable and measures the isolation resistance.
|
||||
46. The charger confirms with CableCheckResponse.
|
||||
47. The CableCheckRequest/CableCheckResponse are repeated until the charger says "Finished".
|
||||
47. The car sends PreChargeRequest. With this, the car announces the target voltage of the charger before closing the circut. The goal
|
||||
* Checkpoint550: The car changes to CP State to C or D, by applying an additional resistor between CP and ground.
|
||||
* Checkpoint560: The car sends CableCheckRequest. This contains the information, whether the connector is locked.
|
||||
* Checkpoint561: The charger applies voltage to the cable and measures the isolation resistance.
|
||||
* Checkpoint565: The charger confirms with CableCheckResponse.
|
||||
* Checkpoint566: The CableCheckRequest/CableCheckResponse are repeated until the charger says "Finished".
|
||||
* Checkpoint570: The car sends PreChargeRequest. With this, the car announces the target voltage of the charger before closing the circut. The goal
|
||||
is, to adjust the chargers output voltage to match the cars battery voltage. Also a current limit (max 2A) is sent.
|
||||
48. The charger confirms with PreChargeResponse. This response contains the actual voltage on the charger.
|
||||
49. The charger adjusts its output voltage according to the requested voltage.
|
||||
50. The car measures the voltage on the inlet and on the battery.
|
||||
51. The above steps (PreChargeRequest, PreChargeResponse, measuring physical voltage) are repeating, while the
|
||||
* Checkpoint575: The charger confirms with PreChargeResponse. This response contains the actual voltage on the charger.
|
||||
* Checkpoint580: The charger adjusts its output voltage according to the requested voltage.
|
||||
* Checkpoint581: The car measures the voltage on the inlet and on the battery.
|
||||
* Checkpoint582: The above steps (PreChargeRequest, PreChargeResponse, measuring physical voltage) are repeating, while the
|
||||
physical voltage did not yet reach the target voltage.
|
||||
51. If the difference is small enough (less than 20V according to [ref x] chapter 4.4.1.10), the car
|
||||
* Checkpoint590: If the difference is small enough (less than 20V according to [ref x] chapter 4.4.1.10), the car
|
||||
closes the power relay.
|
||||
51. The car sends PowerDelivery(Start)Request.
|
||||
52. The charger confirms with PowerDeliveryResponse.
|
||||
53. The car sends CurrentDemandRequest (repeated while the charging is ongoing). In this message, the car tells the charger the target voltage and
|
||||
* Checkpoint600: The car sends PowerDelivery(Start)Request.
|
||||
* Checkpoint605: The charger confirms with PowerDeliveryResponse.
|
||||
* Checkpoint700: The car sends CurrentDemandRequest (repeated while the charging is ongoing). In this message, the car tells the charger the target voltage and
|
||||
target current.
|
||||
54. The charger confirms with CurrentDemandResponse. This contains the measured voltage, measured current, and flags which show which limitation
|
||||
* Checkpoint705: The charger confirms with CurrentDemandResponse. This contains the measured voltage, measured current, and flags which show which limitation
|
||||
is active (current limitation, voltage limitation, power limitation).
|
||||
55. The CurrentDemandRequest/CurrentDemandResponse are repeated during the charging.
|
||||
55. When the end of charging is decided (battery full or user wish), the car sends PowerDelivery(Stop)Request.
|
||||
56. The charger confirms with PowerDeliveryResponse.
|
||||
57. The car sends WeldingDetectionRequest.
|
||||
58. The charger confirms with WeldingDetectionResponse.
|
||||
59. The car sends SessionStopRequest.
|
||||
60. The charger confirms with SessionStopResponse.
|
||||
* Checkpoint710: The CurrentDemandRequest/CurrentDemandResponse are repeated during the charging.
|
||||
* Checkpoint800: When the end of charging is decided (battery full or user wish), the car sends PowerDelivery(Stop)Request.
|
||||
* Checkpoint805: The charger confirms with PowerDeliveryResponse.
|
||||
* Checkpoint850: The car sends WeldingDetectionRequest.
|
||||
* Checkpoint855: The charger confirms with WeldingDetectionResponse.
|
||||
* Checkpoint900: The car sends SessionStopRequest.
|
||||
* Checkpoint905: The charger confirms with SessionStopResponse.
|
||||
|
||||
|
||||
|
||||
## Change history / functional status
|
||||
### 2022-10-19 [*EvseMode*] Communication/AVLN with Ioniq car established
|
||||
* Using a TPlink TL-PA4010P with firmware MAC-QCA7420-1.4.0.20-00-20171027-CS and the PIB configuration file patched for evse according to the open-plc-utils docu.
|
||||
* Python software running on Win10, Python 3.10.8
|
||||
* On control pilot, sending 5% PWM to initiate digital communication with the car
|
||||
* Since the TPlink is configured as coordinator, it sends "alive" messages, and the IONIQ starts sending the SLAC_PARAM.REQ.
|
||||
* Per keystroke, we trigger a SET_KEY before the car is connected. The TPlink responds with "rejected", but this is normal, the LEDs are turning off and on, key is accepted.
|
||||
* Python script interprets the relevant incoming messages (SLAC_PARAM.REQ, MNBC_SOUND.IND, SLAC_MATCH.REQ) and reacts accordingly.
|
||||
* After successfull SLAC sequence, all three LEDs on the TPlink are ON, means: Network (AVLN) is established.
|
||||
* In wireshark, we see that the car is sending UDP multicast messages to destination port 15118. This looks like a good sign, that it wants a ISO15118 compatible communication.
|
||||
![image](https://user-images.githubusercontent.com/98478946/196766285-1c3152f7-31db-4b5f-98b1-9f1216f9b9de.png)
|
||||
|
||||
### 2022-10-19 [*ListenMode*] Sniffing mode not yet working with the TPlink adaptors
|
||||
* with a Devolo dLAN 200 AVplus, software INT6000-MAC-4-4-4405-00-4497-20101201-FINAL-B in original parametrization, it is possible
|
||||
to see the complete SLAC traffic (both directions) which sniffing the communication between a real charger and a real car. This does
|
||||
NOT work with the TPlink adaptors. They route only "their own" direction of the traffic to the ethernet. Means: The pev-configured device
|
||||
does not see the real car, and the evse-configured device does not see the real charger. This is bad for sniffing.
|
||||
|
||||
### 2022-10-21 [*EvseMode*] SLAC, SDP and ICMP are working
|
||||
Using the TPlink and Win10 laptop as evse, the python script runs successfully the SLAC and SDP (SECC discovery protocol). Afterwards, the car uses
|
||||
neighbor solicitation (ICMP) to confirm the IPv6 address, and the Win10 responds to it. The car tries to open the TCP on port 15118, this is failing
|
||||
because of missing implementation of the listener on PC side.
|
||||
|
||||
### 2022-10-26 [*ListenMode*] Network/AVLN is established
|
||||
Using the TPlink in EVSE mode and Win10 laptop, listening to a communication setup between real car and real alpitronics charger, the python script
|
||||
successfully extracts the NID and NMK from the SLAC_MATCH response, sets this information into the TPlink, and the TPlink turns three
|
||||
LEDs on. Means: Network established. When we send a broadcast software version request, we get three responses: One from the TPlink, one from the
|
||||
PLC modem of the car, and one from the PLC modem of the charger. This confirms, that the network is established.
|
||||
But: From the higher level communication (IPv6, UDP, TCP) we see only the broadcast neighbor solicitation at the beginning. The remaining traffic
|
||||
is hidden, most likely because the TPlink "too intelligent", it knows who has which MAC address and hides traffic which is not intended for the
|
||||
third participant in the network. Trace in results/2022-10-26_WP4_networkEstablishedButHiddenCommunication.pcapng
|
||||
|
||||
### 2022-11-09 [*EvseMode*][*PevMode*] Exi decoder first steps working
|
||||
Using EXI decoder/encoder from basis https://github.com/Martin-P/OpenV2G and created fork https://github.com/uhi22/OpenV2Gx to
|
||||
provide a command-line interface, which can be used by the python script. The OpenV2G includes generated source code for four
|
||||
xml schemas (Handshake, DIN, ISO1, ISO2), provided by Siemens. Seems to be good maintained and is very efficient, because the
|
||||
decoder/encoder are directly available as C code, dedicated for each schema. This skips the slow process of reading the schema,
|
||||
parsing it, creating the grammer information. On Windows10 notebook, measured 15ms for decoder run from python via command line.
|
||||
The OpenV2G was compiled on Windows10 using the included makefile, using the `mingw32-make all`.
|
||||
The OpenV2G decoder/encoder code reveals some differences between the different schemas (DIN versus ISO). As starting point, only the
|
||||
DIN schema is considered in the command line interface and python part.
|
||||
|
||||
The python part now contains the charging state machines for car and charger, as draft.
|
||||
|
||||
Using the TPlink and Win10 laptop as evse, connected to Ioniq car, the python script successfully succeeds to SLAC, TCP connection,
|
||||
schema handshake, SessionSetup, ServiceDiscovery, ServicePaymentSelection. It stops on ChargeParameterDiscovery, most likely to
|
||||
missing or wrong implementation. Results (log file and pcap) are stored in
|
||||
https://github.com/uhi22/pyPLC/tree/master/results.
|
||||
|
||||
As summary, the concept with the python script together with the compiled EXI decoder works. Further efforts can be spent on
|
||||
completing the missing details of the V2G messages.
|
||||
|
||||
### 2022-11-11 [*EvseMode*] Ioniq in the PreCharge loop
|
||||
The EVSE state machine, together with the EXI decoder/encoder, is able to talk to the Ioniq car until the PreCharge loop. The
|
||||
car terminates the loop after some seconds, because the intended voltage is not reached (no physical electricity connected to the
|
||||
charge port). Maybe it is possible to convince the car to close the relay, just by pretending "voltage is reached" in the
|
||||
PreCharge response. But maybe the car makes a plausibilization with the physical voltage, then further development would require
|
||||
a physical power supply.
|
||||
|
||||
### 2022-11-15 [*PevMode*] Draft of SLAC sequencer
|
||||
In PevMode, the software runs through the SLAC sequence with a simulated Evse. After SLAC is finished, we send a software
|
||||
version request broadcast message, to find out, whether we have at least two homeplug modems in the network (one for the
|
||||
car and one for the charger). If this is fulfilled, we should use the SDP to discover the chargers IPv6 address. But this
|
||||
is not yet implemented.
|
||||
|
||||
### 2022-11-25 v0.2 On ABB charger until ChargeParamDiscoveryRequest
|
||||
- With Win10 notebook in PevMode, tested on Alpitronics HPC and ABB Triple charger. On the Alpi, the SLAC and SDP works. The TCP connection fails. On ABB, the SLAC, SDP and TCP works. Also the protocol negotiation works. We come until ChargeParamDiscoveryReqest.
|
||||
- Log messages are sent via UDP port 514 as broadcast, like Syslog messages. The Wireshark shows them as readable text, so we have the actual communication between car and charger in the trace and also the debug log.
|
||||
- Example pcap in results/2022-11-25_v0.2_ABB_until_ChargeParamDiscovery.pcapng
|
||||
- With Win10 notebook in EvseMode, tested on the Ioniq car. It comes until the CurrentDemandRequest.
|
||||
- For using Raspberry in PevMode without display, there is now the pevNoGui.py, which can be auto-started by configuring a service which calls starter.sh, and this calls starter.py (this is still expermental).
|
||||
- The old Raspberry model B needs 90s from power-on until it sends the first log messages. Means, the boot is quite slow.
|
||||
- Raspberry in PevMode and Win10 notebook in EvseMode work well together until the PreCharge.
|
||||
- Known issues:
|
||||
- The TCP port, which is announced in the SDP response, is ignored. This can be the root cause of failing TCP connection on Alpitronics.
|
||||
- The SLAC timing includes too long wait times. This may be the root cause for failing SLAC on Supercharger and Compleo.
|
||||
|
||||
### 2022-12-02 v0.3 On Alpitonics until ChargeParameterDiscovery
|
||||
- TCP connection works now on Alpitronics charger
|
||||
- ContractAuthentication loop works
|
||||
|
||||
### 2022-12-13 v0.4 On Compleo, Light Bulb survives 400V cable check and PreCharge
|
||||
- SLAC issue is fixed on Compleo. Authorization works. Hardware interface "Dieter" controls the CP into state C.
|
||||
- The charger delivers power in the cable check, and a connected 230V bulb makes bright light and survives the 400V.
|
||||
- PreCharge starts, but terminates before full voltage is reached. Switching the load with power-relay is not yet implemented from
|
||||
hardware side. Without the load, we see the intended 230V precharge voltage, and run into timeout (to be investigated).
|
||||
|
||||
### 2022-12-20 Measurement of inlet voltage works
|
||||
- Tests ran on Alpitronics HPC.
|
||||
- Measuring the inlet voltage with Arduino "Dieter" works. During CableCheck and PreCharge, the inlet voltage is shown in the GUI.
|
||||
- The Alpi confirms the PowerDelivery (start), but rejects the CurrentDemandRequest with FAILED_SequenceError and EVSE_Shutdown.
|
||||
- Results (log file and pcap) are stored in https://github.com/uhi22/pyPLC/tree/master/results.
|
||||
|
||||
### 2022-12-21 v0.5 Light-bulb-demo-charging works on multiple chargers
|
||||
- On 3 of 4 tested charger models, the light-bulb-demo works: AlpitronicHPC, ABB HPC, ABB Triple. The Ionity Tritium overshoots the target voltage due to missing load, and aborts.
|
||||
- Welding detection gives negative or no answer.
|
||||
- Traces https://github.com/uhi22/pyPLC/blob/master/results/2022-12-21_westpark_alpi_charge_ok_with_bulb.pcapng and https://github.com/uhi22/pyPLC/blob/master/results/2022-12-21_alpi_ABBHPC_ABB_Ionity_lightbulb_3of4ok.decoded.txt
|
||||
- Pictures and discussion in https://openinverter.org/forum/viewtopic.php?p=50172#p50172
|
||||
|
||||
### 2023-02-27 PEV mode with OLED-display works on headless Raspberry
|
||||
- Charging status is shown on OLED display. Details in [hardware.md](doc/hardware.md)
|
||||
- RaspberryPi 3 configured to auto-start the PEV software as service. Startup time around 21 seconds from power-up until the SLAC starts. Details
|
||||
in [installation_on_raspberry.md](doc/installation_on_raspberry.md)
|
||||
|
||||
### 2023-03-03 v0.6 Tea-Time on Alpitronics charger
|
||||
Made a tea, using the RaspberryPi3 and tpLink modem on Alpitronics hypercharger.
|
||||
|
||||
### Test results on real-world chargers
|
||||
## Test results on real-world chargers
|
||||
|
||||
See [charger_test_results.md](doc/charger_test_results.md)
|
||||
|
||||
|
@ -357,3 +357,16 @@ However, the software will help to explore and understand the behavior of the ca
|
|||
That's is definitely a goal, at it looks reachable. Of course, two aspects need to be considered:
|
||||
- This project is not a final product. Further development will be necessary to ensure compatibility with chargers, and make it flexible for practical use.
|
||||
- Some parts are not covered by this project at all, e.g. communication with the BMS, connector lock, safety considerations.
|
||||
|
||||
## References
|
||||
* [i] https://www.goingelectric.de/wiki/CCS-Technische-Details/ knowledge collection
|
||||
* [ii] https://openinverter.org/forum/viewtopic.php?p=37085#p37085 discussion of this project
|
||||
* [iii] https://github.com/qca/open-plc-utils utilities for configuring the PLC adaptor
|
||||
* [iv] https://github.com/karpierz/pcap-ct library for low-level-network-access
|
||||
* [v] https://github.com/FlUxIuS/V2Gdecoder demo for EXI decoder
|
||||
* [vi] https://github.com/SwitchEV/iso15118 another "nearly" open source CCS project
|
||||
* [vii] https://books.google.de/books?id=WYlmEAAAQBAJ&pg=PA99&lpg=PA99&dq=%22ampsnif%22&source=bl&ots=hqCjdFooZ-&sig=ACfU3U0EleLZQu0zWhHQZGktp8OytCMrLg&hl=de&sa=X&ved=2ahUKEwjT0Yq88P36AhWj_rsIHeGMA5MQ6AF6BAgKEAM#v=onepage&q=%22ampsnif%22&f=false How to enable sniffer mode.
|
||||
* [viii] https://www.mdpi.com/2076-3417/6/6/165/htm "Building an Interoperability Test System for Electric Vehicle Chargers Based on ISO/IEC 15118 and IEC 61850 Standards", including V2G message sequence chart
|
||||
* [ix] https://www.oppcharge.org/dok/ISO_15118-2_OpportunityCharging_Rev1.3.0.pdf Pantograph specific differences with some insight into ISO15118.
|
||||
* [x] https://assured-project.eu/storage/files/assured-10-interoperability-reference.pdf Fast and Smart Charging Solutions for
|
||||
Full Size Urban Heavy Duty Applications
|
||||
|
|
Loading…
Reference in a new issue