From 6f3b56bc8e7bfa4baad7036b46024214a0ae28bd Mon Sep 17 00:00:00 2001 From: Brandon Date: Fri, 5 Jan 2024 13:05:11 -0500 Subject: [PATCH] allow multiple current helpers per rail (#117) * allow multiple current helpers per rail * use first dwell time --- klippy/extras/homing.py | 26 ++++++++++++++++++-------- klippy/stepper.py | 7 ++++++- 2 files changed, 24 insertions(+), 9 deletions(-) diff --git a/klippy/extras/homing.py b/klippy/extras/homing.py index adfd9d062..6dc8b6ffe 100644 --- a/klippy/extras/homing.py +++ b/klippy/extras/homing.py @@ -259,10 +259,15 @@ def _set_current_homing(self, homing_axes): affected_rails = affected_rails | set(partial_rails) for rail in affected_rails: - ch = rail.get_tmc_current_helper() - if ch is not None and ch.needs_home_current_change(): - ch.set_current_for_homing(print_time) - self.toolhead.dwell(ch.current_change_dwell_time) + chs = rail.get_tmc_current_helpers() + dwell_time = None + for ch in chs: + if ch is not None and ch.needs_home_current_change(): + if dwell_time is None: + dwell_time = ch.current_change_dwell_time + ch.set_current_for_homing(print_time) + if dwell_time: + self.toolhead.dwell(dwell_time) def _set_current_post_homing(self, homing_axes): print_time = self.toolhead.get_last_move_time() @@ -273,10 +278,15 @@ def _set_current_post_homing(self, homing_axes): affected_rails = affected_rails | set(partial_rails) for rail in affected_rails: - ch = rail.get_tmc_current_helper() - if ch is not None and ch.needs_home_current_change(): - ch.set_current_for_normal(print_time) - self.toolhead.dwell(ch.current_change_dwell_time) + chs = rail.get_tmc_current_helpers() + dwell_time = None + for ch in chs: + if ch is not None and ch.needs_home_current_change(): + if dwell_time is None: + dwell_time = ch.current_change_dwell_time + ch.set_current_for_normal(print_time) + if dwell_time: + self.toolhead.dwell(dwell_time) def home_rails(self, rails, forcepos, movepos): # Notify of upcoming homing operation diff --git a/klippy/stepper.py b/klippy/stepper.py index 0a79f88ea..3880ab05b 100644 --- a/klippy/stepper.py +++ b/klippy/stepper.py @@ -400,10 +400,12 @@ def __init__( self.endstop_map = {} self.add_extra_stepper(config) mcu_stepper = self.steppers[0] + self._tmc_current_helpers = [ + s.get_tmc_current_helper() for s in self.steppers + ] self.get_name = mcu_stepper.get_name self.get_commanded_position = mcu_stepper.get_commanded_position self.calc_position_from_coord = mcu_stepper.calc_position_from_coord - self.get_tmc_current_helper = mcu_stepper.get_tmc_current_helper # Primary endstop position mcu_endstop = self.endstops[0][0] if hasattr(mcu_endstop, "get_position_endstop"): @@ -482,6 +484,9 @@ def __init__( % (config.get_name(),) ) + def get_tmc_current_helpers(self): + return self._tmc_current_helpers + def get_range(self): return self.position_min, self.position_max