This script sets up the build environment collects dependencies and provides commands for building and uploading Marlin from the commandline. It uses the official Arduino toolchain. Everything is standalone, nothing is installed.
The script is setup by default to build the Marlin fork “Skynet3D” for the Anet A8 Prusa clone on a Raspberry Pi.
Recently Anet A6/A8 support has been merged back into the main Marlin branch. You can find example configurations for Anet printers in the Marlin sources at: https://github.com/MarlinFirmware/Marlin/tree/1.1.x/Marlin/example_configurations/Anet If you want to build stock Marlin change the “marlinRepositoryUrl” parameter respectively.
Several parameters at the beginning of the script allow to adapt it further to your needs.
-
If you dont need additional hardware/board definitions because you can use the ones that come with the toolchain set the parameter “hardwareDefintionDirectory” to an empty string. This prevents the script from trying to copy the board definition that is needed for the A8.
-
If you need additional libraries for your build add them to the "getDependencies" function.
-
The build platform architecture is autodetected. At the moment Linux 32 Bit, 64 Bit and ARM are supported.
Reminder: If you are running octopi on you Raspberry you need to disconnect it from your printer before uploading, otherwise the serial port is blocked.
Download and configure the toolchain and the necessary libraries for building Marlin.
Download Marlin sources.
Update an existing Marlin clone.
Build without uploading.
Build and upload Marlin. If you are running octopi on you Raspberry
you need to disconnect it before uploading otherwise the serial port is blocked.
Backup the Marlin configuration to the named backup.
Restore the given configuration into the Marlin directory.
Cleanup everything. Remove Marlin sources and Arduino toolchain.
Set the serialport for uploading the firmware. Overrides the default set in the script.
Show help.