endstop_phase: Convert to using tmc mcu_phase_offset
Now that the TMC drivers track the phase offset, use that to implement endstop phase. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
06b8169f56
commit
f759df3cd7
|
@ -25,7 +25,7 @@ class PhaseCalc:
|
||||||
if module is not None:
|
if module is not None:
|
||||||
self.tmc_module = module
|
self.tmc_module = module
|
||||||
if self.phases is None:
|
if self.phases is None:
|
||||||
self.phases = module.get_microsteps() * 4
|
phase_offset, self.phases = module.get_phase_offset()
|
||||||
break
|
break
|
||||||
if self.phases is not None:
|
if self.phases is not None:
|
||||||
self.phase_history = [0] * self.phases
|
self.phase_history = [0] * self.phases
|
||||||
|
@ -34,18 +34,15 @@ class PhaseCalc:
|
||||||
return (int(float(driver_phase) / driver_phases * phases + .5) % phases)
|
return (int(float(driver_phase) / driver_phases * phases + .5) % phases)
|
||||||
def calc_phase(self, stepper):
|
def calc_phase(self, stepper):
|
||||||
mcu_pos = stepper.get_mcu_position()
|
mcu_pos = stepper.get_mcu_position()
|
||||||
if self.tmc_module is None:
|
mcu_phase_offset = 0
|
||||||
phase = mcu_pos % self.phases
|
if self.tmc_module is not None:
|
||||||
else:
|
mcu_phase_offset, phases = self.tmc_module.get_phase_offset()
|
||||||
try:
|
if mcu_phase_offset is None:
|
||||||
driver_phase, driver_phases = self.tmc_module.get_phase()
|
if self.printer.get_start_args().get('debugoutput') is None:
|
||||||
except Exception as e:
|
raise self.printer.command_error("Stepper %s phase unknown"
|
||||||
msg = "Unable to get stepper %s phase: %s" % (self.name, str(e))
|
% (self.name,))
|
||||||
logging.exception(msg)
|
mcu_phase_offset = 0
|
||||||
raise self.printer.command_error(msg)
|
phase = (mcu_pos + mcu_phase_offset) % self.phases
|
||||||
if stepper.is_dir_inverted():
|
|
||||||
driver_phase = (driver_phases - 1) - driver_phase
|
|
||||||
phase = self.convert_phase(driver_phase, driver_phases)
|
|
||||||
self.phase_history[phase] += 1
|
self.phase_history[phase] += 1
|
||||||
self.last_phase = phase
|
self.last_phase = phase
|
||||||
self.last_mcu_position = mcu_pos
|
self.last_mcu_position = mcu_pos
|
||||||
|
|
|
@ -266,21 +266,22 @@ class TMCCommandHelper:
|
||||||
gcmd.respond_info("Run Current: %0.2fA Hold Current: %0.2fA"
|
gcmd.respond_info("Run Current: %0.2fA Hold Current: %0.2fA"
|
||||||
% (prev_run_current, prev_hold_current))
|
% (prev_run_current, prev_hold_current))
|
||||||
# Stepper phase tracking
|
# Stepper phase tracking
|
||||||
def get_microsteps(self):
|
def _get_phases(self):
|
||||||
return 256 >> self.fields.get_field("mres")
|
return (256 >> self.fields.get_field("mres")) * 4
|
||||||
def get_phase(self):
|
def get_phase_offset(self):
|
||||||
|
return self.mcu_phase_offset, self._get_phases()
|
||||||
|
def _query_phase(self):
|
||||||
field_name = "mscnt"
|
field_name = "mscnt"
|
||||||
if self.fields.lookup_register(field_name, None) is None:
|
if self.fields.lookup_register(field_name, None) is None:
|
||||||
# TMC2660 uses MSTEP
|
# TMC2660 uses MSTEP
|
||||||
field_name = "mstep"
|
field_name = "mstep"
|
||||||
reg = self.mcu_tmc.get_register(self.fields.lookup_register(field_name))
|
reg = self.mcu_tmc.get_register(self.fields.lookup_register(field_name))
|
||||||
mscnt = self.fields.get_field(field_name, reg)
|
return self.fields.get_field(field_name, reg)
|
||||||
return 1023 - mscnt, 1024
|
|
||||||
def _handle_sync_mcu_pos(self, stepper):
|
def _handle_sync_mcu_pos(self, stepper):
|
||||||
if stepper.get_name() != self.stepper_name:
|
if stepper.get_name() != self.stepper_name:
|
||||||
return
|
return
|
||||||
try:
|
try:
|
||||||
driver_phase, driver_phases = self.get_phase()
|
driver_phase = self._query_phase()
|
||||||
except self.printer.command_error as e:
|
except self.printer.command_error as e:
|
||||||
logging.info("Unable to obtain tmc %s phase", self.stepper_name)
|
logging.info("Unable to obtain tmc %s phase", self.stepper_name)
|
||||||
self.mcu_phase_offset = None
|
self.mcu_phase_offset = None
|
||||||
|
@ -288,10 +289,10 @@ class TMCCommandHelper:
|
||||||
if enable_line.is_motor_enabled():
|
if enable_line.is_motor_enabled():
|
||||||
raise
|
raise
|
||||||
return
|
return
|
||||||
if stepper.is_dir_inverted():
|
if not stepper.is_dir_inverted():
|
||||||
driver_phase = (driver_phases - 1) - driver_phase
|
driver_phase = 1023 - driver_phase
|
||||||
phases = self.get_microsteps() * 4
|
phases = self._get_phases()
|
||||||
phase = int(float(driver_phase) / driver_phases * phases + .5) % phases
|
phase = int(float(driver_phase) / 1024 * phases + .5) % phases
|
||||||
moff = (phase - stepper.get_mcu_position()) % phases
|
moff = (phase - stepper.get_mcu_position()) % phases
|
||||||
if self.mcu_phase_offset is not None and self.mcu_phase_offset != moff:
|
if self.mcu_phase_offset is not None and self.mcu_phase_offset != moff:
|
||||||
logging.warning("Stepper %s phase change (was %d now %d)",
|
logging.warning("Stepper %s phase change (was %d now %d)",
|
||||||
|
|
|
@ -260,8 +260,7 @@ class TMC2130:
|
||||||
current_helper = TMCCurrentHelper(config, self.mcu_tmc)
|
current_helper = TMCCurrentHelper(config, self.mcu_tmc)
|
||||||
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
||||||
cmdhelper.setup_register_dump(ReadRegisters)
|
cmdhelper.setup_register_dump(ReadRegisters)
|
||||||
self.get_microsteps = cmdhelper.get_microsteps
|
self.get_phase_offset = cmdhelper.get_phase_offset
|
||||||
self.get_phase = cmdhelper.get_phase
|
|
||||||
# Setup basic register values
|
# Setup basic register values
|
||||||
tmc.TMCStealthchopHelper(config, self.mcu_tmc, TMC_FREQUENCY)
|
tmc.TMCStealthchopHelper(config, self.mcu_tmc, TMC_FREQUENCY)
|
||||||
# Allow other registers to be set from the config
|
# Allow other registers to be set from the config
|
||||||
|
|
|
@ -192,8 +192,7 @@ class TMC2208:
|
||||||
current_helper = tmc2130.TMCCurrentHelper(config, self.mcu_tmc)
|
current_helper = tmc2130.TMCCurrentHelper(config, self.mcu_tmc)
|
||||||
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
||||||
cmdhelper.setup_register_dump(ReadRegisters, self.read_translate)
|
cmdhelper.setup_register_dump(ReadRegisters, self.read_translate)
|
||||||
self.get_microsteps = cmdhelper.get_microsteps
|
self.get_phase_offset = cmdhelper.get_phase_offset
|
||||||
self.get_phase = cmdhelper.get_phase
|
|
||||||
# Setup basic register values
|
# Setup basic register values
|
||||||
self.fields.set_field("mstep_reg_select", True)
|
self.fields.set_field("mstep_reg_select", True)
|
||||||
self.fields.set_field("multistep_filt", True)
|
self.fields.set_field("multistep_filt", True)
|
||||||
|
|
|
@ -68,8 +68,7 @@ class TMC2209:
|
||||||
current_helper = tmc2130.TMCCurrentHelper(config, self.mcu_tmc)
|
current_helper = tmc2130.TMCCurrentHelper(config, self.mcu_tmc)
|
||||||
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
||||||
cmdhelper.setup_register_dump(ReadRegisters)
|
cmdhelper.setup_register_dump(ReadRegisters)
|
||||||
self.get_microsteps = cmdhelper.get_microsteps
|
self.get_phase_offset = cmdhelper.get_phase_offset
|
||||||
self.get_phase = cmdhelper.get_phase
|
|
||||||
# Setup basic register values
|
# Setup basic register values
|
||||||
self.fields.set_field("pdn_disable", True)
|
self.fields.set_field("pdn_disable", True)
|
||||||
self.fields.set_field("mstep_reg_select", True)
|
self.fields.set_field("mstep_reg_select", True)
|
||||||
|
|
|
@ -229,8 +229,7 @@ class TMC2660:
|
||||||
current_helper = TMC2660CurrentHelper(config, self.mcu_tmc)
|
current_helper = TMC2660CurrentHelper(config, self.mcu_tmc)
|
||||||
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
||||||
cmdhelper.setup_register_dump(ReadRegisters)
|
cmdhelper.setup_register_dump(ReadRegisters)
|
||||||
self.get_microsteps = cmdhelper.get_microsteps
|
self.get_phase_offset = cmdhelper.get_phase_offset
|
||||||
self.get_phase = cmdhelper.get_phase
|
|
||||||
|
|
||||||
# CHOPCONF
|
# CHOPCONF
|
||||||
set_config_field = self.fields.set_config_field
|
set_config_field = self.fields.set_config_field
|
||||||
|
|
|
@ -294,8 +294,7 @@ class TMC5160:
|
||||||
current_helper = TMC5160CurrentHelper(config, self.mcu_tmc)
|
current_helper = TMC5160CurrentHelper(config, self.mcu_tmc)
|
||||||
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
cmdhelper = tmc.TMCCommandHelper(config, self.mcu_tmc, current_helper)
|
||||||
cmdhelper.setup_register_dump(ReadRegisters)
|
cmdhelper.setup_register_dump(ReadRegisters)
|
||||||
self.get_microsteps = cmdhelper.get_microsteps
|
self.get_phase_offset = cmdhelper.get_phase_offset
|
||||||
self.get_phase = cmdhelper.get_phase
|
|
||||||
# Setup basic register values
|
# Setup basic register values
|
||||||
tmc.TMCStealthchopHelper(config, self.mcu_tmc, TMC_FREQUENCY)
|
tmc.TMCStealthchopHelper(config, self.mcu_tmc, TMC_FREQUENCY)
|
||||||
# CHOPCONF
|
# CHOPCONF
|
||||||
|
|
Loading…
Reference in New Issue