bltouch: Don't assume reset will do a pin_up in test_sensor()

Some clones don't raise the pin on a reset and the ANTClabs BL-Touch
sometimes doesn't raise the pin either.

Rework the (infrequently called) sensor test code to always issue a
pin_up command before the touch command.  Also, perform a reset and
retry if the sensor test fails.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-03-30 12:32:48 -04:00
parent 2b916e79c7
commit 9f2a025762
1 changed files with 16 additions and 9 deletions

View File

@ -146,15 +146,22 @@ class BLTouchEndstopWrapper:
return
# Raise the bltouch probe and test if probe is raised
self.sync_print_time()
check_start_time = self.send_cmd('reset', duration=self.pin_move_time)
check_end_time = self.send_cmd('touch_mode')
self.send_cmd(None)
success = self.verify_state(check_start_time, check_end_time, True)
if not success:
raise homing.EndstopError("BLTouch failed to verify sensor state")
# Test was successful
self.next_test_time = check_end_time + TEST_TIME
self.sync_print_time()
for retry in range(3):
check_start_time = self.send_cmd('pin_up',
duration=self.pin_move_time)
self.send_cmd('touch_mode')
check_end_time = self.send_cmd(None)
success = self.verify_state(check_start_time, check_end_time, True)
self.sync_print_time()
if success:
# The "bltouch connection" test completed successfully
self.next_test_time = check_end_time + TEST_TIME
return
msg = "BLTouch failed to verify sensor state"
if retry >= 2:
raise homing.EndstopError(msg)
self.gcode.respond_info(msg + '; retrying.')
self.send_cmd('reset', duration=RETRY_RESET_TIME)
def multi_probe_begin(self):
if self.stow_on_each_sample:
return