stepper: Support step_pulse_duration even on TMC drivers in UART/SPI mode
Commit 689231df
changed the default step_pulse_duration to 100ns for
TMC drivers that are configured in UART/SPI mode, but it failed to
document that change in Config_Changes.md and Config_Reference.md.
Update those documents to reflect that change.
Update the code so that a user may specify a custom
step_pulse_duration even on TMC drivers that are configured in
UART/SPI mode. This may be useful for drivers that use a level
shifter on the step pin that requires more than a ~300ns to detect a
level change.
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
54acca37ba
commit
520273e5ab
|
@ -16,9 +16,10 @@ use the older (typically less accurate) definition, define a custom
|
||||||
`resistance1: 100000`, and `beta: 3950`.
|
`resistance1: 100000`, and `beta: 3950`.
|
||||||
|
|
||||||
20211104: The "step pulse duration" option in "make menuconfig" has
|
20211104: The "step pulse duration" option in "make menuconfig" has
|
||||||
been removed. A new `step_pulse_duration` setting in the
|
been removed. The default step duration for TMC drivers configured in
|
||||||
[stepper config section](Config_Reference.md#stepper) should be set
|
UART or SPI mode is now 100ns. A new `step_pulse_duration` setting in
|
||||||
for all steppers that need a custom pulse duration.
|
the [stepper config section](Config_Reference.md#stepper) should be
|
||||||
|
set for all steppers that need a custom pulse duration.
|
||||||
|
|
||||||
20211102: Several deprecated features have been removed. The stepper
|
20211102: Several deprecated features have been removed. The stepper
|
||||||
`step_distance` option has been removed (deprecated on 20201222). The
|
`step_distance` option has been removed (deprecated on 20201222). The
|
||||||
|
|
|
@ -157,7 +157,9 @@ microsteps:
|
||||||
# The minimum time between the step pulse signal edge and the
|
# The minimum time between the step pulse signal edge and the
|
||||||
# following "unstep" signal edge. This is also used to set the
|
# following "unstep" signal edge. This is also used to set the
|
||||||
# minimum time between a step pulse and a direction change signal.
|
# minimum time between a step pulse and a direction change signal.
|
||||||
# The default is 0.000002 (which is 2us).
|
# The default is 0.000000100 (100ns) for TMC steppers that are
|
||||||
|
# configured in UART or SPI mode, and the default is 0.000002 (which
|
||||||
|
# is 2us) for all other steppers.
|
||||||
endstop_pin:
|
endstop_pin:
|
||||||
# Endstop switch detection pin. If this endstop pin is on a
|
# Endstop switch detection pin. If this endstop pin is on a
|
||||||
# different mcu than the stepper motor then it enables "multi-mcu
|
# different mcu than the stepper motor then it enables "multi-mcu
|
||||||
|
|
|
@ -14,6 +14,8 @@ class error(Exception):
|
||||||
# Steppers
|
# Steppers
|
||||||
######################################################################
|
######################################################################
|
||||||
|
|
||||||
|
MIN_BOTH_EDGE_DURATION = 0.000000200
|
||||||
|
|
||||||
# Interface to low-level mcu and chelper code
|
# Interface to low-level mcu and chelper code
|
||||||
class MCU_stepper:
|
class MCU_stepper:
|
||||||
def __init__(self, name, step_pin_params, dir_pin_params, step_dist,
|
def __init__(self, name, step_pin_params, dir_pin_params, step_dist,
|
||||||
|
@ -70,7 +72,8 @@ class MCU_stepper:
|
||||||
self._step_pulse_duration = .000002
|
self._step_pulse_duration = .000002
|
||||||
invert_step = self._invert_step
|
invert_step = self._invert_step
|
||||||
sbe = int(self._mcu.get_constants().get('STEPPER_BOTH_EDGE', '0'))
|
sbe = int(self._mcu.get_constants().get('STEPPER_BOTH_EDGE', '0'))
|
||||||
if self._req_step_both_edge and sbe:
|
if (self._req_step_both_edge and sbe
|
||||||
|
and self._step_pulse_duration <= MIN_BOTH_EDGE_DURATION):
|
||||||
# Enable stepper optimized step on both edges
|
# Enable stepper optimized step on both edges
|
||||||
self._step_both_edge = True
|
self._step_both_edge = True
|
||||||
self._step_pulse_duration = 0.
|
self._step_pulse_duration = 0.
|
||||||
|
|
Loading…
Reference in New Issue