democratize access to car decoder rings
Go to file
grekiki 699dc63a88
Scons cython builder (#316)
* migrate to home pc

* style

* this works

* this is hacky

* why doesn't this work

* this should work

* no lint

* link against libdbc wtih abs path

* new env

Co-authored-by: Adeeb Shihadeh <adeebshihadeh@gmail.com>
2020-11-26 16:11:23 -08:00
.github/workflows remove redundant linter checks 2020-11-26 11:36:10 -08:00
can Scons cython builder (#316) 2020-11-26 16:11:23 -08:00
generator Lexus NX300 (#313) 2020-10-27 17:31:44 -07:00
site_scons/site_tools Scons cython builder (#316) 2020-11-26 16:11:23 -08:00
.gitignore Scons cython builder (#316) 2020-11-26 16:11:23 -08:00
.pre-commit-config.yaml Scons cython builder (#316) 2020-11-26 16:11:23 -08:00
Dockerfile Scons cython builder (#316) 2020-11-26 16:11:23 -08:00
ESR.dbc Add files via upload (#147) 2019-03-14 11:20:39 -07:00
README.md Add reference to CANdevStudio in README file 2020-01-16 10:18:43 -08:00
SConstruct Scons cython builder (#316) 2020-11-26 16:11:23 -08:00
__init__.py make opendbc import work, and ignore junk 2017-06-05 01:36:59 -07:00
acura_ilx_2016_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
acura_ilx_2016_nidec.dbc Honda Nidec: added wrong config radar value 2018-07-23 15:49:19 -07:00
acura_rdx_2018_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
acura_rdx_2020_can_generated.dbc Add 2020 Acura RDX (#290) 2020-10-11 13:26:23 -07:00
bmw_e9x_e8x.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
cadillac_ct6_chassis.dbc Cadillac: typo 2018-06-12 23:21:17 -07:00
cadillac_ct6_object.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
cadillac_ct6_powertrain.dbc Remove non ascii characters 2019-09-20 16:17:21 -07:00
chrysler_pacifica_2017_hybrid.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
chrysler_pacifica_2017_hybrid_private_fusion.dbc change chrysler radar to all big endian to avoid OP can parser bug (#141) 2019-02-27 15:42:28 -08:00
ford_cgea1_2_bodycan_2011.dbc Fix manually created dbc files (#154) 2019-04-04 09:48:16 -07:00
ford_cgea1_2_ptcan_2011.dbc Fix manually created dbc files (#154) 2019-04-04 09:48:16 -07:00
ford_fusion_2018_adas.dbc Fix manually created dbc files (#154) 2019-04-04 09:48:16 -07:00
ford_fusion_2018_pt.dbc Fix manually created dbc files (#154) 2019-04-04 09:48:16 -07:00
ford_lincoln_base_pt.dbc Ford: Add new base DBC. (#287) 2020-09-08 15:24:49 -07:00
gm_global_a_chassis.dbc GM: typo 2018-06-12 23:18:46 -07:00
gm_global_a_high_voltage_management.dbc Fixed up cell voltage readings and added more commands (#220) 2020-05-26 22:36:56 -07:00
gm_global_a_lowspeed.dbc Volt: switch to parsing ACC buttons from powertrain CAN (#74) 2018-02-20 14:56:00 -08:00
gm_global_a_lowspeed_1818125.dbc Update gm_global_a_lowspeed_1818125.dbc (#34) 2017-10-09 21:07:55 -07:00
gm_global_a_object.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
gm_global_a_powertrain.dbc Fix GM message signal sizes 2020-05-08 22:06:51 -07:00
gm_global_a_powertrain_expansion.dbc Fixed up cell voltage readings and added more commands (#220) 2020-05-26 22:36:56 -07:00
honda_accord_lx15t_2018_can_generated.dbc Rename BYTE_ to SET_ME_X (#253) 2020-04-29 13:51:10 -07:00
honda_accord_s2t_2018_can_generated.dbc Rename BYTE_ to SET_ME_X (#253) 2020-04-29 13:51:10 -07:00
honda_accord_touring_2016_can.dbc Fixes and new message for VW MQB, fix for Accord Touring (#193) 2019-10-17 09:02:23 -07:00
honda_civic_hatchback_ex_2017_can_generated.dbc CIVIC_BOSCH needs an empty nidec brake command frame for long control. (#246) 2020-10-05 11:36:40 +02:00
honda_civic_sedan_16_diesel_2019_can_generated.dbc CIVIC_BOSCH needs an empty nidec brake command frame for long control. (#246) 2020-10-05 11:36:40 +02:00
honda_civic_touring_2016_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
honda_clarity_hybrid_2018_can_generated.dbc Use generator for Honda Clarity DBC (#289) 2020-07-23 21:16:14 -07:00
honda_crv_ex_2017_body_generated.dbc Honda BSM body (#286) 2020-07-21 13:46:54 +02:00
honda_crv_ex_2017_can_generated.dbc Rename BYTE_ to SET_ME_X (#253) 2020-04-29 13:51:10 -07:00
honda_crv_executive_2016_can_generated.dbc Adds 2016 Honda CR-V Executive 2020-01-16 10:18:31 -08:00
honda_crv_hybrid_2019_can_generated.dbc Rename BYTE_ to SET_ME_X (#253) 2020-04-29 13:51:10 -07:00
honda_crv_touring_2016_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
honda_fit_ex_2018_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
honda_fit_hybrid_2018_can_generated.dbc fix: Replicate changes done on _honda_2017.dbc (#225) 2020-03-04 10:37:31 -08:00
honda_hrv_touring_2019_can_generated.dbc HRV correct GAS_PEDAL (#266) 2020-06-01 15:26:20 -07:00
honda_insight_ex_2019_can_generated.dbc Rename BYTE_ to SET_ME_X (#253) 2020-04-29 13:51:10 -07:00
honda_odyssey_exl_2018_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
honda_odyssey_extreme_edition_2018_china_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
honda_pilot_touring_2017_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
honda_ridgeline_black_edition_2017_can_generated.dbc Fix honda dbc files after steer torque addition 2019-12-20 11:25:39 -08:00
hyundai_2015_ccan.dbc Remove non ascii characters 2019-09-20 16:17:21 -07:00
hyundai_2015_mcan.dbc add hyundai 2015 (#63) 2017-12-28 11:28:20 -08:00
hyundai_i30_2014.dbc add hyundai_i30_2014.dbc 2017-09-10 00:59:29 -07:00
hyundai_kia_generic.dbc Update hyundai_kia_generic.dbc (#284) 2020-08-02 15:03:11 -07:00
lexus_ct200h_2018_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
lexus_gs300h_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
lexus_is_2018_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
lexus_nx300_2018_pt_generated.dbc Lexus NX300 (#313) 2020-10-27 17:31:44 -07:00
lexus_nx300h_2018_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
lexus_rx_350_2016_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
lexus_rx_hybrid_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
luxgen_s5_2015.dbc fixed to luxgen dbc file 2019-10-16 14:43:59 -07:00
mazda_3_2019.dbc Introduce the new mazda 3 2019/2020 dbc 2020-03-28 12:14:34 -07:00
mazda_2017.dbc Mazda: add missing static bits, tidy up endianness (#263) 2020-05-26 21:58:10 -07:00
mercedes_benz_e350_2010.dbc Update mercedes e350 dbc (#112) 2018-09-17 07:12:03 +02:00
nissan_leaf_2018.dbc Fix wrong message sizes in Nissan 2020-05-08 20:54:26 -07:00
nissan_x_trail_2017.dbc Update X-trail HUD message name, added SPEED_MPH signal (#269) 2020-06-01 14:37:53 -07:00
requirements.txt fix pycapnp 2020-10-29 13:04:23 -07:00
subaru_forester_2017_generated.dbc Subaru preglobal DBC update (#270) 2020-06-11 14:21:26 -07:00
subaru_global_2017_generated.dbc Subaru DBC update (#277) 2020-07-23 11:44:14 -07:00
subaru_global_2020_hybrid_generated.dbc Subaru DBC update (#277) 2020-07-23 11:44:14 -07:00
subaru_outback_2015_generated.dbc Subaru preglobal DBC update (#270) 2020-06-11 14:21:26 -07:00
subaru_outback_2019_generated.dbc Subaru Outback 2019 (#278) 2020-06-29 10:22:08 -07:00
tesla_can.dbc Fix manually created dbc files (#154) 2019-04-04 09:48:16 -07:00
tesla_radar.dbc DBC for the Bosch Radar for Tesla (#158) 2019-05-02 08:14:44 -07:00
toyota_2017_ref_pt.dbc Remove non ascii characters 2019-09-20 16:17:21 -07:00
toyota_adas.dbc Toyota: better name for adas bdc files 2019-06-10 10:33:49 -07:00
toyota_avalon_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_camry_hybrid_2018_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_corolla_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_highlander_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_highlander_hybrid_2018_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_iQ_2009_can.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_nodsu_hybrid_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_nodsu_pt_generated.dbc Lexus NX300 (#313) 2020-10-27 17:31:44 -07:00
toyota_prius_2010_pt.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_prius_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_rav4_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_rav4_hybrid_2017_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_sienna_xle_2018_pt_generated.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -07:00
toyota_tss2_adas.dbc Toyota: better name for adas bdc files 2019-06-10 10:33:49 -07:00
volvo_v40_2017_pt.dbc Volvo DBC files for C1MCA and EUCD platform (#291) 2020-09-29 12:00:26 -07:00
volvo_v60_2015_pt.dbc Volvo DBC files for C1MCA and EUCD platform (#291) 2020-09-29 12:00:26 -07:00
vw_golf_mk4.dbc Updates for Volkswagen support (#191) 2019-10-10 14:24:22 -07:00
vw_mqb_2010.dbc Add SWA_01 message detail and CRC support for VW MQB (#236) 2020-04-02 12:23:05 -07:00

README.md

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