From 19ed40041d24b37fb0e9f2bdfc3136c27118f932 Mon Sep 17 00:00:00 2001 From: Remi Bettan Date: Sun, 11 Aug 2024 11:36:01 +0300 Subject: [PATCH] hw reset errors handling --- src/ds/d500/d500-device.cpp | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/src/ds/d500/d500-device.cpp b/src/ds/d500/d500-device.cpp index c43b375e73..47090b5f2b 100644 --- a/src/ds/d500/d500-device.cpp +++ b/src/ds/d500/d500-device.cpp @@ -94,8 +94,35 @@ namespace librealsense void d500_device::hardware_reset() { command cmd(ds::HWRST); - cmd.require_response = false; - _hw_monitor->send(cmd); + cmd.require_response = true; + int retries = 0; + bool success = false; + const int ERR_SWNotReady = -21; + const int ERR_Operation_Timeout = -18; + do + { + auto res = _hw_monitor->send(cmd); + if (res.size() == 0) + return; // happens when no error occurs + + auto hwm_ans = *reinterpret_cast(res.data()); + if (hwm_ans == hwmon_response::hwm_Success) + success = true; + else + { + if (hwm_ans == ERR_SWNotReady) + { + retries++; + std::this_thread::sleep_for(std::chrono::milliseconds(100)); + LOG_WARNING("HW Reset - SW not ready received"); + } + else + { + throw std::runtime_error("HW Reset - error received - " + static_cast(hwm_ans)); + } + } + + } while (!success && retries < 3); } void d500_device::enter_update_state() const