2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Frequently asked questions
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								==========================
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-03-31 13:55:41 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								1.  [How can I donate to the project? ](#how-can-i-donate-to-the-project ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  [How do I calculate the step_distance parameter in the printer config file? ](#how-do-i-calculate-the-step_distance-parameter-in-the-printer-config-file ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  [Where's my serial port? ](#wheres-my-serial-port ) 
						 
					
						
							
								
									
										
										
										
											2018-04-20 11:43:21 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								4.  [When the micro-controller restarts the device changes to /dev/ttyUSB1 ](#when-the-micro-controller-restarts-the-device-changes-to-devttyusb1 ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								5.  [The "make flash" command doesn't work ](#the-make-flash-command-doesnt-work ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								6.  [How do I change the serial baud rate? ](#how-do-i-change-the-serial-baud-rate ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								7.  [Can I run Klipper on something other than a Raspberry Pi 3? ](#can-i-run-klipper-on-something-other-than-a-raspberry-pi-3 ) 
						 
					
						
							
								
									
										
										
										
											2019-01-07 13:59:18 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								8.  [Can I run multiple instances of Klipper on the same host machine? ](#can-i-run-multiple-instances-of-klipper-on-the-same-host-machine ) 
						 
					
						
							
								
									
										
										
										
											2019-01-21 11:57:44 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								9.  [Do I have to use OctoPrint? ](#do-i-have-to-use-octoprint ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								10.  [Why can't I move the stepper before homing the printer? ](#why-cant-i-move-the-stepper-before-homing-the-printer ) 
						 
					
						
							
								
									
										
										
										
											2019-05-08 16:48:14 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								11.  [Why is the Z position_endstop set to 0.5 in the default configs? ](#why-is-the-z-position_endstop-set-to-05-in-the-default-configs ) 
						 
					
						
							
								
									
										
										
										
											2019-01-21 11:57:44 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								12.  [I converted my config from Marlin and the X/Y axes work fine, but I just get a screeching noise when homing the Z axis ](#i-converted-my-config-from-marlin-and-the-xy-axes-work-fine-but-i-just-get-a-screeching-noise-when-homing-the-z-axis ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								13.  [My TMC motor driver turns off in the middle of a print ](#my-tmc-motor-driver-turns-off-in-the-middle-of-a-print ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								14.  [I keep getting random "Lost communication with MCU" errors ](#i-keep-getting-random-lost-communication-with-mcu-errors ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								15.  [My Raspberry Pi keeps rebooting during prints ](#my-raspberry-pi-keeps-rebooting-during-prints ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								16.  [When I set "restart_method=command" my AVR device just hangs on a restart ](#when-i-set-restart_methodcommand-my-avr-device-just-hangs-on-a-restart ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								17.  [Will the heaters be left on if the Raspberry Pi crashes? ](#will-the-heaters-be-left-on-if-the-raspberry-pi-crashes ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								18.  [How do I convert a Marlin pin number to a Klipper pin name? ](#how-do-i-convert-a-marlin-pin-number-to-a-klipper-pin-name ) 
						 
					
						
							
								
									
										
										
										
											2020-07-16 12:53:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								19.  [Do I have to wire my device to a specific type of micro-controller pin? ](#do-i-have-to-wire-my-device-to-a-specific-type-of-micro-controller-pin ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								20.  [How do I cancel an M109/M190 "wait for temperature" request? ](#how-do-i-cancel-an-m109m190-wait-for-temperature-request ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								21.  [Can I find out whether the printer has lost steps? ](#can-i-find-out-whether-the-printer-has-lost-steps ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								22.  [Why does Klipper report errors? I lost my print! ](#why-does-klipper-report-errors-i-lost-my-print ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								23.  [How do I upgrade to the latest software? ](#how-do-i-upgrade-to-the-latest-software ) 
						 
					
						
							
								
									
										
										
										
											2020-08-02 17:05:51 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								24.  [How do I uninstall klipper? ](#how-do-i-uninstall-klipper ) 
						 
					
						
							
								
									
										
										
										
											2018-03-31 13:55:41 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### How can I donate to the project?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Thanks. Kevin has a Patreon page at:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[https://www.patreon.com/koconnor ](https://www.patreon.com/koconnor )
							 
						 
					
						
							
								
									
										
										
										
											2018-01-05 11:42:00 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								### How do I calculate the step_distance parameter in the printer config file?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you know the steps per millimeter for the axis then use a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								calculator to divide 1.0 by steps_per_mm. Then round this number to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								six decimal places and place it in the config (six decimal places is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								nano-meter precision).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The step_distance defines the distance that the axis will travel on
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								each motor driver pulse. It can also be calculated from the axis
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pitch, motor step angle, and driver microstepping. If unsure, do a web
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								search for "calculate steps per mm" to find an online calculator.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-01-27 11:29:42 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Klipper uses step_distance instead of steps_per_mm in order to use
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								consistent units of measurement in the config file. (The config uses
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								millimeters for all distance measurements.) It is believed that
							 
						 
					
						
							
								
									
										
										
										
											2019-01-27 16:52:16 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								steps_per_mm originated as an optimization on old 8-bit
							 
						 
					
						
							
								
									
										
										
										
											2019-01-27 11:29:42 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								micro-controllers (the desire to use a multiply instead of a divide in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								some low-level code). Continuing to configure this one distance in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								units of "inverse millimeters" is felt to be quirky and unnecessary.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Where's my serial port?
  
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The general way to find a USB serial port is to run `ls
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/dev/serial/by-id/*` from an ssh terminal on the host machine. It will
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								likely produce output similar to the following:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/dev/serial/by-id/usb-1a86_USB2.0-Serial-if00-port0
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The name found in the above command is stable and it is possible to
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								use it in the config file and while flashing the micro-controller
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								code. For example, a flash command might look similar to:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sudo service klipper stop
							 
						 
					
						
							
								
									
										
										
										
											2018-06-01 17:18:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								make flash FLASH_DEVICE=/dev/serial/by-id/usb-1a86_USB2.0-Serial-if00-port0
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								sudo service klipper start
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and the updated config might look like:
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[mcu]
							 
						 
					
						
							
								
									
										
										
										
											2018-06-01 17:18:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								serial: /dev/serial/by-id/usb-1a86_USB2.0-Serial-if00-port0
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Be sure to copy-and-paste the name from the "ls" command that you ran
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								above as the name will be different for each printer.
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-06-01 17:18:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If you are using multiple micro-controllers and they do not have
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								unique ids (common on boards with a CH340 USB chip) then follow the
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								directions above using the command `ls /dev/serial/by-path/*`  instead.
							 
						 
					
						
							
								
									
										
										
										
											2018-06-01 17:18:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-20 11:43:21 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### When the micro-controller restarts the device changes to /dev/ttyUSB1
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Follow the directions in the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"[Where's my serial port? ](#wheres-my-serial-port )" section to prevent
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								this from occurring.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-05 11:42:00 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### The "make flash" command doesn't work
  
						 
					
						
							
								
									
										
										
										
											2017-12-11 17:28:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The code attempts to flash the device using the most common method for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								each platform. Unfortunately, there is a lot of variance in flashing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								methods, so the "make flash" command may not work on all boards.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you're having an intermittent failure or you do have a standard
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								setup, then double check that Klipper isn't running when flashing
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								(sudo service klipper stop), make sure OctoPrint isn't trying to
							 
						 
					
						
							
								
									
										
										
										
											2017-12-11 17:28:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								connect directly to the device (open the Connection tab in the web
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								page and click Disconnect if the Serial Port is set to the device),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and make sure FLASH_DEVICE is set correctly for your board (see the
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[question above ](#wheres-my-serial-port )).
							 
						 
					
						
							
								
									
										
										
										
											2017-12-11 17:28:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								However, if "make flash" just doesn't work for your board, then you
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								will need to manually flash. See if there is a config file in the
							 
						 
					
						
							
								
									
										
										
										
											2020-12-03 15:06:58 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[config directory ](../config ) with specific instructions for flashing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the device. Also, check the board manufacturer's documentation to see
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if it describes how to flash the device. Finally, it may be possible
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to manually flash the device using tools such as "avrdude" or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"bossac" - see the [bootloader document ](Bootloaders.md ) for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								additional information.
							 
						 
					
						
							
								
									
										
										
										
											2017-12-11 17:28:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### How do I change the serial baud rate?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-11-13 14:06:27 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The recommended baud rate for Klipper is 250000. This baud rate works
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								well on all micro-controller boards that Klipper supports. If you've
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								found an online guide recommending a different baud rate, then ignore
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								that part of the guide and continue with the default value of 250000.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you want to change the baud rate anyway, then the new rate will
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								need to be configured in the micro-controller (during **make
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								menuconfig**) and that updated code will need to be compiled and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								flashed to the micro-controller. The Klipper printer.cfg file will
							 
						 
					
						
							
								
									
										
										
										
											2020-11-16 18:47:32 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								also need to be updated to match that baud rate (see the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[config reference ](Config_Reference.md#mcu ) for details).  For
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								example:
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[mcu]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								baud: 250000
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The baud rate shown on the OctoPrint web page has no impact on the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								internal Klipper micro-controller baud rate. Always set the OctoPrint
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								baud rate to 250000 when using Klipper.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-11-13 14:06:27 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The Klipper micro-controller baud rate is not related to the baud rate
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								of the micro-controller's bootloader. See the
							 
						 
					
						
							
								
									
										
										
										
											2018-11-13 14:40:35 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[bootloader document ](Bootloaders.md ) for additional information on
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bootloaders.
							 
						 
					
						
							
								
									
										
										
										
											2018-11-13 14:06:27 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Can I run Klipper on something other than a Raspberry Pi 3?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The recommended hardware is a Raspberry Pi 2, Raspberry Pi 3, or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Raspberry Pi 4.
							 
						 
					
						
							
								
									
										
										
										
											2018-03-02 11:28:01 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper will run on a Raspberry Pi 1 and on the Raspberry Pi Zero, but
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								these boards don't have enough processing power to run OctoPrint
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								well. It is common for print stalls to occur on these slower machines
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								when printing directly from OctoPrint. (The printer may move faster
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								than OctoPrint can send movement commands.) If you wish to run on one
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								one of these slower boards anyway, consider using the "virtual_sdcard"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								feature when printing (see
							 
						 
					
						
							
								
									
										
										
										
											2020-11-16 18:47:32 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[config reference ](Config_Reference.md#virtual_sdcard ) for details).
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For running on the Beaglebone, see the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Beaglebone specific installation instructions ](beaglebone.md ).
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Klipper has been run on other machines. The Klipper host software only
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requires Python running on a Linux (or similar) computer. However, if
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								you wish to run it on a different machine you will need Linux admin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								knowledge to install the system prerequisites for that particular
							 
						 
					
						
							
								
									
										
										
										
											2020-12-03 15:06:58 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								machine. See the [install-octopi.sh ](../scripts/install-octopi.sh )
							 
						 
					
						
							
								
									
										
										
										
											2019-04-14 21:12:21 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								script for further information on the necessary Linux admin steps.
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-25 17:42:43 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If you are looking to run the Klipper host software on a low-end chip,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								then be aware that, at a minimum, a machine with "double precision
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								floating point" hardware is required.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you are looking to run the Klipper host software on a shared
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								general-purpose desktop or server class machine, then note that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper has some real-time scheduling requirements. If, during a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								print, the host computer also performs an intensive general-purpose
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								computing task (such as defragmenting a hard drive, 3d rendering,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								heavy swapping, etc.), then it may cause Klipper to report print
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								errors.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Note: If you are not using an OctoPi image, be aware that several
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Linux distributions enable a "ModemManager" (or similar) package that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								can disrupt serial communication. (Which can cause Klipper to report
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								seemingly random "Lost communication with MCU" errors.) If you install
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper on one of these distributions you may need to disable that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								package.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-01-07 13:59:18 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Can I run multiple instances of Klipper on the same host machine?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								It is possible to run multiple instances of the Klipper host software,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								but doing so requires Linux admin knowledge. The Klipper installation
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								scripts ultimately cause the following Unix command to be run:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								~/klippy-env/bin/python ~/klipper/klippy/klippy.py ~/printer.cfg -l /tmp/klippy.log
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								One can run multiple instances of the above command as long as each
							 
						 
					
						
							
								
									
										
										
										
											2019-02-03 17:41:57 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								instance has its own printer config file, its own log file, and its
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								own pseudo-tty. For example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								~/klippy-env/bin/python ~/klipper/klippy/klippy.py ~/printer2.cfg -l /tmp/klippy2.log -I /tmp/printer2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-01-07 13:59:18 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you choose to do this, you will need to implement the necessary
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								start, stop, and installation scripts (if any). The
							 
						 
					
						
							
								
									
										
										
										
											2020-12-03 15:06:58 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[install-octopi.sh ](../scripts/install-octopi.sh ) script and the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[klipper-start.sh ](../scripts/klipper-start.sh ) script may be useful
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								as examples.
							 
						 
					
						
							
								
									
										
										
										
											2019-01-07 13:59:18 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-01-21 11:57:44 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Do I have to use OctoPrint?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The Klipper software is not dependent on OctoPrint. It is possible to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								use alternative software to send commands to Klipper, but doing so
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requires Linux admin knowledge.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper creates a "virtual serial port" via the "/tmp/printer" file,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and it emulates a classic 3d-printer serial interface via that file.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In general, alternative software may work with Klipper as long as it
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								can be configured to use "/tmp/printer" for the printer serial port.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								### Why can't I move the stepper before homing the printer?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The code does this to reduce the chance of accidentally commanding the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								head into the bed or a wall. Once the printer is homed the software
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								attempts to verify each move is within the position_min/max defined in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the config file. If the motors are disabled (via an M84 or M18
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								command) then the motors will need to be homed again prior to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								movement.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-04 13:19:11 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If you want to move the head after canceling a print via OctoPrint,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								consider changing the OctoPrint cancel sequence to do that for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								you. It's configured in OctoPrint via a web browser under:
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Settings->GCODE Scripts
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you want to move the head after a print finishes, consider adding
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the desired movement to the "custom g-code" section of your slicer.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-20 19:33:54 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If the printer requires some additional movement as part of the homing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								process itself (or fundamentally does not have a homing process) then
							 
						 
					
						
							
								
									
										
										
										
											2019-11-07 16:50:52 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								consider using a safe_z_home or homing_override section in the config
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								file. If you need to move a stepper for diagnostic or debugging
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								purposes then consider adding a force_move section to the config
							 
						 
					
						
							
								
									
										
										
										
											2020-11-16 18:47:32 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								file. See [config reference ](Config_Reference.md#customized_homing )
							 
						 
					
						
							
								
									
										
										
										
											2019-04-14 21:12:21 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								for further details on these options.
							 
						 
					
						
							
								
									
										
										
										
											2018-05-20 19:33:54 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								### Why is the Z position_endstop set to 0.5 in the default configs?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For cartesian style printers the Z position_endstop specifies how far
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the nozzle is from the bed when the endstop triggers. If possible, it
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is recommended to use a Z-max endstop and home away from the bed (as
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								this reduces the potential for bed collisions). However, if one must
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								home towards the bed then it is recommended to position the endstop so
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								it triggers when the nozzle is still a small distance away from the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bed. This way, when homing the axis, it will stop before the nozzle
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								touches the bed. See the [bed level document ](Bed_Level.md ) for more
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								information.
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### I converted my config from Marlin and the X/Y axes work fine, but I just get a screeching noise when homing the Z axis
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 12:25:24 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Short answer: First, make sure you have verified the stepper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								configuration as described in the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[config check document ](Config_checks.md ). If the problem persists,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								try reducing the max_z_velocity setting in the printer config.
							 
						 
					
						
							
								
									
										
										
										
											2017-11-30 15:00:00 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Long answer: In practice Marlin can typically only step at a rate of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								around 10000 steps per second. If it is requested to move at a speed
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								that would require a higher step rate then Marlin will generally just
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								step as fast as it can. Klipper is able to achieve much higher step
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								rates, but the stepper motor may not have sufficient torque to move at
							 
						 
					
						
							
								
									
										
										
										
											2020-01-05 20:19:43 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								a higher speed. So, for a Z axis with a high gearing ratio or high
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								microsteps setting the actual obtainable max_z_velocity may be smaller
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								than what is configured in Marlin.
							 
						 
					
						
							
								
									
										
										
										
											2017-12-11 18:15:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-05 13:04:01 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### My TMC motor driver turns off in the middle of a print
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-29 11:06:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If using the TMC2208 (or TMC2224) driver in "standalone mode" then
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make sure to use the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[latest version of Klipper ](#how-do-i-upgrade-to-the-latest-software ). A
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								workaround for a TMC2208 "stealthchop" driver problem was added to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper in mid-March of 2020.
							 
						 
					
						
							
								
									
										
										
										
											2018-05-05 13:04:01 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-10-09 11:15:22 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### I keep getting random "Lost communication with MCU" errors
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This is commonly caused by hardware errors on the USB connection
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								between the host machine and the micro-controller. Things to look for:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Use a good quality USB cable between the host machine and 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  micro-controller. Make sure the plugs are secure.
							 
						 
					
						
							
								
									
										
										
										
											2019-01-05 20:59:12 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  If using a Raspberry Pi, use a 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  [good quality power supply ](https://www.raspberrypi.org/documentation/hardware/raspberrypi/power/README.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  for the Raspberry Pi and use a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  [good quality USB cable ](https://www.raspberrypi.org/forums/viewtopic.php?p=589877#p589877 )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  to connect that power supply to the Pi. If you get "under voltage"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  warnings from OctoPrint, this is related to the power supply and it
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  must be fixed.
							 
						 
					
						
							
								
									
										
										
										
											2018-10-09 11:15:22 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Make sure the printer's power supply is not being overloaded. (Power 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  fluctuations to the micro-controller's USB chip may result in resets
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  of that chip.)
							 
						 
					
						
							
								
									
										
										
										
											2019-01-07 10:28:25 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Verify stepper, heater, and other printer wires are not crimped or 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  frayed. (Printer movement may place stress on a faulty wire causing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  it to lose contact, briefly short, or generate excessive noise.)
							 
						 
					
						
							
								
									
										
										
										
											2018-10-09 11:15:22 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  There have been reports of high USB noise when both the printer's 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  power supply and the host's 5V power supply are mixed. (If you find
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  that the micro-controller powers on when either the printer's power
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  supply is on or the USB cable is plugged in, then it indicates the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  5V power supplies are being mixed.) It may help to configure the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  micro-controller to use power from only one source. (Alternatively,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  if the micro-controller board can not configure its power source,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  one may modify a USB cable so that it does not carry 5V power
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  between the host and micro-controller.)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-20 16:18:53 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### My Raspberry Pi keeps rebooting during prints
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This is most likely do to voltage fluctuations. Follow the same
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								troubleshooting steps for a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								["Lost communication with MCU" ](#i-keep-getting-random-lost-communication-with-mcu-errors )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								error.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-12-11 18:15:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### When I set "restart_method=command" my AVR device just hangs on a restart
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Some old versions of the AVR bootloader have a known bug in watchdog
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								event handling. This typically manifests when the printer.cfg file has
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								restart_method set to "command". When the bug occurs, the AVR device
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								will be unresponsive until power is removed and reapplied to the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								device (the power or status LEDs may also blink repeatedly until the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								power is removed).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The workaround is to use a restart_method other than "command" or to
							 
						 
					
						
							
								
									
										
										
										
											2018-01-05 11:42:00 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								flash an updated bootloader to the AVR device. Flashing a new
							 
						 
					
						
							
								
									
										
										
										
											2017-12-11 18:15:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								bootloader is a one time step that typically requires an external
							 
						 
					
						
							
								
									
										
										
										
											2019-05-07 22:59:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								programmer - see [Bootloaders ](Bootloaders.md ) for further details.
							 
						 
					
						
							
								
									
										
										
										
											2018-01-12 18:38:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-03-13 11:26:15 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Will the heaters be left on if the Raspberry Pi crashes?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The software has been designed to prevent that. Once the host enables
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a heater, the host software needs to confirm that enablement every 5
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								seconds. If the micro-controller does not receive a confirmation every
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								5 seconds it goes into a "shutdown" state which is designed to turn
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								off all heaters and stepper motors.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								See the "config_digital_out" command in the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[MCU commands ](MCU_Commands.md ) document for further details.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-04-09 22:00:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In addition, the micro-controller software is configured with a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								minimum and maximum temperature range for each heater at startup (see
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the min_temp and max_temp parameters in the
							 
						 
					
						
							
								
									
										
										
										
											2020-11-16 18:47:32 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[config reference ](Config_Reference.md#extruder ) for details). If the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								micro-controller detects that the temperature is outside of that range
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								then it will also enter a "shutdown" state.
							 
						 
					
						
							
								
									
										
										
										
											2018-04-09 22:00:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Separately, the host software also implements code to check that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								heaters and temperature sensors are functioning correctly. See the
							 
						 
					
						
							
								
									
										
										
										
											2020-11-16 18:47:32 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[config reference ](Config_Reference.md#verify_heater ) for further
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								details.
							 
						 
					
						
							
								
									
										
										
										
											2018-04-09 22:00:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-24 21:36:37 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### How do I convert a Marlin pin number to a Klipper pin name?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-26 10:09:08 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Short answer: In some cases one can use Klipper's `pin_map: arduino` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								feature. Otherwise, for "digital" pins, one method is to search for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the requested pin in Marlin's fastio header files. The Atmega2560 and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Atmega1280 chips use
							 
						 
					
						
							
								
									
										
										
										
											2018-08-24 21:36:37 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[fastio_1280.h ](https://github.com/MarlinFirmware/Marlin/blob/1.1.9/Marlin/fastio_1280.h ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								while the Atmega644p and Atmega1284p chips use
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[fastio_644.h ](https://github.com/MarlinFirmware/Marlin/blob/1.1.9/Marlin/fastio_644.h ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For example, if you are looking to translate Marlin's digital pin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								number 23 on an atmega2560 then one could find the following line in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Marlin's fastio_1280.h file:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#define DIO23_PIN PINA1
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `DIO23`  indicates the line is for Marlin's pin 23 and the `PINA1` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								indicates the pin uses the hardware name of `PA1` . Klipper uses the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								hardware names (eg, `PA1` ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Long answer: Klipper uses the standard pin names defined by the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								micro-controller. On the Atmega chips these hardware pins have names
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								like `PA4` , `PC7` , or `PD2` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Long ago, the Arduino project decided to avoid using the standard
							 
						 
					
						
							
								
									
										
										
										
											2018-08-26 10:09:08 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								hardware names in favor of their own pin names based on incrementing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								numbers - these Arduino names generally look like `D23`  or `A14` . This
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								was an unfortunate choice that has lead to a great deal of confusion.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In particular the Arduino pin numbers frequently don't translate to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the same hardware names. For example, `D21`  is `PD0`  on one common
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Arduino board, but is `PC7`  on another common Arduino board.
							 
						 
					
						
							
								
									
										
										
										
											2018-08-24 21:36:37 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In order to support 3d printers based on real Arduino boards, Klipper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								supports the Arduino pin aliases. This feature is enabled by adding
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`pin_map: arduino`  to the [mcu] section of the config file. When these 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								aliases are enabled, Klipper understands pin names that start with the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								prefix "ar" (eg, Arduino pin `D23`  is Klipper alias `ar23` ) and the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								prefix "analog" (eg, Arduino pin `A14`  is Klipper alias `analog14` ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper does not use the Arduino names directly because we feel a name
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								like D7 is too easily confused with the hardware name PD7.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Marlin primarily follows the Arduino pin numbering scheme.  However,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Marlin supports a few chips that Arduino does not support and in some
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cases it supports pins that Arduino boards do not expose. In these
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cases, Marlin chose their own pin numbering scheme. Klipper does not
							 
						 
					
						
							
								
									
										
										
										
											2018-08-26 10:09:08 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								support these custom pin numbers - check Marlin's fastio headers (see
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								above) to translate these pin numbers to their standard hardware
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								names.
							 
						 
					
						
							
								
									
										
										
										
											2018-08-24 21:36:37 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-16 12:53:49 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Do I have to wire my device to a specific type of micro-controller pin?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								It depends on the type of device and type of pin:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ADC pins (or Analog pins): For thermistors and similar "analog"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sensors, the device must be wired to an "analog" or "ADC" capable pin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on the micro-controller. If you configure Klipper to use a pin that is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								not analog capable, Klipper will report a "Not a valid ADC pin" error.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								PWM pins (or Timer pins): Klipper does not use hardware PWM by default
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								for any device. So, in general, one may wire heaters, fans, and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								similar devices to any general purpose IO pin. However, fans and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								output_pin devices may be optionally configured to use `hardware_pwm:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								True`, in which case the micro-controller must support hardware PWM on
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the pin (otherwise, Klipper will report a "Not a valid PWM pin"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								error). Note that hardware PWM is currently only supported on the avr,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								atsam, samd21, and linux micro-controllers.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								IRQ pins (or Interrupt pins): Klipper does not use hardware interrupts
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on IO pins, so it is never necessary to wire a device to one of these
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								micro-controller pins.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SPI pins: When using hardware SPI it is necessary to wire the pins to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the micro-controller's SPI capable pins. However, most devices can be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								configured to use "software SPI", in which case any general purpose IO
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pins may be used.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								I2C pins: When using I2C it is necessary to wire the pins to the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								micro-controller's I2C capable pins.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Other devices may be wired to any general purpose IO pin. For example,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								steppers, heaters, fans, Z probes, servos, LEDs, common hd44780/st7920
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								LCD displays, the Trinamic UART control line may be wired to any
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								general purpose IO pin.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-20 16:19:46 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### How do I cancel an M109/M190 "wait for temperature" request?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Navigate to the OctoPrint terminal tab and issue an M112 command in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the terminal box. The M112 command will cause Klipper to enter into a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"shutdown" state, and it will cause OctoPrint to disconnect from
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Klipper. Navigate to the OctoPrint connection area and click on
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"Connect" to cause OctoPrint to reconnect. Navigate back to the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								terminal tab and issue a FIRMWARE_RESTART command to clear the Klipper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								error state.  After completing this sequence, the previous heating
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								request will be canceled and a new print may be started.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-10 13:39:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Can I find out whether the printer has lost steps?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In a way, yes. Home the printer, issue a `GET_POSITION`  command, run
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								your print, home again and issue another `GET_POSITION` . Then compare
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the values in the `mcu:`  line.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This might be helpful to tune settings like stepper motor currents,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								accelerations and speeds without needing to actually print something
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and waste filament: just run some high-speed moves in between the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`GET_POSITION`  commands. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Note that endstop switches themselves tend to trigger at slightly
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								different positions, so a difference of a couple of microsteps is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								likely the result of endstop inaccuracies. A stepper motor itself can
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								only lose steps in increments of 4 full steps. (So, if one is using 16
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								microsteps, then a lost step on the stepper would result in the "mcu:"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								step counter being off by a multiple of 64 microsteps.)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-06-05 16:48:42 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Why does Klipper report errors? I lost my print!
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Short answer: We want to know if our printers detect a problem so that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the underlying issue can be fixed and we can obtain great quality
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								prints. We definitely do not want our printers to silently produce low
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								quality prints.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Long answer: Klipper has been engineered to automatically workaround
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								many transient problems. For example, it automatically detects
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								communication errors and will retransmit; it schedules actions in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								advance and buffers commands at multiple layers to enable precise
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								timing even with intermittent interference. However, should the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								software detect an error that it can not recover from, if it is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								commanded to take an invalid action, or if it detects it is hopelessly
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								unable to perform its commanded task, then Klipper will report an
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								error. In these situations there is a high risk of producing a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								low-quality print (or worse). It is hoped that alerting the user will
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								empower them to fix the underlying issue and improve the overall
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								quality of their prints.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								There are some related questions: Why doesn't Klipper pause the print
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								instead? Report a warning instead? Check for errors before the print?
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Ignore errors in user typed commands? etc? Currently Klipper reads
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								commands using the G-Code protocol, and unfortunately the G-Code
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								command protocol is not flexible enough to make these alternatives
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								practical today. There is developer interest in improving the user
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								experience during abnormal events, but it is expected that will
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								require notable infrastructure work (including a shift away from
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								G-Code).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-12 18:38:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### How do I upgrade to the latest software?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-10 13:49:01 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The first step to upgrading the software is to review the latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[config changes ](Config_Changes.md ) document. On occasion, changes are
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								made to the software that require users to update their settings as
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								part of a software upgrade. It is a good idea to review this document
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								prior to upgrading.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								When ready to upgrade, the general method is to ssh into the Raspberry
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Pi and run:
							 
						 
					
						
							
								
									
										
										
										
											2018-01-12 18:38:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cd ~/klipper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								git pull
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								~/klipper/scripts/install-octopi.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Then one can recompile and flash the micro-controller code. For
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2018-04-25 10:28:33 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								make menuconfig
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make clean
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-01-12 18:38:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								sudo service klipper stop
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make flash FLASH_DEVICE=/dev/ttyACM0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sudo service klipper start
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								However, it's often the case that only the host software changes. In
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								this case, one can update and restart just the host software with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cd ~/klipper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								git pull
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sudo service klipper restart
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If after using this shortcut the software warns about needing to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								reflash the micro-controller or some other unusual error occurs, then
							 
						 
					
						
							
								
									
										
										
										
											2019-12-10 13:49:01 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								follow the full upgrade steps outlined above.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If any errors persist then double check the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[config changes ](Config_Changes.md ) document, as you may need to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								modify the printer configuration.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Note that the RESTART and FIRMWARE_RESTART g-code commands do not load
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								new software - the above "sudo service klipper restart" and "make
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								flash" commands are needed for a software change to take effect.
							 
						 
					
						
							
								
									
										
										
										
											2020-08-02 17:05:51 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### How do I uninstall Klipper?
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-12-03 15:06:58 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								On the firmware end, nothing special needs to happen. Just follow the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								flashing directions for the new firmware.
							 
						 
					
						
							
								
									
										
										
										
											2020-08-02 17:05:51 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-12-03 15:06:58 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								On the raspberry pi end, an uninstall script is available in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[scripts/klipper-uninstall.sh ](../scripts/klipper-uninstall.sh ). For
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								example:
							 
						 
					
						
							
								
									
										
										
										
											2020-08-02 17:05:51 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sudo ~/klipper/scripts/klipper-uninstall.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								rm -rf ~/klippy-env ~/klipper
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```