-
Notifications
You must be signed in to change notification settings - Fork 91
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
Comments
Hi Pagode,
You shouldnt connect directly the boards to arduino due. Grab a 5v to 3.3v
level shifter, like 74ahc1g08.
Tell us your progress after that.
Good luck,
J
…On Mon 30 Oct 2017 at 10:36 Pagode ***@***.***> wrote:
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:
[image: reply]
<https://user-images.githubusercontent.com/33216693/32160508-55edf1c2-bd52-11e7-9d96-8587370158c2.JPG>
Wiring:
red = 5V (Pin 1)
green = Ground (Pin 3)
yellow = TX (Pin 2)
white = RX (Pin 9)
black = fault (Pin 6)
[image: anhang1]
<https://user-images.githubusercontent.com/33216693/32160475-3a78311e-bd52-11e7-95f1-d83e90e3ea03.jpg>
[image: anhang4]
<https://user-images.githubusercontent.com/33216693/32161399-acdc607e-bd55-11e7-854c-55299ae19391.jpg>
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub
<#5>, or mute the thread
<https://github.com/notifications/unsubscribe-auth/AREDHdpKoU7g_AEU-ra6mJVyoBdtTtVqks5sxYqDgaJpZM4QK1Ea>
.
|
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! |
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 ^^ |
Hi @jorakarandas thanks for your suggestion of the level shifter. Please can you read this and let me know if I've understood correctly: |
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. |
Thank you.
…On Thu, Aug 22, 2019 at 11:07 AM Collin Kidder ***@***.***> wrote:
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.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#5?email_source=notifications&email_token=AMIBEI2ON5TFNJWTDAN3D3DQFXDCDA5CNFSM4EBLKENKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOD43MJRA#issuecomment-523683012>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AMIBEIYBLEFT67CK2NAGYJLQFXDCDANCNFSM4EBLKENA>
.
--
Niall
NZ cell +64 221 275 438
|
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 -> 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. |
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. |
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. |
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. |
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. |
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. |
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? |
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. |
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. |
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. |
Alrighty, I made it work! Summary of what works for me on my 2016 BMS boards: Thanks Collin for writing and informally supporting this stuff. Thanks everyone else for their support. |
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 ;-) |
I reckon this can be marked as closed now? |
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. 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? |
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. |
@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 ;) |
@NiallDarwin appreciate it and thanks to the entire group... she is now talking! |
Bonjour @collin80 , 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, voici le câblage effectué, j'ai suivi les instructions que tu avais donné. Merci d'avance de ton aide précieuse. ;) |
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. |
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. |
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:
Wiring:
red = 5V (Pin 1)
green = Ground (Pin 3)
yellow = TX (Pin 2)
white = RX (Pin 9)
black = fault (Pin 6)
The text was updated successfully, but these errors were encountered: