Cleanup stepper ISR. Allow cleaning for endstops.
This commit is contained in:
parent
a4e1d83599
commit
6040d4080e
2 changed files with 32 additions and 30 deletions
|
@ -94,7 +94,7 @@ block_t* Stepper::current_block = NULL; // A pointer to the block currently bei
|
||||||
// private:
|
// private:
|
||||||
|
|
||||||
uint8_t Stepper::last_direction_bits = 0; // The next stepping-bits to be output
|
uint8_t Stepper::last_direction_bits = 0; // The next stepping-bits to be output
|
||||||
uint16_t Stepper::cleaning_buffer_counter = 0;
|
int16_t Stepper::cleaning_buffer_counter = 0;
|
||||||
|
|
||||||
#if ENABLED(X_DUAL_ENDSTOPS)
|
#if ENABLED(X_DUAL_ENDSTOPS)
|
||||||
bool Stepper::locked_x_motor = false;
|
bool Stepper::locked_x_motor = false;
|
||||||
|
@ -341,10 +341,8 @@ HAL_STEP_TIMER_ISR {
|
||||||
|
|
||||||
void Stepper::isr() {
|
void Stepper::isr() {
|
||||||
|
|
||||||
hal_timer_t ocr_val;
|
#define ENDSTOP_NOMINAL_OCR_VAL 1500 * HAL_TICKS_PER_US // Check endstops every 1.5ms to guarantee two stepper ISRs within 5ms for BLTouch
|
||||||
|
#define OCR_VAL_TOLERANCE 500 * HAL_TICKS_PER_US // First max delay is 2.0ms, last min delay is 0.5ms, all others 1.5ms
|
||||||
#define ENDSTOP_NOMINAL_OCR_VAL 1500 * HAL_TICKS_PER_US // check endstops every 1.5ms to guarantee two stepper ISRs within 5ms for BLTouch
|
|
||||||
#define OCR_VAL_TOLERANCE 500 * HAL_TICKS_PER_US // First max delay is 2.0ms, last min delay is 0.5ms, all others 1.5ms
|
|
||||||
|
|
||||||
#if DISABLED(LIN_ADVANCE)
|
#if DISABLED(LIN_ADVANCE)
|
||||||
// Disable Timer0 ISRs and enable global ISR again to capture UART events (incoming chars)
|
// Disable Timer0 ISRs and enable global ISR again to capture UART events (incoming chars)
|
||||||
|
@ -355,6 +353,7 @@ void Stepper::isr() {
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
hal_timer_t ocr_val;
|
||||||
static uint32_t step_remaining = 0; // SPLIT function always runs. This allows 16 bit timers to be
|
static uint32_t step_remaining = 0; // SPLIT function always runs. This allows 16 bit timers to be
|
||||||
// used to generate the stepper ISR.
|
// used to generate the stepper ISR.
|
||||||
#define SPLIT(L) do { \
|
#define SPLIT(L) do { \
|
||||||
|
@ -367,42 +366,45 @@ void Stepper::isr() {
|
||||||
ocr_val = L;\
|
ocr_val = L;\
|
||||||
}while(0)
|
}while(0)
|
||||||
|
|
||||||
|
// Time remaining before the next step?
|
||||||
if (step_remaining) {
|
if (step_remaining) {
|
||||||
if (ENDSTOPS_ENABLED)
|
|
||||||
endstops.update();
|
|
||||||
if (step_remaining > ENDSTOP_NOMINAL_OCR_VAL) {
|
|
||||||
step_remaining -= ENDSTOP_NOMINAL_OCR_VAL;
|
|
||||||
ocr_val = ENDSTOP_NOMINAL_OCR_VAL;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
ocr_val = step_remaining;
|
|
||||||
step_remaining = 0; // last one before the ISR that does the step
|
|
||||||
}
|
|
||||||
|
|
||||||
|
// Make sure endstops are updated
|
||||||
|
if (ENDSTOPS_ENABLED) endstops.update();
|
||||||
|
|
||||||
|
// Next ISR either for endstops or stepping
|
||||||
|
ocr_val = step_remaining <= ENDSTOP_NOMINAL_OCR_VAL ? step_remaining : ENDSTOP_NOMINAL_OCR_VAL;
|
||||||
|
step_remaining -= ocr_val;
|
||||||
_NEXT_ISR(ocr_val);
|
_NEXT_ISR(ocr_val);
|
||||||
|
|
||||||
#if DISABLED(LIN_ADVANCE)
|
#if DISABLED(LIN_ADVANCE)
|
||||||
#ifdef CPU_32_BIT
|
#ifdef CPU_32_BIT
|
||||||
HAL_timer_set_count(STEP_TIMER_NUM, ocr_val);
|
HAL_timer_set_count(STEP_TIMER_NUM, ocr_val);
|
||||||
#else
|
#else
|
||||||
NOLESS(OCR1A, TCNT1 + 16);
|
NOLESS(OCR1A, TCNT1 + 16);
|
||||||
|
#endif
|
||||||
|
HAL_ENABLE_ISRs(); // re-enable ISRs
|
||||||
#endif
|
#endif
|
||||||
HAL_ENABLE_ISRs(); // re-enable ISRs
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// When cleaning, discard the current block and run fast
|
||||||
|
//
|
||||||
if (cleaning_buffer_counter) {
|
if (cleaning_buffer_counter) {
|
||||||
--cleaning_buffer_counter;
|
if (cleaning_buffer_counter < 0)
|
||||||
|
++cleaning_buffer_counter; // Count up for endstop hit
|
||||||
|
else {
|
||||||
|
--cleaning_buffer_counter; // Count down for abort print
|
||||||
|
#ifdef SD_FINISHED_RELEASECOMMAND
|
||||||
|
if (!cleaning_buffer_counter && (SD_FINISHED_STEPPERRELEASE)) enqueue_and_echo_commands_P(PSTR(SD_FINISHED_RELEASECOMMAND));
|
||||||
|
#endif
|
||||||
|
}
|
||||||
current_block = NULL;
|
current_block = NULL;
|
||||||
planner.discard_current_block();
|
planner.discard_current_block();
|
||||||
#ifdef SD_FINISHED_RELEASECOMMAND
|
_NEXT_ISR(HAL_STEPPER_TIMER_RATE / 10000); // Run at max speed - 10 KHz
|
||||||
if (!cleaning_buffer_counter && (SD_FINISHED_STEPPERRELEASE)) enqueue_and_echo_commands_P(PSTR(SD_FINISHED_RELEASECOMMAND));
|
HAL_ENABLE_ISRs(); // Re-enable ISRs
|
||||||
#endif
|
|
||||||
_NEXT_ISR(HAL_STEPPER_TIMER_RATE / 10000); // Run at max speed - 10 KHz
|
|
||||||
HAL_ENABLE_ISRs(); // re-enable ISRs
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ class Stepper {
|
||||||
private:
|
private:
|
||||||
|
|
||||||
static uint8_t last_direction_bits; // The next stepping-bits to be output
|
static uint8_t last_direction_bits; // The next stepping-bits to be output
|
||||||
static uint16_t cleaning_buffer_counter;
|
static int16_t cleaning_buffer_counter;
|
||||||
|
|
||||||
#if ENABLED(X_DUAL_ENDSTOPS)
|
#if ENABLED(X_DUAL_ENDSTOPS)
|
||||||
static bool locked_x_motor, locked_x2_motor;
|
static bool locked_x_motor, locked_x2_motor;
|
||||||
|
|
Reference in a new issue