toolhead: Separate out priming flush notification to its own timer

Simplify the code by introducing a separate lookahead priming flush
timer.  After this change, the flush_timer is not active in any of the
special queuing states.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2023-11-27 18:02:47 -05:00
parent 93cd8834f3
commit 9e574c3497
1 changed files with 21 additions and 4 deletions

View File

@ -232,6 +232,7 @@ class ToolHead:
self.print_time = 0. self.print_time = 0.
self.special_queuing_state = "Flushed" self.special_queuing_state = "Flushed"
self.flush_timer = self.reactor.register_timer(self._flush_handler) self.flush_timer = self.reactor.register_timer(self._flush_handler)
self.priming_timer = None
self.drip_completion = None self.drip_completion = None
# Kinematic step generation scan window time tracking # Kinematic step generation scan window time tracking
self.kin_flush_delay = SDS_CHECK_TIME self.kin_flush_delay = SDS_CHECK_TIME
@ -360,21 +361,24 @@ class ToolHead:
return self.print_time return self.print_time
def _check_pause(self): def _check_pause(self):
eventtime = self.reactor.monotonic() eventtime = self.reactor.monotonic()
est_print_time = self.mcu.estimated_print_time(eventtime)
buffer_time = self.print_time - est_print_time
if self.special_queuing_state: if self.special_queuing_state:
if self.check_stall_time: if self.check_stall_time:
# Was in "Flushed" state and got there from idle input # Was in "Flushed" state and got there from idle input
est_print_time = self.mcu.estimated_print_time(eventtime)
if est_print_time < self.check_stall_time: if est_print_time < self.check_stall_time:
self.print_stall += 1 self.print_stall += 1
self.check_stall_time = 0. self.check_stall_time = 0.
# Transition from "Flushed"/"Priming" state to "Priming" state # Transition from "Flushed"/"Priming" state to "Priming" state
self.special_queuing_state = "Priming" self.special_queuing_state = "Priming"
self.need_check_pause = -1. self.need_check_pause = -1.
self.reactor.update_timer(self.flush_timer, eventtime + 0.100) if self.priming_timer is None:
self.priming_timer = self.reactor.register_timer(
self._priming_handler)
wtime = eventtime + max(0.100, buffer_time - BUFFER_TIME_LOW)
self.reactor.update_timer(self.priming_timer, wtime)
# Check if there are lots of queued moves and pause if so # Check if there are lots of queued moves and pause if so
while 1: while 1:
est_print_time = self.mcu.estimated_print_time(eventtime)
buffer_time = self.print_time - est_print_time
pause_time = buffer_time - BUFFER_TIME_HIGH pause_time = buffer_time - BUFFER_TIME_HIGH
if pause_time <= 0.: if pause_time <= 0.:
break break
@ -382,9 +386,22 @@ class ToolHead:
self.need_check_pause = self.reactor.NEVER self.need_check_pause = self.reactor.NEVER
return return
eventtime = self.reactor.pause(eventtime + min(1., pause_time)) eventtime = self.reactor.pause(eventtime + min(1., pause_time))
est_print_time = self.mcu.estimated_print_time(eventtime)
buffer_time = self.print_time - est_print_time
if not self.special_queuing_state: if not self.special_queuing_state:
# In main state - defer pause checking until needed # In main state - defer pause checking until needed
self.need_check_pause = est_print_time + BUFFER_TIME_HIGH + 0.100 self.need_check_pause = est_print_time + BUFFER_TIME_HIGH + 0.100
def _priming_handler(self, eventtime):
self.reactor.unregister_timer(self.priming_timer)
self.priming_timer = None
try:
if self.special_queuing_state == "Priming":
self.flush_step_generation()
self.check_stall_time = self.print_time
except:
logging.exception("Exception in priming_handler")
self.printer.invoke_shutdown("Exception in priming_handler")
return self.reactor.NEVER
def _flush_handler(self, eventtime): def _flush_handler(self, eventtime):
try: try:
print_time = self.print_time print_time = self.print_time