mirror of
https://github.com/MarlinFirmware/Marlin.git
synced 2024-11-27 22:08:02 +00:00
Improvement for ENSURE_SMOOTH_MOVES
Instead of waiting for a single long block, compare the complete block buffer runtime for the long_move() check.
This commit is contained in:
parent
0f891e848b
commit
8190483eeb
@ -136,6 +136,10 @@ float Planner::previous_speed[NUM_AXIS],
|
|||||||
float Planner::position_float[NUM_AXIS] = { 0 };
|
float Planner::position_float[NUM_AXIS] = { 0 };
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if ENABLED(ENSURE_SMOOTH_MOVES)
|
||||||
|
uint32_t Planner::block_buffer_runtime_us = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class and Instance Methods
|
* Class and Instance Methods
|
||||||
*/
|
*/
|
||||||
@ -954,6 +958,7 @@ void Planner::_buffer_line(const float &a, const float &b, const float &c, const
|
|||||||
segment_time = (MIN_BLOCK_TIME) * 1000UL;
|
segment_time = (MIN_BLOCK_TIME) * 1000UL;
|
||||||
}
|
}
|
||||||
block->segment_time = segment_time;
|
block->segment_time = segment_time;
|
||||||
|
block_buffer_runtime_us += segment_time;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
block->nominal_speed = block->millimeters * inverse_mm_s; // (mm/sec) Always > 0
|
block->nominal_speed = block->millimeters * inverse_mm_s; // (mm/sec) Always > 0
|
||||||
|
@ -206,6 +206,10 @@ class Planner {
|
|||||||
static float extruder_advance_k;
|
static float extruder_advance_k;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if ENABLED(ENSURE_SMOOTH_MOVES)
|
||||||
|
static uint32_t block_buffer_runtime_us; //Theoretical block buffer runtime in µs
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -363,6 +367,9 @@ class Planner {
|
|||||||
static block_t* get_current_block() {
|
static block_t* get_current_block() {
|
||||||
if (blocks_queued()) {
|
if (blocks_queued()) {
|
||||||
block_t* block = &block_buffer[block_buffer_tail];
|
block_t* block = &block_buffer[block_buffer_tail];
|
||||||
|
#if ENABLED(ENSURE_SMOOTH_MOVES)
|
||||||
|
block_buffer_runtime_us -= block->segment_time; //We can't be sure how long an active block will take, so don't count it.
|
||||||
|
#endif
|
||||||
SBI(block->flag, BLOCK_BIT_BUSY);
|
SBI(block->flag, BLOCK_BIT_BUSY);
|
||||||
return block;
|
return block;
|
||||||
}
|
}
|
||||||
@ -374,11 +381,15 @@ class Planner {
|
|||||||
static bool long_move() {
|
static bool long_move() {
|
||||||
if (blocks_queued()) {
|
if (blocks_queued()) {
|
||||||
block_t* block = &block_buffer[block_buffer_tail];
|
block_t* block = &block_buffer[block_buffer_tail];
|
||||||
return block->segment_time > (LCD_UPDATE_THRESHOLD) * 1000UL;
|
return block_buffer_runtime_us > (LCD_UPDATE_THRESHOLD) * 1000UL + (MIN_BLOCK_TIME) * 3000UL;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void clear_block_buffer_runtime(){
|
||||||
|
block_buffer_runtime_us = 0;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if ENABLED(AUTOTEMP)
|
#if ENABLED(AUTOTEMP)
|
||||||
|
@ -1067,6 +1067,9 @@ void Stepper::finish_and_disable() {
|
|||||||
|
|
||||||
void Stepper::quick_stop() {
|
void Stepper::quick_stop() {
|
||||||
cleaning_buffer_counter = 5000;
|
cleaning_buffer_counter = 5000;
|
||||||
|
#if ENABLED(ENSURE_SMOOTH_MOVES)
|
||||||
|
planner.clear_block_buffer_runtime();
|
||||||
|
#endif
|
||||||
DISABLE_STEPPER_DRIVER_INTERRUPT();
|
DISABLE_STEPPER_DRIVER_INTERRUPT();
|
||||||
while (planner.blocks_queued()) planner.discard_current_block();
|
while (planner.blocks_queued()) planner.discard_current_block();
|
||||||
current_block = NULL;
|
current_block = NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user