2021-07-22 01:40:40 +03:00
|
|
|
# Beaglebone
|
|
|
|
|
2017-07-05 20:21:02 +03:00
|
|
|
This document describes the process of running Klipper on a Beaglebone
|
2017-10-12 03:50:24 +03:00
|
|
|
PRU.
|
2017-07-05 20:21:02 +03:00
|
|
|
|
2021-07-27 20:29:36 +03:00
|
|
|
## Building an OS image
|
2017-07-05 20:21:02 +03:00
|
|
|
|
|
|
|
Start by installing the
|
2021-05-29 22:09:43 +03:00
|
|
|
[Debian 9.9 2019-08-03 4GB SD IoT](https://beagleboard.org/latest-images)
|
|
|
|
image. One may run the image from either a micro-SD card or from
|
|
|
|
builtin eMMC. If using the eMMC, install it to eMMC now by following
|
|
|
|
the instructions from the above link.
|
2017-07-05 20:21:02 +03:00
|
|
|
|
|
|
|
Then ssh into the beaglebone machine (ssh debian@beaglebone --
|
|
|
|
password is "temppwd") and install Klipper by running the following
|
|
|
|
commands:
|
|
|
|
```
|
|
|
|
git clone https://github.com/KevinOConnor/klipper
|
|
|
|
./klipper/scripts/install-beaglebone.sh
|
|
|
|
```
|
|
|
|
|
2021-07-27 20:29:36 +03:00
|
|
|
## Install Octoprint
|
2017-07-05 20:21:02 +03:00
|
|
|
|
|
|
|
One may then install Octoprint:
|
|
|
|
```
|
|
|
|
git clone https://github.com/foosel/OctoPrint.git
|
|
|
|
cd OctoPrint/
|
|
|
|
virtualenv venv
|
|
|
|
./venv/bin/python setup.py install
|
|
|
|
```
|
|
|
|
|
|
|
|
And setup OctoPrint to start at bootup:
|
|
|
|
```
|
|
|
|
sudo cp ~/OctoPrint/scripts/octoprint.init /etc/init.d/octoprint
|
|
|
|
sudo chmod +x /etc/init.d/octoprint
|
|
|
|
sudo cp ~/OctoPrint/scripts/octoprint.default /etc/default/octoprint
|
|
|
|
sudo update-rc.d octoprint defaults
|
|
|
|
```
|
|
|
|
|
|
|
|
It is necessary to modify OctoPrint's **/etc/default/octoprint**
|
|
|
|
configuration file. One must change the OCTOPRINT_USER user to
|
2017-10-12 03:23:58 +03:00
|
|
|
"debian", change NICELEVEL to 0, uncomment the BASEDIR, CONFIGFILE,
|
|
|
|
and DAEMON settings and change the references from "/home/pi/" to
|
|
|
|
"/home/debian/":
|
2017-07-05 20:21:02 +03:00
|
|
|
```
|
|
|
|
sudo nano /etc/default/octoprint
|
|
|
|
```
|
|
|
|
|
|
|
|
Then start the Octoprint service:
|
|
|
|
```
|
|
|
|
sudo systemctl start octoprint
|
|
|
|
```
|
|
|
|
|
|
|
|
Make sure the octoprint web server is accessible - it should be at:
|
|
|
|
[http://beaglebone:5000/](http://beaglebone:5000/)
|
|
|
|
|
2021-07-27 20:29:36 +03:00
|
|
|
## Building the micro-controller code
|
2017-07-05 20:21:02 +03:00
|
|
|
|
|
|
|
To compile the Klipper micro-controller code, start by configuring it
|
|
|
|
for the "Beaglebone PRU":
|
|
|
|
```
|
|
|
|
cd ~/klipper/
|
|
|
|
make menuconfig
|
|
|
|
```
|
|
|
|
|
|
|
|
To build and install the new micro-controller code, run:
|
|
|
|
```
|
|
|
|
sudo service klipper stop
|
|
|
|
make flash
|
|
|
|
sudo service klipper start
|
|
|
|
```
|
|
|
|
|
2018-06-27 19:04:26 +03:00
|
|
|
It is also necessary to compile and install the micro-controller code
|
|
|
|
for a Linux host process. Run "make menuconfig" a second time and
|
|
|
|
configure it for a "Linux process":
|
2017-08-26 06:31:58 +03:00
|
|
|
```
|
|
|
|
make menuconfig
|
|
|
|
```
|
|
|
|
|
|
|
|
Then install this micro-controller code as well:
|
|
|
|
```
|
|
|
|
sudo service klipper stop
|
|
|
|
make flash
|
|
|
|
sudo service klipper start
|
|
|
|
```
|
|
|
|
|
2021-07-27 20:29:36 +03:00
|
|
|
## Remaining configuration
|
2017-07-05 20:21:02 +03:00
|
|
|
|
|
|
|
Complete the installation by configuring Klipper and Octoprint
|
|
|
|
following the instructions in
|
2017-10-12 03:50:24 +03:00
|
|
|
[the main installation document](Installation.md#configuring-klipper).
|
2018-03-02 19:28:01 +03:00
|
|
|
|
2021-07-27 20:29:36 +03:00
|
|
|
## Printing on the Beaglebone
|
2018-03-02 19:28:01 +03:00
|
|
|
|
|
|
|
Unfortunately, the Beaglebone processor can sometimes struggle to run
|
|
|
|
OctoPrint well. Print stalls have been known to occur on complex
|
|
|
|
prints (the printer may move faster than OctoPrint can send movement
|
|
|
|
commands). If this occurs, consider using the "virtual_sdcard" feature
|
2020-11-17 02:47:32 +03:00
|
|
|
(see [config reference](Config_Reference.md#virtual_sdcard) for
|
|
|
|
details) to print directly from Klipper.
|