democratize access to car decoder rings
Go to file
Justin Newberry 5f096db742
scons: export opendbc_python (#1015)
export
2024-02-28 11:18:08 -08:00
.github/workflows CI: enable docker cache pull (#1011) 2024-02-22 22:47:05 -08:00
can scons: export opendbc_python (#1015) 2024-02-28 11:18:08 -08:00
generator honda: add missing semicolon (#1014) 2024-02-26 10:44:43 -08:00
site_scons/site_tools cython dependency scanner 2021-01-11 14:16:02 -08:00
.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 (#997) 2024-02-21 09:02:13 -08:00
Dockerfile bump cereal (#1012) 2024-02-24 01:29:02 -08:00
ESR.dbc Add files via upload (#147) 2019-03-14 11:20:39 -07:00
FORD_CADS.dbc Create FORD_CADS.dbc (#351) 2021-03-12 13:23:32 -08:00
LICENSE add license 2021-04-30 14:25:37 -07:00
README.md update README link to cabana 2022-11-21 00:08:22 -08:00
SConstruct update build flag 2023-08-24 14:04:09 -07:00
__init__.py make opendbc import work, and ignore junk 2017-06-05 01:36:59 -07:00
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 Honda Nidec: added wrong config radar value 2018-07-23 15:49:19 -07:00
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: 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 GM: fix set speed scaling (#679) 2022-08-12 18:29:30 -07:00
chrysler_pacifica_2017_hybrid_generated.dbc chrysler: more signals (#1001) 2024-01-20 21:54:48 -08: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
chrysler_ram_dt_generated.dbc chrysler: more signals (#1001) 2024-01-20 21:54:48 -08:00
chrysler_ram_hd_generated.dbc chrysler: more signals (#1001) 2024-01-20 21:54:48 -08:00
comma_body.dbc body: add knee and few other messages (#674) 2022-07-26 14:03:29 -07: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 METRIC_UNITS signal (#1010) 2024-02-24 01:30:19 -08:00
gm_global_a_chassis.dbc GM: typo 2018-06-12 23:18:46 -07:00
gm_global_a_high_voltage_management.dbc Updated Chevrolet Volt HV management messages (#345) 2021-06-23 14:04:30 -07:00
gm_global_a_lowspeed.dbc Update gm_global_a_lowspeed.dbc to include BOLT EUV Blindspot indicator (#962) 2023-11-02 14:11:35 -07:00
gm_global_a_lowspeed_1818125.dbc Fix non-standard units in GM global A lowspeed (#327) 2020-12-19 15:45:56 -08:00
gm_global_a_object.dbc Fix all typos in opendbc (#299) 2020-09-29 11:59:26 -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
gm_global_a_powertrain_generated.dbc GM: Add sport mode status (#1009) 2024-02-24 01:34:11 -08: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 honda_civic_touring_2016_can_generated.dbc: remove `CM_ SG_ 450` (#982) 2023-12-03 19:35:03 -08: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 Fix comments syntax (#324) 2020-12-03 13:35:07 -08:00
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
honda_pilot_2023_can_generated.dbc honda: add missing semicolon (#1014) 2024-02-26 10:44:43 -08: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 add hyundai 2015 (#63) 2017-12-28 11:28:20 -08:00
hyundai_canfd.dbc Hyundai CAN FD: add Manual Speed Limit Assist message (#950) 2023-09-11 20:20:16 -07:00
hyundai_i30_2014.dbc add hyundai_i30_2014.dbc 2017-09-10 00:59:29 -07:00
hyundai_kia_generic.dbc hyundai_kia_generic: sign detection (#963) 2023-12-03 19:37:52 -08:00
hyundai_kia_mando_corner_radar_generated.dbc Hyundai corner radar DBC (#712) 2022-10-11 16:04:19 -07:00
hyundai_kia_mando_front_radar_generated.dbc setup generator for hyundai radar dbc (#710) 2022-09-21 21:40:31 -07:00
hyundai_santafe_2007.dbc Hyundai SantaFe CM and Opel Omega B databases added (#910) 2023-08-04 23:39:43 -07:00
luxgen_s5_2015.dbc DBCs: fix duplicate messages (#603) 2022-05-06 22:52:00 -07:00
mazda_3_2019.dbc Mazda 3: Add gear values to be processed by OP (#492) 2022-01-13 22:40:27 -08:00
mazda_2017.dbc Mazda updates (#816) 2023-09-08 13:40:58 -07:00
mazda_radar.dbc mazda_radar: fix track msg names and remove unrelated radar msgs (#599) 2022-04-29 11:47:19 -07:00
mazda_rx8.dbc Mazda: add RX-8 (#849) 2023-06-09 13:52:35 -07:00
mercedes_benz_e350_2010.dbc Update mercedes e350 dbc (#112) 2018-09-17 07:12:03 +02:00
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
opel_omega_2001.dbc Hyundai SantaFe CM and Opel Omega B databases added (#910) 2023-08-04 23:39:43 -07:00
pyproject.toml Ruff: propogate config from OP (#916) 2023-08-14 12:52:47 -07:00
requirements.txt CI: Pylint to ruff (#911) 2023-08-07 15:26:46 -07:00
subaru_forester_2017_generated.dbc Subaru: preglobal normalize signals to global (#929) 2023-08-29 10:08:58 -07:00
subaru_global_2017_generated.dbc Subaru: cruise_rpm and cruise_throttle are 13 bits (#995) 2023-12-29 19:14:18 -05:00
subaru_global_2020_hybrid_generated.dbc Subaru: cruise_rpm and cruise_throttle are 13 bits (#995) 2023-12-29 19:14:18 -05:00
subaru_outback_2015_generated.dbc Subaru: preglobal normalize signals to global (#929) 2023-08-29 10:08:58 -07:00
subaru_outback_2019_generated.dbc Subaru: preglobal normalize signals to global (#929) 2023-08-29 10:08:58 -07:00
tesla_can.dbc DBC changes for Tesla Raven support (#994) 2024-02-23 22:01:30 +01:00
tesla_powertrain.dbc powertrain DBC (#432) 2021-10-09 14:05:30 +02: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_iQ_2009_can.dbc remove CHFFR_METRIC comments 2021-11-20 20:51:58 -08:00
toyota_new_mc_pt_generated.dbc Toyota: LVSTP definition (#1002) 2024-02-24 01:29:54 -08:00
toyota_nodsu_pt_generated.dbc Toyota: LVSTP definition (#1002) 2024-02-24 01:29:54 -08:00
toyota_prius_2010_pt.dbc remove CHFFR_METRIC comments 2021-11-20 20:51:58 -08:00
toyota_radar_dsu_tssp.dbc Toyota: radar dsu tss-p radar support, aka nodsu (#707) 2022-10-17 21:27:50 -07:00
toyota_tnga_k_pt_generated.dbc Toyota: LVSTP definition (#1002) 2024-02-24 01:29:54 -08: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 DBCs: fix duplicate messages (#603) 2022-05-06 22:52:00 -07:00
volvo_v60_2015_pt.dbc Volvo: Turn signal and brakepress signal update for v40 and byte order asthetic fix for v40/v60. (#459) 2021-10-31 15:06:49 -07:00
vw_golf_mk4.dbc VAG focusing on TCU (#947) 2024-02-09 16:08:34 -08: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.