Skip to content

Bootloader Entry

Klipper can be instructed to reboot into a Bootloader in one of the following ways:

Requesting the bootloader

Virtual Serial

If a virtual (USB-ACM) serial port is in use, pulsing DTR while at 1200 baud will request the bootloader.

Python (with flash_usb)

To enter the bootloader using python (using flash_usb):

> cd klipper/scripts
> python3 -c 'import flash_usb as u; u.enter_bootloader("<DEVICE>")'
Entering bootloader on <DEVICE>

Where <DEVICE> is your serial device, such as /dev/serial.by-id/usb-Klipper[...] or /dev/ttyACM0

Note that if this fails, no output will be printed, success is indicated by printing Entering bootloader on <DEVICE>.

Picocom

picocom -b 1200 <DEVICE>
<Ctrl-A><Ctrl-P>

Where <DEVICE> is your serial device, such as /dev/serial.by-id/usb-Klipper[...] or /dev/ttyACM0

<Ctrl-A><Ctrl-P> means holding Ctrl, pressing and releasing a, pressing and releasing p, then releasing Ctrl

Physical serial

If a physical serial port is being used on the MCU (even if a USB serial adapter is being used to connect to it), sending the string <SPACE><FS><SPACE>Request Serial Bootloader!!<SPACE>~ requests the bootloader.

<SPACE> is an ASCII literal space, 0x20.

<FS> is the ASCII File Separator, 0x1c.

Note that this is not a valid message as per the MCU Protocol, but sync characters(~) are still respected.

Because this message must be the only thing in the "block" it is received in, prefixing an extra sync character can increase reliability if other tools were previously accessing the serial port.

Shell

stty <BAUD> < /dev/<DEVICE>
echo $'~ \x1c Request Serial Bootloader!! ~' >> /dev/<DEVICE>

Where <DEVICE> is your serial port, such as /dev/ttyS0, or /dev/serial/by-id/gpio-serial2, and

<BAUD> is the baud rate of the serial port, such as 115200.

CANBUS

If CANBUS is in use, a special admin message will request the bootloader. This message will be respected even if the device already has a nodeid, and will also be processed if the mcu is shutdown.

This method also applies to devices operating in CANBridge mode.

Katapult's flashtool.py

python3 ./katapult/scripts/flashtool.py -i <CAN_IFACE> -u <UUID> -r

Where <CAN_IFACE> is the can interface to use. If using can0, both the -i and <CAN_IFACE> may be omitted.

<UUID> is the UUID of your CAN device.

See the CANBUS Documentation for information on finding the CAN UUID of your devices.

Entering the bootloader

When klipper receives one of the above bootloader requests:

If Katapult (formerly known as CANBoot) is available, klipper will request that Katapult stay active on the next boot, then reset the MCU (therefore entering Katapult).

If Katapult is not available, klipper will then try to enter a platform-specific bootloader, such as STM32's DFU mode(see note).

In short, Klipper will reboot to Katapult if installed, then a hardware specific bootloader if available.

For details about the specific bootloaders on various platforms see Bootloaders

Notes

STM32 DFU Warning

Note that on some boards, like the Octopus Pro v1, entering DFU mode can cause undesired actions (such as powering the heater while in DFU mode). It is recommended to disconnect heaters, and otherwise prevent undesired operations when using DFU mode. Consult the documentation for your board for more details.