Advertise on DISCO3.CO.UK
Forum · Gallery · Wiki · Shop · Sponsors
DISCO3.CO.UK > In Car Electronics (D3)

Trying to sniff CAN bus - Without breaking my Disco! (oops?)
Post Reply  Down to end
Page 1 of 2 12>
chrisoverson
 


Member Since: 10 Dec 2020
Location: Bideford
Posts: 29

United Kingdom 2006 Discovery 3 TDV6 HSE Auto Tonga GreenDiscovery 3
Trying to sniff CAN bus - Without breaking my Disco! (oops?)

Hi all, I'm trying to accomplish something potentially exciting (for me at least) and would appreciate some technical help!

I want to read can bus messages and eventually re-send some, for two primary reasons:
1 - build my own 4x4 info display
2 - make the heater vents/fans work with the FBH

I've wired an arduino nano up to an MCP2515 board, then made up a cable using some quality ethernet cable and a OBD II connector.

I've wired the MCP2515 to the medium speed High and Low as indicated from all the research I've done... (pins 3 and 11), but having a great deal of trouble getting it working.

I can read a few messages, but after a short while (a few seconds to a minute or so) it stops, and the car gets upset - warning messages on dash, hazards flash, "Vehicle Fault - System Shutting Down" on head unit.

I've used both a simple example mcp2515 script, and the CanHacker software and code to sniff the messages. Both do the same.

After taking the key out and holding my breath for a minute or so, I can restart and everything is fine, until I start sniffing again.

Would anyone know what the problem is? I've triple checked all my connections, and so far the only things I suspect is either a voltage issue that's upsetting the car, or maybe my cable is too long and introducing issues? It's approximately 1.5m long, twisted pair.

Thank you very much in advance!
  
Post #219687028th Dec 2020 7:45 pm
View user's profile Send private message View poster's gallery Reply with quote
Pete K
 


Member Since: 15 Jan 2016
Location: GL
Posts: 10362

England 2005 Discovery 3 TDV6 HSE Auto Rimini RedDiscovery 3

I can’t answer your question.

However if you want a less dangerous way of getting 4x4 data, get it from the audio optical network. A lot less dangerous !
  
Post #219687428th Dec 2020 8:09 pm
View user's profile Send private message View poster's gallery Reply with quote
chrisoverson
 


Member Since: 10 Dec 2020
Location: Bideford
Posts: 29

United Kingdom 2006 Discovery 3 TDV6 HSE Auto Tonga GreenDiscovery 3

[img]

Hi Pete, thanks for the reply Smile

Would the audio optical network only show me the same image as on screen, or all the raw data?

I appreciate there's some risk involved with this, but hopefully once I'm past this stage, as long as I don't send any silly codes over the can I should be good and can have some real fun Smile (I work as a software developer, just not overly familiar with can)[/img]
  
Post #219687728th Dec 2020 8:14 pm
View user's profile Send private message View poster's gallery Reply with quote
epninety
 


Member Since: 12 Oct 2012
Location: Hampshire
Posts: 327

Wales 2005 Discovery 3 TDV6 HSE Auto Java BlackDiscovery 3

I've logged the canbus using RPi3 and the Waveshare dual can adapter, and also on my (Linux) laptop with a USBTin interface. My cable to the interface device was a modified cheap'n'nasty canbus extender from ebay (ribbon, not twisted), and I had some problems when the cable was longer than about a foot.

Like you, turn everything off, key out, then on restart everything is fine.

I was doing this as a downtime project last christmas, I reverse engineered the messages which control the dash instruments, so I could put a D3 dash into my kit car. This year I've not got much done on the car, so I haven't been back to it, but I have control of all the gauges and almost all the warning llights, and info messages, plus custom text.
  
Post #219688528th Dec 2020 8:45 pm
View user's profile Send private message View poster's gallery Reply with quote
chrisoverson
 


Member Since: 10 Dec 2020
Location: Bideford
Posts: 29

United Kingdom 2006 Discovery 3 TDV6 HSE Auto Tonga GreenDiscovery 3

Great! Thanks. I'll try to rework my setup with a much shorter cable and just extend the USB to the arduino if necessary, and see how I get on. I imagine I might be introducing noise into the CAN lines.
  
Post #219689228th Dec 2020 8:54 pm
View user's profile Send private message View poster's gallery Reply with quote
Pete K
 


Member Since: 15 Jan 2016
Location: GL
Posts: 10362

England 2005 Discovery 3 TDV6 HSE Auto Rimini RedDiscovery 3

Optical network will give you raw data
  
Post #219690328th Dec 2020 9:34 pm
View user's profile Send private message View poster's gallery Reply with quote
chrisoverson
 


Member Since: 10 Dec 2020
Location: Bideford
Posts: 29

