...
Date | Individual | Progress | Concerns | ||
sept. 18 | Jess | Got CANable adapters working, updated verified mcp2515 works on MCI rev 5 that has the CANable adapter soldered to it. Questions:
| CANable adapter should probably not be soldered to the board in future. Also had to sacrifice a system CAN terminating resistor in the debug process, sorry Blockers:
| ||
sept 21 - 9am | Aashmika + Kristen |
|
| ||
sept 25 | Jess | Figured out how to connect steering stalk to rev 4, tested some firmware
|
| ||
Oct 11 | Jess | Found source of CC DECR not working on steering. We implement interrupts in firmware using the STM32 external event input interface, which only has 16 lines. We set this up in firmware so we can register an interrupt on each pin number, e.g. PB1 and PA2 works but if you register PB1 then PA1 registering for PA1 will fail. The regen button and the CC on/off button still don’t consistently trigger interrupts. ADC values for CC on/off are consistently ~1600, with no noticeable variability when the button is pressed. The interrupt never triggers. ADC values for regen toggle are ~1600 when the button is unpressed, then they jump to ~1800 when the button is pressed. Occasionally the interrupt triggers, but not consistently. To have minicom ADC and interrupt logging, use branch Couldn’t find the center console board. Tried switching cables for driver display, but it seems pretty busted. |
| ||
Oct. 12 🦃 | Jess | ===== DAY ===== Tested MCI with a bugfix from MPXE validation, the flow for setting drive output → getting pedal commands seems to work now. Precharge used to flip PB0 properly, but not PA10 (I was told this was because it only flips PA10 if the relay is connected, which it wasn’t, so this was expected behaviour). Now, precharge doesn’t seem to flip either, but this is under progress by hardware at the moment so hopefully will be fixed soon. Aside from that, MCI counts as validated. ===== EVENING ===== Steering: decided it’s not worth fixing it in hardware (too many jumpers required), but stuff sorta works intermittently. Functionality confirmed in firmware, but need to fix up actual project to work in all functionality. Decided DRL toggle is the lane assist button (PA6) and horn (PB1) pin needs to change to allow CC DECR (PA1) to have an interrupt. MCI: drive fsm + pedal → mcp2515 output flow all works. Precharge logic being validated by hardware. Power distro: learned how to set it up for testing, will work on it tomorrow w/ Ryan. Power select: things seem ok, seems like there’s a lot of problems in hardware. Some preliminary test results shown below: Readings for pins with the front power distro wires hooked up to e-load @ 0.5A (12 volts shown) and aux power wires hooked up to power supply & 12V.
| |||
Oct. 13 | Jess + Aashmika | Worked on power distro, work is on branch bts7200-messs
Problem was the load switches couldn’t handle eload in constant current mode and were overload protecting (greater than 500 mA @ 12V for example). Putting eload into constant resistance mode allowed load switch to work consistently. Also added initialization to pin on PCA9539r to set it properly. We might have destroyed U6 and U5 from the overloading with constant current mode as they are constantly enabled now. We also shorted a controller board (3v3 or 12v) and it died. RIP. | Aashmika cries. Couldn’t work on MCI. | ||
Oct 14 | Jess | Power selection, working on branch The “valid” signals work for aux and DCDC, i.e. they’re all 1 except valid_3 when aux is plugged in, and all 1 except valid_2 when dcdc is plugged in. Thermistors didn’t seem to be populated. Power distro, working on branch | |||
Oct 15 | Jess + Aashmika + Ricky | Driver Display: did some setup on raspi, working on getting Precharge: Having problems with precharge and testing to see what could be the issue. Checked fets Q2, Q4 and Q5 all working fine, trying to figure out how the SR latch works. Checked to see if the capacitor is connected to the board and it is connected. Testing the And_out (yellow), reset pin (blue), and SR latch output (purple). Evening shift: Got the driver display app running on the display, steps here: Driver Display setup | |||
Oct 17 | Jess | Tried to talk to new motor controllers. Note: LAWICEL slcan dongle must be used, can’t use peak-can dongle. The old software we were using for the WaveSculptor 20s doesn’t seem to work; it connects but doesn’t seem to read messages and can’t upload/download configs. I suspect the old version of the software isn’t compatible with these controllers. I submitted a request for the newer version of the software through the ‘contact us’ page on their website since the software isn’t listed there. Candumping using karl ding’s old dbc file on github https://github.com/karlding/wavesculptor-22-dbc (with device id changed to 0x400 rather than 0x80 via kvaser DBC editor) gave some output. Next steps are hopefully wait for tritium to give us the new software, otherwise reach out to other solar car teams / post in the solar racing reddit to see if anyone else has a copy of the software. Do we have any contacts at tritium? | |||
Oct 24 | Hewitt | Worked on figuring out why MCP2515 smoke test isn’t working on MCI rev. 4. Wasn’t working on the MCI rev. 5 either, but loopback tests passed on the MSXII charger interface board. We’re also not communicating with the MCP2515 on the MCI rev. 4 (registers read either 0 or 255 before and after trying to change them), but other two boards seem to be working okay in that regard. MCP2515 SPI connections should be identical across all boards, so seems like the rev. 4 one isn’t working. Since it seems to be working, will try to get the charger interface board connected to the WaveSculptor 22 CAN bus tomorrow and start looking at getting readings from it + figuring out whether the MCI is sending all CAN messages at once. | |||
Oct 25 | Selina + Jess | I2C communication not working with ads1015 on pedal board (failing at Also tried to run the smoke test for bts_7200. It’s working on the power distro board when running from the | |||
Oct 25 | Hewitt | Got MSXII charger interface board connected to the WaveSculptor CAN bus. It didn’t seem to be receiving messages when running the MCP2515 smoketest, but was sending messages fine. Flashed MCI FW to the board and verified that it can see CAN messages; it consistently stops calling both velocity and bus message CBs once it gets a bus measurement message. Will look into figuring out the cause of this and look into manually triggering MCI CAN messages tomorrow/later on in the week. Additionally, looks like the WaveSculptor is sending all the update messages at the same time, so we’ll need to look into ways to make this work with the MCP2515. | |||
Oct 26 | Jess | Found another pedal board in the box, so since the ADS1015 is fried on the original one we’re using, Ricky is porting the connectors to the working one. We fried the old one because the potentiometer used was shorted, so now we’re just not connecting the grounds on the pots for the new one. Didn’t get to check it worked fully, but it should work. | |||
Oct 26 | Aashmika + Ricky | Precharge:
AFE: Soldered on the duraclik and microfit connectors, also fixed two ICs that was soldered on the wrong way Pedal Board: Soldered the two potentiometers onto the board for the 3V3 and potentiometer pin but not the ground pin DCDC and Power Distribution: Soldered on the connectors that has easy connections Power Select: Soldered the two thermistors onto the board | |||
Oct 27th | Aashmika + Ricky | Precharge:
| |||
Oct 27 | Hewitt | Worked on figuring out the issue with the MCP2515/WaveSculptor. The MCP2515 driver doesn’t have functionality to set the RTR bit when TXing, which is needed to request a message from the WaveSculptor, so we’ll need to implement this. Generally, the issues seem to stem from the filter configuration on the MCP2515. The current MCI FW uses It seems like the MCP2515 issue where it would only receive a few messages and then stop calling the CBs happens when multiple CAN messages are received at the same time. This is consistent with previous behaviour where we’d sometimes see multiple speed rx’s before seeing a bus measurement rx and eventually failing, since the WaveSculptor seems to send ~4 speed rx’s at around the same time, then a delay, then one of every expected rx at the same time. When testing with the config on It seems like the MCP2515 supports 6 filters total across both rx buffers, so it might make sense to look into adding this functionality to the driver if/when we get the current filter issue resolved. | |||
Oct 28 | Ricky | AFE: fixed the led on the board and checked all components to make sure that they are in the correct direction MCI: I fixed LED4 and Q8 to be in the correct direction now. Found one last U7 left in the MCI Precharge box Battery Module Connector: I have soldered all of the 14pin connectors on the 30 boards | |||
Oct 28 | Hewitt | Continued work on MCI: wrote Looked into requesting status messages by sending a CAN message with the RTR bit set, but I couldn’t get an implementation that didn’t stop working after getting a few messages (similar to earlier MCP2515 issues), so leaving this for now. | |||
Oct 28 | Jess + Selina | Worked on | |||
Oct 29th | Aashmika + Ricky | Precharge Precharge now works! Latching and precharge + discharge sequences were scoped and matched expected function. We also put on the other connectors on MCI for the power train testing. See precharge v5.0 testing document for more information. Pedal Found that the 3V0 pedal regulator is dead on the original pedal board. Replaced it with the reg from the other pedal board, but this regulator seems to only output 1.25V. Note that the other board has a short from 3V3 to GND which is not a priority fix. 1.25V is not enough for the operating conditions of the ADC, so I will look for a replacement. Ricky also crimped the input pots so they can go in the pedal connetor. After replacing the IC, communication works once again! Now with the pots in place, both pots give readings of 3-1486 depending on the turn. Power Distribution + Precharge: Crimped power and ground wires from the PD and put the wires into Precharge to give power Power Distribution + Power Selection: I connected the power supply from the power selection to the power distribution Power Selection + DC-DC Converter: Soldered the power and GND wires from the power DC-DC Converter to power selection |