chipmisc: Fix replicape enable line setup
The enable lines are not one per stepper - instead there are 5 distinct enable settings. Handle them properly. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
47e458210e
commit
02b141ac43
|
@ -98,6 +98,10 @@ host_mcu: host
|
||||||
# The name of the mcu config section that communicates with the
|
# The name of the mcu config section that communicates with the
|
||||||
# Klipper "linux process" mcu instance. This parameter must be
|
# Klipper "linux process" mcu instance. This parameter must be
|
||||||
# provided.
|
# provided.
|
||||||
|
#standstill_power_down: False
|
||||||
|
# This parameter controls the CFG6_ENN line on all stepper
|
||||||
|
# motors. True sets the enable lines to "open". The default is
|
||||||
|
# False.
|
||||||
stepper_x_microstep_mode: spread16
|
stepper_x_microstep_mode: spread16
|
||||||
# This parameter controls the CFG1 and CFG2 pins of the given
|
# This parameter controls the CFG1 and CFG2 pins of the given
|
||||||
# stepper motor driver. Available options are: disable, 1, 2,
|
# stepper motor driver. Available options are: disable, 1, 2,
|
||||||
|
|
|
@ -338,13 +338,14 @@ class Replicape:
|
||||||
"power_fan2": (pca9685_pwm, 9), "power_fan3": (pca9685_pwm, 10) }
|
"power_fan2": (pca9685_pwm, 9), "power_fan3": (pca9685_pwm, 10) }
|
||||||
# Setup stepper config
|
# Setup stepper config
|
||||||
self.stepper_dacs = {}
|
self.stepper_dacs = {}
|
||||||
shift_registers = [1] * 5
|
shift_registers = [1, 0, 0, 1, 1]
|
||||||
for port, name in enumerate('xyzeh'):
|
for port, name in enumerate('xyzeh'):
|
||||||
prefix = 'stepper_%s_' % (name,)
|
prefix = 'stepper_%s_' % (name,)
|
||||||
sc = config.getchoice(
|
sc = config.getchoice(
|
||||||
prefix + 'microstep_mode', ReplicapeStepConfig, 'disable')
|
prefix + 'microstep_mode', ReplicapeStepConfig, 'disable')
|
||||||
if sc is None:
|
if sc is None:
|
||||||
continue
|
continue
|
||||||
|
sc |= shift_registers[port]
|
||||||
if config.getboolean(prefix + 'chopper_off_time_high', False):
|
if config.getboolean(prefix + 'chopper_off_time_high', False):
|
||||||
sc |= 1<<3
|
sc |= 1<<3
|
||||||
if config.getboolean(prefix + 'chopper_hysteresis_high', False):
|
if config.getboolean(prefix + 'chopper_hysteresis_high', False):
|
||||||
|
@ -358,6 +359,14 @@ class Replicape:
|
||||||
self.stepper_dacs[channel] = cur / REPLICAPE_MAX_CURRENT
|
self.stepper_dacs[channel] = cur / REPLICAPE_MAX_CURRENT
|
||||||
self.pins[prefix + 'enable'] = (ReplicapeDACEnable, channel)
|
self.pins[prefix + 'enable'] = (ReplicapeDACEnable, channel)
|
||||||
self.enabled_channels = {ch: False for cl, ch in self.pins.values()}
|
self.enabled_channels = {ch: False for cl, ch in self.pins.values()}
|
||||||
|
if [i for i in [0, 1, 2] if 11+i in self.stepper_dacs]:
|
||||||
|
# Enable xyz steppers
|
||||||
|
shift_registers[0] &= ~1
|
||||||
|
if [i for i in [3, 4] if 11+i in self.stepper_dacs]:
|
||||||
|
# Enable eh steppers
|
||||||
|
shift_registers[3] &= ~1
|
||||||
|
if config.getboolean('standstill_power_down', False):
|
||||||
|
shift_registers[4] &= ~1
|
||||||
shift_registers.reverse()
|
shift_registers.reverse()
|
||||||
self.host_mcu.add_config_cmd("send_spi bus=%d dev=%d msg=%s" % (
|
self.host_mcu.add_config_cmd("send_spi bus=%d dev=%d msg=%s" % (
|
||||||
REPLICAPE_SHIFT_REGISTER_BUS, REPLICAPE_SHIFT_REGISTER_DEVICE,
|
REPLICAPE_SHIFT_REGISTER_BUS, REPLICAPE_SHIFT_REGISTER_DEVICE,
|
||||||
|
|
Loading…
Reference in New Issue