[Ovmsdev] Volt/Ampera CAN bus - what is known

Mark Webb-Johnson mark at webb-johnson.net
Tue May 29 12:54:21 HKT 2012

Best reference I could find for CAN messages on the Volt/Ampera:




Original reference link was from dpeillow. Thanks.

I've written to the guy (RScott) to see if he can help out.

From what's written in this document, we can get easily SOC, speed, and gps position. And, that is a fantastic start. Michael (in Germany) has started work on this, and his Ampera logs look good.

Michael: can we discuss here, on the ovmsdev mailing list, so others know what is going on?

Regards, Mark.

EVtools.info - Chevy Volt OBD2 CAN Data


The Chevy Volt produces an amazing amount of information, that can be obtained with an inexpensive (~$30) OBD2 connector. While OBD2 is typically used to troubleshoot problems by requesting data from the car, the Volt produces a constant stream of data. This includes speed, battery charge, accelerator/brake position, shifter (PRNDL), and latitude/longitude.

About OBD2/CAN

OBD2 is a protocol that most cars built since 1996 include. It provides a way for tools to find out why the 'Check Engine' light is on, as well as a way of requesting data for troubleshooting. In some cars, like the Volt, it acts like a local area network, where parts of the car communicate with each other. CAN is simply one of many formats that can be used for transferring data.

OBD2 usage in the Volt

The Volt has 2 connectors (the standard one on the drivers' side, and an extra auxillary one on the passengers' side), with a total of 5 buses:
OBD2 Location	Pins	OBD2 Protocol	Data Protocol	Speed	CAN ID length	Use
Primary Data Link Connector	1	SAE J2411 (SWCAN)	Low Speed GMLAN	33.3kbps	???	Body Electrical Services
Primary Data Link Connector	6, 14	Standard CAN (ISO 15765-4, J2284-3)	High Speed GMLAN	500kbps	11 bits	Primary Powertrain Bus
Primary Data Link Connector	12, 13	???	High Speed GMLAN	500kbps	???	Chassis Expansion Bus
Auxillary Data Connector	3, 11	???	High Speed GMLAN	500kbps	???	High Volt Energy Management
Auxillary Data Connector	12, 13	???	High Speed GMLAN	500kbps	???	High Volt Powertrain Expansion Bus
The Primary Powertrain Bus is easily accessible via inexpensive tools. It has been said that all data is gatewayed to the primary DLC, and that the right-hand side was is really only useful for service programming of specific modules.

What Tools Can I Use?

There are many different OBD2 tools that you can use, depending on what you are looking to do. Just about any should be able to read trouble codes (if the 'check engine' light comes on). If you are looking to get data from the car, there are several known options:
DashDaq - The DashDaq is one of the best ways to display Volt data in real-time, where it is visible while driving. The drawback is that it is pricy, with an MSRP of $790 with the Volt license. It can record data onto memory card, but it is unclear if it has a 'Monitor All' mode that can record all data from the Volt, rather than just what is requested.

ElmScan 5 - A cable that connects a laptop to the OBD2 port. It includes software, or custom software can be written for it. To use the 'Monitor All' mode, software needs to send a special command to the ELM327 chipset. MSRP is $39.95.

Generic ELM327 Cables - The ELM327 chip is commonly used for cables like the ElmScan 5. Most OBD2 software should be able to work with any cable using the ELM327 chip, except that the 'Monitor All' mode requires the ability to switch to 500kbps. As a warning, there are known counterfeits out there, that do not use the real ELM chips.

ScanGauge - This has an LCD display (2 lines of 10 characters each) that can display information. Very useful to see data in real-time, but it does not look like it can record data (or take advantage of 'Monitor All'). Prices start at $99.95.

