General Info
The following should be taken as an overall guide on what you are going to be achieving.
PLEASE DO NOT TAKE THE SCREENSHOTS/CONFIGURATIONS ON THIS PAGE EXACTLY AS WRTTEN AS THEY MAY NOT BE COMPATIBLE WITH YOUR PARTICULAR MAINBOARD
Before doing anything it is good to have some dependencies installed. Do this by running these on your Pi:
sudo apt update
sudo apt upgrade
sudo apt install python3 python3-serial
Installing Katapult
First you need to clone the Katapult repo onto your pi. Run the following commands to clone (or update) the repo:
test -e ~/katapult && (cd ~/katapult && git pull) || (cd ~ && git clone https://github.com/Arksine/katapult) ; cd ~
This will clone the Katapult repo into a new folder in your home directory called “katapult” if you don’t already have it, or it will update your Katapult folder to the latest version if you did already have it.
To configure the Katapult firmware, run these commands to change into the katapult directory and then modify the firmware menu:
cd ~/katapult
make menuconfig
You will need to adapt the below instructions so they cover your board’s specicific configuration. You can find screenshots of settings for common toolheads in the Common Mainboard Hardware section.
If your board doesn’t exist in the common_hardware folder already, then you want the Processor, Clock Reference, and Application Start offset to be set as per whatever board you are running. Set the “Build Katapult deployment application” (this is really only for updating but doesn’t hurt having it enabled at this stage), and make sure “Communication Interface” is set to USB. Also make sure the “Support bootloader entry on rapid double click of reset button” is marked. It makes it so a double press of the reset button will force the board into Katapult mode. Makes re-flashing after a mistake a lot easier. Lastly, setting the Status LED GPIO Pin won’t affect how katapult functions, but it will give a nice visual indicator (of an LED flashing on and off once a second) on the toolhead to show the board is sitting in Katapult mode.
Press Q to quit the menu (it will ask to save, choose yes).
Compile the firmware with make
. You will now have a katapult.bin at ~/katapult/out/katapult.bin.
make clean
make
To flash, connect your mainboard to the Pi via USB then put the mainboard into DFU/BOOT mode (your mainboard user manual should have instructions on doing this).
If your toolhead board uses an STM32 based MCU use these flashing steps
If your toolhead board uses an RP2040 MCU, use these flashing steps
STM32 based boards
To confirm it’s in DFU mode you can run the command lsusb
and look for an entry of “STMicroelectronics STM Device in DFU mode”
lsusb
You can then flash the Katapult firmware to your mainboard by running
cd ~/katapult
make
sudo dfu-util -R -a 0 -s 0x08000000:leave -D ~/katapult/out/katapult.bin -d 0483:df11
If the result shows an “Error during download get_status” or something, but above it it still has “File downloaded successfully” then it still flashed OK and you can ignore that error.
Katapult is now installed, click here for the next steps.
RP2040 based boards
To confirm it’s in BOOT mode, run an lsusb
command and you should see the device as a “Raspberry Pi boot” device (or similar)
lsusb
Note the address of the usb device => 2e8a:0003
You can then flash the Katapult firmware to your toolhead board by running
cd ~/katapult
make flash FLASH_DEVICE=2e8a:0003
where the FLASH_DEVICE ID is what you noted down from the lsusb
command.
It should look something like this if the download was successfull
Katapult is now installed, click here for the next steps.
Katapult is now installed
Katapult should now be successfully flashed. Take out any DFU jumpers on your mainboard (if it needed them) and double-click the reset button on your board. Check that the board is in Katapult mode by running
ls /dev/serial/by-id
You should see a “usb-katapult_…” device there. If you don’t, then double-click the RESET button on your board and ls /dev/serial/by-id
again.
If you keep seeing the board, but it shows as “usb-Klipper_…” instead of “usb-katapult_…” even after double-clicking the reset button then you may have a dodgy reset button or aren’t getting the double-click timing correct. Either way, another method to kick the board into Katapult mode (assuming the Katapult install from further above was successful) is to run ~/katapult/scripts/flashtool.py -r -d /dev/serial/by-id/usb-Klipper_....
putting in the usb_Klipper full path name that your board is showing up as.
If you do not see a Katapult device listed in your /dev/serial/by-id, or if you get a
cannot access '/dev/serial/by-id': No such file or directory
then your mainboard isn’t currently sitting in Katapult mode. Double-click the reset button on your mainboard thenls /dev/serial/by-id
again. If you still don’t see a Katapult device then either the flash didn’t work or you had incorrect settings in the Katapultmake menuconfig
screen. Go back and try again.
As you are installing Katapult onto the mainboard that you are also going to use for USB-CAN-Bridge mode klipper, you still will not have a working CAN network at this stage. You can flash klipper to your mainboard via Katapult, but in reality it is flashing over USB and not flashing over CAN.
Flashing klipper via Katapult will be covered shortly.
Installing USB-CAN-Bridge Klipper
Move into the klipper directory on the Pi by running:
cd ~/klipper
Then go into the klipper configuration menu by running:
make menuconfig
Again, if your mainboard is already in Common Mainboard Hardware then you can copy the Klipper settings from there.
Otherwise, you want the Processor and Clock Reference to be set as per whatever board you are running. Set Communication interface to ‘USB to CAN bus bridge’ then set the CAN Bus interface to use the pins that are specific to your mainboard. Also set the CAN bus speed to the same as the speed in your can0 file. In this guide it is set to 1000000.
Once you have the firmware configured, run a make clean
to make sure there are no old files hanging around, then make
to compile the firmware. It will save the firmware to ~/klipper/out/klipper.bin
make clean
make
Using Katapult to flash Klipper
Stop the Klipper service on the Pi by running:
sudo service klipper stop
Run an ls /dev/serial/by-id/
and take note of the Katapult device that it shows:
ls /dev/serial/by-id/
If the above command didn’t show a ‘katapult’ device, or threw a “no such file or directory” error, then quickly double-click the RESET button on your mainboard and run the command again. Until you get a result from a ls /dev/serial/by-id/
there is no point doing further steps below.
Run this command to install klipper firmware via Katapult via USB. Use the device ID you just retrieved in the above ls command.
python3 ~/katapult/scripts/flashtool.py -f ~/klipper/out/klipper.bin -d /dev/serial/by-id/usb-katapult_your_board_id
Klipper is now installed
This should have now installed klipper firmware to your mainboard. You can verify by running lsusb
and you should see a “Geschwister Schneider CAN adapter” or similar device.
Check that the can0 interface is up by running ip -s -d link show can0
. If everything is correct you will see something like this:
ip -s -d link show can0
You see a can0 interface, the “qlen” will be 128, and the bitrate will be 1000000
If the
ip -s -d link show can0
command returns an error (eg. “Device can0 does not exist) then reboot your Pi withsudo reboot now
and once the Pi is back up checkip -s -d link show can0
again. If you still get the error then your mainboard isn’t showing as a CAN adapter and you need to go back to the Installing USB-CAN-Bridge Klipper and try again, making sure the Klippermake menuconfig
settings are absolutely correct.If the can0 network shows up, but the qlen isn’t 128 or the bitrate isn’t 1000000 then go back to Getting_Started and check the can0 file settigns in both the ifupdown section and the netplan section.
You can now run the Klipper canbus query to retrieve the canbus_uuid of your mainboard:
~/klippy-env/bin/python ~/klipper/scripts/canbus_query.py can0
Use this UUID in the [mcu] section of your printer.cfg in order for Klipper (on Pi) to connect to the mainboard.
Start the Klipper service on the Pi again by running:
sudo service klipper start
Dissappearing Mainboard UUID
There is a quirk with USB-CAN-Bridge klipper if you don’t have any second/other CAN nodes connected up (either due to not having done that step yet, or if there is something wrong with the toolhead/other CAN device or wiring) where the Mainboard UUID will stop showing up to a query and can cause your web interface/klipper logs to show connection errors to ‘mcu’.
If you are still at this early stage of your flashing journey where you haven’t yet set up/connected the toolhead, all it means is if you keep doing a CAN query the mainboard UUID will stop showing. Don’t be alarmed, it’s normal. Once you have the second CAN device connect you won’t see this behaviour, and it won’t stop the mainboard from still acting as a USB-CAN-Bridge for your Pi.
However, if you already had a working CAN toolhead setup and you see this problem, then the dissappearing UUID is not the cause of any errors/issues with your system. It can be a symptom of a problem, not the cause. Don’t get lost trying to troubleshoot why the mainboard UUID dissappears. It’s fine. Just hit the reset button on your mainboard (once), or power cycle the printer, and the mainboard UUID will return for at least a bit.
Next Step
Now that your mainboard is fully flashed, and you have a working can0 CANBus network, the next step is to flash your toolhead board.