United Kingdom 2006 Discovery 3 TDV6 HSE Auto Tonga GreenDiscovery 3

Okidoke...

I've remade my cable, and now rather than 1.5m of canbus wiring it's less than 1 inch, just about managed to fit the mcp2515 and the arduino nano inside the obd II plug with a lot of jiggerypokeryy.

(and yes! the lid did go back on! Very Happy)

I haven't a clue where to start reading the data from the audio optical system, but that sounds interesting too.
  
Post #219693829th Dec 2020 12:08 am
View user's profile Send private message View poster's gallery Reply with quote
McAdam
 


Member Since: 21 Nov 2020
Location: Canary Islands
Posts: 129

Spain 2005 Discovery 3 4.4 V8 HSE Auto Zambezi SilverDiscovery 3

Wow, Its amazing how many times I think of something I want to do to the car and someone makes a post at the same time.

I want to replace the Nav display with an Android Auto head unit, and as I go offroading at least 50% of the time in the car, its extremely handy to hand to have 4x4i but also a large display with off road routes/sat images.

I investigated it this morning, and didnt really come up with any good conclusions.

The headunit I ordered does have canbus connectors, but unsure how it would work with the car. If it does work, I would then need to find an android app to create some dashboard, or build one myself.

I am curious as to the MOST network, and trying to sniff from there.
I briefly looked at building a GVIF (how the display communicated with nav box) to Analogue RCA converter, but couldn't find any kind of ready solutions - and it seems that the 4x4i screen is hardcoded into the screen chip anyway.
I did think about getting a reverse screen connector and converting the 40 pin screen connector back to analogue... but thats insane Very Happy
I know that IID is able to get the info over BT via the IID Tool, so the data must exist somewhere easily accessible.

Anyway... this is project 42 on my list of insane things for my disco... so i will watch here and give any input if I ever can.
 Pre-Production
D3 V8 #264
LHD '04 HSE
Living its life as a 50/50 On/Off road car exploring the Canary Islands 
 
Post #219694129th Dec 2020 12:19 am
View user's profile Send private message View poster's gallery Reply with quote
chrisoverson
 


Member Since: 10 Dec 2020
Location: Bideford
Posts: 29

United Kingdom 2006 Discovery 3 TDV6 HSE Auto Tonga GreenDiscovery 3

Please keep in mind with anything I say that I'm new to this forum, this vehicle, and can bus, but I'm reasonably techinical, do software development daily, and I'm learning fast - so I might have some idea what I'm on about, but by no means an authority and may be dead wrong.

It's my understanding that there's virtually no chance any 3rd party system you can buy will show 4x4 information unless it's captured from where it's generated in the car already.

There's two canbus systems in the disco 3, high speed and medium speed. Medium speed includes information sent to the head unit, and, from reading some other threads here, also contains the information sent to the 4x4 display, but I haven't verified that as yet.

I'm sticking to medium speed where possible as I think I'm less likely to do serious damage there as it's not talking directly to the engine, and most of my areas of interest are on the medium bus anyway (FBH, fans, head unit), but I will probably need to play with both.

The way I'm planning to do it... is first identify and capture all info relating to the 4x4 positioning - steering angles, suspension info and so on, and then use this to make my own interface which will most likely be an android app. It won't be simple or quick, but could be interesting.

The other main thing I want to do is control miscelaneous items in the car, starting with fans so I can preheat the car along with running the FBH (which I have working through a 1533 timer and a remote GSM relay), but in time if possible controlling the windows, suspension and other such things might be fun and interesting.

I don't think my photo came through last time, so here's the little plug I've made (see attached)


  
Post #219694529th Dec 2020 12:28 am
View user's profile Send private message View poster's gallery Reply with quote
McAdam
 


Member Since: 21 Nov 2020
Location: Canary Islands
Posts: 129

Spain 2005 Discovery 3 4.4 V8 HSE Auto Zambezi SilverDiscovery 3

Your plug looks good.

There is a can connection in the back of the nav display, that connects to the HU via a private Can Network.
This might be an interesting point to tap into for 4x4i - since it makes sense that the nav screen would have some kind of filtered can.





There have been multiple attempts at can hacking in various LR cars including many RRs.

I still have nightmares from the last time I tried to Can Hack a 2013 Mini Cooper s... 28 hours of sniffing, but never able to trigger anything successfully. I was using an AutoPi.io adaptor to ensure I could focus on just the sniffing and not have to worry about anything else.

Good luck, and if you get further, I would be very interested in seeing how I can help!
 Pre-Production
D3 V8 #264
LHD '04 HSE
Living its life as a 50/50 On/Off road car exploring the Canary Islands 
 
Post #219694929th Dec 2020 12:44 am
View user's profile Send private message View poster's gallery Reply with quote
Pete K
 


