aboutsummaryrefslogtreecommitdiffstats
path: root/klippy
diff options
context:
space:
mode:
Diffstat (limited to 'klippy')
-rw-r--r--klippy/extras/output_pin.py (renamed from klippy/chipmisc.py)50
-rw-r--r--klippy/klippy.py4
2 files changed, 21 insertions, 33 deletions
diff --git a/klippy/chipmisc.py b/klippy/extras/output_pin.py
index f28361a9..eda2ad2b 100644
--- a/klippy/chipmisc.py
+++ b/klippy/extras/output_pin.py
@@ -3,48 +3,46 @@
# Copyright (C) 2017,2018 Kevin O'Connor <kevin@koconnor.net>
#
# This file may be distributed under the terms of the GNU GPLv3 license.
-import pins
-
-
-######################################################################
-# Output pins
-######################################################################
PIN_MIN_TIME = 0.100
-class PrinterPin:
- def __init__(self, printer, config):
- self.printer = printer
- self.is_pwm = 'pwm' in config.get_name().split()[0]
+class PrinterOutputPin:
+ def __init__(self, config):
+ self.printer = config.get_printer()
+ ppins = self.printer.lookup_object('pins')
+ self.is_pwm = config.getboolean('pwm', False)
if self.is_pwm:
- self.mcu_pin = pins.setup_pin(printer, 'pwm', config.get('pin'))
+ self.mcu_pin = ppins.setup_pin('pwm', config.get('pin'))
cycle_time = config.getfloat('cycle_time', 0.100, above=0.)
hardware_pwm = config.getboolean('hardware_pwm', False)
self.mcu_pin.setup_cycle_time(cycle_time, hardware_pwm)
self.scale = config.getfloat('scale', 1., above=0.)
else:
- self.mcu_pin = pins.setup_pin(
- printer, 'digital_out', config.get('pin'))
+ self.mcu_pin = ppins.setup_pin('digital_out', config.get('pin'))
self.scale = 1.
self.mcu_pin.setup_max_duration(0.)
self.last_value_time = 0.
- self.last_value = config.getfloat(
- 'value', 0., minval=0., maxval=self.scale) / self.scale
- self.is_static = config.get_name().startswith('static_')
- if self.is_static:
+ static_value = config.getfloat('static_value', None,
+ minval=0., maxval=self.scale)
+ if static_value is not None:
+ self.is_static = True
+ self.last_value = static_value / self.scale
self.mcu_pin.setup_start_value(
self.last_value, self.last_value, True)
else:
+ self.is_static = False
+ self.last_value = config.getfloat(
+ 'value', 0., minval=0., maxval=self.scale) / self.scale
shutdown_value = config.getfloat(
'shutdown_value', 0., minval=0., maxval=self.scale) / self.scale
self.mcu_pin.setup_start_value(self.last_value, shutdown_value)
- self.gcode = printer.lookup_object('gcode')
+ self.gcode = self.printer.lookup_object('gcode')
self.gcode.register_command("SET_PIN", self.cmd_SET_PIN,
desc=self.cmd_SET_PIN_help)
cmd_SET_PIN_help = "Set the value of an output pin"
def cmd_SET_PIN(self, params):
pin_name = self.gcode.get_str('PIN', params)
- pin = self.printer.lookup_object('pin ' + pin_name, None)
+ pin = self.printer.lookup_object('output_pin ' + pin_name, None)
if pin is not self:
if pin is None:
raise self.gcode.error("Pin not configured")
@@ -67,15 +65,5 @@ class PrinterPin:
self.last_value = value
self.last_value_time = print_time
-
-######################################################################
-# Setup
-######################################################################
-
-def add_printer_objects(printer, config):
- for s in config.get_prefix_sections('digital_output '):
- printer.add_object('pin' + s.section[14:], PrinterPin(printer, s))
- for s in config.get_prefix_sections('static_pwm_output '):
- printer.add_object('pin' + s.section[17:], PrinterPin(printer, s))
- for s in config.get_prefix_sections('pwm_output '):
- printer.add_object('pin' + s.section[10:], PrinterPin(printer, s))
+def load_config_prefix(config):
+ return PrinterOutputPin(config)
diff --git a/klippy/klippy.py b/klippy/klippy.py
index 69ceea50..9a16d8f0 100644
--- a/klippy/klippy.py
+++ b/klippy/klippy.py
@@ -7,7 +7,7 @@
import sys, os, optparse, logging, time, threading
import collections, ConfigParser, importlib
import util, reactor, queuelogger, msgproto
-import gcode, pins, mcu, chipmisc, toolhead, extruder, heater
+import gcode, pins, mcu, toolhead, extruder, heater
message_ready = "Printer is ready"
@@ -209,7 +209,7 @@ class Printer:
m.add_printer_objects(self, config)
for section in fileconfig.sections():
self.try_load_module(config, section)
- for m in [chipmisc, toolhead, extruder, heater]:
+ for m in [toolhead, extruder, heater]:
m.add_printer_objects(self, config)
# Validate that there are no undefined parameters in the config file
valid_sections = { s: 1 for s, o in self.all_config_options }