summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorSzczepan Zalega <szczepan@nitrokey.com>2017-02-28 21:02:30 +0100
committerSzczepan Zalega <szczepan@nitrokey.com>2017-03-11 15:41:51 +0100
commit802dd4543b7634f498bd44909461eae6d7975abb (patch)
tree5a244bfa7677f98a82e3ee2922dcea05b1c37a61 /include
parentf12b6a9c29f8d236ca969f45d3be1cd9ee5a749f (diff)
downloadlibnitrokey-802dd4543b7634f498bd44909461eae6d7975abb.tar.gz
libnitrokey-802dd4543b7634f498bd44909461eae6d7975abb.tar.bz2
Make device-level reconnect on problem with sending
Make it 3 times before throwing exception Call hid_exit on last device disconnection Signed-off-by: Szczepan Zalega <szczepan@nitrokey.com>
Diffstat (limited to 'include')
-rw-r--r--include/device.h8
1 files changed, 7 insertions, 1 deletions
diff --git a/include/device.h b/include/device.h
index 5d7ee12..7b300e5 100644
--- a/include/device.h
+++ b/include/device.h
@@ -50,6 +50,7 @@ public:
cnt busy_progressbar;
cnt command_result_not_equal_0_recv;
cnt communication_successful;
+ cnt low_level_reconnect;
std::string get_as_string();
} m_counters = {};
@@ -59,7 +60,7 @@ public:
const milliseconds send_receive_delay, const int retry_receiving_count,
const milliseconds retry_timeout);
- virtual ~Device(){show_stats(); disconnect();}
+ virtual ~Device();
// lack of device is not actually an error,
// so it doesn't throw
@@ -97,6 +98,9 @@ public:
DeviceModel get_device_model() const {return m_model;}
private:
std::atomic<uint8_t> last_command_status;
+ void _reconnect();
+ bool _connect();
+ bool _disconnect();
protected:
const uint16_t m_vid;
@@ -115,6 +119,8 @@ protected:
std::atomic<hid_device *>mp_devhandle;
+
+ static std::atomic_int instances_count;
};
class Stick10 : public Device {