|
@@ -91,8 +91,8 @@ volatile uint32_t Stepper::step_events_completed = 0; // The number of step even
|
91
|
91
|
|
92
|
92
|
#if ENABLED(ADVANCE) || ENABLED(LIN_ADVANCE)
|
93
|
93
|
|
94
|
|
- unsigned char Stepper::old_OCR0A = 0;
|
95
|
|
- volatile unsigned char Stepper::eISR_Rate = 200; // Keep the ISR at a low rate until needed
|
|
94
|
+ uint8_t Stepper::old_OCR0A = 0;
|
|
95
|
+ volatile uint8_t Stepper::eISR_Rate = 200; // Keep the ISR at a low rate until needed
|
96
|
96
|
|
97
|
97
|
#if ENABLED(LIN_ADVANCE)
|
98
|
98
|
volatile int Stepper::e_steps[E_STEPPERS];
|
|
@@ -332,12 +332,12 @@ ISR(TIMER1_COMPA_vect) { Stepper::isr(); }
|
332
|
332
|
|
333
|
333
|
void Stepper::isr() {
|
334
|
334
|
if (cleaning_buffer_counter) {
|
|
335
|
+ --cleaning_buffer_counter;
|
335
|
336
|
current_block = NULL;
|
336
|
337
|
planner.discard_current_block();
|
337
|
338
|
#ifdef SD_FINISHED_RELEASECOMMAND
|
338
|
|
- if ((cleaning_buffer_counter == 1) && (SD_FINISHED_STEPPERRELEASE)) enqueue_and_echo_commands_P(PSTR(SD_FINISHED_RELEASECOMMAND));
|
|
339
|
+ if (!cleaning_buffer_counter && (SD_FINISHED_STEPPERRELEASE)) enqueue_and_echo_commands_P(PSTR(SD_FINISHED_RELEASECOMMAND));
|
339
|
340
|
#endif
|
340
|
|
- cleaning_buffer_counter--;
|
341
|
341
|
OCR1A = 200; // Run at max speed - 10 KHz
|
342
|
342
|
return;
|
343
|
343
|
}
|
|
@@ -570,7 +570,6 @@ void Stepper::isr() {
|
570
|
570
|
#endif
|
571
|
571
|
|
572
|
572
|
// Calculate new timer value
|
573
|
|
- uint16_t timer, step_rate;
|
574
|
573
|
if (step_events_completed <= (uint32_t)current_block->accelerate_until) {
|
575
|
574
|
|
576
|
575
|
MultiU24X32toH16(acc_step_rate, acceleration_time, current_block->acceleration_rate);
|
|
@@ -580,7 +579,7 @@ void Stepper::isr() {
|
580
|
579
|
NOMORE(acc_step_rate, current_block->nominal_rate);
|
581
|
580
|
|
582
|
581
|
// step_rate to timer interval
|
583
|
|
- timer = calc_timer(acc_step_rate);
|
|
582
|
+ uint16_t timer = calc_timer(acc_step_rate);
|
584
|
583
|
OCR1A = timer;
|
585
|
584
|
acceleration_time += timer;
|
586
|
585
|
|
|
@@ -622,6 +621,7 @@ void Stepper::isr() {
|
622
|
621
|
#endif
|
623
|
622
|
}
|
624
|
623
|
else if (step_events_completed > (uint32_t)current_block->decelerate_after) {
|
|
624
|
+ uint16_t step_rate;
|
625
|
625
|
MultiU24X32toH16(step_rate, deceleration_time, current_block->acceleration_rate);
|
626
|
626
|
|
627
|
627
|
if (step_rate < acc_step_rate) { // Still decelerating?
|
|
@@ -632,7 +632,7 @@ void Stepper::isr() {
|
632
|
632
|
step_rate = current_block->final_rate;
|
633
|
633
|
|
634
|
634
|
// step_rate to timer interval
|
635
|
|
- timer = calc_timer(step_rate);
|
|
635
|
+ uint16_t timer = calc_timer(step_rate);
|
636
|
636
|
OCR1A = timer;
|
637
|
637
|
deceleration_time += timer;
|
638
|
638
|
|