The first step in this project was to scope the signal on the data bus, which uses J1850 VPW, to verify I had the right source for the data, verify the voltage, and verify the signal itself. I had a few automotive 3-pin connectors lying around, so I spliced in a connector on the ECM tuning cable. The connector was 4-pin, but only 3 pins were used: GND, +12v, and Data.
In the above image you can see one transmission that was captured on the data bus. The high signal was 7 volts, as it should be.
Inverting and printing the image, I was able to decode the signal, which was transmitted as a total of 7 bytes. The header was 3 bytes, the message was another 3 bytes, and there was 1 byte for CRC (cyclic redundancy check) which I have yet to figure out if I want to verify the integrity of the message received.
The next step in the project will be to create some code to automatically capture and decode this data, then send it via serial com (most likely using an Arduino for simplicity) so I can see the HEX values of the data that was sent.
The above binary:
00101000
00011011
00010000
00000010
00000000
00000000
11010101
Translated to:
0x28
0x1B
0x10
0x2
0x0
0x0
0xD5
The above is an RPM message sent from the ECM while the bike was off. I'm trying to find a good resource for the captured data, to determine what messages are what. So far I've found 1 example online of someone doing a similar project, http://momex.cat/en/HD-tacho-part1, and there is also a nice reference to the data on Github at https://github.com/stelian42/HarleyDroid/blob/master/README which shows the following data and its meaning:
28 1b 10 02 xx xx : rpm, xxxx = rotations/minute * 4 48 29 10 02 xx xx : speed, xxxx = km/h * 128 48 3b 40 xx : gear in neutral if (xx & 0x20), : clutch engaged if (xx & 0x80) 48 da 40 39 xx : turn signals, xx = 1,2,3 for left/right/both 68 88 10 03 : check engine indicator off 68 88 10 83 : check engine indicator on a8 3b 10 03 xx : current gear, xx = 1,3,7,15,31,63 for gears 1-6 a8 49 10 10 xx : engine temperature, xx = degrees Fahrenheit a8 69 10 06 xx xx : odometer, xxxx = ticks, each tick = 0.4 meters a8 69 10 86 xx xx : same as above, but a wraparound occured a8 83 10 0a xx xx : fuel consumption, xxxx = ticks, each tick = 0.000040 liters a8 83 10 8a xx xx : same as above, but a wraparound occured a8 83 61 12 dx : fuel gauge, x = level (0-15)
Discussions
Become a Hackaday.io Member
Create an account to leave a comment. Already have an account? Log In.