From fdb52d4e70f5f702c1c09d40be48d69de9c8ca2e Mon Sep 17 00:00:00 2001 From: Rogerio Goncalves Date: Thu, 4 Jul 2024 14:06:23 +0100 Subject: [PATCH] feat/tmc - warning for sense_resistor --- klippy/extras/tmc2130.py | 14 ++++++++++++++ klippy/extras/tmc5160.py | 14 ++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/klippy/extras/tmc2130.py b/klippy/extras/tmc2130.py index e7ba9ddd5..3ecae3f2e 100644 --- a/klippy/extras/tmc2130.py +++ b/klippy/extras/tmc2130.py @@ -5,6 +5,7 @@ # This file may be distributed under the terms of the GNU GPLv3 license. import math from . import bus, tmc +from configfile import PrinterConfig TMC_FREQUENCY = 13200000.0 @@ -200,6 +201,19 @@ class TMC2130CurrentHelper(tmc.BaseTMCCurrentHelper): def __init__(self, config, mcu_tmc): super().__init__(config, mcu_tmc, MAX_CURRENT) + pconfig: PrinterConfig = self.printer.lookup_object("configfile") + + self.sense_resistor = config.get("sense_resistor", None) + if self.sense_resistor is None: + pconfig.warn( + "config", + f"""[{self.name}] sense_resistor not specified; using default = 0.110. + If this value is wrong, it might burn your house down. + This parameter will be mandatory in future versions. + Specify the parameter to resolve this warning""", + self.name, + "sense_resistor", + ) self.sense_resistor = config.getfloat( "sense_resistor", 0.110, above=0.0 diff --git a/klippy/extras/tmc5160.py b/klippy/extras/tmc5160.py index 1477ba84f..f1003f977 100644 --- a/klippy/extras/tmc5160.py +++ b/klippy/extras/tmc5160.py @@ -6,6 +6,7 @@ import math from . import tmc from . import tmc2130 +from configfile import PrinterConfig TMC_FREQUENCY = 12000000.0 @@ -254,6 +255,19 @@ class TMC5160CurrentHelper(tmc.BaseTMCCurrentHelper): def __init__(self, config, mcu_tmc): super().__init__(config, mcu_tmc, MAX_CURRENT) + pconfig: PrinterConfig = self.printer.lookup_object("configfile") + + self.sense_resistor = config.get("sense_resistor", None) + if self.sense_resistor is None: + pconfig.warn( + "config", + f"""[{self.name}] sense_resistor not specified; using default = 0.075. + If this value is wrong, it might burn your house down. + This parameter will be mandatory in future versions. + Specify the parameter to resolve this warning""", + self.name, + "sense_resistor", + ) self.sense_resistor = config.getfloat( "sense_resistor", 0.075, above=0.0