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

  • Post author:
  • Post category:其他


原文链接:

添加链接描述

前言:

产生问题的情况背景: 现在我有两台打印机设备 分别是 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