Files
opendbc-meb/opendbc/dbc
infiniteCable2 09c217f287 Basic Safety Tests for Volkswagen MEB (#20)
* Create test_volkswagen_meb.py

* Update longitudinal.h add override safety checks

* Update volkswagen_meb.h cleanup and point to longitudinal.h checks

* Update lateral.h unused custom

* Update safety_declarations.h

* Update test_volkswagen_meb.py clean

* Update lateral.h

* Update safety_declarations.h

* Update volkswagen_meb.h

* Update volkswagen_meb.h

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update volkswagen_meb.h

* Update safety_declarations.h

* Update longitudinal.h

* Update safety_declarations.h

* Update longitudinal.h

* Update volkswagen_meb.h

* Update test_volkswagen_meb.py

* Update common.py adapted long accek safety test with overriding mechanism

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update common.py

* Update test_elm327.py adapt test to vw range

* Update routes.py

* Update volkswagen_pq.h cleanup unused

* Update test_volkswagen_pq.py adapt

* Update test_volkswagen_pq.py for now, MADS later if neccessary

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update safety_helpers.h

* Update test_volkswagen_meb.py

* Update longitudinal.h

* Update common.py

* Update safety_helpers.py

* Update test_volkswagen_meb.py

* Update longitudinal.h

* Update test_elm327.py

* Update common.py

* Update common.py

* Update test_volkswagen_pq.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update lateral.h

* Update volkswagen_meb.h

* Update volkswagen_meb.h

* Update safety_helpers.h

* Update safety_helpers.py

* Update safety_helpers.h

* Update safety_helpers.py

* Update safety_helpers.h

* Update common.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update test_volkswagen_meb.py

* Update safety_helpers.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update test_volkswagen_meb.py

* Update volkswagen_meb.h fix

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Revert "Update common.py"

This reverts commit eee29957ab.

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update lateral.py

* Update common.py

* Update common.py

* Update common.py test

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update common.py

* Update test_volkswagen_meb.py

* Update common.py

* Update common.py

* Update common.py

* Update lateral.py

* Update lateral.h

* Update safety_declarations.h

* Update lateral.h

* Update routes.py

* Update routes.py

* Create icbm.py

* Delete opendbc/sunnypilot/car/volkswagen/icbm.py wrong branch

* Update common.py vw diag range

* Update common.py fix

* Update common.py fix vw diag range

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py

* Update test_volkswagen_meb.py fixes

* Update test_volkswagen_meb.py

* Update common.py testing

* Update volkswagen_meb.h fix steer power range

* Update common.py

* Update volkswagen_pq.h

* Update test_volkswagen_pq.py

* Update volkswagen_meb.h

* Delete opendbc/car/volkswagen/pandacan.py

* Update carcontroller.py cleanup

* Update test_volkswagen_meb.py

* Update common.py

* Update vw_mqbevo.dbc

* Update vw_mqbevo.dbc

* Update test_volkswagen_pq.py

---------

Co-authored-by: infiniteCable <75014343+infiniteCable@users.noreply.github.com>
2025-10-28 20:29:40 +01:00
..
2024-07-31 22:46:43 -07:00
2024-07-31 22:46:43 -07:00
2024-07-31 22:46:43 -07:00
2024-07-31 22:46:43 -07:00
2024-07-31 22:46:43 -07:00
2024-08-17 12:42:16 -07:00
2024-07-31 22:46:43 -07:00
2025-10-26 14:06:03 +01:00

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_ACCEL in message 490. 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" PCM
    

    is better than:

    SG_ VEHICLE_SPEED : 7|15@0+ (0.00620,0) [0|115] "mph" PCM
    

    However, 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 read 0x64 0x00 0x00: clearly, the gas pedal position is within the first byte of the message and I might be tempted to define the signal GAS_POS as:

    SG_ GAS_POS : 7|8@0+ (1,0) [0|100] "%" PCM
    

    However, 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] "%" PCM
    

    which 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.