openpilot is an open source driver assistance system. openpilot performs the functions of Automated Lane Centering and Adaptive Cruise Control for over 200 supported car makes and models.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Vehicle Researcher d64fb1838d openpilot v0.9.7 release 11 months ago
..
can openpilot v0.9.7 release 11 months ago
site_scons/site_tools openpilot v0.9.7 release 11 months ago
.gitignore openpilot v0.9.4 release 2 years ago
FORD_CADS.dbc openpilot v0.9.4 release 2 years ago
README.md openpilot v0.9.7 release 11 months ago
SConstruct openpilot v0.9.7 release 11 months ago
__init__.py openpilot v0.9.4 release 2 years ago
acura_ilx_2016_can_generated.dbc openpilot v0.9.7 release 11 months ago
acura_ilx_2016_nidec.dbc openpilot v0.9.4 release 2 years ago
acura_rdx_2018_can_generated.dbc openpilot v0.9.7 release 11 months ago
acura_rdx_2020_can_generated.dbc openpilot v0.9.4 release 2 years ago
chrysler_pacifica_2017_hybrid_generated.dbc openpilot v0.9.6 release 1 year ago
chrysler_pacifica_2017_hybrid_private_fusion.dbc openpilot v0.9.4 release 2 years ago
chrysler_ram_dt_generated.dbc openpilot v0.9.6 release 1 year ago
chrysler_ram_hd_generated.dbc openpilot v0.9.6 release 1 year ago
comma_body.dbc openpilot v0.9.4 release 2 years ago
ford_fusion_2018_adas.dbc openpilot v0.9.4 release 2 years ago
ford_lincoln_base_pt.dbc openpilot v0.9.7 release 11 months ago
gm_global_a_chassis.dbc openpilot v0.9.4 release 2 years ago
gm_global_a_object.dbc openpilot v0.9.4 release 2 years ago
gm_global_a_powertrain_generated.dbc openpilot v0.9.7 release 11 months ago
honda_accord_2018_can_generated.dbc openpilot v0.9.4 release 2 years ago
honda_civic_ex_2022_can_generated.dbc openpilot v0.9.7 release 11 months ago
honda_civic_hatchback_ex_2017_can_generated.dbc openpilot v0.9.4 release 2 years ago
honda_civic_touring_2016_can_generated.dbc openpilot v0.9.7 release 11 months ago
honda_crv_ex_2017_body_generated.dbc openpilot v0.9.4 release 2 years ago
honda_crv_ex_2017_can_generated.dbc openpilot v0.9.4 release 2 years ago
honda_crv_executive_2016_can_generated.dbc openpilot v0.9.7 release 11 months ago
honda_crv_touring_2016_can_generated.dbc openpilot v0.9.7 release 11 months ago
honda_fit_ex_2018_can_generated.dbc openpilot v0.9.7 release 11 months ago
honda_insight_ex_2019_can_generated.dbc openpilot v0.9.4 release 2 years ago
honda_odyssey_exl_2018_generated.dbc openpilot v0.9.7 release 11 months ago
honda_odyssey_extreme_edition_2018_china_can_generated.dbc openpilot v0.9.7 release 11 months ago
hyundai_canfd.dbc openpilot v0.9.7 release 11 months ago
hyundai_kia_generic.dbc openpilot v0.9.6 release 1 year ago
hyundai_kia_mando_front_radar_generated.dbc openpilot v0.9.4 release 2 years ago
mazda_2017.dbc openpilot v0.9.5 release 1 year ago
nissan_leaf_2018_generated.dbc openpilot v0.9.4 release 2 years ago
nissan_x_trail_2017_generated.dbc openpilot v0.9.4 release 2 years ago
pyproject.toml openpilot v0.9.7 release 11 months ago
requirements.txt openpilot v0.9.7 release 11 months ago
subaru_forester_2017_generated.dbc openpilot v0.9.5 release 1 year ago
subaru_global_2017_generated.dbc openpilot v0.9.6 release 1 year ago
subaru_global_2020_hybrid_generated.dbc openpilot v0.9.6 release 1 year ago
subaru_outback_2015_generated.dbc openpilot v0.9.5 release 1 year ago
subaru_outback_2019_generated.dbc openpilot v0.9.5 release 1 year ago
tesla_can.dbc openpilot v0.9.7 release 11 months ago
tesla_powertrain.dbc openpilot v0.9.4 release 2 years ago
tesla_radar_bosch_generated.dbc openpilot v0.9.7 release 11 months ago
tesla_radar_continental_generated.dbc openpilot v0.9.7 release 11 months ago
toyota_adas.dbc openpilot v0.9.4 release 2 years ago
toyota_new_mc_pt_generated.dbc openpilot v0.9.7 release 11 months ago
toyota_nodsu_pt_generated.dbc openpilot v0.9.7 release 11 months ago
toyota_tnga_k_pt_generated.dbc openpilot v0.9.7 release 11 months ago
toyota_tss2_adas.dbc openpilot v0.9.4 release 2 years ago
vw_golf_mk4.dbc openpilot v0.9.6 release 1 year ago
vw_mqb_2010.dbc openpilot v0.9.7 release 11 months ago

README.md

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.