博客
关于我
UEFI开发探索90- YIE002USB开发板(13 Linux编程)
阅读量:620 次
发布时间:2019-03-12

本文共 3385 字,大约阅读时间需要 11 分钟。

YIE002USB开发板之Linux编程

1 建立开发目录

与上一篇文章类似,首先创建开发目录,新建文件夹hidlibusb并将以下文件复制进去:

libusb/hid.chidapi/hidapi.hhidtest/test.c

为当前代码编写Makefile,内容如下:

all: hidtest-libusb libslibs: libhidapi-libusb.soCC      ?= gccCFLAGS  ?= -Wall -g -fpicLDFLAGS ?= -Wall -gCOBJS_LIBUSB = hid.oCOBJS = $(COBJS_LIBUSB) test.oOBJS      = $(COBJS)LIBS_USB  = `pkg-config libusb-1.0 --libs` -lrt -lpthreadLIBS      = $(LIBS_USB)INCLUDES ?= `pkg-config libusb-1.0 --cflags`# Console Test Programhidtest-libusb: $(COBJS) $(CC) $(LDFLAGS) $^ $(LIBS_USB) -o $@# Shared Libslibhidapi-libusb.so: $(COBJS_LIBUSB) $(CC) $(LDFLAGS) $(LIBS_USB) -shared -fpic -Wl,-soname,$@.0 $^ -o $@# Objects$(COBJS): %.o: %.c $(CC) $(CFLAGS) -c $(INCLUDES) $< -o $@clean: rm -f $(OBJS) hidtest-libusb libhidapi-libusb.so hidtest.o.PHONY: clean libs

2 代码编写

完成目录创建后,对代码进行修改。USB HID的三种通信方式——hid_read()hid_write()通信方式,以及Feature report的通信方式——在上一篇文章中已经实现。由于现在libusb下的hid.c中提供了统一的函数接口,这两种方式的代码不需要修改,我们只需添加支持Input report和Output report的代码即可。

2.1 添加Output report的处理代码

奇怪的是,libusb的源文件hid.c中已经提供了处理Input report的函数hid_get_input_report(),但是却没有提供处理Output report的函数。因此,实现Output report的代码需要做一些修改。

hid_send_feature_report()函数中,修改以下代码:

int HID_API_EXPORT HID_API_CALLhid_set_output_report(hid_device *dev, const unsigned char *data, size_t length) {    int res = -1;    int skipped_report_id = 0;    int report_number = data[0];    if (report_number == 0x0) {        data++;        length--;        skipped_report_id = 1;    }    res = libusb_control_transfer(dev->device_handle,        LIBUSB_REQUEST_TYPE_CLASS | LIBUSB_RECIPIENT_INTERFACE | LIBUSB_ENDPOINT_OUT,        0x09/*HID set_report*/,        (2/*HID Output*/ << 8) | report_number,        dev->interface,        (unsigned char *)data,        length,        1000/*timeout millis*/);    if (res < 0) {        return -1;    }    if (skipped_report_id) {        length++;    }    return length;}

2.2 Input report与Output report通信方式

其他两种通信方式在上一篇文章中已经实现,无需修改代码。现在需要添加的,是发送Output report和接收Input report的代码,如下所示:

memset(yie_buf, 0, sizeof(yie_buf));yie_buf[0] = 0x00;yie_buf[1] = 0xA0;yie_buf[2] = 0x0A;yie_buf[3] = 0x0B;yie_buf[4] = 0x0C;res = hid_set_output_report(handle, yie_buf, 17);if (res < 0) {    printf("Unable to send a output report.\n");}memset(yie_buf, 0, sizeof(yie_buf));res = hid_get_input_report(handle, yie_buf, sizeof(yie_buf));if (res < 0) {    printf("Unable to get a input report.\n");    printf("%ls", hid_error(handle));} else {    // Print out the returned buffer.    printf("Input Report\n   ");    printf("report number:%d\n   ", yie_buf[0]);    for (i = 1; i < res; i++) {        printf("%02x ", yie_buf[i]);    }    printf("\n");}

##启动命令行,使用make命令编译,得到执行文件hidtest-libusb

##插入自制的USB HID设备,运行hidtest-libusb,输出信息如下:

robin@NUC6CAYHC:~/luotest/hidapi$ sudo ./ hidtest-libusb……Manufacturer String: RobinProduct String: Robin's UEFI ExplorerSerial Number: (77) My123Indexed String 1: RobinFeature Report   report number:0a0 03 0b 0c 00 00 00 00 00 00 00 00 00 00 00 00Input Report   report number:0a0 02 0b 0c 00 00 00 00 00 00 00 00 00 00 00 00Read data,Length=16a0 01 0b 0c 00 00 00 00 00 00 00 00 00 00 00 00

对照以前制作USB HID设备的博客,可知三种通信模式,已经都实现了。

至此,我们在YIE002开发板的开篇中,规划的所有代码,都已经完成。从开发板的USB HID设备制作,到上位机的Windows软件、UEFI软件和Linux软件,全部介绍完毕。

YIE002开发板,与UEFI相关的学习,到此篇为止,全部结束。关于此开发板的其他嵌入式编程,请移步到我的“嵌入式开发”专栏中查阅,我会不定期更新的。

项目代码位置

项目代码位于:gitee.com/luobing4365/uefi-explorer

代码存储路径:/90/hidlibusb下

转载地址:http://skxxz.baihongyu.com/

你可能感兴趣的文章
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
NHibernate学习[1]
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>