mirror of
https://github.com/Klipper3d/klipper.git
synced 2025-07-07 23:17:37 -06:00
pins: Explicitly pass can_invert and can_pullup to lookup_pin()
Don't pass pin_type to lookup_pin() - instead, if a pin can be inverted or can have a pullup, then the caller must explicitly specify that when calling lookup_pin(). This simplifies the code for the cases where it is not valid to invert or pullup. Explicitly pass the pin_type to setup_pin() and have ppins.setup_pin() apply default pullup and invert flags. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
7a9553b38a
commit
273a98d39a
13 changed files with 39 additions and 50 deletions
|
@ -29,10 +29,11 @@ class StepperEnablePin:
|
|||
def lookup_enable_pin(ppins, pin):
|
||||
if pin is None:
|
||||
return StepperEnablePin(None, 9999)
|
||||
pin_params = ppins.lookup_pin('digital_out', pin, 'stepper_enable')
|
||||
pin_params = ppins.lookup_pin(pin, can_invert=True,
|
||||
share_type='stepper_enable')
|
||||
enable = pin_params.get('class')
|
||||
if enable is None:
|
||||
mcu_enable = pin_params['chip'].setup_pin(pin_params)
|
||||
mcu_enable = pin_params['chip'].setup_pin('digital_out', pin_params)
|
||||
mcu_enable.setup_max_duration(0.)
|
||||
pin_params['class'] = enable = StepperEnablePin(mcu_enable)
|
||||
return enable
|
||||
|
@ -51,7 +52,8 @@ class PrinterStepper:
|
|||
# Stepper definition
|
||||
ppins = printer.lookup_object('pins')
|
||||
self.mcu_stepper = ppins.setup_pin('stepper', config.get('step_pin'))
|
||||
dir_pin_params = ppins.lookup_pin('digital_out', config.get('dir_pin'))
|
||||
dir_pin = config.get('dir_pin')
|
||||
dir_pin_params = ppins.lookup_pin(dir_pin, can_invert=True)
|
||||
self.mcu_stepper.setup_dir_pin(dir_pin_params)
|
||||
step_dist = config.getfloat('step_distance', above=0.)
|
||||
self.mcu_stepper.setup_step_distance(step_dist)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue