aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--config/example-extras.cfg11
-rw-r--r--config/generic-duet2.cfg4
-rw-r--r--docs/Config_Changes.md4
-rw-r--r--klippy/extras/sx1509.py24
4 files changed, 18 insertions, 25 deletions
diff --git a/config/example-extras.cfg b/config/example-extras.cfg
index 9f164476..f7225735 100644
--- a/config/example-extras.cfg
+++ b/config/example-extras.cfg
@@ -939,11 +939,14 @@
# prefix. Each expander provides a set of 16 pins (sx1509_my_sx1509:PIN_0 to
# sx1509_my_sx1509:PIN_15) which can be used in the printer configuration.
#[sx1509 my_sx1509]
-#address:
+#i2c_mcu: mcu
+# The name of the micro-controller that the SX1509 chip is connected
+# to. The default is "mcu".
+#i2c_address:
# I2C address used by this expander. Depending on the hardware jumpers
-# this is one out of the following addresses: 0x3E 0x3F 0x70 0x71. This
-# parameter must be provided
-#bus: 0
+# this is one out of the following addresses: 62 63 112 113. This
+# parameter must be provided.
+#i2c_bus: 0
# If the I2C implementation of your microcontroller supports multiple I2C
# busses, you may specify the bus number here. The default is 0.
diff --git a/config/generic-duet2.cfg b/config/generic-duet2.cfg
index 163575eb..86a7245f 100644
--- a/config/generic-duet2.cfg
+++ b/config/generic-duet2.cfg
@@ -39,7 +39,7 @@
# | FAN8 | sx1509_duex:PIN_15* |
# Pins marked with (*) assume the following sx1509 config section:
#[sx1509 duex]
-#address: 0x3E
+#i2c_address: 62
#
## Heaters and Thermistors
# | Extruder Drive | HEAT pin | TEMP pin |
@@ -324,7 +324,7 @@ serial: /dev/ttyACM0
restart_method: command
[sx1509 duex]
-address: 0x3E # Address is fixed on duex boards
+i2c_address: 62 # Address is fixed on duex boards
[printer]
kinematics: cartesian
diff --git a/docs/Config_Changes.md b/docs/Config_Changes.md
index 04e6499f..3b8db909 100644
--- a/docs/Config_Changes.md
+++ b/docs/Config_Changes.md
@@ -6,6 +6,10 @@ All dates in this document are approximate.
# Changes
+20190404: The sx1509 config parameters have changed. The 'address'
+parameter is now 'i2c_address' and it must be specified as a decimal
+number. Where 0x3E was previously used, specify 62.
+
20190328: The min_speed value in [temperature_fan] config
will now be respected and the fan will always run at this
speed or higher in PID mode.
diff --git a/klippy/extras/sx1509.py b/klippy/extras/sx1509.py
index 4acb6400..cedec97c 100644
--- a/klippy/extras/sx1509.py
+++ b/klippy/extras/sx1509.py
@@ -3,9 +3,8 @@
# Copyright (C) 2018 Florian Heilmann <Florian.Heilmann@gmx.net>
#
# This file may be distributed under the terms of the GNU GPLv3 license.
-
-import mcu
import pins
+import bus
# Word registers
REG_RESET = 0x7D
@@ -26,25 +25,19 @@ class SX1509(object):
def __init__(self, config):
self._printer = config.get_printer()
self._name = config.get_name().split()[1]
- self._chip_address = int(config.get('address'), 0)
- self._bus = config.getint('bus', minval=0, default=0)
+ self._i2c = bus.MCU_I2C_from_config(config, default_speed=400000)
self._ppins = self._printer.lookup_object("pins")
self._ppins.register_chip("sx1509_" + self._name, self)
- self._mcu = mcu.get_printer_mcu(self._printer, config.get('mcu', 'mcu'))
+ self._mcu = self._i2c.get_mcu()
self._mcu.register_config_callback(self._build_config)
- self._oid = self._mcu.create_oid()
- self._i2c_write_cmd = self._i2c_modify_cmd = None
+ self._oid = self._i2c.get_oid()
self._last_clock = 0
- self._freq = 400000 # Fixed frequency for SX1509
# Set up registers default values
self.reg_dict = {REG_DIR : 0xFFFF, REG_DATA : 0,
REG_PULLUP : 0, REG_PULLDOWN : 0,
REG_INPUT_DISABLE : 0, REG_ANALOG_DRIVER_ENABLE : 0}
self.reg_i_on_dict = {reg : 0 for reg in REG_I_ON}
def _build_config(self):
- self._mcu.add_config_cmd(
- "config_i2c oid=%d bus=%d rate=%d address=%d" % (
- self._oid, self._bus, self._freq, self._chip_address))
# Reset the chip
self._mcu.add_config_cmd("i2c_write oid=%d data=%02x%02x" % (
self._oid, REG_RESET, 0x12))
@@ -62,12 +55,6 @@ class SX1509(object):
for _reg, _data in self.reg_dict.iteritems():
self._mcu.add_config_cmd("i2c_write oid=%d data=%02x%04x" % (
self._oid, _reg, _data), is_init=True)
- # Build commands
- cmd_queue = self._mcu.alloc_command_queue()
- self._i2c_write_cmd = self._mcu.lookup_command(
- "i2c_write oid=%c data=%*s", cq=cmd_queue)
- self._i2c_modify_cmd = self._mcu.lookup_command(
- "i2c_modify_bits oid=%c reg=%*s clear_set_bits=%*s", cq=cmd_queue)
def setup_pin(self, pin_type, pin_params):
if pin_type == 'digital_out' and pin_params['pin'][0:4] == "PIN_":
return SX1509_digital_out(self, pin_params)
@@ -104,8 +91,7 @@ class SX1509(object):
# Byte
data += [self.reg_i_on_dict[reg] & 0xFF]
clock = self._mcu.print_time_to_clock(print_time)
- self._i2c_write_cmd.send([self._oid, data],
- minclock=self._last_clock, reqclock=clock)
+ self._i2c.i2c_write(data, minclock=self._last_clock, reqclock=clock)
self._last_clock = clock
class SX1509_digital_out(object):