So you’re can0 interface is online, but a query returns nothing:

image

First up, if you previously could see UUID’s returned, and then put them into your printer.cfg file, but now you can’t see anything from a canbus query don’t panic. Once a UUID has been “grabbed” by klipper-on-pi then it won’t show up to a query. This is normal.

Note: If your board is meant to be in Katapult mode, and you have a blinking LED on the toolhead indicating the board is in katapult mode (if the status LED is supported) then the Klipper service on the pi won’t be grabbing the UUID. It will only grab application: klipper UUID’s.

Firmware

If you haven’t put the UUID into your printer.cfg then this means that your method of CAN adapting (standalone adapter or usb-can-bridge mainboard) is running OK but can’t see anything on the network. Starting at the adapter end, if you are using a usb-can-bridge mainboard then double check that the klipper firmware you flashed had the correct pins set for the CAN network. If you used the wrong pins then the mainboard will boot fine, and even show the can0 interface fine, but will be looking on the wrong pins for CAN traffic and so will never find any other nodes. Note that you should never be able to get into a situation with a usb-can-bridge mainboard where it shows the can0 interface fine but can’t find at least its own UUID to a query.

Next, check the firmware of your toolhead. If you never saw the toolhead Katapult or klipper as a UUID at all then double check the Katapult/klipper firmware for incorrect settings. This could be any setting as even a single incorrect setting on this firmware will either stop the toolhead from booting at all (in which case you won’t see it on the network) or it boots but is looking at the wrong CAN pins/has the wrong CAN speed (in which case you also won’t see it on the network).

I’m going to assume you are using Katapult from this point on. If this had the correct settings (which you have double checked) and it flashed OK then we can assume it has booted into Katapult. I would recommend setting a status_led pin in the config (I have outlined the correct pins to use for this in the toolhead_flashing/common_hardware entries) as it will be flashing an LED if it is sitting in Katapult mode.

Wiring

If it’s sitting in Katapult but you still can’t see a UUID then your problem is likely down to wiring. (Thanks to @drachenkaetzchen for the much better writeup than my original one)

  • First thing Shut down the Pi with sudo shutdown now and then power off the whole printer. There needs to be no power before testing further.

  • Each side of the CAN Bus needs the 120 Ohm resistor in place. Ensure you got the appropriate jumpers set. The Octopus is an exception, it has no jumper, the 120 Ohm resistor is always present.

  • For all following measurements, your printer must be powered off.

  • Ensure using a multimeter in continuity mode that CAN_L from one side actually ends up on CAN_L on the other side. Same for CAN_H. Remove all termination resistors for that. If one of your boards has a fixed 120 Ohm resistor, remove the jumper on the other board. Then use your multimeter in Ohms mode to measure from one side to the other, you should read close to 0 ohms. If you read 120 Ohms, you probably have swapped CAN_L and CAN_H

  • With everything connected, measure resistance between CAN_L and CAN_H. You should read 60 Ohms (2x 120 Ohm in parallel = 60 Ohms). If you get 120 Ohm, then there might be a break in the wire or you forgot to set the jumper

  • If you suspect that CAN_L or CAN_H might be broken, measure in resistance mode (not continuity!) between CAN_L on one board with CAN_L on the other board. If you get 240 Ohms, then there’s a break in CAN_L. Repeat the measurement for CAN_H

can0 Interface

There are guides floating around on the internet (I can’t find them now but I swear I’ve seen them in the past) that instruct users to add post-boot tasks to modify the CAN speed or txqueuelen to something different than is stated in the /etc/systemd/network/25-can.network file. If your firmware/wiring/everything looks fine yet you still can’t get a UUID then this is a good thing to check.

To test this hypothesis, make sure you are absolutely sure of the CAN speed you set when compiling the katapult/klipper firmware for your device (if you are using this guide then that will be one million, 1000000) then run the following commands to manually take down the can0 interface then bring it back up with the “known correct” speed

To stop the can0 interface:

sudo ip link set can0 down type can

To start the can0 interface (replace the bitrate to whatever you are using if it isn’t 1000000)

sudo ip link set can0 up type can bitrate 1000000

To confirm the network is back up and running at the correct speeds run ip -details -statistics link show can0 and look for the following:

image

If it looks good then re-run a canbus query to see if the UUID shows up now.

If your UUIDs show up then reboot the printer and check again. If they now don’t show up then you probably have one of these post-boot script things interfering. Usually it is in the rc.local file. Run:

sudo nano /etc/rc.local

and if you see any lines referecing “can0” then put a # at the start of the line to comment it out (or delete the whole line), then reboot and canbus query once again. Hopefully it’s all good at this point.

If the rc.local file isn’t the problem, but you still get post-boot no UUIDs but you do get UUIDs after manually setting the can0 speed with the commands, then the overriding “script” is somewhere else. As linux has a bunch of different ways to change settings after a boot it is hard to cover all of them here. Just take the information you have now figured out (something is changing my can0 speed afterboot, it isn’t the rc.local file) and ask your favourite helpers/discord channels/forums/wherever.

BUS-OFF

There are rare cases where certain circumstances lead to the CAN interface on your Pi going into a BUS-OFF state. You can see this when you run:

ip -s -d link show can0

image

This means your can0 interface on your Pi is no longer listening for CAN traffic, even if you have a node (like a toolhead) that you “fix” and it should be detectable.

For example, the wrong Klipper firmware on a toolhead can possibly make the toolhead innaccessible over CAN (no UUID to a query, won’t connect in Klipper) but also causes the CAN adapter to freak out and go into a BUS-OFF state. Even if you then double-click the reset button on the toolhead and you know the Katapult firmware on it is fine so you should now see the UUID, you won’t while the can0 interface itself stays BUS-OFF.

One way to kick the can0 interface out of BUS-OFF is to manually turn the interface off and on again by running:

sudo ip link set can0 down type can

then:

sudo ip link set can0 up type can bitrate 1000000

It is probably a good idea to have your toolhead/node/whatever in a “It should be working” state before you do this (ie. double-click reset to put the node into Katapult mode). If there is an active node already when you do the above off/on of the interface then you should be able to now do a

~/katapult/scripts/flashtool.py -q

and see your node UUID again, and be able to reflash Klipper to it (if needed).

Return to Troubleshooting