Upgrading a Creality Ender 3: SKR Mini E3 & BLTouch
Henk installed an SKR Mini E3 V2.0 board with a touchscreen and a BL Touch Z leveling sensor. The kit includes a working build of Marlin 2.0.x firmware for the Creality Ender-3. This comes pre-loaded on the SD card and can be used immediately following installation (it’s called FIRMWARE.CUR). After starting up the printer, the BLT’s probe goes up (deploys) and down (stows) which is supposed to happen (self test) and lights up red. We also get an info message saying ‘Fade Height OFF’ which I read online is fine. The touchscreen works fine and the BLT seems to function; however when we go to ABL (auto bed leveling) and start the procedure, an error occurs. It’s also not possible to move the Z axis up and down with the move menu, although we can clearly see it’s moving up and down just fine when homing the Z axis. When moving the X and Y axis, the distance moved also doesn’t seem to be right.
It’s recommended to update the firmware, so I’ll start with that. I followed the instructions on the Github page:
- Download the desired firmware BIN file to your computer.
- Rename the file to firmware.bin if it differs.
- Copy the file to the SD card included with the board.
- Power on the 3D Printer with the SD card loaded.
I downloaded the ‘firmware-bltouch-for-z-homing.bin’ and removed the firmware.cur file just to be sure it wouldn’t interfere. What is supposed to happen is that the screen goes blue for about 20 seconds while it’s flashing the software, and renames the file to FIRMWARE.CUR; but neither happen. When I tried INIT SD CARD the printer started moving and I encountered a new error with the BLT and a suggestion to restart the machine (was too slow to take a picture of this). However after that the file was renamed to FIRMWARE.CUR. The homing of the X and Y axis still happens with the end stops so I don’t think it properly worked.
I tried starting a test print hoping something would happen but I got an error with the BLT instead (which makes sense).
Then after following this tutorial, I disconnected the Z endstop and moved the black and white cable there. After that the Z leveling automatically happens with the BLT and the print head moves to the center, but since the BLTouch was too far away from the bed, the nozzle damaged the bed.
After moving the BLTouch up Z leveling went fine; however when starting ABL it only worked in the center of the bed, the next corner (left front) produced an error ‘Probing Failed’.
Setting the Z Probe offset
I could still start prints though since that only used the center bed Z leveling; however it would start printing approximately 12 mm above the bed so I need to set the Z probe offset first. I tried this via the menu. The positive offset seemed to work (the printer started printing higher), but the negative offset (which I needed) didn’t change anything so that also wasn’t great.
Next I wanted to use this method:
“Basically if I have an object of a known size, i.e. a cube that I use calipers to measure the height, raise the Z axis (using the controls on the printer), put the cube directly under the nozzle and adjust the Z axis so that the nozzle barely touches the cube, I’d know exactly the Z Probe Offset. If the cube is say 15 mm tall and the Z axis shows 15.88 mm, I’d set the Z Probe Offset to be -0.88 mm. So much less guess work in this. Don’t forget to store the settings after setting the Z Probe Offset. Since my settings are pretty good using the Babystep Z (with my firmware options simply called Z Probe Offset), I haven’t actually tried using a cube of known size to set the offset.”
However since there’s also still the issue of not being able to move the axes properly that didn’t help.
My next attempt is connecting the printer via Pronterface to see if I could magically make the axes move properly. Moving 0.1mm and 1mm seemed to be fine, moving 10mm the print head moved about 1.5mm, and moving 100mm the printer just made a skitting sound and the print head didn’t move in X or Y direction. The Z axis doesn’t move at all. After disconnecting and reconnecting and sending commands in pronterface it did work (for a while) but I have no clue what changed; the Z axis is still not moving though. Homing the axes with the single X, Y and Z axis homing button behaved strangely; after the X and Y axis homed, the print head suddenly started traveling to the right and tried to go through the machine so I quickly turned it off. After that I homed the axes individually and nothing strange happened so I’m just confused since everything that’s happening seems so random.
I connected the printer to Pronterface since this is how this tutorial is setting the Z Probe Offset. I saw that they sent an M503 command to get an overview of all of the current settings so I started with that.
So the steps I followed are:
- Home X, Y and Z
- M851 Z0 (resets Z offset to 0; I checked if it worked with another M503 command)
- M500 (stores these settings in the EEPROM)
- M501 (restore settings, set them as active parameters)
- M503 (displays current active settings)
- G28 Z (homes Z axis only)
- G1 F60 Z0 (moves nozzle to current 0.00 Z with 60 as speed): at this point the nozzle is about 3.5mm above the bed (estimated with sliding a 3mm acrylic sheet under the nozzle)
- M211 S0 (switches off soft endstops, which prevent you from going below the absolute 0)
- Move the Z axis down with a piece of paper between the nozzle and the bed with very small steps until you can barely move the paper due to the friction. THIS IS THE FIRST TIME THAT I CAN ACTUALLY MOVE THE Z AXIS. For me this was at Z: -3.30mm. Add the thickness of the paper (0.08 in my case), so that makes a Z Probe Offset of -3.38mm.
- M851 Z -3.38 (sets Z offset to true offset)
- M211 S1 (turns on soft endstops)
- M500 (saves these settings to EEPROM)
- M501 (set EEPROM as active parameters)
- M503 (check again if everything was properly saved)
I don’t know why but now I could move the Z axis with the buttons in Pronterface. Then a bit later it didn’t; I could see the Z axis value changing on the touch screen but nothing was actually moving. After following the homing procedure, M500, M501 and M503 it however did move; but Z0 is again floating about 15mm above the bed. When redoing all of the steps above a regular print starts at the correct Z0 again.
ABL still didn’t work (same issue as this person). I also checked Reddit and tried to level the bed via the Marlin LCD emulator (if you press the physical button for 3 seconds you can switch modes, more information on that here). That also didn’t work.
After printing a test print I wanted to see if ABL magically worked, and it actually did. For the first time it finished the entire bed leveling procedure, leaving me very confused why it works now suddenly. It also is now possible to move all of the axes.
For the next test print I changed the Z Probe offset to 3.88, since I had to babystep Z to -.50mm because it was still printing in the air; while printing I babystepped to +0.10mm again for the squares in the back of the bed, but that was too much for the squares in the middle and front, so I’m guessing the printer is not using the ABL data. In this post it’s mentioned that you need a G29 (bed leveling/ABL) right after a G28, since G28 clears the mesh. I’m going to check this by adding a G29 to the gcode of the test squares.
Startup code from PrusaSlicer:
I still babystepped immediately +0.1mm and halfway through to +0.2mm so I decided to change the Z offset to -3.68mm. My conclusion is that the G29 is actually necessary. At first I thought that would be another issue to fix but luckily, there is a PrusaSlicer for an Ender 3 with BLTouch installed specifically which does precisely that so for now the BLTouch install is complete.