stepper: detect duplicate endstops
When adding steppers to a `PrinterRail`, detect duplicated `endstop_pin` settings and add them to the already-registered endstop. Signed-off-by: Lasse Dalegaard <dalegaard@gmail.com>
This commit is contained in:
parent
9014677cbd
commit
caec91b149
|
@ -264,6 +264,7 @@ class PrinterRail:
|
||||||
self.stepper_units_in_radians = units_in_radians
|
self.stepper_units_in_radians = units_in_radians
|
||||||
self.steppers = []
|
self.steppers = []
|
||||||
self.endstops = []
|
self.endstops = []
|
||||||
|
self.endstop_map = {}
|
||||||
self.add_extra_stepper(config)
|
self.add_extra_stepper(config)
|
||||||
mcu_stepper = self.steppers[0]
|
mcu_stepper = self.steppers[0]
|
||||||
self.get_name = mcu_stepper.get_name
|
self.get_name = mcu_stepper.get_name
|
||||||
|
@ -336,18 +337,37 @@ class PrinterRail:
|
||||||
def add_extra_stepper(self, config):
|
def add_extra_stepper(self, config):
|
||||||
stepper = PrinterStepper(config, self.stepper_units_in_radians)
|
stepper = PrinterStepper(config, self.stepper_units_in_radians)
|
||||||
self.steppers.append(stepper)
|
self.steppers.append(stepper)
|
||||||
if self.endstops and config.get('endstop_pin', None) is None:
|
endstop_pin = config.get('endstop_pin', None)
|
||||||
|
if self.endstops and endstop_pin is None:
|
||||||
# No endstop defined - use primary endstop
|
# No endstop defined - use primary endstop
|
||||||
self.endstops[0][0].add_stepper(stepper)
|
self.endstops[0][0].add_stepper(stepper)
|
||||||
return
|
return
|
||||||
printer = config.get_printer()
|
printer = config.get_printer()
|
||||||
ppins = printer.lookup_object('pins')
|
ppins = printer.lookup_object('pins')
|
||||||
mcu_endstop = ppins.setup_pin('endstop', config.get('endstop_pin'))
|
pin_params = ppins.parse_pin(endstop_pin, True, True)
|
||||||
|
# Normalize pin name
|
||||||
|
pin_name = "%s:%s" % (pin_params['chip_name'], pin_params['pin'])
|
||||||
|
# Look for already-registered endstop
|
||||||
|
endstop = self.endstop_map.get(pin_name, None)
|
||||||
|
if endstop is None:
|
||||||
|
# New endstop, register it
|
||||||
|
mcu_endstop = ppins.setup_pin('endstop', endstop_pin)
|
||||||
|
self.endstop_map[pin_name] = {'endstop': mcu_endstop,
|
||||||
|
'invert': pin_params['invert'],
|
||||||
|
'pullup': pin_params['pullup']}
|
||||||
|
name = stepper.get_name(short=True)
|
||||||
|
self.endstops.append((mcu_endstop, name))
|
||||||
|
query_endstops = printer.load_object(config, 'query_endstops')
|
||||||
|
query_endstops.register_endstop(mcu_endstop, name)
|
||||||
|
else:
|
||||||
|
mcu_endstop = endstop['endstop']
|
||||||
|
changed_invert = pin_params['invert'] != endstop['invert']
|
||||||
|
changed_pullup = pin_params['pullup'] != endstop['pullup']
|
||||||
|
if changed_invert or changed_pullup:
|
||||||
|
raise error("Pinter rail %s shared endstop pin %s "
|
||||||
|
"must specify the same pullup/invert settings" % (
|
||||||
|
self.get_name(), pin_name))
|
||||||
mcu_endstop.add_stepper(stepper)
|
mcu_endstop.add_stepper(stepper)
|
||||||
name = stepper.get_name(short=True)
|
|
||||||
self.endstops.append((mcu_endstop, name))
|
|
||||||
query_endstops = printer.load_object(config, 'query_endstops')
|
|
||||||
query_endstops.register_endstop(mcu_endstop, name)
|
|
||||||
def setup_itersolve(self, alloc_func, *params):
|
def setup_itersolve(self, alloc_func, *params):
|
||||||
for stepper in self.steppers:
|
for stepper in self.steppers:
|
||||||
stepper.setup_itersolve(alloc_func, *params)
|
stepper.setup_itersolve(alloc_func, *params)
|
||||||
|
|
Loading…
Reference in New Issue