1
0
mirror of https://github.com/bdring/Grbl_Esp32.git synced 2025-01-17 14:18:16 +01:00

Manually snyc'ing with Devt

This commit is contained in:
bdring 2020-07-25 16:05:19 -05:00
parent 98cd90dd01
commit 4c6125f860
7 changed files with 0 additions and 604 deletions

View File

@ -384,8 +384,6 @@ void motors_set_direction_pins(uint8_t onMask) {
}
}
// for testing
#ifndef USE_TRINAMIC
// returns the next spi index. We cannot preassign to axes because ganged (X2 type axes) might
// need to be inserted into the order of axes.
uint8_t get_next_trinamic_driver_index() {
@ -447,8 +445,6 @@ void TMC2130Stepper::switchCSpin(bool state) {
}
#endif
#endif
// ============================== Class Methods ================================================
Motor :: Motor() {

View File

@ -92,10 +92,6 @@
#include "servo_axis.h"
#endif
#ifdef USE_TRINAMIC
#include "grbl_trinamic.h"
#endif
#ifdef USE_UNIPOLAR
#include "grbl_unipolar.h"
#endif

View File

@ -1,536 +0,0 @@
/*
grbl_trinamic.cpp - Support for Trinamic Stepper Drivers SPI Mode
using the TMCStepper library
Part of Grbl_ESP32
Copyright (c) 2019 Barton Dring for Buildlog.net LLC
Grbl_ESP32 is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Grbl is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Grbl. If not, see <http://www.gnu.org/licenses/>.
*/
#include "grbl.h"
#ifdef USE_TRINAMIC
/*
The drivers can use SPI daisy chaining to allow the use of a single CS_PIN.
The PCB must be designed for this, with SDO pins connected to the
next driver's SDI pin and the final SDO going back to the CPU.
To set this up, #define TRINAMIC_DAISY_CHAIN in your machine definition
file (Machines/something.h).
Set the CS_PIN definition for every axis to the same pin, like this...
#define X_CS_PIN GPIO_NUM_17
#define Y_CS_PIN GPIO_NUM_17
...etc.
Indexes are assigned to each axis in daisy chain mode as shown below.
This assumes your first SPI driver axis is X and there are no gaps until
the last SPI driver.
*/
// TODO try to use the #define ## method to clean this up
//#define DRIVER(driver, axis) driver##Stepper = TRINAMIC_axis## = driver##Stepper(axis##_CS_PIN, axis##_RSENSE);
#ifdef X_TRINAMIC
#ifdef X_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_X = TMC2130Stepper(X_CS_PIN, X_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef X_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_X = TMC2209Stepper(X_CS_PIN, X_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef X_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_X = TMC5160Stepper(X_CS_PIN, X_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef X2_TRINAMIC
#ifdef X2_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_X2 = TMC2130Stepper(X2_CS_PIN, X2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef X2_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_X2 = TMC2209Stepper(X2_CS_PIN, X2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef X2_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_X2 = TMC5160Stepper(X2_CS_PIN, X2_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef Y_TRINAMIC
#ifdef Y_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_Y = TMC2130Stepper(Y_CS_PIN, Y_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Y_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_Y = TMC2209Stepper(Y_CS_PIN, Y_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Y_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_Y = TMC5160Stepper(Y_CS_PIN, Y_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef Y2_TRINAMIC
#ifdef Y2_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_Y2 = TMC2130Stepper(Y2_CS_PIN, Y2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Y2_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_Y2 = TMC2209Stepper(Y2_CS_PIN, Y2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Y2_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_Y2 = TMC5160Stepper(Y2_CS_PIN, Y2_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef Z_TRINAMIC
#ifdef Z_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_Z = TMC2130Stepper(Z_CS_PIN, Z_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Z_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_Z = TMC2209Stepper(Z_CS_PIN, Z_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Z_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_Z = TMC5160Stepper(Z_CS_PIN, Z_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef Z2_TRINAMIC
#ifdef Z2_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_Z2 = TMC2130Stepper(Z2_CS_PIN, Z2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Z2_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_Z2 = TMC2209Stepper(Z2_CS_PIN, Z2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef Z2_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_Z2 = TMC5160Stepper(Z2_CS_PIN, Z2_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef A_TRINAMIC
#ifdef A_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_A = TMC2130Stepper(A_CS_PIN, A_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef A_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_A = TMC2209Stepper(A_CS_PIN, A_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef A_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_A = TMC5160Stepper(A_CS_PIN, A_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef A2_TRINAMIC
#ifdef A2_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_A2 = TMC2130Stepper(A2_CS_PIN, A2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef A2_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_A2 = TMC2209Stepper(A2_CS_PIN, A_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef A2_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_A2 = TMC5160Stepper(A2_CS_PIN, A2_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef B_TRINAMIC
#ifdef B_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_B = TMC2130Stepper(B_CS_PIN, B_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef B_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_B = TMC2209Stepper(B_CS_PIN, B_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef B_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_B = TMC5160Stepper(B_CS_PIN, B_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef B2_TRINAMIC
#ifdef B2_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_B2 = TMC2130Stepper(B2_CS_PIN, B2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef B2_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_B2 = TMC2209Stepper(B2_CS_PIN, B2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef B2_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_B2 = TMC5160Stepper(B2_CS_PIN, B2_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef C_TRINAMIC
#ifdef C_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_C = TMC2130Stepper(C_CS_PIN, C_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef C_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_C = TMC2209Stepper(C_CS_PIN, C_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef C_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_C = TMC5160Stepper(C_CS_PIN, C_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
#ifdef C2_TRINAMIC
#ifdef C2_DRIVER_TMC2130
TMC2130Stepper TRINAMIC_C2 = TMC2130Stepper(C2_CS_PIN, C2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef C2_DRIVER_TMC2209
TMC2209Stepper TRINAMIC_C2 = TMC2209Stepper(C2_CS_PIN, C2_RSENSE, get_next_trinamic_driver_index());
#endif
#ifdef C2_DRIVER_TMC5160
TMC5160Stepper TRINAMIC_C2 = TMC5160Stepper(C2_CS_PIN, C2_RSENSE, get_next_trinamic_driver_index());
#endif
#endif
void Trinamic_Init() {
grbl_msg_sendf(CLIENT_SERIAL, MSG_LEVEL_INFO, "TMCStepper Init using Library Ver 0x%06x", TMCSTEPPER_VERSION);
// On Slack Grbl_Esp32 channel, Mitch Bradley suggested.
// "Any pin that could possibly be implemented with a GPIO pin needs
// a pinMode before the first active use. pinMode(OUTPUT) does not have to
// precede digitalWrite(HIGH), as the following sequence is useful:
// digitalWrite(GPIOn, HIGH);
// pinMode(GPIOn, OUTPUT);
// The reason for that sequence is that, for pins that default to input mode/tri-state,
// setting it HIGH first prevents a low-going transition if the pin output register
// happens to be LOW when you select OUTPUT mode."
// Notes on using I2S out:
// The TMC connected to the I2S out requires SPI clocking down (approximately 100 KHz)
// to work in concert with slow CS operations by I2S out.
#ifdef X_DRIVER_TMC2130
digitalWrite(X_CS_PIN, HIGH);
pinMode(X_CS_PIN, OUTPUT);
TRINAMIC_X.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef X2_DRIVER_TMC2130
digitalWrite(X2_CS_PIN, HIGH);
pinMode(X2_CS_PIN, OUTPUT);
TRINAMIC_X2.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef Y_DRIVER_TMC2130
digitalWrite(Y_CS_PIN, HIGH);
pinMode(Y_CS_PIN, OUTPUT);
TRINAMIC_Y.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef Y2_DRIVER_TMC2130
digitalWrite(Y2_CS_PIN, HIGH);
pinMode(Y2_CS_PIN, OUTPUT);
TRINAMIC_Y2.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef Z_DRIVER_TMC2130
digitalWrite(Z_CS_PIN, HIGH);
pinMode(Z_CS_PIN, OUTPUT);
TRINAMIC_Z.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef Z2_DRIVER_TMC2130
digitalWrite(Z2_CS_PIN, HIGH);
pinMode(Z2_CS_PIN, OUTPUT);
TRINAMIC_Z2.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef A_DRIVER_TMC2130
digitalWrite(A_CS_PIN, HIGH);
pinMode(A_CS_PIN, OUTPUT);
TRINAMIC_A.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef A2_DRIVER_TMC2130
digitalWrite(A2_CS_PIN, HIGH);
pinMode(A2_CS_PIN, OUTPUT);
TRINAMIC_A2.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef B_DRIVER_TMC2130
digitalWrite(B_CS_PIN, HIGH);
pinMode(B_CS_PIN, OUTPUT);
TRINAMIC_B.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef B2_DRIVER_TMC2130
digitalWrite(B2_CS_PIN, HIGH);
pinMode(B2_CS_PIN, OUTPUT);
TRINAMIC_B2.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef C_DRIVER_TMC2130
digitalWrite(C_CS_PIN, HIGH);
pinMode(C_CS_PIN, OUTPUT);
TRINAMIC_C.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
#ifdef C2_DRIVER_TMC2130
digitalWrite(C2_CS_PIN, HIGH);
pinMode(C2_CS_PIN, OUTPUT);
TRINAMIC_C2.setSPISpeed(TRINAMIC_SPI_FREQ);
#endif
SPI.begin();
#ifdef USE_MACHINE_TRINAMIC_INIT
machine_trinamic_setup();
return;
#endif
#ifdef X_TRINAMIC
TRINAMIC_X.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_X.test_connection(), "X");
TRINAMIC_X.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_X.microsteps(axis_settings[X_AXIS]->microsteps->get());
TRINAMIC_X.rms_current(axis_settings[X_AXIS]->run_current->get() * 1000.0, axis_settings[X_AXIS]->hold_current->get() / 100.0);
TRINAMIC_X.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_X.pwm_autoscale(1);
#endif
#ifdef X2_TRINAMIC
TRINAMIC_X2.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_X2.test_connection(), "X2");
TRINAMIC_X2.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_X2.microsteps(axis_settings[X_AXIS]->microsteps->get());
TRINAMIC_X2.rms_current(axis_settings[X_AXIS]->run_current->get() * 1000.0, axis_settings[X_AXIS]->hold_current->get() / 100.0);
TRINAMIC_X2.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_X2.pwm_autoscale(1);
#endif
#ifdef Y_TRINAMIC
TRINAMIC_Y.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_Y.test_connection(), "Y");
TRINAMIC_Y.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_Y.microsteps(axis_settings[Y_AXIS]->microsteps->get());
TRINAMIC_Y.rms_current(axis_settings[Y_AXIS]->run_current->get() * 1000.0, axis_settings[Y_AXIS]->hold_current->get() / 100.0);
TRINAMIC_Y.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_Y.pwm_autoscale(1);
#endif
#ifdef Y2_TRINAMIC
TRINAMIC_Y2.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_Y2.test_connection(), "Y2");
TRINAMIC_Y2.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_Y2.microsteps(axis_settings[Y_AXIS]->microsteps->get());
TRINAMIC_Y2.rms_current(axis_settings[Y_AXIS]->run_current->get() * 1000.0, axis_settings[Y_AXIS]->hold_current->get() / 100.0);
TRINAMIC_Y2.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_Y2.pwm_autoscale(1);
#endif
#ifdef Z_TRINAMIC
TRINAMIC_Z.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_Z.test_connection(), "Z");
TRINAMIC_Z.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_Z.microsteps(axis_settings[Z_AXIS]->microsteps->get());
TRINAMIC_Z.rms_current(axis_settings[Z_AXIS]->run_current->get() * 1000.0, axis_settings[Z_AXIS]->hold_current->get() / 100.0);
TRINAMIC_Z.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_Z.pwm_autoscale(1);
#endif
#ifdef Z2_TRINAMIC
TRINAMIC_Z2.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_Z2.test_connection(), "Z2");
TRINAMIC_Z2.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_Z2.microsteps(axis_settings[Z_AXIS]->microsteps->get());
TRINAMIC_Z2.rms_current(axis_settings[Z_AXIS]->run_current->get() * 1000.0, axis_settings[Z_AXIS]->hold_current->get() / 100.0);
TRINAMIC_Z2.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_Z2.pwm_autoscale(1);
#endif
#ifdef A_TRINAMIC
TRINAMIC_A.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_A.test_connection(), "A");
TRINAMIC_A.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_A.microsteps(axis_settings[A_AXIS]->microsteps->get());
TRINAMIC_A.rms_current(axis_settings[A_AXIS]->run_current->get() * 1000.0, axis_settings[A_AXIS]->hold_current->get() / 100.0);
TRINAMIC_A.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_A.pwm_autoscale(1);
#endif
#ifdef A2_TRINAMIC
TRINAMIC_A2.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_A2.test_connection(), "A2");
TRINAMIC_A2.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_A2.microsteps(axis_settings[A_AXIS]->microsteps->get());
TRINAMIC_A2.rms_current(axis_settings[A_AXIS]->run_current->get() * 1000.0, axis_settings[A_AXIS]->hold_current->get() / 100.0);
TRINAMIC_A2.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_A2.pwm_autoscale(1);
#endif
#ifdef B_TRINAMIC
TRINAMIC_B.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_B.test_connection(), "B");
TRINAMIC_B.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_B.microsteps(axis_settings[B_AXIS]->microsteps->get());
TRINAMIC_B.rms_current(axis_settings[B_AXIS]->run_current->get() * 1000.0, axis_settings[B_AXIS]->hold_current->get() / 100.0);
TRINAMIC_B.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_B.pwm_autoscale(1);
#endif
#ifdef B2_TRINAMIC
TRINAMIC_B2.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_B2.test_connection(), "B2");
TRINAMIC_B2.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_B2.microsteps(axis_settings[B_AXIS]->microsteps->get());
TRINAMIC_B2.rms_current(axis_settings[B_AXIS]->run_current->get() * 1000.0, axis_settings[B_AXIS]->hold_current->get() / 100.0);
TRINAMIC_B2.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_B2.pwm_autoscale(1);
#endif
#ifdef C_TRINAMIC
TRINAMIC_C.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_C.test_connection(), "C");
TRINAMIC_C.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_C.microsteps(axis_settings[C_AXIS]->microsteps->get());
TRINAMIC_C.rms_current(axis_settings[C_AXIS]->run_current->get() * 1000.0, axis_settings[C_AXIS]->hold_current->get() / 100.0);
TRINAMIC_C.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_C.pwm_autoscale(1);
#endif
#ifdef C2_TRINAMIC
TRINAMIC_C2.begin(); // Initiate pins and registries
trinamic_test_response(TRINAMIC_C2.test_connection(), "C2");
TRINAMIC_C2.toff(TRINAMIC_DEFAULT_TOFF);
TRINAMIC_C2.microsteps(axis_settings[C_AXIS]->microsteps->get());
TRINAMIC_C2.rms_current(axis_settings[C_AXIS]->run_current->get() * 1000.0, axis_settings[C_AXIS]->hold_current->get() / 100.0);
TRINAMIC_C2.en_pwm_mode(1); // Enable extremely quiet stepping
TRINAMIC_C2.pwm_autoscale(1);
#endif
}
// Call this function called whenever $$ settings that affect the drivers are changed
void trinamic_change_settings() {
#ifdef X_TRINAMIC
TRINAMIC_X.microsteps(axis_settings[X_AXIS]->microsteps->get());
TRINAMIC_X.rms_current(axis_settings[X_AXIS]->run_current->get() * 1000.0, axis_settings[X_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef X2_TRINAMIC
TRINAMIC_X2.microsteps(axis_settings[X_AXIS]->microsteps->get());
TRINAMIC_X2.rms_current(axis_settings[X_AXIS]->run_current->get() * 1000.0, axis_settings[X_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef Y_TRINAMIC
TRINAMIC_Y.microsteps(axis_settings[Y_AXIS]->microsteps->get());
TRINAMIC_Y.rms_current(axis_settings[Y_AXIS]->run_current->get() * 1000.0, axis_settings[Y_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef Y2_TRINAMIC
TRINAMIC_Y2.microsteps(axis_settings[Y_AXIS]->microsteps->get());
TRINAMIC_Y2.rms_current(axis_settings[Y_AXIS]->run_current->get() * 1000.0, axis_settings[Y_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef Z_TRINAMIC
TRINAMIC_Z.microsteps(axis_settings[Z_AXIS]->microsteps->get());
TRINAMIC_Z.rms_current(axis_settings[Z_AXIS]->run_current->get() * 1000.0, axis_settings[Z_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef Z2_TRINAMIC
TRINAMIC_Z2.microsteps(axis_settings[Z_AXIS]->microsteps->get());
TRINAMIC_Z2.rms_current(axis_settings[Z_AXIS]->run_current->get() * 1000.0, axis_settings[Z_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef A_TRINAMIC
TRINAMIC_A.microsteps(axis_settings[A_AXIS]->microsteps->get());
TRINAMIC_A.rms_current(axis_settings[A_AXIS]->run_current->get() * 1000.0, axis_settings[A_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef A2_TRINAMIC
TRINAMIC_A2.microsteps(axis_settings[A_AXIS]->microsteps->get());
TRINAMIC_A2.rms_current(axis_settings[A_AXIS]->run_current->get() * 1000.0, axis_settings[A_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef B_TRINAMIC
TRINAMIC_B.microsteps(axis_settings[B_AXIS]->microsteps->get());
TRINAMIC_B.rms_current(axis_settings[B_AXIS]->run_current->get() * 1000.0, axis_settings[B_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef B2_TRINAMIC
TRINAMIC_B2.microsteps(axis_settings[B_AXIS]->microsteps->get());
TRINAMIC_B2.rms_current(axis_settings[B_AXIS]->run_current->get() * 1000.0, axis_settings[B_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef C_TRINAMIC
TRINAMIC_C.microsteps(axis_settings[C_AXIS]->microsteps->get());
TRINAMIC_C.rms_current(axis_settings[C_AXIS]->run_current->get() * 1000.0, axis_settings[C_AXIS]->hold_current->get() / 100.0);
#endif
#ifdef C2_TRINAMIC
TRINAMIC_C2.microsteps(axis_settings[C_AXIS]->microsteps->get());
TRINAMIC_C2.rms_current(axis_settings[C_AXIS]->run_current->get() * 1000.0, axis_settings[C_AXIS]->hold_current->get() / 100.0);
#endif
}
// Display the response of the attempt to connect to a Trinamic driver
void trinamic_test_response(uint8_t result, const char* axis) {
if (result) {
switch (result) {
case 1:
grbl_msg_sendf(CLIENT_SERIAL, MSG_LEVEL_INFO, "%s Trinamic driver test failed. Check connection", axis);
break;
case 2:
grbl_msg_sendf(CLIENT_SERIAL, MSG_LEVEL_INFO, "%s Trinamic driver test failed. Check motor power", axis);
break;
}
} else
grbl_msg_sendf(CLIENT_SERIAL, MSG_LEVEL_INFO, "%s Trinamic driver test passed", axis);
}
void trinamic_stepper_enable(bool enable) {
// Trinamic_Init() has already enabled the drivers in case #define USE_TRINAMIC_ENABLE is not used
// so the previous_state is set accordingly
static bool previous_state = true;
uint8_t toff;
if (enable == previous_state)
return;
previous_state = enable;
if (enable)
toff = TRINAMIC_DEFAULT_TOFF;
else
toff = 0; // diables driver
#ifdef X_TRINAMIC
TRINAMIC_X.toff(toff);
#endif
#ifdef X2_TRINAMIC
TRINAMIC_X2.toff(toff);
#endif
#ifdef Y_TRINAMIC
TRINAMIC_Y.toff(toff);
#endif
#ifdef Y2_TRINAMIC
TRINAMIC_Y2.toff(toff);
#endif
#ifdef Z_TRINAMIC
TRINAMIC_Z.toff(toff);
#endif
#ifdef Z2_TRINAMIC
TRINAMIC_Z2.toff(toff);
#endif
#ifdef A_TRINAMIC
TRINAMIC_A.toff(toff);
#endif
#ifdef A2_TRINAMIC
TRINAMIC_A2.toff(toff);
#endif
#ifdef B_TRINAMIC
TRINAMIC_B.toff(toff);
#endif
#ifdef B2_TRINAMIC
TRINAMIC_B2.toff(toff);
#endif
#ifdef C_TRINAMIC
TRINAMIC_C.toff(toff);
#endif
#ifdef C2_TRINAMIC
TRINAMIC_C2.toff(toff);
#endif
}
// returns the next spi index. We cannot preassign to axes because ganged (X2 type axes) might
// need to be inserted into the order of axes.
uint8_t get_next_trinamic_driver_index() {
#ifdef TRINAMIC_DAISY_CHAIN
static uint8_t index = 1; // they start at 1
return index++;
#else
return -1;
#endif
}
#ifdef USE_I2S_OUT
//
// Override default function and insert a short delay
//
void TMC2130Stepper::switchCSpin(bool state) {
digitalWrite(_pinCS, state);
delay(I2S_OUT_DELAY_MS);
}
#endif
#endif

View File

@ -1,47 +0,0 @@
/*
grbl_trinamic.h - Support for TMC2130 Stepper Drivers SPI Mode
Part of Grbl_ESP32
Copyright (c) 2019 Barton Dring for Buildlog.net LLC
GrblESP32 is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Grbl is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Grbl. If not, see <http://www.gnu.org/licenses/>.
*/
#define TRINAMIC_DEFAULT_TOFF 5
#ifndef GRBL_TRINAMIC_h
#define GRBL_TRINAMIC_h
#include "grbl.h"
// the default current sense resistors used on most driver modules
#define TMC2130_RSENSE_DEFAULT 0.11f
#define TMC5160_RSENSE_DEFAULT 0.075f
#define TRINAMIC_SPI_FREQ 100000
#ifdef USE_TRINAMIC
#include <TMCStepper.h> // https://github.com/teemuatlut/TMCStepper
void Trinamic_Init();
void trinamic_change_settings();
void trinamic_test_response(uint8_t result, const char* axis);
void trinamic_stepper_enable(bool enable);
#ifdef USE_MACHINE_TRINAMIC_INIT
void machine_trinamic_setup();
#endif
uint8_t get_next_trinamic_driver_index();
#endif
#endif // GRBL_TRIAMINIC_h

View File

@ -74,12 +74,3 @@ uint8_t get_step_pin_mask(uint8_t axis_idx) {
uint8_t get_direction_pin_mask(uint8_t axis_idx) {
return bit(axis_idx);
}
// this allows a conditional re-init of the trinamic settings
void settings_spi_driver_init() {
#ifdef USE_TRINAMIC
trinamic_change_settings();
#else
grbl_msg_sendf(CLIENT_SERIAL, MSG_LEVEL_INFO, "No SPI drivers setup");
#endif
}

View File

@ -80,6 +80,5 @@ uint8_t get_step_pin_mask(uint8_t i);
// Returns the direction pin mask according to Grbl's internal axis numbering
uint8_t get_direction_pin_mask(uint8_t i);
void settings_spi_driver_init();
#endif

View File

@ -441,9 +441,6 @@ void stepper_init() {
timer_enable_intr(STEP_TIMER_GROUP, STEP_TIMER_INDEX);
timer_isr_register(STEP_TIMER_GROUP, STEP_TIMER_INDEX, onStepperDriverTimer, NULL, 0, NULL);
#endif
#ifdef USE_TRINAMIC
Trinamic_Init();
#endif
}