关于USB通信中使用libusb的心得 (主要是针对VID PID相同的情况下的处理)

原文链接:添加链接描述

前言:

产生问题的情况背景: 现在我有两台打印机设备 分别是 A 和 B 并且A,B 的USB通讯线为同一种 即PID和VID相同

现在的操作 是 A,B两台设备同时连接PC机 并且在不进行拔插的情况下 先后控制A,B设备

具体操作为:A进卡->A后方出卡->B接住A后出的卡->B后出卡 (即两个设备的先后使用 但是时间衔接很近 无法人工干预)

解决办法:

现有情报1:在linux下进行的实验操作,才用的是libusb进行控制

设备的序列号就是唯一的,所以根据参照VID和PID打开的源码,如下就是打开一个指定serialnumber的设备。

libusb_device_handle* libusb_open_device_with_serialnumber(
libusb_context* ctx, const char* serial_number) {
struct libusb_device** devs;
struct libusb_device* dev;
struct libusb_device_handle* handle = NULL;
char string[128];
char serialnumber[128] = “”;
uint8_t string_index[3];
size_t i = 0;
int r = 0;

if (serial_number)
strcpy(serialnumber, serial_number);

if (libusb_get_device_list(ctx, &devs) < 0)
return NULL;

while ((dev = devs[i++]) != NULL) {
struct libusb_device_descriptor desc;
r = libusb_get_device_descriptor(dev, &desc);

if (r < 0)
goto out;

string_index[2] = desc.iSerialNumber;
r = libusb_open(dev, &handle);

if (r < 0) {
handle = NULL;
break;
}

if (libusb_get_string_descriptor_ascii(handle, string_index[2], (unsigned char*)string, 128) >= 0) {
if (!strcmp(serialnumber, string))
break;
}

libusb_close(handle);
handle = NULL;
}

out:
libusb_free_device_list(devs, 1);
return handle;
}

参考地址: https://www.cnblogs.com/time-invariant/p/6194547.html

猜你喜欢

转载自blog.csdn.net/qq_43248127/article/details/113761669