MDI, GM-TIS, GDS - MDI (Multiple Diagnostic Interface), GDS (GM's Global Diagnostic System software), GM-TIS. These are various names/components for the official GM tools for accessing the data. It falls into the "If you have to ask, you cannot afford it" pricing category (one source quotes $1,500/year just for the service information).

There are likely other products that would work, but the above are known to work with the Chevy Volt.

Primary Powertrain Bus - List of CAN IDs

The Primary Powertrain Bus -- the one that is easily accessible using many OBD2 tools -- uses CAN 11-bit IDs (which can, in theory, range from 0x000 to 0x7FF, or 0 to 2047). In reality, it appears that there are 105 of them:
096 097 098 0AA 0B1 0B9 0BA 0BB   0BC 0BD 0C1 0C5 0C7 0C9 0D1 0D3
0F1 120 12A 130 135 137 139 140   148 160 17D 182 185 186 1A1 1A3
1C3 1C4 1C5 1C6 1DF 1E1 1E5 1E9   1EB 1ED 1EF 1F1 1F3 1F4 1F5 1FB
200 202 204 206 214 222 224 226   228 230 236 238 287 2C3 2C7 2F1
2F9 32A 348 34A 3C1 3C9 3CB 3D1   3DC 3DD 3E3 3E9 3ED 3F1 3F9 3FB
3FC 451 4C1 4C5 4C7 4C9 4CB 4D1   4D7 4D9 4E1 4E9 4F1 500 514 52A
530 589 770 772 773 778 77D 77F   787 
Primary Powertrain Bus - Known Data

CAN ID	Location	Data	Units	Notes
0C9	Byte 5	Accelerator	0 (0%) to 254 (100%)	 
0F1	Byte 2	Brake	0 (0%) to Unknown (254?)	Typical pressure on brake pedal generates about 30.
135	Byte 1	Drive Position	0=Park, 1=Neutral, 2=Drive/L, 3=Reverse	 
1A1	Byte 8	Accelerator	0 (0%) to 254 (100%)	 
1C3	Byte 8	Accelerator	0 (0%) to 254 (100%)	 
1EF	Bytes 3-4	Gas Engine RPM	RPM	 
1F5	Byte 4	Shift Position	PRNDL	1=Park, 2=Reverse, N=Neutral, D=Drive, L=Low
206	Bytes 1-2	Battery SOC	.250kWh	Units possibly .244kWh
32A	Bytes 1-4	GPS Latitude	Milliarcseconds	 
32A	Bytes 5-8	GPS Longitude	Milliarcseconds	 
3E9	Bytes 1-2	Speed	1/100 MPH	55MPH would be 5500 (0x157c)
Data Analysis: Chevy Volt 0 to 60 MPH in 8.53 seconds

One of the numbers that people look at for performance cars is the "0 to 60MPH" number (or the closely related "0 to 100KPH" number).
I was able to accelerate from 0 to 60MPH (although not in perfect conditions, as I started at a slight angle), taking 8.53 seconds. That was in Sports mode and L. The 0 to 30MPH time was 3.45s (which perhaps was a bit high due to the slight angle I started at).

The calculation assumes several things, such as the data I have actually being 1/100MPH units (but it could be offset a bit from reality, as I believe the Volt speedometer reads a couple percent above the true speed). I started the time from the last 0.00MPH reading (which, interestingly, occurs after the accelerator reaches 100%), and end when I hit 60.19MPH (the previous reading was 59.07). It was .468s from the last 0% reading on the accelerator until the car showed >0.0MPH, which would make the 0-60 time 9.0 seconds, if you calculated that way.

This was done by an amateur, on the open road, giving safety priority, and wasn't under ideal conditions (specifically, starting at a slight angle, and not perfectly flat). However, it proves that the 8.5s figure that is sometimes quoted seems quite accurate. And when Edmunds tested it at 9.2s, and Consumer Reports at 9.4s, it is likely that they were not using the Sports mode.

See below for the analysis of the cost of a jackrabbit start.

For the curious, here is most/all of the data that I used (from a file with 188,606 lines in it, as this was part of a longer trip):

11:48:45.829: 206 639600
11:48:45.954: 1A1 00004100000000
11:48:46.110: 1A1 00004100000008   [Accelerator at ~3%]
11:48:46.313: 1A1 000041000000FE   [Accelerator at 100%]
11:48:46.422: 3E9 000000FF004E00FB
11:48:46.516: 3E9 00A30100004000FB
11:48:49.636: 3E9 0BAC01AC0B3C019E [Speed 29.88MPH]
11:48:49.870: 3E9 0C3B01C20BED01B4 [Speed 31.31MPH]
11:48:49.885: 206 628600
11:48:54.955: 206 5FCA00
11:48:54.955: 3E9 1783051017350509 [Speed 60.19MPH]
The information on the right side are my notes. The CAN ID 206 is the battery SOC, the last 2 numbers of CAN ID 1A1 are the accelerator position, and the first 4 numbers in the CAN ID 3E9 are the speed in 1/100 MPH.

Data Analysis: Cost of a Jackrabbit Start

Since this is the Volt, I should address energy efficiency of the 0 to 60MPH test, which is the ultimate in jackrabbit starts. For 0-30MPH, it used 0.068kWh of electricity, and for 0-60MPH it used .243kWh of electricity. So it takes 2.5x as much energy to get from 30-60MPH as it does from 0-30MPH. Again, there could be unknown factors here -- it could be, for example, that there is a lag between the time the energy is removed and it is recorded (e.g. if the car reports a number now that is 100ms old).
As a comparison, on a similar drive at that location, 0 to 51.5MPH was achieved (at slower acceleration, with the accelerator down an average of less than 20%, versus 100% for the 0 to 60 number) using .254kWh, driving about 1/2 mile. The 0 to 52.5MPH time during the 0-60MPH test was done with just .182kWh, but only going about 200 feet. Adding in the EPA's 37kWh/100 miles, that would be an extra 0.185kWh added to the jackrabbit start, or 0.367kWh to go 1/2 mile versus .254, or a waste of about .1kWh.

For those wondering why I had to add those extra .185kWh, it's because with the jackrabbit start you hit the top speed after traveling less distance. So to properly compare the slow start with the fast start, you need to add in the energy that would be used to travel that extra distance.

(C) Copyright 2011 EVtools.info

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.openvehicles.com/pipermail/ovmsdev/attachments/20120529/e4884b81/attachment.htm>

More information about the OvmsDev mailing list