Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tesla BMS reverse engineering #5

Open
Pagode opened this issue Oct 30, 2017 · 27 comments
Open

Tesla BMS reverse engineering #5

Pagode opened this issue Oct 30, 2017 · 27 comments

Comments

@Pagode
Copy link

Pagode commented Oct 30, 2017

Hello collin80,

I am currently trying to connect Arduino Due with one Tesla Battery Package as part of a project for my study.
The Arduino is sending its messages but can't find the Tesla board.
I am also not sure how to wire the fault output you described in your hackaday project.
Hopefully you can give me any advice so that I can get further.

I am looking forward to hearing from you!

Reply:
reply

Wiring:
red = 5V (Pin 1)
green = Ground (Pin 3)
yellow = TX (Pin 2)
white = RX (Pin 9)
black = fault (Pin 6)
anhang1

anhang4

@jorakarandas
Copy link

jorakarandas commented Oct 30, 2017 via email

@danfador
Copy link

danfador commented Jun 10, 2018

Hello, @Pagode do you succeeded with tesla BMS and Arduino, I have two model s module and I get an Arduino Due + Molex connector, what else I have to boy to comunicate with Tesla BMS?

One more question, without any external connection does testa BMS balance the cells ore not?

Thank you!

@bstarr119
Copy link

Good Evening All,

I am having similar troubles as the original poster, unfortunately I cannot upload pictures from the mobile site. I have incorporated a level shifter with the due so that I do not over volt the tx rx ports. I will need to figure out something new to try but I am running low on ideas as I am new to CANbus and due ^^

@NiallDarwin
Copy link

Hi @jorakarandas thanks for your suggestion of the level shifter. Please can you read this and let me know if I've understood correctly:
The ESP32 is a 3.3V chip & board so 5V could damage it.
The Tesla BMS boards are 5V.
This means that the Tesla board's Tx & Rx will be running at (up to) 5V and can therefore damage the ESP32. So using a level shifter means you can transmit the signal but drop voltage.
If all this is right I've got another question: Does the shifter cope with the baud rate OK? Is this a specification I need to look for when choosing a board?
Thank you :)

@collin80
Copy link
Owner

Yes, the Tesla hardware runs at 5V but an Arduino Due or an ESP32 run at 3.3v instead. So you need a level shifter to go back and forth between the two voltage levels. What you need is a level shifter that can go fast enough. You have the baud rate of the Tesla hardware (625000) so what you need is a level shifter that can handle 1MHz digital signals. Cheaper shifters probably won't. But, plenty of options exist. And, in a pinch perhaps you've already got AND logic chips. Just feed the input to both inputs to the AND gate and output at the proper voltage. Logic gate chips tend to be plenty fast enough. You just have to make sure that the chips you're using will trigger at 3.3 and 5v even if the inputs are technically higher in voltage than the V+ rail on the chip.

@NiallDarwin
Copy link

NiallDarwin commented Aug 21, 2019 via email

@NiallDarwin
Copy link

So I've now got bi-directional board very like this sparkfun offering and have made something happen. Unfortunately it seems I'm only transmitting not receiving-see screenshot. Two things I'm not sure of* are:
1/ I'm getting my 5V from the 5V pin of the Due. It's getting it from my laptop. My meter shows about 4.9V which I'd expect to be enough. Thoughts?
2/ Does the shifter need any pull up/down on any of the inputs or outputs?
If you want to see the rig, here's a little video.
Thanks :)
Screenshot 2019-08-23 18 07 40
*Lots actually but these are the relevant ones ;)

@collin80
Copy link
Owner

1 -> Yes, 4.9 is sufficiently close. When dealing with USB you nearly never get a true 5V. It's almost always a bit less and it depends on the machine. Laptops tend to be the most lazy.

2 -> It shouldn't need any pull up or down resistors.

A few more pointers: Newer Tesla BMS boards actually communicate at weird higher baud rate. It's something like 632500 baud or something odd like that. It is only a tiny bit faster but tends to make newer boards function better. I remember them still working at the slower speed but you get a lot of errors. Also, the Tesla BMS slave board on the module has a blinky light that flashes when it is sending and receiving. As such, if your set up is working you should see the LED flash briefly every time you send traffic. If you don't then you aren't getting a proper signal through at the proper rate.

@collin80
Copy link
Owner

Just a correction. The slower, older speed is 612500, the newer speed is 631578. So the faster speed is only about 3% faster. But, 3% is a kind of critical zone for serial transmission and a 3% error is enough to make it work quite poorly. So, try both.

