mirror of
				https://github.com/Klipper3d/klipper.git
				synced 2025-10-26 07:46:11 +01:00 
			
		
		
		
	docs: Improvements to RPi_microcontroller.md
Wraps lines to 80 columns. Only use triple backticks on multi-line code excerpts. Add backticks around "sudo raspi-config". Move "Enabling SPI" section to be near pwm and gpio configuration. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
		| @@ -1,23 +1,26 @@ | |||||||
| # RPi microcontroller | # RPi microcontroller | ||||||
|  |  | ||||||
| This document describes the process of running Klipper on a RPi | This document describes the process of running Klipper on a RPi and | ||||||
| and use the same RPi as secondary mcu. | use the same RPi as secondary mcu. | ||||||
|  |  | ||||||
| ## Why use RPi as a secondary MCU? | ## Why use RPi as a secondary MCU? | ||||||
|  |  | ||||||
| Often the MCUs dedicated to controlling 3D printers have a limited and | Often the MCUs dedicated to controlling 3D printers have a limited and | ||||||
| pre-configured number of exposed pins to manage the main printing | pre-configured number of exposed pins to manage the main printing | ||||||
| functions (thermal resistors, extruders, steppers ...). | functions (thermal resistors, extruders, steppers ...). Using the RPi | ||||||
| Using the RPi where Klipper is installed as a secondary MCU gives the | where Klipper is installed as a secondary MCU gives the possibility to | ||||||
| possibility to directly use the GPIOs and the buses (i2c, spi) of the RPi | directly use the GPIOs and the buses (i2c, spi) of the RPi inside | ||||||
| inside klipper without using Octoprint plugins (if used) or external | klipper without using Octoprint plugins (if used) or external programs | ||||||
| programs giving the ability to control everything within the print GCODE. | giving the ability to control everything within the print GCODE. | ||||||
|  |  | ||||||
| **Warning**: If your platform is a _Beaglebone_ and you have correctly followed the installation steps, the linux mcu is already installed and configured for your system. | **Warning**: If your platform is a _Beaglebone_ and you have correctly | ||||||
|  | followed the installation steps, the linux mcu is already installed | ||||||
|  | and configured for your system. | ||||||
|  |  | ||||||
| ## Install the rc script | ## Install the rc script | ||||||
|  |  | ||||||
| If you want to use the host as a secondary MCU the klipper_mcu process must run before the klippy process. | If you want to use the host as a secondary MCU the klipper_mcu process | ||||||
|  | must run before the klippy process. | ||||||
|  |  | ||||||
| After installing Klipper, install the script. run: | After installing Klipper, install the script. run: | ||||||
| ``` | ``` | ||||||
| @@ -26,10 +29,6 @@ sudo cp "./scripts/klipper-mcu-start.sh" /etc/init.d/klipper_mcu | |||||||
| sudo update-rc.d klipper_mcu defaults | sudo update-rc.d klipper_mcu defaults | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Enabling SPI |  | ||||||
|  |  | ||||||
| Make sure the Linux SPI driver is enabled by running sudo raspi-config and enabling SPI under the "Interfacing options" menu. |  | ||||||
|  |  | ||||||
| ## Building the micro-controller code | ## Building the micro-controller code | ||||||
|  |  | ||||||
| To compile the Klipper micro-controller code, start by configuring it | To compile the Klipper micro-controller code, start by configuring it | ||||||
| @@ -38,7 +37,9 @@ for the "Linux process": | |||||||
| cd ~/klipper/ | cd ~/klipper/ | ||||||
| make menuconfig | make menuconfig | ||||||
| ``` | ``` | ||||||
| In the menu, set "Microcontroller Architecture" to "Linux process," then save and exit. |  | ||||||
|  | In the menu, set "Microcontroller Architecture" to "Linux process," | ||||||
|  | then save and exit. | ||||||
|  |  | ||||||
| To build and install the new micro-controller code, run: | To build and install the new micro-controller code, run: | ||||||
| ``` | ``` | ||||||
| @@ -47,9 +48,10 @@ make flash | |||||||
| sudo service klipper start | sudo service klipper start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| If klippy.log reports a "Permission denied" error when attempting to connect | If klippy.log reports a "Permission denied" error when attempting to | ||||||
| to `/tmp/klipper_host_mcu` then you need to add your user to the tty group. | connect to `/tmp/klipper_host_mcu` then you need to add your user to | ||||||
| The following command will add the "pi" user to the tty group: | the tty group.  The following command will add the "pi" user to the | ||||||
|  | tty group: | ||||||
| ``` | ``` | ||||||
| sudo usermod -a -G tty pi | sudo usermod -a -G tty pi | ||||||
| ``` | ``` | ||||||
| @@ -61,12 +63,24 @@ following the instructions in | |||||||
| [RaspberryPi sample config](../config/sample-raspberry-pi.cfg) and | [RaspberryPi sample config](../config/sample-raspberry-pi.cfg) and | ||||||
| [Multi MCU sample config](../config/sample-multi-mcu.cfg). | [Multi MCU sample config](../config/sample-multi-mcu.cfg). | ||||||
|  |  | ||||||
|  | ## Optional: Enabling SPI | ||||||
|  |  | ||||||
|  | Make sure the Linux SPI driver is enabled by running | ||||||
|  | `sudo raspi-config` and enabling SPI under the "Interfacing options" | ||||||
|  | menu. | ||||||
|  |  | ||||||
| ## Optional: Identify the correct gpiochip | ## Optional: Identify the correct gpiochip | ||||||
|  |  | ||||||
| On Rasperry Pi and on many clones the pins exposed on the GPIO belong to the first gpiochip. They can therefore be used on klipper simply by referring them with the name `gpio0..n`. | On Rasperry and on many clones the pins exposed on the GPIO belong to | ||||||
| However, there are cases in which the exposed pins belong to gpiochips other than the first. For example in the case of some OrangePi models or if a Port Expander is used. In these cases it is useful to use the commands to access the _Linux GPIO character device_ to verify the configuration. | the first gpiochip. They can therefore be used on klipper simply by | ||||||
|  | referring them with the name `gpio0..n`. However, there are cases in | ||||||
|  | which the exposed pins belong to gpiochips other than the first. For | ||||||
|  | example in the case of some OrangePi models or if a Port Expander is | ||||||
|  | used. In these cases it is useful to use the commands to access the | ||||||
|  | _Linux GPIO character device_ to verify the configuration. | ||||||
|  |  | ||||||
| To install the _Linux GPIO character device - binary_ on a debian based distro like OctoPi run: | To install the _Linux GPIO character device - binary_ on a debian | ||||||
|  | based distro like octopi run: | ||||||
| ``` | ``` | ||||||
| sudo apt-get install gpiod | sudo apt-get install gpiod | ||||||
| ``` | ``` | ||||||
| @@ -81,9 +95,13 @@ To check the pin number and the pin availability tun: | |||||||
| gpioinfo | gpioinfo | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The chosen pin can thus be used within the configuration as `gpiochip<n>/gpio<o>` where **n** is the chip number as seen by the `gpiodetect` command and **o** is the line number seen by the` gpioinfo` command. | The chosen pin can thus be used within the configuration as | ||||||
|  | `gpiochip<n>/gpio<o>` where **n** is the chip number as seen by the | ||||||
|  | `gpiodetect` command and **o** is the line number seen by the` | ||||||
|  | gpioinfo` command. | ||||||
|  |  | ||||||
| ***Warning:*** only gpio marked as `unused` can be used. It is not possible for a _line_ to be used by multiple processes simultaneously. | ***Warning:*** only gpio marked as `unused` can be used. It is not | ||||||
|  | possible for a _line_ to be used by multiple processes simultaneously. | ||||||
|  |  | ||||||
| For example on a RPi 3B+ where klipper use the GPIO20 for a switch: | For example on a RPi 3B+ where klipper use the GPIO20 for a switch: | ||||||
| ``` | ``` | ||||||
| @@ -160,23 +178,32 @@ gpiochip1 - 8 lines: | |||||||
|  |  | ||||||
| ## Optional: Hardware PWM | ## Optional: Hardware PWM | ||||||
|  |  | ||||||
| Raspberry Pi's have two PWM channels (PWM0 and PWM1) which are exposed on the header or if not, can be routed to existing gpio pins. | Raspberry Pi's have two PWM channels (PWM0 and PWM1) which are exposed | ||||||
| The Linux mcu daemon uses the pwmchip sysfs interface to control hardware pwm devices on Linux hosts. | on the header or if not, can be routed to existing gpio pins.  The | ||||||
| The pwm sysfs interface is not exposed by default on a Raspberry and can be activated by adding a line to ```/boot/config.txt```: | Linux mcu daemon uses the pwmchip sysfs interface to control hardware | ||||||
|  | pwm devices on Linux hosts.  The pwm sysfs interface is not exposed by | ||||||
|  | default on a Raspberry and can be activated by adding a line to | ||||||
|  | `/boot/config.txt`: | ||||||
| ``` | ``` | ||||||
| # Enable pwmchip sysfs interface | # Enable pwmchip sysfs interface | ||||||
| dtoverlay=pwm,pin=12,func=4 | dtoverlay=pwm,pin=12,func=4 | ||||||
| ``` | ``` | ||||||
| This example enables only PWM0 and routes it to gpio12. If both PWM channels need to be enabled you can use ```pwm-2chan```. | This example enables only PWM0 and routes it to gpio12. If both PWM | ||||||
|  | channels need to be enabled you can use `pwm-2chan`. | ||||||
|  |  | ||||||
| The overlay does not expose the pwm line on sysfs on boot and needs to be exported by echo'ing the number of the pwm channel to ```/sys/class/pwm/pwmchip0/export```: | The overlay does not expose the pwm line on sysfs on boot and needs to | ||||||
|  | be exported by echo'ing the number of the pwm channel to | ||||||
|  | `/sys/class/pwm/pwmchip0/export`: | ||||||
| ``` | ``` | ||||||
| echo 0 > /sys/class/pwm/pwmchip0/export | echo 0 > /sys/class/pwm/pwmchip0/export | ||||||
| ``` | ``` | ||||||
| This will create device ```/sys/class/pwm/pwmchip0/pwm0``` in the filesystem. |  | ||||||
| The easiest way to do this is by adding this to ```/etc/rc.local``` before the ```exit 0``` line. |  | ||||||
|  |  | ||||||
| With the sysfs in place, you can now use either the pwm channel(s) by adding the following piece of configuration to your ```printer.cfg```: | This will create device `/sys/class/pwm/pwmchip0/pwm0` in the | ||||||
|  | filesystem. The easiest way to do this is by adding this to | ||||||
|  | `/etc/rc.local` before the `exit 0` line. | ||||||
|  |  | ||||||
|  | With the sysfs in place, you can now use either the pwm channel(s) by | ||||||
|  | adding the following piece of configuration to your `printer.cfg`: | ||||||
| ``` | ``` | ||||||
| [output_pin caselight] | [output_pin caselight] | ||||||
| pin: host:pwmchip0/pwm0 | pin: host:pwmchip0/pwm0 | ||||||
| @@ -184,7 +211,8 @@ pwm: True | |||||||
| hardware_pwm: True | hardware_pwm: True | ||||||
| cycle_time: 0.000001 | cycle_time: 0.000001 | ||||||
| ``` | ``` | ||||||
| This will add hardware pwm control to gpio12 on the Pi (because the overlay was configured to route pwm0 to pin=12). | This will add hardware pwm control to gpio12 on the Pi (because the | ||||||
|  | overlay was configured to route pwm0 to pin=12). | ||||||
|  |  | ||||||
| PWM0 can be routed to gpio12 and gpio18, PWM1 can be routed to gpio13 | PWM0 can be routed to gpio12 and gpio18, PWM1 can be routed to gpio13 | ||||||
| and gpio19: | and gpio19: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user