Setup
Connected to a 12S 1P Li-ion battery stack (some of the many old laptop batteries that were hanging around my basement).
IP and IN on the AFEs seem to be backwards compared to the vertical duraclick connectors. Had to swap the pins in the cable to match it up.
The connections to the cells seem to be crimped improperly, parts of them were squished during crimping, allowing the pins to push out the end of the connector. We should ask Molex for the proper crimp tool, as this happens a lot. This may also be contributing to the fact that the 14 and 16 pin connectors are tough to remove, require 1 hand on the board and 1 hand on the connector.
I dropped the board. It landed on the screw hole. Maybe we should consider moving the screws away from the edge of the board a little more? But the main point here is that I should have been more careful with the board. It landed on a thin rubber mat on the floor in my work area.
Power Validation
All power nets are not connected. Good.
I presume toggling the CS pin is supposed to keep it from going in to sleep state?
Measuring 5V is good. Nothing on either of the 3V0 VREF outputs.
The board seems to be resetting at a rate independent of the rate at which I toggle the CS pin. By resetting, I mean the 5V LED toggling off (for a short time, about 100ms before turning back on). So the device seems to be going into a sleep state or something before waking up again via the SPI command.
Battery Stack Monitor
Gerald Aryeetey (Deactivated) and Micah Black tried to get the LTC6811 chip to talk using code from the old car, modified to work with just 1 AFE.
They seem to always be replying with a '0' for the cell voltage measurement, causing a bad CRC error. It is unknown at this point whether it is a problem with the code or a problem with the hardware.
Here is a scope image of the VREF2 pin when the commands are sent.
So it seems like the device is waking up. More debugging to do. Liam Hawkins any ideas?
The AFE takes time for the references to wake up, and it takes about 3.5mS for the AFE to wake up the references. It shows 5mS here, but would be within the specified range if measured from the end of the rising edge.
Reading further, this wait cycle only applies when waking up the AFE to measure it.
So we went on testing trying to get data from it.
We connected a logic analyzer to the output to see if we were getting the correct data out. The output shows the same data that we send in code, so this verifies that we have the correct SPI port and pinouts. However, still no response from the AFEs.
We looked at the ISOSPI input on the AFEs with an oscilloscope, and that all seemed fine:
Note - the peak are much higher (>+-1V) when zoomed in.
So the data is getting to the AFE side accurately. It is waking up from the communication and powering the DRIVE pin to enable the 5V regulator - the green LED on the board turns on - and then goes back to sleep after 2s.
We did notice that the MISO and MOSI lines seem to be following each other, which I didn’t really expect. The MISO/MOSI pins seem to be shorted on the board, but I remember Liam Hawkins mentioned at one point that the LTC6820 chips are not ‘idle’ - they will actively drive some of the lines and might be causing this measurement?. We should probably do some more digging into the LTC6820 datasheet to see what we should expect on the SPI port.
Any thoughts Liam Hawkins ?
Debugging Jun 6 2020
Going off the last comment of the SPI lines being shorted, I double checked them and they seemed to be fine. No shorts that I could see. I measured the other SPI bus on the carrier (for the Current Sense) and it was not shorted - which seemed like the expected behaviour.
I checked all the pins on the LTC6820 and confirmed that it was only the MISO/MOSI pins that were shorted. Thinking it could be some solder stuck underneath the chip connecting the backs of the pins, I flooded those pins with solder, then removed it using the solder wick. Still shorted.
Poking around the board a little more, I found the culprit. MISO/MOSI on SPI1 are shorted underneath the controller board connector, so that you can only see it if you’re looking at an angle less than about 30 degrees to the horizontal. And it really does just look like flux unless you have the right lighting. I tried to get a picture, but it doesn’t really do it justice:
Plugging everything back in, we immediately get data back!
But is it the data expected?
We are sending it: 0x00, 0x02, 0x2b, 0x0a which should be the command to read configuration register A, followed by the 2 bytes of the Packet Error Code used to check for data errors.
It sent back:
0xFA, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC6, 0x52
Which should be the 6 bytes of data in Configuration Register A followed by the 2 bytes of the packet error code. According to the Validation Page (and the datasheet), this is expected - with only the GPIOs and the DTEN bits set.
And the python script I had created earlier for generating and checking the CRC gives a CRC of 0xC652 for the same 6-byte message so everything is working!
Yay!
Here’s the python program if anyone wants it:
This is the modified smoke_spi main.c I used to get the data:
Now going back to the Plutus code that we were originally trying to run to read voltages: It works!
[0] projects/plutus/src/main.c:19: THIS IS THE START[0] libraries/ms-helper/src/persist.c:112: Found valid section at 0x801f800 (0x10 bytes), loading data [0] projects/plutus/src/main.c:22: Board type: 0 [0] projects/plutus/src/ltc_afe_fsm.c:65: TRIGGERED CELL CONVERSION SUCCESSFULLY [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 0 with value 40889 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 1 with value 40862 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 2 with value 40590 [0] projects/plutus/src/ltc_afe_impl.c:240: CALCULATING PACKET ERROR CODE (CRC) FOR rev_pec=48032 and data_pec=48032 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 3 with value 40897 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 4 with value 41418 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 5 with value 41621 [0] projects/plutus/src/ltc_afe_impl.c:240: CALCULATING PACKET ERROR CODE (CRC) FOR rev_pec=64312 and data_pec=64312 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 6 with value 41517 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 7 with value 41479 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 8 with value 41443 [0] projects/plutus/src/ltc_afe_impl.c:240: CALCULATING PACKET ERROR CODE (CRC) FOR rev_pec=39510 and data_pec=39510 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 9 with value 39617 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 10 with value 41053 [0] projects/plutus/src/ltc_afe_impl.c:230: Got cell voltage for cell index: 11 with value 40681 [0] projects/plutus/src/ltc_afe_impl.c:240: CALCULATING PACKET ERROR CODE (CRC) FOR rev_pec=38042 and data_pec=38042 [0] projects/plutus/src/ltc_afe_fsm.c:79: READING FROM CELLS [0] projects/plutus/src/ltc_afe_fsm.c:86: RUNNING CELL CALLBACK
Comparing to the Keysight U1282A multimeter, all voltages were within 1mV, expect for the top 2 cells (the last 2 printed out) which measured low by the LTC6811 by 1.3mV and 1.6mV respectively.
Overall, voltage reading is a success!
Temperature Readings
-I need to attach some thermistors first…
I put a variety of them on so that we can estimate temperature accuracy over the full range:
Thermistor Cell Input number | Bottom Resistor Value | Expected Voltage (10k upper resistor, 3V0 ref) | Temperature Result Expected |
---|---|---|---|
0 | 10k | 1.5 | 25 |
1 | 3.3k | 0.74436 | 52 |
2 | 10k | 1.5 | 25 |
3 | 4.7k | 0.959186 | 43 |
4 | 10k | 1.5 | 25 |
5 | 5.1k | 1.013245 | 41 |
6 | 10k | 1.5 | 25 |
7 | 6.8k | 1.214285 | 34 |
8 | 10k | 1.5 | 25 |
9 | 10k pot | 0-1.5 | 25+ |
10 | 10k | 1.5 | 25 |
11 | 3.3k | 0.74436 | 52 |
12 | 4.7k | 0.959186 | 43 |
13 | 5.1k | 1.013245 | 41 |
14 | 6.8k | 1.214285 | 34 |
15 | 10k | 1.5 | 25 |
16 | 10k | 1.5 | 25 |
17 | 1.5@25C | 25 |