@BobbyBleacher
Copy link

Yes, the Tesla hardware runs at 5V but an Arduino Due or an ESP32 run at 3.3v instead. So you need a level shifter to go back and forth between the two voltage levels. What you need is a level shifter that can go fast enough.

Any recommendations? There seem to be an endless amount to choose from. I'm doing that same thing here as Niall (started hooking up my packs and inverter yesterday). Can't bring it all online and disconnect from the grid until I get all the monitoring online, though.

I bought the Due and the Teensy per the readme. Flashed the Due, but I'm guessing without the shifter in place I can't get any data to transfer because my serial monitor was completely blank.

@collin80
Copy link
Owner

One of the easiest things, and I think I said this above, is to just use a two input AND gate. Such a chip is here: https://www.mouser.com/Search/Refine?Keyword=74AHC1G08

It's a cheap trick. You provide your input to each chip at both input gates so that a positive signal on the gate turns it on. Then you power one gate with 3.3v for output to the Due or other 3.3v MCU and you provide 5v power to the other gate and use it to send to the Tesla BMS board. So, two AND gates, one inputs from the TeslaBMS and outputs to the Due, the other inputs from the Due and outputs to the BMS. These are then used as level shifters. AND gates are plenty fast for a sub-1MHz signal. In fact, the chip I linked to above switches in about 10ns so would probably work up to nearly 100MHz. That's sufficiently fast and the chips are pretty cheap too.

@wizkid057
Copy link

Was linked here by a friend. I haven't really followed this project, as I developed my own software/hardware to run the BMBs quite a while back (I actually just reflash the 8051 using Tesla's own update protocol, reverse engineered, and run my own code there.)

Anyway, the digital isolator used between the BMS side and the external connector can operate at 2.5V to 5.5V... and can essentially act as a level shifter on its own. Just power the external side from whatever voltage in that range would be useful to you. The filtering before the isolator is geared towards 5V operation, and this is the voltage Tesla uses for the bus... but definitely not a solid requirement. It'll give a few tenths of a volt loss most likely, but shouldn't drop things below the 2.5V minimum at 3.3V supply.

In fact, I'm actually currently running my own home setup with 36 of these in a chain, and it's running at 3.3V directly off of my board's 3.3V regulator (repurposed the board from another project... will eventually use 5V). Realtime view: https://wk057.solar/bms.php

All of that said, I'm unsure what the benefit of level shifter would be exactly, unless the 3.3V rail isn't strong enough to provide the few mA per board needed to run the isolators. You should just be able to power the whole thing from 3.3V and be done with it. The BMB won't know any differently, since the isolated side is still powered by 5V.

@collin80
Copy link
Owner

I'm sure you're right. We never investigated the situation that much. We saw that the Tesla main board uses 5v so we kept using that voltage and just added cheap AND gates to shift the signal level. But, it's good to know that this is not strictly necessary. So I suppose everyone else might as well just plain power it with 3.3v and be done.

@BobbyBleacher
Copy link

Well, Niall is getting more than me out of it. When I start up it tells me starting up and factory settings reset, but how do I actually retrieve any useful data now that I'm connected?

@BobbyBleacher
Copy link

Disregard, I've got this all connected, powered up, and operating.,The boards just aren't being recognized by the Due for some reason. I've tried the tx/rx pins as well as the cantx/rx with no success.

@KeithMcdorman
Copy link

Worth noting that if you hooked up the due to 5v signals your signal pins may be toast. The due is not 5v tolerant. Been there done that.

@BobbyBleacher
Copy link

BobbyBleacher commented Sep 2, 2019

Signal pins are still outputting 3.54v

Connected up to an FTDI board and ran the python script to see if I could dump literally anything from RX and it's just completely empty.

@NiallDarwin
Copy link

NiallDarwin commented Sep 21, 2019

Alrighty, I made it work!
IT WORKS :)
The problem was simple. I was using the wrong serial pins on the Arduino. If you look closely there's three TX/RX ports. I'd gone in on the 0 pair but the board was using the 1s.
We also found that as per lots of advice here the Tesla boards work fine on the 3.3V of the Arduino so no need for the level shifter.
To diagnose this a friend came over and brought his logic analyser. This enabled us to see what the various channels were doing and was much, much better than just blindly trying different leads in different pins. They're NZ$18 here in NZ so probably about US$10 and worth at least 100x more!

