democratize access to car decoder rings
Go to file
Shane Smiskol 15e4ae8d48
Toyota: add auto high beam message from camera (#878)
* add msg

* rename

* generate
2023-07-05 19:28:14 -07:00
.github/workflows bump to python 3.11.4 (#865) 2023-06-30 17:35:57 -07:00
can CANParser: check if signals exist (#870) 2023-07-01 02:04:33 -07:00
generator Toyota: add auto high beam message from camera (#878) 2023-07-05 19:28:14 -07:00
site_scons/site_tools
.gitignore libdbc: build both static and shared library (#786) 2023-03-27 16:01:39 -07:00
.pre-commit-config.yaml pre-commit: autoupdate hooks (#866) 2023-06-30 17:34:53 -07:00
Dockerfile bump to python 3.11.4 (#865) 2023-06-30 17:35:57 -07:00
ESR.dbc
FORD_CADS.dbc
LICENSE
README.md
SConstruct add cpplint (#773) 2022-12-31 16:49:26 -08:00
__init__.py
acura_ilx_2016_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
acura_ilx_2016_nidec.dbc
acura_rdx_2018_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
acura_rdx_2020_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
bmw_e9x_e8x.dbc BMW dbc improvements (#831) 2023-05-27 16:35:34 -07:00
cadillac_ct6_chassis.dbc
cadillac_ct6_object.dbc
cadillac_ct6_powertrain.dbc
chrysler_pacifica_2017_hybrid_generated.dbc Chrysler: add temporary EPS fault bit (#781) 2023-02-10 15:22:58 -08:00
chrysler_pacifica_2017_hybrid_private_fusion.dbc
chrysler_ram_dt_generated.dbc Chrysler: add temporary EPS fault bit (#781) 2023-02-10 15:22:58 -08:00
chrysler_ram_hd_generated.dbc Chrysler: add temporary EPS fault bit (#781) 2023-02-10 15:22:58 -08:00
comma_body.dbc
ford_cgea1_2_bodycan_2011.dbc
ford_cgea1_2_ptcan_2011.dbc
ford_fusion_2018_adas.dbc
ford_fusion_2018_pt.dbc
ford_lincoln_base_pt.dbc Ford: rename TrnRng_D_RqGsm Sport value (#778) 2023-02-02 20:05:52 -08:00
gm_global_a_chassis.dbc
gm_global_a_high_voltage_management.dbc
gm_global_a_lowspeed.dbc
gm_global_a_lowspeed_1818125.dbc
gm_global_a_object.dbc
gm_global_a_powertrain_expansion.dbc
gm_global_a_powertrain_generated.dbc GM: Add single pedal mode signals for Bolt EV/EUV (#789) 2023-03-26 17:14:30 -07:00
honda_accord_2018_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_civic_ex_2022_can_generated.dbc Honda: add alt gears for Thai HR-V hybrid (#814) 2023-05-25 23:28:32 -07:00
honda_civic_hatchback_ex_2017_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_civic_touring_2016_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_clarity_hybrid_2018_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_crv_ex_2017_body_generated.dbc
honda_crv_ex_2017_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_crv_executive_2016_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_crv_touring_2016_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_fit_ex_2018_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_fit_hybrid_2018_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_insight_ex_2019_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_odyssey_exl_2018_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
honda_odyssey_extreme_edition_2018_china_can_generated.dbc remove duplicate signal names from Honda DBCs (#822) 2023-04-17 09:56:43 -07:00
hyundai_2015_ccan.dbc hyundai_2015_ccan.dbc: fix signal scale (#732) 2023-03-28 00:34:17 -07:00
hyundai_2015_mcan.dbc
hyundai_canfd.dbc hyundai_canfd: fix signal range 2023-06-02 15:22:08 -07:00
hyundai_i30_2014.dbc
hyundai_kia_generic.dbc Add ISG state to HK generic (#860) 2023-06-30 22:41:29 -07:00
hyundai_kia_mando_corner_radar_generated.dbc
hyundai_kia_mando_front_radar_generated.dbc
luxgen_s5_2015.dbc
mazda_3_2019.dbc
mazda_2017.dbc Mazda: update BSM signals and add comments (#815) 2023-06-15 20:15:54 -07:00
mazda_radar.dbc
mazda_rx8.dbc Mazda: add RX-8 (#849) 2023-06-09 13:52:35 -07:00
mercedes_benz_e350_2010.dbc
nissan_leaf_2018_generated.dbc Nissan: common DBC (#841) 2023-05-27 22:25:33 -07:00
nissan_x_trail_2017_generated.dbc Nissan: common DBC (#841) 2023-05-27 22:25:33 -07:00
nissan_xterra_2011.dbc More on Nissan (#746) 2023-03-27 16:19:03 -07:00
pyproject.toml add poetry pyproject required fields 2023-06-18 16:06:42 +01:00
requirements.txt bump to python 3.11.4 (#865) 2023-06-30 17:35:57 -07:00
subaru_forester_2017_generated.dbc
subaru_global_2017_generated.dbc Subaru: Signals Cleanup (#862) 2023-06-23 21:05:02 +01:00
subaru_global_2020_hybrid_generated.dbc Subaru: add AEB related signals (#858) 2023-06-16 16:25:57 -07:00
subaru_outback_2015_generated.dbc
subaru_outback_2019_generated.dbc
tesla_can.dbc
tesla_powertrain.dbc
tesla_radar.dbc
toyota_2017_ref_pt.dbc
toyota_adas.dbc
toyota_iQ_2009_can.dbc
toyota_new_mc_pt_generated.dbc Toyota: add auto high beam message from camera (#878) 2023-07-05 19:28:14 -07:00
toyota_nodsu_pt_generated.dbc Toyota: add auto high beam message from camera (#878) 2023-07-05 19:28:14 -07:00
toyota_prius_2010_pt.dbc
toyota_radar_dsu_tssp.dbc
toyota_tnga_k_pt_generated.dbc Toyota: add auto high beam message from camera (#878) 2023-07-05 19:28:14 -07:00
toyota_tss2_adas.dbc
volvo_v40_2017_pt.dbc
volvo_v60_2015_pt.dbc
vw_golf_mk4.dbc VW PQ: EPB_1 sort and VAL table (#838) 2023-05-27 19:12:17 -07:00
vw_mqb_2010.dbc VW MQB: Cleanup HCA control message (#805) 2023-04-15 11:17:46 -07:00

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.