2018-03-08 20:06:24 +01:00
|
|
|
This document describes the commands that Klipper supports. These are
|
|
|
|
commands that one may enter into the OctoPrint terminal tab.
|
|
|
|
|
|
|
|
# G-Code commands
|
|
|
|
|
|
|
|
Klipper supports the following standard G-Code commands:
|
|
|
|
- Move (G0 or G1): `G1 [X<pos>] [Y<pos>] [Z<pos>] [E<pos>] [F<speed>]`
|
|
|
|
- Dwell: `G4 P<milliseconds>`
|
|
|
|
- Move to origin: `G28 [X] [Y] [Z]`
|
|
|
|
- Turn off motors: `M18` or `M84`
|
|
|
|
- Wait for current moves to finish: `M400`
|
2018-03-08 20:40:26 +01:00
|
|
|
- Select tool: `T<index>`
|
2018-03-08 20:06:24 +01:00
|
|
|
- Use absolute/relative distances for extrusion: `M82`, `M83`
|
|
|
|
- Use absolute/relative coordinates: `G90`, `G91`
|
|
|
|
- Set position: `G92 [X<pos>] [Y<pos>] [Z<pos>] [E<pos>]`
|
2018-03-18 16:29:40 +01:00
|
|
|
- Set speed factor override percentage: `M220 S<percent>`
|
2018-03-08 20:06:24 +01:00
|
|
|
- Set extrude factor override percentage: `M221 S<percent>`
|
2018-06-15 18:00:33 +02:00
|
|
|
- Set acceleration: `M204 S<value>`
|
2018-03-08 20:06:24 +01:00
|
|
|
- Get extruder temperature: `M105`
|
|
|
|
- Set extruder temperature: `M104 [T<index>] [S<temperature>]`
|
|
|
|
- Set extruder temperature and wait: `M109 [T<index>] S<temperature>`
|
2018-10-28 19:19:30 +01:00
|
|
|
- Note: M109 always waits for temperature to settle at requested
|
|
|
|
value
|
2018-03-08 20:06:24 +01:00
|
|
|
- Set bed temperature: `M140 [S<temperature>]`
|
|
|
|
- Set bed temperature and wait: `M190 S<temperature>`
|
2018-10-28 19:19:30 +01:00
|
|
|
- Note: M190 always waits for temperature to settle at requested
|
|
|
|
value
|
2018-03-08 20:06:24 +01:00
|
|
|
- Set fan speed: `M106 S<value>`
|
|
|
|
- Turn fan off: `M107`
|
|
|
|
- Emergency stop: `M112`
|
|
|
|
- Get current position: `M114`
|
|
|
|
- Get firmware version: `M115`
|
|
|
|
|
|
|
|
For further details on the above commands see the
|
|
|
|
[RepRap G-Code documentation](http://reprap.org/wiki/G-code).
|
|
|
|
|
|
|
|
Klipper's goal is to support the G-Code commands produced by common
|
|
|
|
3rd party software (eg, OctoPrint, Printrun, Slic3r, Cura, etc.) in
|
|
|
|
their standard configurations. It is not a goal to support every
|
|
|
|
possible G-Code command. Instead, Klipper prefers human readable
|
|
|
|
["extended G-Code commands"](#extended-g-code-commands).
|
|
|
|
|
2018-10-28 15:11:15 +01:00
|
|
|
If one requires a less common G-Code command then it may be possible
|
|
|
|
to implement it with a custom Klipper gcode_macro (see
|
|
|
|
[example-extras.cfg](../config/example-extras.cfg) for details). For
|
|
|
|
example, one might use this to implement: `G10`, `G11`, `G12`, `G29`,
|
|
|
|
`G30`, `G31`, `M42`, `M80`, `M81`, etc.
|
|
|
|
|
2018-03-08 20:06:24 +01:00
|
|
|
## G-Code SD card commands
|
|
|
|
|
|
|
|
Klipper also supports the following standard G-Code commands if the
|
|
|
|
"virtual_sdcard" config section is enabled:
|
|
|
|
- List SD card: `M20`
|
|
|
|
- Initialize SD card: `M21`
|
|
|
|
- Select SD file: `M23 <filename>`
|
|
|
|
- Start/resume SD print: `M24`
|
|
|
|
- Pause SD print: `M25`
|
|
|
|
- Set SD position: `M26 S<offset>`
|
|
|
|
- Report SD print status: `M27`
|
|
|
|
|
2018-07-08 16:12:23 +02:00
|
|
|
## G-Code display commands
|
|
|
|
|
|
|
|
The following standard G-Code commands are available if a "display"
|
|
|
|
config section is enabled:
|
|
|
|
- Display Message: `M117 <message>`
|
|
|
|
- Set build percentage: `M73 P<percent>`
|
|
|
|
|
2018-07-08 16:20:36 +02:00
|
|
|
## Other available G-Code commands
|
|
|
|
|
|
|
|
The following standard G-Code commands are currently available, but
|
|
|
|
using them is not recommended:
|
|
|
|
- Offset axes: `M206 [X<offset>] [Y<offset>] [Z<offset>]` (Use
|
|
|
|
SET_GCODE_OFFSET instead.)
|
|
|
|
- Get Endstop Status: `M119` (Use QUERY_ENDSTOPS instead.)
|
|
|
|
|
2018-03-08 20:06:24 +01:00
|
|
|
# Extended G-Code Commands
|
|
|
|
|
|
|
|
Klipper uses "extended" G-Code commands for general configuration and
|
|
|
|
status. These extended commands all follow a similar format - they
|
|
|
|
start with a command name and may be followed by one or more
|
|
|
|
parameters. For example: `SET_SERVO SERVO=myservo ANGLE=5.3`. In this
|
|
|
|
document, the commands and parameters are shown in uppercase, however
|
|
|
|
they are not case sensitive. (So, "SET_SERVO" and "set_servo" both run
|
|
|
|
the same command.)
|
|
|
|
|
|
|
|
The following standard commands are supported:
|
|
|
|
- `QUERY_ENDSTOPS`: Probe the axis endstops and report if they are
|
|
|
|
"triggered" or in an "open" state. This command is typically used to
|
|
|
|
verify that an endstop is working correctly.
|
2018-03-10 03:43:24 +01:00
|
|
|
- `GET_POSITION`: Return information on the current location of the
|
|
|
|
toolhead.
|
2018-04-21 01:58:37 +02:00
|
|
|
- `SET_GCODE_OFFSET [X=<pos>|X_ADJUST=<adjust>]
|
|
|
|
[Y=<pos>|Y_ADJUST=<adjust>] [Z=<pos>|Z_ADJUST=<adjust>]`: Set a
|
|
|
|
positional offset to apply to future G-Code commands. This is
|
|
|
|
commonly used to virtually change the Z bed offset or to set nozzle
|
|
|
|
XY offsets when switching extruders. For example, if
|
|
|
|
"SET_GCODE_OFFSET Z=0.2" is sent, then future G-Code moves will
|
|
|
|
have 0.2mm added to their Z height. If the X_ADJUST style parameters
|
|
|
|
are used, then the adjustment will be added to any existing offset
|
|
|
|
(eg, "SET_GCODE_OFFSET Z=-0.2" followed by "SET_GCODE_OFFSET
|
|
|
|
Z_ADJUST=0.3" would result in a total Z offset of 0.1).
|
2018-03-18 16:23:20 +01:00
|
|
|
- `PID_CALIBRATE HEATER=<config_name> TARGET=<temperature>
|
|
|
|
[WRITE_FILE=1]`: Perform a PID calibration test. The specified
|
|
|
|
heater will be enabled until the specified target temperature is
|
|
|
|
reached, and then the heater will be turned off and on for several
|
|
|
|
cycles. If the WRITE_FILE parameter is enabled, then the file
|
|
|
|
/tmp/heattest.txt will be created with a log of all temperature
|
|
|
|
samples taken during the test.
|
2018-09-18 22:00:13 +02:00
|
|
|
- `TURN_OFF_HEATERS`: Turn off all heaters.
|
2018-04-21 04:13:29 +02:00
|
|
|
- `SET_VELOCITY_LIMIT [VELOCITY=<value>] [ACCEL=<value>]
|
2018-07-08 20:08:21 +02:00
|
|
|
[ACCEL_TO_DECEL=<value>] [SQUARE_CORNER_VELOCITY=<value>]`: Modify
|
|
|
|
the printer's velocity limits. Note that one may only set values
|
|
|
|
less than or equal to the limits specified in the config file.
|
2018-05-20 18:52:19 +02:00
|
|
|
- `SET_PRESSURE_ADVANCE [EXTRUDER=<config_name>] [ADVANCE=<pressure_advance>]
|
2018-04-01 21:26:25 +02:00
|
|
|
[ADVANCE_LOOKAHEAD_TIME=<pressure_advance_lookahead_time>]`:
|
2018-05-20 18:52:19 +02:00
|
|
|
Set pressure advance parameters. If EXTRUDER is not specified, it
|
|
|
|
defaults to the active extruder.
|
2018-05-24 15:42:33 +02:00
|
|
|
- `STEPPER_BUZZ STEPPER=<config_name>`: Move the given stepper forward
|
|
|
|
one mm and then backward one mm, repeated 10 times. This is a
|
|
|
|
diagnostic tool to help verify stepper connectivity.
|
2019-02-07 00:50:00 +01:00
|
|
|
- `MANUAL_PROBE [SPEED=<speed>]`: Run a helper script useful for
|
|
|
|
measuring the height of the nozzle at a given location. If SPEED is
|
|
|
|
specified, it sets the speed of TESTZ commands (the default is
|
|
|
|
5mm/s). During a manual probe, the following additional commands are
|
|
|
|
available:
|
|
|
|
- `ACCEPT`: This command accepts the current Z position and
|
|
|
|
concludes the manual probing tool.
|
|
|
|
- `ABORT`: This command terminates the manual probing tool.
|
|
|
|
- `TESTZ Z=<value>`: This command moves the nozzle up or down by the
|
|
|
|
amount specified in "value". For example, `TESTZ Z=-.1` would move
|
|
|
|
the nozzle down .1mm while `TESTZ Z=.1` would move the nozzle up
|
|
|
|
.1mm. The value may also be `+`, `-`, `++`, or `--` to move the
|
|
|
|
nozzle up or down an amount relative to previous attempts.
|
|
|
|
- `Z_ENDSTOP_CALIBRATE [SPEED=<speed>]`: Run a helper script useful
|
|
|
|
for calibrating a Z position_endstop config setting. See the
|
|
|
|
MANUAL_PROBE command for details on the parameters and the
|
|
|
|
additional commands available while the tool is active.
|
2018-03-08 20:06:24 +01:00
|
|
|
- `RESTART`: This will cause the host software to reload its config
|
|
|
|
and perform an internal reset. This command will not clear error
|
|
|
|
state from the micro-controller (see FIRMWARE_RESTART) nor will it
|
|
|
|
load new software (see
|
|
|
|
[the FAQ](FAQ.md#how-do-i-upgrade-to-the-latest-software)).
|
|
|
|
- `FIRMWARE_RESTART`: This is similar to a RESTART command, but it
|
|
|
|
also clears any error state from the micro-controller.
|
2018-09-16 17:37:00 +02:00
|
|
|
- `SAVE_CONFIG`: This command will overwrite the main printer config
|
|
|
|
file and restart the host software. This command is used in
|
|
|
|
conjunction with other calibration commands to store the results of
|
|
|
|
calibration tests.
|
2018-03-08 20:06:24 +01:00
|
|
|
- `STATUS`: Report the Klipper host software status.
|
|
|
|
- `HELP`: Report the list of available extended G-Code commands.
|
|
|
|
|
|
|
|
## Custom Pin Commands
|
|
|
|
|
2018-03-28 21:11:10 +02:00
|
|
|
The following command is available when an "output_pin" config section
|
|
|
|
is enabled:
|
2018-03-08 20:06:24 +01:00
|
|
|
- `SET_PIN PIN=config_name VALUE=<value>`
|
|
|
|
|
|
|
|
## Servo Commands
|
|
|
|
|
|
|
|
The following commands are available when a "servo" config section is
|
|
|
|
enabled:
|
2018-11-14 15:38:09 +01:00
|
|
|
- `SET_SERVO SERVO=config_name [WIDTH=<seconds>] [ENABLE=<0|1>]`
|
|
|
|
- `SET_SERVO SERVO=config_name [ANGLE=<degrees>] [ENABLE=<0|1>]`
|
2018-03-08 20:06:24 +01:00
|
|
|
|
|
|
|
## Probe
|
|
|
|
|
|
|
|
The following commands are available when a "probe" config section is
|
|
|
|
enabled:
|
|
|
|
- `PROBE`: Move the nozzle downwards until the probe triggers.
|
|
|
|
- `QUERY_PROBE`: Report the current status of the probe ("triggered"
|
|
|
|
or "open").
|
2019-02-10 00:20:28 +01:00
|
|
|
- `PROBE_CALIBRATE [SPEED=<speed>]`: Run a helper script useful for
|
|
|
|
calibrating the probe's z_offset. See the MANUAL_PROBE command for
|
|
|
|
details on the parameters and the additional commands available
|
|
|
|
while the tool is active.
|
2018-03-08 20:06:24 +01:00
|
|
|
|
2018-12-04 04:52:32 +01:00
|
|
|
## BLTouch
|
|
|
|
|
|
|
|
The following command is available when a "bltouch" config section is
|
|
|
|
enabled:
|
|
|
|
- `BLTOUCH_DEBUG COMMAND=<command>`: This sends a command to the
|
|
|
|
BLTouch. It may be useful for debugging. Available commands are:
|
|
|
|
pin_down, touch_mode, pin_up, self_test, reset.
|
|
|
|
|
2019-01-06 02:24:35 +01:00
|
|
|
See [Working with the BL-Touch](BLTouch.md) for more details.
|
|
|
|
|
2018-03-08 20:06:24 +01:00
|
|
|
## Delta Calibration
|
|
|
|
|
|
|
|
The following commands are available when the "delta_calibrate" config
|
|
|
|
section is enabled:
|
2018-09-26 19:07:18 +02:00
|
|
|
- `DELTA_CALIBRATE [METHOD=manual]`: This command will probe seven
|
|
|
|
points on the bed and recommend updated endstop positions, tower
|
2019-02-10 04:54:24 +01:00
|
|
|
angles, and radius. If METHOD=manual is specified then the manual
|
|
|
|
probing tool is activated - see the MANUAL_PROBE command above for
|
|
|
|
details on the additional commands available while this tool is
|
|
|
|
active.
|
2018-08-29 04:57:29 +02:00
|
|
|
- `DELTA_ANALYZE`: This command is used during enhanced delta
|
|
|
|
calibration. See [Delta Calibrate](Delta_Calibrate.md) for details.
|
2018-03-08 20:06:24 +01:00
|
|
|
|
|
|
|
## Bed Tilt
|
|
|
|
|
|
|
|
The following commands are available when the "bed_tilt" config
|
|
|
|
section is enabled:
|
2018-09-26 19:07:18 +02:00
|
|
|
- `BED_TILT_CALIBRATE [METHOD=manual]`: This command will probe the
|
|
|
|
points specified in the config and then recommend updated x and y
|
2019-02-10 04:54:24 +01:00
|
|
|
tilt adjustments. If METHOD=manual is specified then the manual
|
|
|
|
probing tool is activated - see the MANUAL_PROBE command above for
|
|
|
|
details on the additional commands available while this tool is
|
|
|
|
active.
|
2018-03-11 02:20:48 +01:00
|
|
|
|
2018-08-11 02:27:21 +02:00
|
|
|
## Mesh Bed Leveling
|
|
|
|
|
|
|
|
The following commands are available when the "bed_mesh" config
|
|
|
|
section is enabled:
|
2018-09-26 19:07:18 +02:00
|
|
|
- `BED_MESH_CALIBRATE [METHOD=manual]`: This command probes the bed
|
|
|
|
using generated points specified by the parameters in the
|
|
|
|
config. After probing, a mesh is generated and z-movement is
|
2019-02-10 04:54:24 +01:00
|
|
|
adjusted according to the mesh. If METHOD=manual is specified then
|
|
|
|
the manual probing tool is activated - see the MANUAL_PROBE command
|
|
|
|
above for details on the additional commands available while this
|
|
|
|
tool is active.
|
2018-08-11 02:27:21 +02:00
|
|
|
- `BED_MESH_OUTPUT`: This command outputs the current probed z values
|
|
|
|
and current mesh values to the terminal.
|
|
|
|
- `BED_MESH_MAP`: This command probes the bed in a similar fashion
|
|
|
|
to BED_MESH_CALIBRATE, however no mesh is generated. Instead,
|
|
|
|
the probed z values are serialized to json and output to the
|
|
|
|
terminal. This allows octoprint plugins to easily capture the
|
|
|
|
data and generate maps approximating the bed's surface. Note
|
|
|
|
that although no mesh is generated, any currently stored mesh
|
2018-10-16 20:13:38 +02:00
|
|
|
will be cleared.
|
2018-08-11 02:27:21 +02:00
|
|
|
- `BED_MESH_CLEAR`: This command clears the mesh and removes all
|
|
|
|
z adjustment. It is recommended to put this in your end-gcode.
|
2018-10-05 01:01:18 +02:00
|
|
|
- `BED_MESH_PROFILE LOAD=<name> SAVE=<name> REMOVE=<name>`: This
|
2018-09-27 03:04:27 +02:00
|
|
|
command provides profile management for mesh state. LOAD will
|
|
|
|
restore the mesh state from the profile matching the supplied name.
|
|
|
|
SAVE will save the current mesh state to a profile matching the
|
|
|
|
supplied name. Remove will delete the profile matching the
|
|
|
|
supplied name from persistent memory. Note that after SAVE or
|
|
|
|
REMOVE operations have been run the SAVE_CONFIG gcode must be run
|
|
|
|
to make the changes to peristent memory permanent.
|
2018-08-11 02:27:21 +02:00
|
|
|
|
2018-05-21 20:48:01 +02:00
|
|
|
## Z Tilt
|
|
|
|
|
|
|
|
The following commands are available when the "z_tilt" config section
|
|
|
|
is enabled:
|
|
|
|
- `Z_TILT_ADJUST`: This command will probe the points specified in the
|
|
|
|
config and then make independent adjustments to each Z stepper to
|
|
|
|
compensate for tilt.
|
|
|
|
|
2018-03-11 02:20:48 +01:00
|
|
|
## Dual Carriages
|
|
|
|
|
2018-03-28 21:11:10 +02:00
|
|
|
The following command is available when the "dual_carriage" config
|
2018-03-11 02:20:48 +01:00
|
|
|
section is enabled:
|
|
|
|
- `SET_DUAL_CARRIAGE CARRIAGE=[0|1]`: This command will set the active
|
|
|
|
carriage. It is typically invoked from the activate_gcode and
|
|
|
|
deactivate_gcode fields in a multiple extruder configuration.
|
2018-06-30 18:17:32 +02:00
|
|
|
|
|
|
|
## TMC2130
|
|
|
|
|
|
|
|
The following command is available when the "tmc2130" config section
|
|
|
|
is enabled:
|
|
|
|
- `DUMP_TMC STEPPER=<name>`: This command will read the TMC2130 driver
|
|
|
|
registers and report their values.
|
2018-07-26 18:12:07 +02:00
|
|
|
|
2018-10-11 04:15:00 +02:00
|
|
|
## Endstop adjustments by stepper phase
|
|
|
|
|
|
|
|
The following commands are available when an "endstop_phase" config
|
|
|
|
section is enabled:
|
|
|
|
- `ENDSTOP_PHASE_CALIBRATE [STEPPER=<config_name>]`: If no STEPPER
|
|
|
|
parameter is provided then this command will reports statistics on
|
|
|
|
endstop stepper phases during past homing operations. When a STEPPER
|
|
|
|
parameter is provided it arranges for the given endstop phase
|
|
|
|
setting to be written to the config file (in conjunction with the
|
|
|
|
SAVE_CONFIG command).
|
|
|
|
|
2018-07-26 18:12:07 +02:00
|
|
|
## Force movement
|
|
|
|
|
|
|
|
The following commands are available when the "force_move" config
|
|
|
|
section is enabled:
|
|
|
|
- `FORCE_MOVE STEPPER=<config_name> DISTANCE=<value>
|
|
|
|
VELOCITY=<value>`: This command will forcibly move the given stepper
|
|
|
|
the given distance (in mm) at the given constant velocity (in
|
|
|
|
mm/s). No acceleration is performed; no boundary checks are
|
|
|
|
performed; no kinematic updates are made; other parallel steppers on
|
|
|
|
an axis will not be moved. Use caution as an incorrect command could
|
|
|
|
cause damage! Using this command will almost certainly place the
|
|
|
|
low-level kinematics in an incorrect state; issue a G28 afterwards
|
|
|
|
to reset the kinematics. This command is intended for low-level
|
|
|
|
diagnostics and debugging.
|
2018-08-01 21:40:35 +02:00
|
|
|
- `SET_KINEMATIC_POSITION [X=<value>] [Y=<value>] [Z=<value>]`: Force
|
|
|
|
the low-level kinematic code to believe the toolhead is at the given
|
|
|
|
cartesian position. This is a diagnostic and debugging command; use
|
|
|
|
SET_GCODE_OFFSET and/or G92 for regular axis transformations. If an
|
|
|
|
axis is not specified then it will default to the position that the
|
|
|
|
head was last commanded to. Setting an incorrect or invalid position
|
|
|
|
may lead to internal software errors. This command may invalidate
|
|
|
|
future boundary checks; issue a G28 afterwards to reset the
|
|
|
|
kinematics.
|
2019-01-02 23:45:35 +01:00
|
|
|
|
|
|
|
## Send message (respond) to host
|
|
|
|
|
|
|
|
The following commands are availabe when the "respond" config section is
|
|
|
|
enabled.
|
|
|
|
- `M118 <message>`: echo the message prepended with the configured default
|
|
|
|
prefix (or `echo: ` if no prefix is configured).
|
|
|
|
- `RESPOND MSG="<message>"`: echo the message prepended with the configured default
|
|
|
|
prefix (or `echo: ` if no prefix is configured).
|
|
|
|
- `RESPOND TYPE=echo MSG="<message>"`: echo the message prepended with `echo: `.
|
|
|
|
- `RESPOND TYPE=command MSG="<message>"`: echo the message prepended with `// `.
|
|
|
|
Octopint can be configured to respond to these messages (e.g.
|
|
|
|
`RESPOND TYPE=command MSG=action:pause`).
|
|
|
|
- `RESPOND TYPE=error MSG="<message>"`: echo the message prepended with `!! `.
|
|
|
|
- `RESPOND PREFIX=<prefix> MSG="<message>"`: echo the message prepended with `<prefix>`
|
|
|
|
(The `PREFIX` parameter will take priority over the `TYPE` parameter)
|
2019-01-21 23:24:17 +01:00
|
|
|
|
|
|
|
## Pause Resume
|
|
|
|
|
|
|
|
The following commands are available when the "pause_resume" config section
|
|
|
|
is enabled:
|
|
|
|
- `PAUSE`: Pauses the current print. The current position is captured for
|
|
|
|
restoration upon resume.
|
|
|
|
- `RESUME [VELOCITY=<value>]`: Resumes the print from a pause, first restoring
|
|
|
|
the previously captured position. The VELOCITY parameter determines the speed
|
|
|
|
at which the tool should return to the original captured position.
|