Distinct Chopper Timing settings (#19781)
Co-authored-by: Scott Lahteine <github@thinkyhead.com>
This commit is contained in:
		
				
					committed by
					
						 Scott Lahteine
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							32ca42ead3
						
					
				
				
					commit
					9124f1d7c8
				
			| @@ -2471,10 +2471,26 @@ | |||||||
|    * CHOPPER_PRUSAMK3_24V // Imported parameters from the official Průša firmware for MK3 (24V) |    * CHOPPER_PRUSAMK3_24V // Imported parameters from the official Průša firmware for MK3 (24V) | ||||||
|    * CHOPPER_MARLIN_119   // Old defaults from Marlin v1.1.9 |    * CHOPPER_MARLIN_119   // Old defaults from Marlin v1.1.9 | ||||||
|    * |    * | ||||||
|    * Define you own with |    * Define your own with: | ||||||
|    * { <off_time[1..15]>, <hysteresis_end[-3..12]>, hysteresis_start[1..8] } |    * { <off_time[1..15]>, <hysteresis_end[-3..12]>, hysteresis_start[1..8] } | ||||||
|    */ |    */ | ||||||
|   #define CHOPPER_TIMING CHOPPER_DEFAULT_12V |   #define CHOPPER_TIMING CHOPPER_DEFAULT_12V        // All axes (override below) | ||||||
|  |   //#define CHOPPER_TIMING_X  CHOPPER_DEFAULT_12V   // For X Axes (override below) | ||||||
|  |   //#define CHOPPER_TIMING_X2 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_Y  CHOPPER_DEFAULT_12V   // For Y Axes (override below) | ||||||
|  |   //#define CHOPPER_TIMING_Y2 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_Z  CHOPPER_DEFAULT_12V   // For Z Axes (override below) | ||||||
|  |   //#define CHOPPER_TIMING_Z2 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_Z3 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_Z4 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E  CHOPPER_DEFAULT_12V   // For Extruders (override below) | ||||||
|  |   //#define CHOPPER_TIMING_E1 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E2 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E3 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E4 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E5 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E6 CHOPPER_DEFAULT_12V | ||||||
|  |   //#define CHOPPER_TIMING_E7 CHOPPER_DEFAULT_12V | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
|    * Monitor Trinamic drivers |    * Monitor Trinamic drivers | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ | |||||||
| #include <SPI.h> | #include <SPI.h> | ||||||
|  |  | ||||||
| enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | ||||||
| #define TMC_INIT(ST, STEALTH_INDEX) tmc_init(stepper##ST, ST##_CURRENT, ST##_MICROSTEPS, ST##_HYBRID_THRESHOLD, stealthchop_by_axis[STEALTH_INDEX]) | #define TMC_INIT(ST, STEALTH_INDEX) tmc_init(stepper##ST, ST##_CURRENT, ST##_MICROSTEPS, ST##_HYBRID_THRESHOLD, stealthchop_by_axis[STEALTH_INDEX], chopper_timing_##ST) | ||||||
|  |  | ||||||
| //   IC = TMC model number | //   IC = TMC model number | ||||||
| //   ST = Stepper object letter | //   ST = Stepper object letter | ||||||
| @@ -131,15 +131,15 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC2130) | #if HAS_DRIVER(TMC2130) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC2130Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth) { |   void tmc_init(TMCMarlin<TMC2130Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth, const chopper_timing_t &chop_init) { | ||||||
|     st.begin(); |     st.begin(); | ||||||
|  |  | ||||||
|     CHOPCONF_t chopconf{0}; |     CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 1; |     chopconf.tbl = 0b01; | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.intpol = INTERPOLATE; |     chopconf.intpol = INTERPOLATE; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); |     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
| @@ -166,15 +166,15 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC2160) | #if HAS_DRIVER(TMC2160) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC2160Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth) { |   void tmc_init(TMCMarlin<TMC2160Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth, const chopper_timing_t &chop_init) { | ||||||
|     st.begin(); |     st.begin(); | ||||||
|  |  | ||||||
|     CHOPCONF_t chopconf{0}; |     CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 1; |     chopconf.tbl = 0b01; | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.intpol = INTERPOLATE; |     chopconf.intpol = INTERPOLATE; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); |     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
| @@ -484,7 +484,7 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC2208) | #if HAS_DRIVER(TMC2208) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC2208Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth) { |   void tmc_init(TMCMarlin<TMC2208Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth, const chopper_timing_t &chop_init) { | ||||||
|     TMC2208_n::GCONF_t gconf{0}; |     TMC2208_n::GCONF_t gconf{0}; | ||||||
|     gconf.pdn_disable = true; // Use UART |     gconf.pdn_disable = true; // Use UART | ||||||
|     gconf.mstep_reg_select = true; // Select microsteps with UART |     gconf.mstep_reg_select = true; // Select microsteps with UART | ||||||
| @@ -495,10 +495,10 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
|     TMC2208_n::CHOPCONF_t chopconf{0}; |     TMC2208_n::CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 0b01; // blank_time = 24 |     chopconf.tbl = 0b01; // blank_time = 24 | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.intpol = INTERPOLATE; |     chopconf.intpol = INTERPOLATE; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); |     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
| @@ -526,7 +526,7 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC2209) | #if HAS_DRIVER(TMC2209) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC2209Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth) { |   void tmc_init(TMCMarlin<TMC2209Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth, const chopper_timing_t &chop_init) { | ||||||
|     TMC2208_n::GCONF_t gconf{0}; |     TMC2208_n::GCONF_t gconf{0}; | ||||||
|     gconf.pdn_disable = true; // Use UART |     gconf.pdn_disable = true; // Use UART | ||||||
|     gconf.mstep_reg_select = true; // Select microsteps with UART |     gconf.mstep_reg_select = true; // Select microsteps with UART | ||||||
| @@ -537,10 +537,10 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
|     TMC2208_n::CHOPCONF_t chopconf{0}; |     TMC2208_n::CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 0b01; // blank_time = 24 |     chopconf.tbl = 0b01; // blank_time = 24 | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.intpol = INTERPOLATE; |     chopconf.intpol = INTERPOLATE; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); |     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
| @@ -568,14 +568,14 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC2660) | #if HAS_DRIVER(TMC2660) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC2660Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t, const bool) { |   void tmc_init(TMCMarlin<TMC2660Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t, const bool, const chopper_timing_t &chop_init) { | ||||||
|     st.begin(); |     st.begin(); | ||||||
|  |  | ||||||
|     TMC2660_n::CHOPCONF_t chopconf{0}; |     TMC2660_n::CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 1; |     chopconf.tbl = 0b01; | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
|     st.sdoff(0); |     st.sdoff(0); | ||||||
| @@ -590,15 +590,15 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC5130) | #if HAS_DRIVER(TMC5130) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC5130Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth) { |   void tmc_init(TMCMarlin<TMC5130Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth, const chopper_timing_t &chop_init) { | ||||||
|     st.begin(); |     st.begin(); | ||||||
|  |  | ||||||
|     CHOPCONF_t chopconf{0}; |     CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 1; |     chopconf.tbl = 0b01; | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.intpol = INTERPOLATE; |     chopconf.intpol = INTERPOLATE; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); |     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
| @@ -625,15 +625,15 @@ enum StealthIndex : uint8_t { STEALTH_AXIS_XY, STEALTH_AXIS_Z, STEALTH_AXIS_E }; | |||||||
|  |  | ||||||
| #if HAS_DRIVER(TMC5160) | #if HAS_DRIVER(TMC5160) | ||||||
|   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> |   template<char AXIS_LETTER, char DRIVER_ID, AxisEnum AXIS_ID> | ||||||
|   void tmc_init(TMCMarlin<TMC5160Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth) { |   void tmc_init(TMCMarlin<TMC5160Stepper, AXIS_LETTER, DRIVER_ID, AXIS_ID> &st, const uint16_t mA, const uint16_t microsteps, const uint32_t hyb_thrs, const bool stealth, const chopper_timing_t &chop_init) { | ||||||
|     st.begin(); |     st.begin(); | ||||||
|  |  | ||||||
|     CHOPCONF_t chopconf{0}; |     CHOPCONF_t chopconf{0}; | ||||||
|     chopconf.tbl = 1; |     chopconf.tbl = 0b01; | ||||||
|     chopconf.toff = chopper_timing.toff; |     chopconf.toff = chop_init.toff; | ||||||
|     chopconf.intpol = INTERPOLATE; |     chopconf.intpol = INTERPOLATE; | ||||||
|     chopconf.hend = chopper_timing.hend + 3; |     chopconf.hend = chop_init.hend + 3; | ||||||
|     chopconf.hstrt = chopper_timing.hstrt - 1; |     chopconf.hstrt = chop_init.hstrt - 1; | ||||||
|     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); |     TERN_(SQUARE_WAVE_STEPPING, chopconf.dedge = true); | ||||||
|     st.CHOPCONF(chopconf.sr); |     st.CHOPCONF(chopconf.sr); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -76,7 +76,18 @@ typedef struct { | |||||||
|   uint8_t hstrt; |   uint8_t hstrt; | ||||||
| } chopper_timing_t; | } chopper_timing_t; | ||||||
|  |  | ||||||
| static constexpr chopper_timing_t chopper_timing = CHOPPER_TIMING; | #ifndef CHOPPER_TIMING_X | ||||||
|  |   #define CHOPPER_TIMING_X CHOPPER_TIMING | ||||||
|  | #endif | ||||||
|  | #ifndef CHOPPER_TIMING_Y | ||||||
|  |   #define CHOPPER_TIMING_Y CHOPPER_TIMING | ||||||
|  | #endif | ||||||
|  | #ifndef CHOPPER_TIMING_Z | ||||||
|  |   #define CHOPPER_TIMING_Z CHOPPER_TIMING | ||||||
|  | #endif | ||||||
|  | #ifndef CHOPPER_TIMING_E | ||||||
|  |   #define CHOPPER_TIMING_E CHOPPER_TIMING | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if HAS_TMC220x | #if HAS_TMC220x | ||||||
|   void tmc_serial_begin(); |   void tmc_serial_begin(); | ||||||
| @@ -90,9 +101,10 @@ void reset_trinamic_drivers(); | |||||||
| // X Stepper | // X Stepper | ||||||
| #if AXIS_IS_TMC(X) | #if AXIS_IS_TMC(X) | ||||||
|   extern TMC_CLASS(X, X) stepperX; |   extern TMC_CLASS(X, X) stepperX; | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_X = CHOPPER_TIMING_X; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define X_ENABLE_INIT() NOOP |     #define X_ENABLE_INIT() NOOP | ||||||
|     #define X_ENABLE_WRITE(STATE) stepperX.toff((STATE)==X_ENABLE_ON ? chopper_timing.toff : 0) |     #define X_ENABLE_WRITE(STATE) stepperX.toff((STATE)==X_ENABLE_ON ? chopper_timing_X.toff : 0) | ||||||
|     #define X_ENABLE_READ() stepperX.isEnabled() |     #define X_ENABLE_READ() stepperX.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(X) |   #if AXIS_HAS_SQUARE_WAVE(X) | ||||||
| @@ -103,9 +115,10 @@ void reset_trinamic_drivers(); | |||||||
| // Y Stepper | // Y Stepper | ||||||
| #if AXIS_IS_TMC(Y) | #if AXIS_IS_TMC(Y) | ||||||
|   extern TMC_CLASS(Y, Y) stepperY; |   extern TMC_CLASS(Y, Y) stepperY; | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_Y = CHOPPER_TIMING_Y; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define Y_ENABLE_INIT() NOOP |     #define Y_ENABLE_INIT() NOOP | ||||||
|     #define Y_ENABLE_WRITE(STATE) stepperY.toff((STATE)==Y_ENABLE_ON ? chopper_timing.toff : 0) |     #define Y_ENABLE_WRITE(STATE) stepperY.toff((STATE)==Y_ENABLE_ON ? chopper_timing_Y.toff : 0) | ||||||
|     #define Y_ENABLE_READ() stepperY.isEnabled() |     #define Y_ENABLE_READ() stepperY.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(Y) |   #if AXIS_HAS_SQUARE_WAVE(Y) | ||||||
| @@ -116,9 +129,10 @@ void reset_trinamic_drivers(); | |||||||
| // Z Stepper | // Z Stepper | ||||||
| #if AXIS_IS_TMC(Z) | #if AXIS_IS_TMC(Z) | ||||||
|   extern TMC_CLASS(Z, Z) stepperZ; |   extern TMC_CLASS(Z, Z) stepperZ; | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_Z = CHOPPER_TIMING_Z; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define Z_ENABLE_INIT() NOOP |     #define Z_ENABLE_INIT() NOOP | ||||||
|     #define Z_ENABLE_WRITE(STATE) stepperZ.toff((STATE)==Z_ENABLE_ON ? chopper_timing.toff : 0) |     #define Z_ENABLE_WRITE(STATE) stepperZ.toff((STATE)==Z_ENABLE_ON ? chopper_timing_Z.toff : 0) | ||||||
|     #define Z_ENABLE_READ() stepperZ.isEnabled() |     #define Z_ENABLE_READ() stepperZ.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(Z) |   #if AXIS_HAS_SQUARE_WAVE(Z) | ||||||
| @@ -129,9 +143,13 @@ void reset_trinamic_drivers(); | |||||||
| // X2 Stepper | // X2 Stepper | ||||||
| #if HAS_X2_ENABLE && AXIS_IS_TMC(X2) | #if HAS_X2_ENABLE && AXIS_IS_TMC(X2) | ||||||
|   extern TMC_CLASS(X2, X) stepperX2; |   extern TMC_CLASS(X2, X) stepperX2; | ||||||
|  |   #ifndef CHOPPER_TIMING_X2 | ||||||
|  |     #define CHOPPER_TIMING_X2 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_X2 = CHOPPER_TIMING_X2; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define X2_ENABLE_INIT() NOOP |     #define X2_ENABLE_INIT() NOOP | ||||||
|     #define X2_ENABLE_WRITE(STATE) stepperX2.toff((STATE)==X_ENABLE_ON ? chopper_timing.toff : 0) |     #define X2_ENABLE_WRITE(STATE) stepperX2.toff((STATE)==X_ENABLE_ON ? chopper_timing_X2.toff : 0) | ||||||
|     #define X2_ENABLE_READ() stepperX2.isEnabled() |     #define X2_ENABLE_READ() stepperX2.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(X2) |   #if AXIS_HAS_SQUARE_WAVE(X2) | ||||||
| @@ -142,9 +160,13 @@ void reset_trinamic_drivers(); | |||||||
| // Y2 Stepper | // Y2 Stepper | ||||||
| #if HAS_Y2_ENABLE && AXIS_IS_TMC(Y2) | #if HAS_Y2_ENABLE && AXIS_IS_TMC(Y2) | ||||||
|   extern TMC_CLASS(Y2, Y) stepperY2; |   extern TMC_CLASS(Y2, Y) stepperY2; | ||||||
|  |   #ifndef CHOPPER_TIMING_Y2 | ||||||
|  |     #define CHOPPER_TIMING_Y2 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_Y2 = CHOPPER_TIMING_Y2; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define Y2_ENABLE_INIT() NOOP |     #define Y2_ENABLE_INIT() NOOP | ||||||
|     #define Y2_ENABLE_WRITE(STATE) stepperY2.toff((STATE)==Y_ENABLE_ON ? chopper_timing.toff : 0) |     #define Y2_ENABLE_WRITE(STATE) stepperY2.toff((STATE)==Y_ENABLE_ON ? chopper_timing_Y2.toff : 0) | ||||||
|     #define Y2_ENABLE_READ() stepperY2.isEnabled() |     #define Y2_ENABLE_READ() stepperY2.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(Y2) |   #if AXIS_HAS_SQUARE_WAVE(Y2) | ||||||
| @@ -155,9 +177,13 @@ void reset_trinamic_drivers(); | |||||||
| // Z2 Stepper | // Z2 Stepper | ||||||
| #if HAS_Z2_ENABLE && AXIS_IS_TMC(Z2) | #if HAS_Z2_ENABLE && AXIS_IS_TMC(Z2) | ||||||
|   extern TMC_CLASS(Z2, Z) stepperZ2; |   extern TMC_CLASS(Z2, Z) stepperZ2; | ||||||
|  |   #ifndef CHOPPER_TIMING_Z2 | ||||||
|  |     #define CHOPPER_TIMING_Z2 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_Z2 = CHOPPER_TIMING_Z2; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(Z2) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(Z2) | ||||||
|     #define Z2_ENABLE_INIT() NOOP |     #define Z2_ENABLE_INIT() NOOP | ||||||
|     #define Z2_ENABLE_WRITE(STATE) stepperZ2.toff((STATE)==Z_ENABLE_ON ? chopper_timing.toff : 0) |     #define Z2_ENABLE_WRITE(STATE) stepperZ2.toff((STATE)==Z_ENABLE_ON ? chopper_timing_Z2.toff : 0) | ||||||
|     #define Z2_ENABLE_READ() stepperZ2.isEnabled() |     #define Z2_ENABLE_READ() stepperZ2.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(Z2) |   #if AXIS_HAS_SQUARE_WAVE(Z2) | ||||||
| @@ -168,9 +194,13 @@ void reset_trinamic_drivers(); | |||||||
| // Z3 Stepper | // Z3 Stepper | ||||||
| #if HAS_Z3_ENABLE && AXIS_IS_TMC(Z3) | #if HAS_Z3_ENABLE && AXIS_IS_TMC(Z3) | ||||||
|   extern TMC_CLASS(Z3, Z) stepperZ3; |   extern TMC_CLASS(Z3, Z) stepperZ3; | ||||||
|  |   #ifndef CHOPPER_TIMING_Z3 | ||||||
|  |     #define CHOPPER_TIMING_Z3 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_Z3 = CHOPPER_TIMING_Z3; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define Z3_ENABLE_INIT() NOOP |     #define Z3_ENABLE_INIT() NOOP | ||||||
|     #define Z3_ENABLE_WRITE(STATE) stepperZ3.toff((STATE)==Z_ENABLE_ON ? chopper_timing.toff : 0) |     #define Z3_ENABLE_WRITE(STATE) stepperZ3.toff((STATE)==Z_ENABLE_ON ? chopper_timing_Z3.toff : 0) | ||||||
|     #define Z3_ENABLE_READ() stepperZ3.isEnabled() |     #define Z3_ENABLE_READ() stepperZ3.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(Z3) |   #if AXIS_HAS_SQUARE_WAVE(Z3) | ||||||
| @@ -181,9 +211,13 @@ void reset_trinamic_drivers(); | |||||||
| // Z4 Stepper | // Z4 Stepper | ||||||
| #if HAS_Z4_ENABLE && AXIS_IS_TMC(Z4) | #if HAS_Z4_ENABLE && AXIS_IS_TMC(Z4) | ||||||
|   extern TMC_CLASS(Z4, Z) stepperZ4; |   extern TMC_CLASS(Z4, Z) stepperZ4; | ||||||
|  |   #ifndef CHOPPER_TIMING_Z4 | ||||||
|  |     #define CHOPPER_TIMING_Z4 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_Z4 = CHOPPER_TIMING_Z4; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) | ||||||
|     #define Z4_ENABLE_INIT() NOOP |     #define Z4_ENABLE_INIT() NOOP | ||||||
|     #define Z4_ENABLE_WRITE(STATE) stepperZ4.toff((STATE)==Z_ENABLE_ON ? chopper_timing.toff : 0) |     #define Z4_ENABLE_WRITE(STATE) stepperZ4.toff((STATE)==Z_ENABLE_ON ? chopper_timing_Z4.toff : 0) | ||||||
|     #define Z4_ENABLE_READ() stepperZ4.isEnabled() |     #define Z4_ENABLE_READ() stepperZ4.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(Z4) |   #if AXIS_HAS_SQUARE_WAVE(Z4) | ||||||
| @@ -194,9 +228,13 @@ void reset_trinamic_drivers(); | |||||||
| // E0 Stepper | // E0 Stepper | ||||||
| #if AXIS_IS_TMC(E0) | #if AXIS_IS_TMC(E0) | ||||||
|   extern TMC_CLASS_E(0) stepperE0; |   extern TMC_CLASS_E(0) stepperE0; | ||||||
|  |   #ifndef CHOPPER_TIMING_E0 | ||||||
|  |     #define CHOPPER_TIMING_E0 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E0 = CHOPPER_TIMING_E0; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E0) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E0) | ||||||
|     #define E0_ENABLE_INIT() NOOP |     #define E0_ENABLE_INIT() NOOP | ||||||
|     #define E0_ENABLE_WRITE(STATE) stepperE0.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E0_ENABLE_WRITE(STATE) stepperE0.toff((STATE)==E_ENABLE_ON ? chopper_timing_E0.toff : 0) | ||||||
|     #define E0_ENABLE_READ() stepperE0.isEnabled() |     #define E0_ENABLE_READ() stepperE0.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E0) |   #if AXIS_HAS_SQUARE_WAVE(E0) | ||||||
| @@ -207,9 +245,13 @@ void reset_trinamic_drivers(); | |||||||
| // E1 Stepper | // E1 Stepper | ||||||
| #if AXIS_IS_TMC(E1) | #if AXIS_IS_TMC(E1) | ||||||
|   extern TMC_CLASS_E(1) stepperE1; |   extern TMC_CLASS_E(1) stepperE1; | ||||||
|  |   #ifndef CHOPPER_TIMING_E1 | ||||||
|  |     #define CHOPPER_TIMING_E1 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E1 = CHOPPER_TIMING_E1; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E1) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E1) | ||||||
|     #define E1_ENABLE_INIT() NOOP |     #define E1_ENABLE_INIT() NOOP | ||||||
|     #define E1_ENABLE_WRITE(STATE) stepperE1.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E1_ENABLE_WRITE(STATE) stepperE1.toff((STATE)==E_ENABLE_ON ? chopper_timing_E1.toff : 0) | ||||||
|     #define E1_ENABLE_READ() stepperE1.isEnabled() |     #define E1_ENABLE_READ() stepperE1.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E1) |   #if AXIS_HAS_SQUARE_WAVE(E1) | ||||||
| @@ -220,9 +262,13 @@ void reset_trinamic_drivers(); | |||||||
| // E2 Stepper | // E2 Stepper | ||||||
| #if AXIS_IS_TMC(E2) | #if AXIS_IS_TMC(E2) | ||||||
|   extern TMC_CLASS_E(2) stepperE2; |   extern TMC_CLASS_E(2) stepperE2; | ||||||
|  |   #ifndef CHOPPER_TIMING_E2 | ||||||
|  |     #define CHOPPER_TIMING_E2 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E2 = CHOPPER_TIMING_E2; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E2) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E2) | ||||||
|     #define E2_ENABLE_INIT() NOOP |     #define E2_ENABLE_INIT() NOOP | ||||||
|     #define E2_ENABLE_WRITE(STATE) stepperE2.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E2_ENABLE_WRITE(STATE) stepperE2.toff((STATE)==E_ENABLE_ON ? chopper_timing_E2.toff : 0) | ||||||
|     #define E2_ENABLE_READ() stepperE2.isEnabled() |     #define E2_ENABLE_READ() stepperE2.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E2) |   #if AXIS_HAS_SQUARE_WAVE(E2) | ||||||
| @@ -233,9 +279,13 @@ void reset_trinamic_drivers(); | |||||||
| // E3 Stepper | // E3 Stepper | ||||||
| #if AXIS_IS_TMC(E3) | #if AXIS_IS_TMC(E3) | ||||||
|   extern TMC_CLASS_E(3) stepperE3; |   extern TMC_CLASS_E(3) stepperE3; | ||||||
|  |   #ifndef CHOPPER_TIMING_E3 | ||||||
|  |     #define CHOPPER_TIMING_E3 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E3 = CHOPPER_TIMING_E3; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E3) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E3) | ||||||
|     #define E3_ENABLE_INIT() NOOP |     #define E3_ENABLE_INIT() NOOP | ||||||
|     #define E3_ENABLE_WRITE(STATE) stepperE3.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E3_ENABLE_WRITE(STATE) stepperE3.toff((STATE)==E_ENABLE_ON ? chopper_timing_E3.toff : 0) | ||||||
|     #define E3_ENABLE_READ() stepperE3.isEnabled() |     #define E3_ENABLE_READ() stepperE3.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E3) |   #if AXIS_HAS_SQUARE_WAVE(E3) | ||||||
| @@ -246,9 +296,13 @@ void reset_trinamic_drivers(); | |||||||
| // E4 Stepper | // E4 Stepper | ||||||
| #if AXIS_IS_TMC(E4) | #if AXIS_IS_TMC(E4) | ||||||
|   extern TMC_CLASS_E(4) stepperE4; |   extern TMC_CLASS_E(4) stepperE4; | ||||||
|  |   #ifndef CHOPPER_TIMING_E4 | ||||||
|  |     #define CHOPPER_TIMING_E4 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E4 = CHOPPER_TIMING_E4; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E4) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E4) | ||||||
|     #define E4_ENABLE_INIT() NOOP |     #define E4_ENABLE_INIT() NOOP | ||||||
|     #define E4_ENABLE_WRITE(STATE) stepperE4.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E4_ENABLE_WRITE(STATE) stepperE4.toff((STATE)==E_ENABLE_ON ? chopper_timing_E4.toff : 0) | ||||||
|     #define E4_ENABLE_READ() stepperE4.isEnabled() |     #define E4_ENABLE_READ() stepperE4.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E4) |   #if AXIS_HAS_SQUARE_WAVE(E4) | ||||||
| @@ -259,9 +313,13 @@ void reset_trinamic_drivers(); | |||||||
| // E5 Stepper | // E5 Stepper | ||||||
| #if AXIS_IS_TMC(E5) | #if AXIS_IS_TMC(E5) | ||||||
|   extern TMC_CLASS_E(5) stepperE5; |   extern TMC_CLASS_E(5) stepperE5; | ||||||
|  |   #ifndef CHOPPER_TIMING_E5 | ||||||
|  |     #define CHOPPER_TIMING_E5 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E5 = CHOPPER_TIMING_E5; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E5) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E5) | ||||||
|     #define E5_ENABLE_INIT() NOOP |     #define E5_ENABLE_INIT() NOOP | ||||||
|     #define E5_ENABLE_WRITE(STATE) stepperE5.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E5_ENABLE_WRITE(STATE) stepperE5.toff((STATE)==E_ENABLE_ON ? chopper_timing_E5.toff : 0) | ||||||
|     #define E5_ENABLE_READ() stepperE5.isEnabled() |     #define E5_ENABLE_READ() stepperE5.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E5) |   #if AXIS_HAS_SQUARE_WAVE(E5) | ||||||
| @@ -272,9 +330,13 @@ void reset_trinamic_drivers(); | |||||||
| // E6 Stepper | // E6 Stepper | ||||||
| #if AXIS_IS_TMC(E6) | #if AXIS_IS_TMC(E6) | ||||||
|   extern TMC_CLASS_E(6) stepperE6; |   extern TMC_CLASS_E(6) stepperE6; | ||||||
|  |   #ifndef CHOPPER_TIMING_E6 | ||||||
|  |     #define CHOPPER_TIMING_E6 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E6 = CHOPPER_TIMING_E6; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E6) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E6) | ||||||
|     #define E6_ENABLE_INIT() NOOP |     #define E6_ENABLE_INIT() NOOP | ||||||
|     #define E6_ENABLE_WRITE(STATE) stepperE6.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E6_ENABLE_WRITE(STATE) stepperE6.toff((STATE)==E_ENABLE_ON ? chopper_timing_E6.toff : 0) | ||||||
|     #define E6_ENABLE_READ() stepperE6.isEnabled() |     #define E6_ENABLE_READ() stepperE6.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E6) |   #if AXIS_HAS_SQUARE_WAVE(E6) | ||||||
| @@ -285,9 +347,13 @@ void reset_trinamic_drivers(); | |||||||
| // E7 Stepper | // E7 Stepper | ||||||
| #if AXIS_IS_TMC(E7) | #if AXIS_IS_TMC(E7) | ||||||
|   extern TMC_CLASS_E(7) stepperE7; |   extern TMC_CLASS_E(7) stepperE7; | ||||||
|  |   #ifndef CHOPPER_TIMING_E7 | ||||||
|  |     #define CHOPPER_TIMING_E7 CHOPPER_TIMING_E | ||||||
|  |   #endif | ||||||
|  |   static constexpr chopper_timing_t chopper_timing_E7 = CHOPPER_TIMING_E7; | ||||||
|   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E7) |   #if ENABLED(SOFTWARE_DRIVER_ENABLE) && AXIS_IS_TMC(E7) | ||||||
|     #define E7_ENABLE_INIT() NOOP |     #define E7_ENABLE_INIT() NOOP | ||||||
|     #define E7_ENABLE_WRITE(STATE) stepperE7.toff((STATE)==E_ENABLE_ON ? chopper_timing.toff : 0) |     #define E7_ENABLE_WRITE(STATE) stepperE7.toff((STATE)==E_ENABLE_ON ? chopper_timing_E7.toff : 0) | ||||||
|     #define E7_ENABLE_READ() stepperE7.isEnabled() |     #define E7_ENABLE_READ() stepperE7.isEnabled() | ||||||
|   #endif |   #endif | ||||||
|   #if AXIS_HAS_SQUARE_WAVE(E7) |   #if AXIS_HAS_SQUARE_WAVE(E7) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user