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:
Kevin O'Connor 2018-01-08 20:50:31 -05:00
parent 47e458210e
commit 02b141ac43
2 changed files with 14 additions and 1 deletions

View File

@ -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,

View File

@ -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,