Difference between revisions of "Refactor"
(→Recore) |
(→Boot Recore from a USB stick, eMMC is blank) |
||
Line 78: | Line 78: | ||
===Boot Recore from a USB stick, eMMC is blank=== | ===Boot Recore from a USB stick, eMMC is blank=== | ||
− | Recore should come pre-flashed with | + | Recore should come pre-flashed with Refactor image on the eMMC. If the eMMC has been wiped for some reason |
+ | and you need to do everything from scratch, here are the instructions: | ||
# Flash the ReFactor Linux distro to a USB drive. | # Flash the ReFactor Linux distro to a USB drive. | ||
# Insert the USB drive in the Recore board. | # Insert the USB drive in the Recore board. |
Revision as of 21:01, 11 August 2021
The latest images for Recore and Replicape are available from github: https://github.com/intelligent-agent/Refactor
Contents
- 1 ReFactor is the next generation of controller board software stack installation.
- 2 Why?
- 3 So how do I use it?
- 4 Building a runnable image for Replicape
- 5 Installing a custom software stack with ReFactor from a base Debian image
ReFactor is the next generation of controller board software stack installation.
It is meant to simplify the lives of new users when they begin using a Thing-Printer controller board. Pre-built images of ReFactor are available for users who want to get up and running quickly with Replicape or Recore.
ReFactor is available for Replicape and Recore, with updates being propagated simultaneously for both platforms.
ReFactor uses Ansible as the underlying framework to describe the desired system state. There are many reasons for this:
- Ansible describes the system's end state, not individual actions to perform, so it is relatively easy to port across platforms (i.e. debian, arch, BSD...)
- The ReFactor repository can be updated from the git repository and Ansible will only change what has been updated from the previous version, not needing a complete reinstallation of the system for upgrades.
- Description of components is modular, making it easy to pick and choose different components for the end goal desired, while keeping each component's setup independent and reliable, and independently updatable.
Why?
The ultimate goal is to have multiple decliations of ReFactor, providing the user the ability to choose which firmware/software stack to run on their hardware. The following pre-build declinations are planned:
- OctoPrint, Klipper, Replicape
- OctoPrint, Klipper, Recore
- OctoPrint, Klipper, Toggle, Replicape
- OctoPrint, Klipper, Toggle, Recore
- Duet Web Control, Klipper, Replicape
- Duet Web Control, Klipper, Recore
- OctoPrint, Klipper, Raspberry Pi [1-3]
- OctoPrint, Klipper, Raspberry Pi 4 (arm64 edition)
Only the options in bold have been implemented so far, while the others are undergoing various steps in development in the order shown in this list.
The ReFactor images with OctoPrint are meant to provide drop-in replacements for the previous Umikaze images, including all the extra goodies that were present in Umikaze, like mjpg-streamer, SMB server, and usbreset for the main ones.
The default login is root with password kamikaze. The system will prompt for an immediate password change, to prevent a massive IoT exploitation through the web. Wouldn't want your printer sending out spam or starting to print unauthorized objects, now would we?
So how do I use it?
ReFactor will be usable differently depending on what platform you're running it from.
Replicape
The Replicape images will be meant to run from the micro SD you flash it to. You cannot boot the Replicape from a USB key at this time. By default, ReFactor images do not flash to the eMMC the way Umikaze used to. Part of this is historical - the early betas of ReFactor did not fit on the eMMC, but there's another advantage as well: it allows you to test out ReFactor on an SD card while keeping your working Redeem config on the eMMC.
Booting Refactor from USB
If you want to boot Refactor from a USB stick, you need to stop u-boot by pressing space during boot. You must run these commands:
setenv bootpart 0:1; setenv oldroot /dev/sda1; setenv devnum 0; run usb_boot load ${devtype} ${bootpart} ${loadaddr} /boot/uEnv.txt; env import -t ${loadaddr} ${filesize} run uname_boot
Recore
The Recore images will need to be flashed to a USB flash drive, as there is no SD slot on the board. Recore's uboot is designed to attempt to boot from a USB drive if there is no OS on the eMMC. If there is an OS on the eMMC, the boot button should force start from the USB. (to be confirmed)
Booting from USB if an OS is present on the eMMC
There are two ways to boot Recore, either booting from the internal storage (eMMC) or from a USB mass storage device.
If the eMMC is partitioned and has an OS, u-boot will launch right into that. In order to override that and load the boot script from a USB dongle, stop u-boot by pressing a key and then write:
run bootcmd_usb0
In order to mount the root filesystem on the USB stick, you must change the kernel command line. In the file /boot/armbianEnv.txt add the line:
extraargs=root=/dev/sda1
This can be done on the USB stick.
USB initilization takes several seconds, so it has been disabled by default on the later u-boot in Refactor. If USB is not initialized, you can do it manually from u-boot:
usb reset
Boot Recore from a USB stick, eMMC is blank
Recore should come pre-flashed with Refactor image on the eMMC. If the eMMC has been wiped for some reason and you need to do everything from scratch, here are the instructions:
- Flash the ReFactor Linux distro to a USB drive.
- Insert the USB drive in the Recore board.
- Insert the Recore board in a host computer with the USB-C connector.
- If the eMMC is blank or the "FEL" button is pressed, the board will go into bootloader mode.
- Upload SPL, EL3 and u-boot through the USB port.
- The board will boot using the USB drive.
- Copy the contents of the USB drive into the eMMC/Internal flash.
AR100 firmware
The ar100 has a binary file that is loaded on startup by klipper.service The binary file comes pre-compiled in Refactor, but can be recompiled on Recore (or on a host computer).
Cross compilation toolchain for ARM64
The AR100 needs a cross compilation toolchain. For ARM64, it can be downloaded from feeds.iagent.no:
http://feeds.iagent.no/toolchains/
The toolchain has been built with
https://github.com/richfelker/musl-cross-make
Cross compilation toolchain for x86_64
The toolchain used during automatic testing and is the same used for the CRUST firmware project:
https://github.com/crust-firmware/crust#building-the-firmware
Compiling the ar100 binary
cd /opt wget http://feeds.iagent.no/toolchains/or1k-linux-musl.tar.xz tar xf or1k-linux-musl.tar.xz export PATH=$PATH:/opt/output/bin
To configure klipper for AR100 and build the binary:
cd /home/debian/klipper/ cp test/configs/ar100.config .config make olddefconfig make
This will produce a bin file located in out/ar100.bin. The file can be "flashed" (really loaded into SRAM) by writing
make flash
This is the same operation that happens from the klipper.service script, so it can also be done by running
systemctl restart klipper
STM32 firmware
The firmware for the stm32f031 mcu that is responsible for ADC conversions and PWM for heaters and fans comes pre-installed in the flash of the MCU. It can be recreated on the board using the Klipper build system.
cd /home/debian/klipper cp test/configs/stm32f0.config .config make menuconfig -> Enable extra low-level configuration options -> Clock Reference internal -> Communication interface (Serial (on USART2 PA15/PA14)) -> Baud rate for serial port: 38400 make systemctl stop klipper make recoreflash FLASH_DEVICE=/dev/ttyS4 systemctl start klipper
Flashing ReFactor from a USB drive
Get the latest ReFactor image from here: https://github.com/intelligent-agent/ReFactor/releases for example:
wget https://github.com/intelligent-agent/Refactor/releases/download/v3.0.0/Refactor-recore-v3.0.0-2021-08-06.img.xz
Assuming you have managed to boot Recore from a USB flash drive and you have the ReFactor image available in the same folder, you can use dd to do a direct transfer of the image from the USB drive to eMMC. On Replicape / BeagleBone this will be /dev/mmcblk1
xz -v -d -c Refactor-recore-v3.0.0-2021-08-06.img.xz | dd of=/dev/mmcblk0
Running Klipper
While details are ironed out there is a script that can be used to restart Klipper that will handle resetting things and setting up the steppers etc.
systemctl restart klipper
Running OctoPrint
OctoPrint should start and run on boot, but if there is a need to restart the daemon, use this command
systemctl restart octoprint
Building a runnable image for Replicape
The Replicape runs on a Beaglebone black (or green, without video output), which has a single core ARM processor running at 1GHz with 512MB of RAM. While impressive for an embedded application, it's rather weak when trying to build a system, which can take a lot of time.
There's a significant time gain when building the image from a more powerful host system, then flashing it to memory from an SD card.
The host system can be any ARM v7 or above architecture machine. In this example, the Raspberry Pi 4 will be used as an example, as it has a quad-core arm64 1.5GHz processor with 1 to 4GB of RAM. Any standard linux platform will do, but you will need a build storage space of at least 5GB for the build to succeed. Using a fast SD or a USB3 flash drive can provide higher disk speeds, reducing build time significantly.
To build an image from ReFactor for the Replicape, follow these steps:
- Browse to a folder on the pi where you wish to run the build
- Clone the git repository for ReFactor
- In the ReFactor folder, run the build-image-in-chroot-end-to-end.sh script. It may take some time, so you may want to consider using a screen or byobu session to protect against network drops if you're doing so through SSH.
- If the build completes successfully, you should be left with a file 'Umikaze-console.img.xz'
- Use etcher to write the .img.xz file to a micro SD card, insert it into the Beaglebone, power it up and wait for it to power down.
- Start using the ReFactor image on your printer
Installing a custom software stack with ReFactor from a base Debian image
At the moment ReFactor only supports using a debian-based distribution as a basis. Further down the line it will be refactored so that many more packaging systems are supported - this is not an Ansible limitation, but rather simply a developer time limitation.
The goal for ReFactor is to allow the end-user to choose a custom software stack, while making installation of those packages easier. In this case, the user will want to learn how to write a simple Ansible playbook - there are multiple examples available in the ReFactor base folder (build_full_klipper_octoprint.yml, install_klipper.yml, any yml file really).
The files starting with "build_full_" are meant to be used for the image building described in the previous section. The files starting with "install_" are designed to be run on a printer platform exclusively - not on a host system.
Each install_ file will install a specific component with its required dependencies. For instance, if you with install toggle, it will also install the Beaglebone's graphics drivers, required for video output, along with a number of libraries that Toggle is reliant on (such as a custom-built libclutter using the framebuffer output instead of the X11 driver).
To install a specific component, make sure that you have installed ansible. Alternatively you can just run the prep_ubuntu.sh script - the only thing it does is make sure that Ansible is ready to execute any further tasks required.
Once Ansible is installed, just run "ansible-playbook install_klipper.yml" for example. Let it run and it will go through to make sure everything is available upon the next reboot.
After all packages have been installed as desired, reboot the system. A reboot is necessary, as depending on the software installed, kernel modules may be enabled / disabled, kernel versions may have changed etc. These are unfortunately not changes that can be done without a reboot.