diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2021-10-17 16:20:08 +0200 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2022-03-29 00:04:48 +0200 |
commit | c23ac4d3050adc9cc0e8e5ca602e486957893e86 (patch) | |
tree | 7f9f6efe32a95c2f590d1b488fdd2b82a01a0905 /tracker-trackhat/settings.cpp | |
parent | dcb84a15532335f5fd59802e23667651bcce4613 (diff) |
tracker/trackhat: debug register writes
Diffstat (limited to 'tracker-trackhat/settings.cpp')
-rw-r--r-- | tracker-trackhat/settings.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/tracker-trackhat/settings.cpp b/tracker-trackhat/settings.cpp index 39be318f..28b97c0a 100644 --- a/tracker-trackhat/settings.cpp +++ b/tracker-trackhat/settings.cpp @@ -1,5 +1,6 @@ #include "trackhat.hpp" #include "compat/sleep.hpp" +#include "compat/timer.hpp" namespace trackhat_impl { @@ -89,6 +90,8 @@ int trackhat_camera::init_regs() auto gain_c = (uint8_t)(gain/0x10); gain %= 0x10; gain_c %= 4; + Timer t; + const uint8_t regs[][3] = { { 0x0c, 0x0f, exp2 }, // exposure lo { 0x0c, 0x10, exp }, // exposure hi @@ -111,14 +114,21 @@ start: goto error; } + if (int elapsed = (int)t.elapsed_ms(); elapsed > 250) + qDebug() << "tracker/trackhat: setting registers took" << elapsed << "ms"; + return TH_SUCCESS; error: if (attempts++ < max_attempts) { + qDebug() << "tracker/trackhat: set register retry attempt" + << attempts << "/" << max_attempts; portable::sleep(10); goto start; } + qDebug() << "tracker/trackhat: failed to set registers"; + return error; } |