Member Since: 15 Jan 2016
Location: GL
Posts: 10362

England 2005 Discovery 3 TDV6 HSE Auto Rimini RedDiscovery 3

The electric windows are basic in these.
Don’t think operated via can.
No chance of operating D3 rear windows.

The private can I believe sends touch screen presses back to the nav to enter destination etc
I don’t think it contains 4x4 data.
While other manufactures have managed to interact with this on gvif units I don’t think there is anything exciting for you.

If you look here on posts titled Tesla or Android I thought an app already existed to display 4x4
Not seen it though

https://www.rrsport.co.uk/forum/in-car-ele...6391ab77bd

The RRS has the same electrical system.

The replacement center consoles is interesting and they clearly have can working getting data like parking sensor distance
  
Post #219695329th Dec 2020 1:05 am
View user's profile Send private message View poster's gallery Reply with quote
epninety
 


Member Since: 12 Oct 2012
Location: Hampshire
Posts: 327

Wales 2005 Discovery 3 TDV6 HSE Auto Java BlackDiscovery 3

Just for interest, here's a little video of the D3 dash running on my bench, all controlled from a microcontroller using commands I reverse engineered from sniffing the canbus.

http://www.ep90.com/downloads/D3dashboard.mp4
  
Post #219701029th Dec 2020 11:28 am
View user's profile Send private message View poster's gallery Reply with quote
TigerRecovery
 


Member Since: 31 May 2017
Location: Long Stratton, Norwich, Norfolk
Posts: 901

Wales 2016 Discovery 4 3.0 SDV6 Landmark LE Auto Waitomo GreyDiscovery 4

There are two types of communication over CAN, 11 bit addresses and 29 bit addresses. Each module has it's own unique ID and will send and receive signals using it's appropriate address. Medium speed is 125Kb/s and High Speed is 500Kb/s.

If you're sending random messages on the bus it will go into expulsion mode where each module will stop sending information. If you also have a terminating resistor, 120 Ohm, across your CAN wires, it will add to the overall bus resistance and again will be detected and cause problems. The bus resistance when measured across pins 3/11 should be 60 Ohm (120 Ohm in parallel).

You can listen to the CAN bus, but to make any sense of the information you are seeing (it will all be in hex), you need the CAN DBC file which allows it to be decoded.

You can also send signals on CAN if you emulate the tester by using a specific ID and then constructing the message to send to a particular module. However, not all modules will respond to all commands and some may need to go into extended diagnostic mode to actually function.

Once unplugged and everything shut down, it should recover normally as the 'fault' has been removed.
 1972 Range Rover Classic 2 door V8
2013 Land Rover Discovery 4 HSE - SCRAPPED
2016 Land Rover Discovery 4 Landmark
2022 Volvo XC40 T5 PHEV 282HP FWD 3 cylinder! 
 
Post #219702129th Dec 2020 12:02 pm
View user's profile Send private message View poster's gallery Reply with quote
chrisoverson
 


Member Since: 10 Dec 2020
Location: Bideford
Posts: 29

United Kingdom 2006 Discovery 3 TDV6 HSE Auto Tonga GreenDiscovery 3

epninety wrote:
Just for interest, here's a little video of the D3 dash running on my bench, all controlled from a microcontroller using commands I reverse engineered from sniffing the canbus.

http://www.ep90.com/downloads/D3dashboard.mp4


Nice work!

I don't suppose you have a list of what IDs and values relate to what? Don't want to put you out, but would save me some time Smile

Another thing I'd like to implement is real time vehicle tracking, with reporting of values such as these. A web based info page for the car if you like.

Thanks everyone for your input, it's very much appreciated. I need to spend some time studying the CAN protocol and will be very careful when I start sending messages, for now I mainly want to listen and detect info, but opening the vents and starting the blowers at the windscreen would be a great start to interface with my FBH remote.
  
Post #219708429th Dec 2020 3:30 pm
View user's profile Send private message View poster's gallery Reply with quote
epninety
 


Member Since: 12 Oct 2012
Location: Hampshire
Posts: 327

Wales 2005 Discovery 3 TDV6 HSE Auto Java BlackDiscovery 3

PM inbound... Very Happy
  
Post #219713529th Dec 2020 5:52 pm
View user's profile Send private message View poster's gallery Reply with quote
Display posts from the last:  
Post Reply Back to top
Page 1 of 2 12>
Jump to:  
Previous Topic | Next Topic >


Posting Rules
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum



DISCO3.CO.UK Copyright © 2004-2024 Futuranet Ltd & Martin Lewis
DISCO3.CO.UK RSS Feed - All Forums

DISCO3.CO.UK is independent and not affiliated to Land Rover.
Switch to Mobile Site