Allow manual_stepper to run in parallel than an other stepper

Signed-off-by: Jeremy Briffaut <kakou@kakou.org>
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Jeremy Briffaut 2020-03-21 10:54:01 +01:00 committed by Kevin O'Connor
parent 6b7e917a8e
commit 6be552f6e6
2 changed files with 23 additions and 15 deletions

View File

@ -255,18 +255,22 @@ The following command is available when a "manual_stepper" config
section is enabled: section is enabled:
- `MANUAL_STEPPER STEPPER=config_name [ENABLE=[0|1]] - `MANUAL_STEPPER STEPPER=config_name [ENABLE=[0|1]]
[SET_POSITION=<pos>] [SPEED=<speed>] [ACCEL=<accel>] [SET_POSITION=<pos>] [SPEED=<speed>] [ACCEL=<accel>]
[MOVE=<pos> [STOP_ON_ENDSTOP=[1|2|-1|-2]]`: This command will alter [MOVE=<pos> [STOP_ON_ENDSTOP=[1|2|-1|-2]] [SYNC=0]`: This command
the state of the stepper. Use the ENABLE parameter to enable/disable will alter the state of the stepper. Use the ENABLE parameter to
the stepper. Use the SET_POSITION parameter to force the stepper to enable/disable the stepper. Use the SET_POSITION parameter to force
think it is at the given position. Use the MOVE parameter to request the stepper to think it is at the given position. Use the MOVE
a movement to the given position. If SPEED and/or ACCEL is specified parameter to request a movement to the given position. If SPEED
then the given values will be used instead of the defaults specified and/or ACCEL is specified then the given values will be used instead
in the config file. If an ACCEL of zero is specified then no of the defaults specified in the config file. If an ACCEL of zero is
acceleration will be performed. If STOP_ON_ENDSTOP=1 is specified specified then no acceleration will be performed. If
then the move will end early should the endstop report as triggered STOP_ON_ENDSTOP=1 is specified then the move will end early should
(use STOP_ON_ENDSTOP=2 to complete the move without error even if the endstop report as triggered (use STOP_ON_ENDSTOP=2 to complete
the endstop does not trigger, use -1 or -2 to stop when the endstop the move without error even if the endstop does not trigger, use -1
reports not triggered). or -2 to stop when the endstop reports not triggered). Normally
future G-Code commands will be scheduled to run after the stepper
move completes, however if a manual stepper move uses SYNC=0 then
future G-Code movement commands may run in parallel with the stepper
movement.
## Probe ## Probe

View File

@ -58,7 +58,7 @@ class ManualStepper:
self.sync_print_time() self.sync_print_time()
def do_set_position(self, setpos): def do_set_position(self, setpos):
self.rail.set_position([setpos, 0., 0.]) self.rail.set_position([setpos, 0., 0.])
def do_move(self, movepos, speed, accel): def do_move(self, movepos, speed, accel, sync=True):
self.sync_print_time() self.sync_print_time()
cp = self.rail.get_commanded_position() cp = self.rail.get_commanded_position()
dist = movepos - cp dist = movepos - cp
@ -73,7 +73,8 @@ class ManualStepper:
self.trapq_free_moves(self.trapq, self.next_cmd_time + 99999.9) self.trapq_free_moves(self.trapq, self.next_cmd_time + 99999.9)
toolhead = self.printer.lookup_object('toolhead') toolhead = self.printer.lookup_object('toolhead')
toolhead.note_kinematic_activity(self.next_cmd_time) toolhead.note_kinematic_activity(self.next_cmd_time)
self.sync_print_time() if sync:
self.sync_print_time()
def do_homing_move(self, movepos, speed, accel, triggered, check_trigger): def do_homing_move(self, movepos, speed, accel, triggered, check_trigger):
if not self.can_home: if not self.can_home:
raise self.gcode.error("No endstop for this manual stepper") raise self.gcode.error("No endstop for this manual stepper")
@ -115,6 +116,7 @@ class ManualStepper:
if 'SET_POSITION' in params: if 'SET_POSITION' in params:
setpos = self.gcode.get_float('SET_POSITION', params) setpos = self.gcode.get_float('SET_POSITION', params)
self.do_set_position(setpos) self.do_set_position(setpos)
sync = self.gcode.get_int('SYNC', params, 1)
homing_move = self.gcode.get_int('STOP_ON_ENDSTOP', params, 0) homing_move = self.gcode.get_int('STOP_ON_ENDSTOP', params, 0)
speed = self.gcode.get_float('SPEED', params, self.velocity, above=0.) speed = self.gcode.get_float('SPEED', params, self.velocity, above=0.)
accel = self.gcode.get_float('ACCEL', params, self.accel, minval=0.) accel = self.gcode.get_float('ACCEL', params, self.accel, minval=0.)
@ -124,7 +126,9 @@ class ManualStepper:
homing_move > 0, abs(homing_move) == 1) homing_move > 0, abs(homing_move) == 1)
elif 'MOVE' in params: elif 'MOVE' in params:
movepos = self.gcode.get_float('MOVE', params) movepos = self.gcode.get_float('MOVE', params)
self.do_move(movepos, speed, accel) self.do_move(movepos, speed, accel, sync)
elif 'SYNC' in params and sync:
self.sync_print_time()
def load_config_prefix(config): def load_config_prefix(config):
return ManualStepper(config) return ManualStepper(config)