This article describes another release for Marlin this version is based on 2.0.9.3 released 25th December 2021 and prepared for use with an updated custom hardware configuration comprising of the: E3D Hemera Hot-end, the BigTreeTech SKR 1.4 Turbo board, TMC2209 stepper drivers and the BLTouch v3.1. The printer frame and PSU are from a Ender 3 Pro (v1).
This release is intended for use with the E3D Hemera Hot-end.
Table of Contents
Here are some highlights on key features enabled in this custom version of Marlin 2.0.9.3:
- Compiled for: LPC1769
- Enables
HOST_ACTION_COMMANDS
in firmware. - E3D Hemera Hot-end support
- Bed-size reduced to safe values 235 and probe margins revised for new hot-end carriage and mount.
- TMC2209 drivers with Stealth-chop & Hybrid threshold enabled on X, Y, Z axis.
- TMC_DEBUG enabled by default.
- BLTouch for ABL Bilinear.
- Auto bed levelling is used in addition to the Z-stop switch.
- Menu for levelling bed corners.
- Restores bed levelling after G28.
- Probes bed once at each point.
- Movement on any axis is restricted until axis’s are homed.
- PID Tuning
- Extruder fan after 50°C
- Z Safe homing
- Advanced pause & filament change
- Homing & Probing wizards
- Junction Deviation
- Support to mute menu sound
- Custom quick commands:
- Home & Level bed
- Home & Info
To read more on changes introduced check the official Marlin 2.0.9.3 change log. Before we begin it’s assumed that you have the following equipment:
- E3D Hemera Hot-end.
- BTT SKR 1.4 Turbo Board.
- BLTouch v3.1 (other versions of the BLTouch will work but you will need to adjust settings related to it and check your wiring).
Preparation
PlatformIO Installation
I suggest VSCode as a quick method for compiling the Marlin 2.0.x from source.
- Download VSCode and install.
- Open VSCode > Extension Manager > Search for and install the official PlatformIO IDE extension.
Firmware configuration source files
You can download the binary release for the firm or optionally build you own with the configuration files and instructions provided.
If you use the binary release please consider reviewing the checklist on tasks to perform after updating your 3D printers firmware.
Binary release
- View and download the: Binary releases v2.0.9.3 on GitLab
Building your own binary
I have made my Marlin configurations and compiled firmware binaries available for download they feature the same changes mentioned within this article; if you use my configuration you should review your Probe offsets, check driver currents & determine if your endstops require inversion.
You will find configurations for both the stock hot-end and the newly added E3D Hemera hot-end:
- Marlin 2.0.9.3 – BTT SKR1.4 and the E3D Hemera Hot-end: https://gitlab.com/oddineers-public/marlin-ender-3/-/tags/Marlin-2.0.9.3-Hemera
To build your own variant from source; start by downloading the relevant Marlin releases used in this article from Marlin 2.0.9.3 branch:
- Official Marlin 2.0.9.3 source code: https://github.com/MarlinFirmware/Marlin/releases/tag/2.0.9.3
Once you have downloaded the sources above you will need to extract them to an accessible location, use the following steps as a reference:
- Download and extract Marlin 2.0.9.3 sources
- Copy the 4 files to the
Marlin
directory contained within the extracted Marlin 2.0.9.3 sources. - Then update the
platform.ini
filedefault_envs
toLPC1769
and save. - Compile by running the PlatformIO build operation: CTRL + ALT + B (Windows users).
Binary release releases are available on the GitLab project page
Firmware configuration modifications
Next we will be modifying 2 specific files from the release to customise the firmware for to our requirements:
/Marlin/Configuration.h
/Marlin/Configuration_adv.h
Depending upon whether you used my configurations or the stock configurations will determine if you need to merge the changes required to support the new hardware:
- Compare file:
/Marlin/Configuration.h
with custom file: Configuration.h (GitLab) - Compare file:
/Marlin/Configuration_adv.h
with custom file: Configuration_adv.h (GitLab)
Switching back to Classic Jerk from Junction Deviation
The binary release attached to the GitLab repository uses Junction Deviation.
In the configuration provided you can change from junction deviation back to classic jerk by commenting out (omitting) #CLASSIC_JERK
(found in file Configuration.h).
To utilise Junction deviation comment out #CLASSIC_JERK:
//#define CLASSIC_JERK
To utilise Classic Jerk remove omission by deleting forward slashes prepended to #CLASSIC_JERK:
#define CLASSIC_JERK
Checklist & suggested reading
Friendly reminder; consider reviewing the checklist on tasks to perform after updating your 3D printers firmware.
It¦s actually a cool and helpful piece of information. I¦m happy that you simply shared this helpful information with us. Please keep us up to date like this. Thank you for sharing.