使用libUSB-win32的简单读写例程参考

USB上位机程序的编写,函数的调用过程.

  1. 调用 void usb_init(void); 进行初始化

  2. 调用usb_find_busses、usb_find_devices和usb_get_busses这三个函数,获得已找到的USB总线序列;然后通过链表遍历所有的USB设备,根据已知的要打开USB设备的ID(VID/PID),找到相应的USB设备.

  3. 调用usb_open函数打开该USB设备

  4. usb_set_configuration(m_dev_handle, 1) //设置配置

  5. intint usb_claim_interface(usb_dev_handle *dev, int interface); 注册与操作系统通信的接口,这个函数必须被调用,因为只有注册接口,才能做相应的操作。

  6. 与USB设备进行通信。使用写入函数 int usb_bulk_write(usb_dev_handle *dev, int ep, char *bytes, int size, int timeout);

  7. int usb_bulk_read(usb_dev_handle *dev, int ep, char *bytes, int size, int timeout);//批量读取 从USB设备读取(接收)数据或向其写入(发送)数据。

  8. int usb_release_interface(usb_dev_handle *dev, int interface); //注销被usb_claim_interface函数调用后的接口,释放资源,和usb_claim_interface对应使用。

  9. int usb_close(usb_dev_handle *dev);//与usb_open相对应,关闭设备,是必须调用的, 返回0成功,<0 失败。

    #include <stdio.h>
    #include <string.h>
    #include <iostream>
    #include "conio.h"
    #include "lusb0_usb.h"
    #pragma comment(lib, "libusb.lib")

    #define m_dev_VID 0x1483 /* Vendor ID of the m_dev /
    #define m_dev_PID 0x5751 /
    Product ID of the m_dev */
    #define EP1_OUT_SIZE 63 //可根据设备修改大小
    #define EP1_IN_SIZE 63

    int main(int argc, char *argv[])
    {
    struct usb_device * m_dev = NULL;
    struct usb_dev_handle *m_dev_handle;
    char str[64];
    memset(str,0,sizeof(str));

    复制代码
         usb_init(); 
         usb_find_busses(); 
         usb_find_devices(); 
         
     struct usb_bus *bus; 
         for(bus = usb_get_busses(); bus; bus = bus->next) 
         { 
                 struct usb_device *dev; 
                 for(dev = bus->devices; dev; dev = dev->next) 
                 { 
                         if(dev->descriptor.idVendor == m_dev_VID && dev->descriptor.idProduct == m_dev_PID) 
                         m_dev=dev; 
                 } 
         } 
         if(!m_dev) 
         { 
                 printf("m_dev not found\n"); 
                 return 1; 
         } 
    
         m_dev_handle = usb_open(m_dev); 
         if(!m_dev_handle) 
         { 
     		printf("Could not open m_dev\n"); 
     		return 1; 
         } 
    
         printf("设备打开成功!\n"); 
         if(usb_set_configuration(m_dev_handle, 1) < 0) 
         { 
                 printf("Could not set configuration\n"); 
                 usb_close(m_dev_handle); 
                 return 1; 
         } 
    
         if(usb_claim_interface(m_dev_handle, 0) < 0) //claim_interface 0 注册与操作系统通信的接口 0
         { 
                 printf("Could not claim interface\n"); 
                 usb_close(m_dev_handle); 
                 return 1; 
         } 
    
    
     //-----获取多个端点的地址-----------------------------
     int num_endpoint = m_dev->config->interface->altsetting->bNumEndpoints;
    
     for (int k = 0; k < num_endpoint; k++) {
         struct usb_endpoint_descriptor endpoint = m_dev->config->interface->altsetting->endpoint[k];
         int endpoint_address = endpoint.bEndpointAddress;
         printf("  Endpoint Address: 0x%02x\n", endpoint_address);
     }
     	
     //------------------------------------------------------------
     	
     char WriteTestData[2048] = {0};
     char ReadTestData[2048] = {0};
     for(int i = 0; i< 2048; i++)
     {
     	WriteTestData[i] = i;
     }
     	
     	//端点1写入数据
         int ret; 
     ret = usb_bulk_write(m_dev_handle, EP_OUT, WriteTestData, EP1_OUT_SIZE, 500);
     if(ret != EP1_OUT_SIZE)
     {
     	printf("端点1写入数据失败! %d\n", ret);
     	return 1;
     }
     else
     {
     	printf("端点1写入数据成功!\n");
     }
    
     //端点1读取数据
     ret = usb_bulk_read(m_dev_handle, EP_IN, ReadTestData, EP1_IN_SIZE, 500);
     if(ret != EP1_IN_SIZE)
     {
     	printf("端点1读取数据失败! %d\n", ret);
     	return 1;
     }
     else
     {
     	printf("端点1读取数据成功!\n");
     	for (int i = 0; i < EP1_IN_SIZE; i++)
     	{
     		printf("%02X ", ReadTestData[i]);
     		if(((i + 1) % 16) == 0)
     		{
     			printf("\n");
     		}
     	}
     	printf("\n");
     }
    
    
     /**************************************************************************/
    
         usb_release_interface(m_dev_handle, 0);		//注销接口,释放资源,和usb_claim_interface搭配使用。
         usb_close(m_dev_handle); 
         printf("\n设备关闭\n"); 
    
         return 0; 

    }

参考:使用libusb-win32库, 批量(bulk)传输方式, 编写上位机软件_编写上位机通讯软件实现usb device设备的 批量数据下载及上传功能-CSDN博客

Qt下libusb-win32的使用(二)批量读写操作 - lknlfy - 博客园

上位机程序:libusb,bulk端点传输,上位机程序资源-CSDN文库

相关推荐
朱包林2 小时前
day27-shell编程(自动化)
linux·运维·服务器·网络·shell脚本
SZ1701102313 小时前
IP协议 标识字段 同一个源IP、目的IP和协议号内唯一
网络·网络协议·tcp/ip
狐574 小时前
2025-06-02-IP 地址规划及案例分析
网络·网络协议·tcp/ip
黎茗Dawn5 小时前
5.子网划分及分片相关计算
网络·智能路由器
恰薯条的屑海鸥5 小时前
零基础在实践中学习网络安全-皮卡丘靶场(第十四期-XXE模块)
网络·学习·安全·web安全·渗透测试
科技小E5 小时前
口罩佩戴检测算法AI智能分析网关V4工厂/工业等多场景守护公共卫生安全
网络·人工智能
御承扬5 小时前
从零开始开发纯血鸿蒙应用之网络检测
网络·华为·harmonyos
DevSecOps选型指南14 小时前
2025软件供应链安全最佳实践︱证券DevSecOps下供应链与开源治理实践
网络·安全·web安全·开源·代码审计·软件供应链安全
国科安芯15 小时前
抗辐照MCU在卫星载荷电机控制器中的实践探索
网络·嵌入式硬件·硬件工程·智能硬件·空间计算
EasyDSS16 小时前
国标GB28181设备管理软件EasyGBS远程视频监控方案助力高效安全运营
网络·人工智能