tmc: Revert incorrect changes to TPWMTHRS setting

It's not valid to set the TPWMTHRS in a "klippy:connect" event handler
because the TMCVirtualPinHelper and TMCCommandHelper classes were
expecting that field to be set during the config reading phase.

Revert "tmc: Fix typo preventing stealthchop threshold from being set"
This reverts commit 7d76067ff9.

Revert "tmc: Query the stepper step_distance from the stepper object"
This reverts commit 67b2852249.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-02-20 11:32:38 -05:00
parent 15f21be5ec
commit e03f75e758
1 changed files with 18 additions and 26 deletions

View File

@ -273,29 +273,21 @@ class TMCMicrostepHelper:
return (1023 - mscnt) >> self.fields.get_field("MRES") return (1023 - mscnt) >> self.fields.get_field("MRES")
# Helper to configure "stealthchop" mode # Helper to configure "stealthchop" mode
class TMCStealthchopHelper: def TMCStealthchopHelper(config, mcu_tmc, tmc_freq):
def __init__(self, config, mcu_tmc, tmc_freq): fields = mcu_tmc.get_fields()
self.name = config.get_name() en_pwm_mode = False
self.fields = fields = mcu_tmc.get_fields() velocity = config.getfloat('stealthchop_threshold', 0., minval=0.)
self.tmc_freq = tmc_freq if velocity:
printer = config.get_printer() stepper_name = " ".join(config.get_name().split()[1:])
self.force_move = printer.try_load_module(config, "force_move") stepper_config = config.getsection(stepper_name)
en_pwm_mode = False step_dist = stepper_config.getfloat('step_distance')
self.velocity = config.getfloat('stealthchop_threshold', 0., minval=0.) step_dist_256 = step_dist / (1 << fields.get_field("MRES"))
if self.velocity: threshold = int(tmc_freq * step_dist_256 / velocity + .5)
printer.register_event_handler("klippy:connect", fields.set_field("TPWMTHRS", max(0, min(0xfffff, threshold)))
self.handle_connect) en_pwm_mode = True
en_pwm_mode = True reg = fields.lookup_register("en_pwm_mode", None)
reg = fields.lookup_register("en_pwm_mode", None) if reg is not None:
if reg is not None: fields.set_field("en_pwm_mode", en_pwm_mode)
fields.set_field("en_pwm_mode", en_pwm_mode) else:
else: # TMC2208 uses en_spreadCycle
# TMC2208 uses en_spreadCycle fields.set_field("en_spreadCycle", not en_pwm_mode)
fields.set_field("en_spreadCycle", not en_pwm_mode)
def handle_connect(self):
stepper_name = " ".join(self.name.split()[1:])
stepper = self.force_move.lookup_stepper(stepper_name)
step_dist = stepper.get_step_dist()
step_dist_256 = step_dist / (1 << self.fields.get_field("MRES"))
threshold = int(self.tmc_freq * step_dist_256 / self.velocity + .5)
self.fields.set_field("TPWMTHRS", max(0, min(0xfffff, threshold)))