aboutsummaryrefslogtreecommitdiff
path: root/src/device/device_io_hid.cpp
diff options
context:
space:
mode:
authorcslashm <cslashm@gmail.com>2019-03-28 17:14:24 +0100
committercslashm <cslashm@gmail.com>2019-04-01 17:40:24 +0200
commit83fc45a41346d12037486214b935e392c5eceee7 (patch)
treecee2d07441cfcb6836f9ced72cc33bbf2b44aa12 /src/device/device_io_hid.cpp
parentMerge pull request #5339 (diff)
downloadmonero-83fc45a41346d12037486214b935e392c5eceee7.tar.xz
Add NanoX support
Diffstat (limited to 'src/device/device_io_hid.cpp')
-rw-r--r--src/device/device_io_hid.cpp21
1 files changed, 18 insertions, 3 deletions
diff --git a/src/device/device_io_hid.cpp b/src/device/device_io_hid.cpp
index f07e0eaae..721bed9ca 100644
--- a/src/device/device_io_hid.cpp
+++ b/src/device/device_io_hid.cpp
@@ -85,7 +85,18 @@ namespace hw {
void device_io_hid::connect(void *params) {
hid_conn_params *p = (struct hid_conn_params*)params;
- this->connect(p->vid, p->pid, p->interface_number, p->usage_page);
+ if (!this->connect(p->vid, p->pid, p->interface_number, p->usage_page)) {
+ ASSERT_X(false, "No device found");
+ }
+ }
+
+ void device_io_hid::connect(const std::vector<hid_conn_params> &hcpV) {
+ for (auto p: hcpV) {
+ if (this->connect(p.vid, p.pid, p.interface_number, p.usage_page)) {
+ return;
+ }
+ }
+ ASSERT_X(false, "No device found");
}
hid_device_info *device_io_hid::find_device(hid_device_info *devices_list, boost::optional<int> interface_number, boost::optional<unsigned short> usage_page) {
@@ -124,14 +135,17 @@ namespace hw {
return result;
}
- void device_io_hid::connect(unsigned int vid, unsigned int pid, boost::optional<int> interface_number, boost::optional<unsigned short> usage_page) {
+ hid_device *device_io_hid::connect(unsigned int vid, unsigned int pid, boost::optional<int> interface_number, boost::optional<unsigned short> usage_page) {
hid_device_info *hwdev_info_list;
hid_device *hwdev;
this->disconnect();
hwdev_info_list = hid_enumerate(vid, pid);
- ASSERT_X(hwdev_info_list, "Unable to enumerate device "+std::to_string(vid)+":"+std::to_string(vid)+ ": "+ safe_hid_error(this->usb_device));
+ if (!hwdev_info_list) {
+ MDEBUG("Unable to enumerate device "+std::to_string(vid)+":"+std::to_string(vid)+ ": "+ safe_hid_error(this->usb_device));
+ return NULL;
+ }
hwdev = NULL;
if (hid_device_info *device = find_device(hwdev_info_list, interface_number, usage_page)) {
hwdev = hid_open_path(device->path);
@@ -141,6 +155,7 @@ namespace hw {
this->usb_vid = vid;
this->usb_pid = pid;
this->usb_device = hwdev;
+ return hwdev;
}