a62d5dd84 Add TSK_06 CRC validation for VW MQB (#234) ce723756f Fixed up sign on Driver Torque, added unit (#233) bd72c72be Added ProPilot HUD messages (#231) f308ca62e Subaru: added counter and checksum to brake msg d1f76d609 Add Motor_20 CRC support (#229) 6252718a9 Add STEER_ANGLE to all STEER_TORUQE_SENSOR messages (#228) c0b426126 Revert "add angle field in torque sensor message to all cars (#227)" bd82848c7 add angle field in torque sensor message to all cars (#227) 56f0259df Lexus CTH fix: brake pressed is on bit 5 like corolla and rav4 9b6ca31b2 fix: Replicate changes done on _honda_2017.dbc (#225) 1bd26d0a6 Added messages. Cleaned up endianness (#226) 44b9e74fa Revert "Toyota: add checksum to BRAKE_MODULE (#224)" 8b18c92e2 Toyota: add checksum to BRAKE_MODULE (#224) 2bab4d6d7 Add Honda-Bosch lane line detection signals. (#223) a1aa3b78f Cleanup of Nissan DBC (#218) c1f764828 reverting changes to Chrysler: speed message seems different from car to car 2de8e9e82 Chrysler: Speed msg is 5 bytes f4ac315ed Chrysler: add counter to 514 0fb62cf86 Toyota Blind Spot Monitor (TSS2-only?) (#219) git-subtree-dir: opendbc git-subtree-split: a62d5dd847c352be2daf28288f093f4c25a8308d
opendbc
The project to democratize access to the decoder ring of your car.
DBC file basics
A DBC file encodes, in a humanly readable way, the information needed to understand a vehicle's CAN bus traffic. A vehicle might have multiple CAN buses and every CAN bus is represented by its own dbc file. Wondering what's the DBC file format? Here and Here a couple of good overviews.
How to start reverse engineering cars
opendbc is integrated with cabana.
Use panda to connect your car to a computer.
How to use reverse engineered DBC
To create custom CAN simulations or send reverse engineered signals back to the car you can use CANdevStudio project.
DBC file preprocessor
DBC files for different models of the same brand have a lot of overlap. Therefore, we wrote a preprocessor to create DBC files from a brand DBC file and a model specific DBC file. The source DBC files can be found in the generator folder. After changing one of the files run the generator.py script to regenerate the output files. These output files will be placed in the root of the opendbc repository and are suffixed by _generated.
Good practices for contributing to opendbc
-
Comments: the best way to store comments is to add them directly to the DBC files. For example:
CM_ SG_ 490 LONG_ACCEL "wheel speed derivative, noisy and zero snapping";is a comment that refers to signal
LONG_ACCELin message490. Using comments is highly recommended, especially for doubts and uncertainties. cabana can easily display/add/edit comments to signals and messages. -
Units: when applicable, it's recommended to convert signals into physical units, by using a proper signal factor. Using a SI unit is preferred, unless a non-SI unit rounds the signal factor much better. For example:
SG_ VEHICLE_SPEED : 7|15@0+ (0.00278,0) [0|70] "m/s" PCMis better than:
SG_ VEHICLE_SPEED : 7|15@0+ (0.00620,0) [0|115] "mph" PCMHowever, the cleanest option is really:
SG_ VEHICLE_SPEED : 7|15@0+ (0.01,0) [0|250] "kph" PCM -
Signal size: always use the smallest amount of bits possible. For example, let's say I'm reverse engineering the gas pedal position and I've determined that it's in a 3 bytes message. For 0% pedal position I read a message value of
0x00 0x00 0x00, while for 100% of pedal position I read0x64 0x00 0x00: clearly, the gas pedal position is within the first byte of the message and I might be tempted to define the signalGAS_POSas:SG_ GAS_POS : 7|8@0+ (1,0) [0|100] "%" PCMHowever, I can't be sure that the very first bit of the message is referred to the pedal position: I haven't seen it changing! Therefore, a safer way of defining the signal is:
SG_ GAS_POS : 6|7@0+ (1,0) [0|100] "%" PCMwhich leaves the first bit unallocated. This prevents from very erroneous reading of the gas pedal position, in case the first bit is indeed used for something else.