Power Loss Shutdown & Power Loss Recovery
Important Notes
1. Function Concepts and Processes
-
Power Loss Shutdown
- Concept: Upon detecting an abnormal power loss, the system does not save the current printing state and directly executes a safe shutdown.
- Recovery Process: After power is restored, the device will automatically restart and stand by. The previous print job is aborted, and you need to manually start a new print.
-
Power Loss Recovery
- Concept: Upon detecting an abnormal power loss, the system immediately saves the current print progress (e.g., position, layer height) before shutting down.
- Recovery Process: After power is restored, user confirmation is typically required before the device can resume and complete the unfinished print from the point of interruption.
2. Core Rules
- Power Loss Shutdown and Power Loss Recovery are mutually exclusive functions and cannot be enabled simultaneously.
- If the Power Loss Shutdown function is enabled, the Power Loss Recovery function will automatically become inactive.
3. How to Choose
- Choose "Power Loss Shutdown": If you are more concerned about electrical safety, or want the device to automatically start up and stand by after power is restored without resuming an interrupted print, enable this function.
- Choose "Power Loss Recovery": If you frequently perform long-duration, critical print jobs and wish to resume printing from the interruption point after a power loss, enable this function.
Wiring
Important Precautions
- FLY C8 Power Loss Shutdown/Recovery Function Notes
- When connecting to other mainboards via USB, the 5V power line must be disconnected or isolated (e.g., by cutting the cable or using a USB cable with only data pins)
- The KPPM module must be connected; otherwise, normal operation is not possible
- If the 5V connection between the lower computer and the upper computer cannot be disconnected, the mainboard must be completely powered off before it can be restarted; otherwise, it may fail to boot normally
- FLY-C8 Wiring
- FLY-C8 V1.2 Wiring
- FLY-C8 using USB connection
Loading...
- FLY-C8 V1.2
Loading...
Configuration
- Power Loss Shutdown
- Power Loss Recovery
Configure Power-off Shutdown
Note
- Method for configuring power-off shutdown
-
Enter the device's IP address in the browser's address bar, for example:
http://192.168.6.179 -
Access the configuration page
- Open the device IP address in the browser, for example:
http://192.168.1.2/ - In fluidd, as shown on the left side of the image below,
uncheck->Filter hidden files and folders. - In mainsail, as shown on the right side of the image below,
check->Show hidden files.
Loading...Loading...- At this point, you can see the
.flyos-configfolder. Entering this folder will reveal thesys-config.conffile. - The
sys-config.conffile is a symbolic link to the configuration fileconfig.txtin the removable diskFlyOS-Conf.
Loading...- Open the
sys-config.conffile, locate theshutdown_pin_stateandshutdown_pin=configurations, and change them to the settings below. - Please note that
shutdown_pin=noneshould be deleted or prefixed with#
- Open the device IP address in the browser, for example:
shutdown_pin_state=1
shutdown_pin=PA21
- Then
Save->Closeand restart the system.
Loading...
Disable Power-Off Shutdown
Note
- Power-off shutdown must be disabled; otherwise, power-loss resume printing will not work.
- There is an auto-shutdown function after saving progress during power-loss resume printing.
- Ensure no other power source is connected to the host, otherwise it will not be able to power on.
-
Enter the device's IP address in the browser's address bar, for example:
http://192.168.6.179 -
Access the configuration page
- Open the device IP address in the browser, for example:
http://192.168.1.2/ - In Fluidd, as shown on the left side of the image below,
uncheck->Filter hidden files and folders. - In Mainsail, as shown on the right side of the image below,
check->Show hidden files.
Loading...Loading...- At this point, you can see the
.flyos-configfolder. Entering this folder will reveal asys-config.conffile. - The
sys-config.conffile is a symlink to the configuration fileconfig.txtin the removable diskFlyOS-Conf.
Loading...- Open the
sys-config.conffile and find the two configurations:shutdown_pin_stateandshutdown_pin= - Add
#before both of these configurations - Then
Save->Closeand restart the device.
Loading... - Open the device IP address in the browser, for example:
plr.cfg Configuration File
- In the printer configuration page, locate the
plr.cfgfile. - Clear its contents and paste the configuration below into it.
- The configuration file content is as follows:
[mcu host]
serial: /tmp/klipper_host_mcu
[power_loss_resume]
power_pin: host:gpiochip1/gpio21
is_shutdown: True # Whether to perform shutdown operation, enabled by default
paused_recover_z: -2.0 # Z-axis movement distance when resuming from a paused print, defaults to no movement
start_gcode:
# G-code executed before resuming the print
# All parameters saved before power loss can be accessed via {PLR}
# Use M118 {PLR} to output all available parameters
# M118 {PLR}
M118 Resuming print: {PLR.print_stats.filename}
M118 Interruption position: X:[{PLR.POS_X}] Y:[{PLR.POS_Y}] Z:[{PLR.POS_Z}] E:[{PLR.POS_E}]
# Restore all heater temperatures
{% for name, heater in PLR.heaters.items() %}
{% if heater.target > 0 %}
M118 Setting heater[{heater.name}] target temperature: {heater.target}
SET_HEATER_TEMPERATURE HEATER="{heater.name}" TARGET={heater.target}
{% endif %}
{% endfor %}
# Wait for extruder temperature
{% if PLR.toolhead.extruder in PLR.heaters and PLR.heaters[PLR.toolhead.extruder].target > 0 %}
{% set extruder = PLR.heaters[PLR.toolhead.extruder] %}
M118 Waiting for [{extruder.name}] to reach target temperature: {extruder.target}
TEMPERATURE_WAIT SENSOR="{extruder.name}" MINIMUM={extruder.target-5} MAXIMUM={extruder.target+5}
{% endif %}
G91 ; Relative positioning
G1 Z2 F100 ; Raise Z, prepare for X, Y homing
G90 ; Absolute positioning
G28 X Y ; Home X and Y axes
M83 ; Relative extrusion mode
# G1 E0.5 F400 ; Extrude a small amount
layer_count: 2 # Execute layer_change_gcode after printing the specified number of layers
layer_change_gcode:
# G-code to execute after printing {layer_count} layers
M118 Restoring print speed
M106 S{PLR.fan_speed} ; Turn on part cooling fan
M220 S{PLR.move_speed_percent} ; Set requested speed percentage
M221 S{PLR.extrude_speed_percent} ; Set requested extrusion speed percentage
shutdown_gcode:
# G-code executed before shutdown
M118 Low power voltage, shutting down
# M112 ; Emergency stop
-
After saving the configuration file above,
-
Open the
printer.cfgfile and add the following content at the very beginning:[include plr.cfg] -
Click "Save and Restart" in the upper right corner.
-
At this point, the Klipper power loss recovery feature has been configured.
About [homing_override]
Note
- If
[homing_override]is used, do not arbitrarily set the homing position within[homing_override]. Failure to do so may result in print resume failure and no responsibility will be accepted. - Configuration instructions for
[homing_override]are provided below.
- Explanation
[force_move]: Enables the forced move function, allowing forced movement to a specified position when not homed.[force_move]replaces theset_position_zfunction in[homing_override]. Failure to configure this way may lead to print resume failure.- The
[homing_override]configuration below is intended to correctly home the Z-axis during print resume.
[force_move]
enable_force_move: true
[homing_override]
axes: z
gcode:
{% set max_x = printer.configfile.config["stepper_x"]["position_max"]|float %}
{% set max_y = printer.configfile.config["stepper_y"]["position_max"]|float %}
{% if 'z' not in printer.toolhead.homed_axes %}
SET_KINEMATIC_POSITION Z=0
G90
G0 Z5 F600
{% endif %}
{% set home_all = 'X' not in params and 'Y' not in params and 'Z' not in params %}
{% if home_all or 'X' in params %}
G28 X
{% endif %}
{% if home_all or 'Y' in params %}
G28 Y
{% endif %}
{% if home_all or 'Z' in params %}
G0 X{max_x / 2} Y{max_y / 2} F3600
G28 Z
G1 Z10 F2000
{% endif %}
- About Lift Explanation
- This configuration only executes when the Z-axis is not homed and does not affect normal usage.
{% if 'z' not in printer.toolhead.homed_axes %}SET_KINEMATIC_POSITION Z=0G90G0 Z5 F600{% endif %}
- This configuration only executes when the Z-axis is not homed and does not affect normal usage.
About Configuration for [gcode_macro _CLIENT_VARIABLE]
- When your configuration includes the
[gcode_macro _CLIENT_VARIABLE]macro and sets the following variables: - Reference
[gcode_macro _CLIENT_VARIABLE]
variable_use_custom_pos: True # Enable custom position
variable_custom_park_dz: 5 # Set custom park height offset
- You must accordingly adjust the
paused_recover_zparameter in the [power_loss_resume] module, making it opposite in sign to the offset value above.
Configuration Correspondence
| Macro Variable | Pause/Resume Module Parameter | Correspondence |
|---|---|---|
variable_custom_park_dz: 5 | paused_recover_z: -5 | Opposite sign, same value |
variable_custom_park_dz: -3 | paused_recover_z: 3 | Opposite sign, same value |
Example Configuration
[gcode_macro _CLIENT_VARIABLE]
variable_use_custom_pos: True
variable_custom_park_dz: 5
[power_loss_resume]
paused_recover_z: -5
Important: Failure to maintain this correspondence may lead to incorrect Z-axis height calculation during print resume or pause recovery, affecting the print.
Testing
First Step Test: Simulating Power Loss via Emergency Stop
- Start printing any file. During the print, click the Emergency Stop button to simulate a power loss scenario.
- Click Firmware Restart again and wait for
Klipperto reconnect and return to normal. - Check if a popup notification appears on the web interface. If it appears, the print resume function is working correctly.
- Subsequently, you can further test with an actual power loss to verify the function's reliability.
Second Step Test: Actual Power Loss Simulation and Function Verification
- Test Preparation: After the system starts normally and connects to
Klipper, first confirm the status of the indicator light next to the host computer. Usually, anLEDwill blink when the system is running. This indicator light is the key one to observe in subsequent steps. - While the device is running normally and connected to
Klipper, directly disconnect the power to simulate a real power loss scenario. - Immediately check if the indicator light next to the host computer turns off completely within 5 seconds.
- If it turns off: The power-off shutdown function is normal. Please proceed with the subsequent steps.
- If it does not turn off: The automatic shutdown function is not working. This is usually due to incorrect related configurations (such as
kppmwiring or settings), which need to be carefully checked and troubleshot.
- Wait at least
5seconds, then reconnect the power. Observe ifKlipperautomatically reconnects and returns to normal operation. (Saving data and shutting down takes3-5seconds). - Check the web interface
- If a popup notification appears: The print resume function has been successfully activated and is operating normally.
- If there is no notification: The print resume function did not start as expected. Please systematically check the relevant configurations based on the above observations.
Loading...