bltouch: Don't raise an error in verify_state()
Return the triggered state from verify_state() and update the callers to raise the error (if needed). Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
d6034013e7
commit
87bfa06b9e
|
@ -101,14 +101,12 @@ class BLTouchEndstopWrapper:
|
||||||
cmd_clock += mcu.seconds_to_clock(max(duration, MIN_CMD_TIME))
|
cmd_clock += mcu.seconds_to_clock(max(duration, MIN_CMD_TIME))
|
||||||
self.next_cmd_time = mcu.clock_to_print_time(cmd_clock)
|
self.next_cmd_time = mcu.clock_to_print_time(cmd_clock)
|
||||||
return self.next_cmd_time
|
return self.next_cmd_time
|
||||||
def verify_state(self, check_start_time, check_end_time, triggered, msg):
|
def verify_state(self, check_start_time, check_end_time, triggered):
|
||||||
# Perform endstop check to verify bltouch reports desired state
|
# Perform endstop check to verify bltouch reports desired state
|
||||||
self.mcu_endstop.home_start(check_start_time, ENDSTOP_SAMPLE_TIME,
|
self.mcu_endstop.home_start(check_start_time, ENDSTOP_SAMPLE_TIME,
|
||||||
ENDSTOP_SAMPLE_COUNT, ENDSTOP_REST_TIME,
|
ENDSTOP_SAMPLE_COUNT, ENDSTOP_REST_TIME,
|
||||||
triggered=triggered)
|
triggered=triggered)
|
||||||
did_trigger = self.mcu_endstop.home_wait(check_end_time)
|
return self.mcu_endstop.home_wait(check_end_time)
|
||||||
if not did_trigger:
|
|
||||||
raise homing.EndstopError("BLTouch failed to %s" % (msg,))
|
|
||||||
def raise_probe(self):
|
def raise_probe(self):
|
||||||
for retry in range(3):
|
for retry in range(3):
|
||||||
self.sync_mcu_print_time()
|
self.sync_mcu_print_time()
|
||||||
|
@ -117,18 +115,18 @@ class BLTouchEndstopWrapper:
|
||||||
check_start_time = self.send_cmd('pin_up',
|
check_start_time = self.send_cmd('pin_up',
|
||||||
duration=self.pin_move_time)
|
duration=self.pin_move_time)
|
||||||
check_end_time = self.send_cmd(None)
|
check_end_time = self.send_cmd(None)
|
||||||
if self.pin_up_not_triggered:
|
if not self.pin_up_not_triggered:
|
||||||
try:
|
# No way to verify - return successfully
|
||||||
self.verify_state(check_start_time, check_end_time,
|
break
|
||||||
False, "raise probe")
|
success = self.verify_state(check_start_time, check_end_time, False)
|
||||||
except homing.CommandError as e:
|
if success:
|
||||||
|
# The "probe raised" test completed successfully
|
||||||
|
break
|
||||||
if retry >= 2:
|
if retry >= 2:
|
||||||
raise
|
raise homing.EndstopError("BLTouch failed to raise probe")
|
||||||
msg = "Failed to verify BLTouch probe is raised; retrying."
|
msg = "Failed to verify BLTouch probe is raised; retrying."
|
||||||
self.gcode.respond_info(msg)
|
self.gcode.respond_info(msg)
|
||||||
self.next_cmd_time += RETRY_RESET_TIME
|
self.next_cmd_time += RETRY_RESET_TIME
|
||||||
continue
|
|
||||||
break
|
|
||||||
def lower_probe(self):
|
def lower_probe(self):
|
||||||
self.test_sensor()
|
self.test_sensor()
|
||||||
self.sync_print_time()
|
self.sync_print_time()
|
||||||
|
@ -149,8 +147,9 @@ class BLTouchEndstopWrapper:
|
||||||
check_start_time = self.send_cmd('reset', duration=self.pin_move_time)
|
check_start_time = self.send_cmd('reset', duration=self.pin_move_time)
|
||||||
check_end_time = self.send_cmd('touch_mode')
|
check_end_time = self.send_cmd('touch_mode')
|
||||||
self.send_cmd(None)
|
self.send_cmd(None)
|
||||||
self.verify_state(check_start_time, check_end_time, True,
|
success = self.verify_state(check_start_time, check_end_time, True)
|
||||||
"verify sensor state")
|
if not success:
|
||||||
|
raise homing.EndstopError("BLTouch failed to verify sensor state")
|
||||||
# Test was successful
|
# Test was successful
|
||||||
self.next_test_time = check_end_time + TEST_TIME
|
self.next_test_time = check_end_time + TEST_TIME
|
||||||
self.sync_print_time()
|
self.sync_print_time()
|
||||||
|
|
Loading…
Reference in New Issue