Summary of what works for me on my 2016 BMS boards:
Run Tesla boards on 3.3V from Arduino
Tesla boards must be connected to their battery pack (or a substitute)
Use RX1/TX1 pins
No need for level shifter
Baud Rate: 631578 (Haven't tried if this is necessarily the only one but it does work for me)

Thanks Collin for writing and informally supporting this stuff. Thanks everyone else for their support.

@samsta
Copy link

samsta commented Sep 24, 2019

Niall's friend with the logic analyser here.

In hindsight, we could have just looked at config.h which explicitly uses serial port 1 (not 0). Ah well ;-)

@NiallDarwin
Copy link

I reckon this can be marked as closed now?

@sogorman
Copy link

sogorman commented Sep 28, 2019

Wk057 (been following your work for a while, have chatted with you a few times ago about 5 years ago, big fan), @collin80 , and @NiallDarwin thanks for all the hard work on this project. I am trying to get my arduino to interface with the Tesla BMS and have not had much luck. I have tried running at both 612500 and 617647 baud rate with no response from the board.

I took @wizkid057 advice and am running the board at 3.3V off the arduino header as to not require level shifting on the serial bus.

One question for the three of you.... does the board need to be powered by the pack as well? not sure if the 6S leads from the cells power and subsystem on the module.

I added some debug code to the setup function but here is all I am getting in the serial debugger.

image

I am using Serial1 in config.h and the BMS is connected to RX1, and TX1 on the arduino. I verified that I am utilizing the correct serial port on the arduino by doing a local loop back and I verified that the hex data sent was received.

Here are some pics of my test bench...

Anything jump out at you guys?

IMG_0947
IMG_0946
IMG_0948

@collin80
Copy link
Owner

As WK057 said, the power you give the board is powering the isolation chip. So, you can power that chip with 3.3 or 5v but it was meant for 5V so it probably works best with 5V if you can swing it. But, the BMS side is powered by the cells themselves. Ordinarily the current draw is quite low and everything wakes up when you send it traffic. But, you do need power at the cells in order for the 8051 processor and BMS chip to operate. So, that is your biggest hurdle.

@NiallDarwin
Copy link

@sogorman Yes, the boards need to get power from the Tesla batteries. I've edited my summary above to include this important piece of info. You didn't miss it previously ;)

@sogorman
Copy link

sogorman commented Oct 3, 2019

@NiallDarwin appreciate it and thanks to the entire group... she is now talking!

@Nzo-Po1
Copy link

Nzo-Po1 commented Jul 4, 2023

Bonjour @collin80 ,
J'ai besoin de ton aide concernant le code que tu utilises afin d'afficher la tension et la température du pack de batterie. En effet, j'utilise comme support la carte arduino DUE R3 qui fonctionne en 3,3V. Voila le code que j'utilise :
question_collin

Mes principales questions porte surtout sur le code car je ne sais pas où trouver la bilbliothèque SerialConsole.h. Je n'ai pas un niveau élevé en programmation mais il semble que ce soit une bibliothèque que tu ai fais toi même. Sais-tu où puis-je la trouver et comment l'ajouter aux bibliothèques de la carte ?
De plus, je ne comprends pas comment faire fonctionner cette ligne : SerialSpecialInit(USART0, 612500).
Suis-je censé ajouter une bibliothèque ou bien rajouter autre chose ? Pour être honnête, je ne sais pas à quoi corespond non plus les fonctions que tu as écrites comme "BMSModuleManager.h" ou bien "Logger.h". Tu les a écris en JAVA mais la carte Arduino n'et programmable qu'en C++ il me semble, c'est pourquoi je me sens un peu perdu :(

De plus, voici le câblage effectué, j'ai suivi les instructions que tu avais donné.
schema_collin

Merci d'avance de ton aide précieuse. ;)

@collin80
Copy link
Owner

collin80 commented Jul 5, 2023

Well, of all the languages I can read, French is not one! ;) But, thankfully Google Translate exists. I believe you haven't properly downloaded all of the source code for TeslaBMS. The function "SerialSpecialInit" is found right in TeslaBMS.ino up near the top. The SerialConsole and other missing files are also right here in the repo so try downloading it all again. Lastly, make sure you have selected Arduino Due (Native Port) as the board you are compiling for. It's really easy to accidentally try to compile for a different board but this will not work.

@Nzo-Po1
Copy link

Nzo-Po1 commented Jul 6, 2023

Sorry @collin80, I forgot to translate ;) Indeed, I saw that I forgot to download all the libraries I need like due_can, wireEEprom ... So for now, the code compiles fine but I don't have the text in the serial monitor that I'm supposed to have ... Do you think you know why? I'll keep looking.
Anyway, thanks for your work, it helps me a lot 👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests