原文链接:
添加链接描述
前言:
产生问题的情况背景: 现在我有两台打印机设备 分别是 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