FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 从入门到追忆
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章
  • 书籍
  • FreeBSD 中文期刊
  • 编辑日志
  • 2025-123 下游项目
    • FreeBSD 发布工程:新主管上任
    • GhostBSD:从易用到挣扎与重生
    • BSD Now 与将来
    • 字符设备驱动教程(第三部分)
    • 学会走路——连接 GPIO 系统
    • FreeBSD 中对 SYN 段的处理
    • FreeBSD 2024 年秋季峰会
  • 2024-1112 虚拟化
    • 字符设备驱动程序教程(第二部分)
    • 面向 Linux 和 Windows 用户的 bhyve
    • Xen 与 FreeBSD
    • Wifibox:一种嵌入式虚拟化无线路由器
    • 嵌入式 FreeBSD:Fabric——起步阶段
    • DGP:一种新的数据包控制方法
    • 会议报告:我在都柏林的 EuroBSDCon 体验
  • 2024-0910 内核开发
    • 字符设备驱动程序教程
    • VPP 移植到了 FreeBSD:基础用法
    • 利用 Kyua 的 Jail 功能提升 FreeBSD 测试套件的并行效率
    • FreeBSD 上的 Valgrind
    • 嵌入式 FreeBSD:探索 bhyve
    • TCP/IP 历险记:FreeBSD TCP 协议栈中的 Pacing
    • 实用软件:实现无纸化(Paperless)
  • 2024-0708 存储与文件系统
    • FreeBSD 中的 NVMe-oF
    • FreeBSD iSCSI 入门
    • 使用 ZFS 原生加密保护数据
    • 嵌入式 FreeBSD:打造自己的镜像
    • TCP LRO 简介
    • 基于 Samba 的时间机器备份
  • 2024-0506 配置管理对决
    • 基本系统中的 mfsBSD
    • rdist
    • Hashicorp Vault
    • 在 GitHub 上向 FreeBSD 提交 PR
    • 悼念 Mike Karels
    • 2024 年 5-6 月来信
    • 嵌入式 FreeBSD 面包板
    • TCP/IP 历险记:TCP BBLog
    • 实用软件:开发定制 Ansible 模块
  • 2024-0304 开发工作流与集成
    • FreeBSD 内核开发工作流程
    • FreeBSD 与 KDE 持续集成(CI)
    • 更现代的内核调试工具
    • 从零开始的 ZFS 镜像及 makefs -t zfs
    • 提升 Git 使用体验
  • 2024-0102 网络(十周年)
    • FreeBSD 中的 RACK 栈和替代 TCP 栈
    • FreeBSD 14 中有关 TCP 的更新
    • if_ovpn 还是 OpenVPN
    • SR-IOV 已成为 FreeBSD 的重要功能
    • FreeBSD 接口 API(IfAPI)
    • BATMAN:更优的可移动热点网络方式
    • 配置自己的 VPN——基于 FreeBSD、Wireguard、IPv6 和广告拦截
    • 实用软件:使用 Zabbix 监控主机
  • 2023-1112 FreeBSD 14.0
    • LinuxBoot:从 Linux 启动 FreeBSD
    • FreeBSD 容器镜像
    • 现在用 Webhook 触发我
    • 新的 Ports 提交者:oel Bodenmann (jbo@freebsd.org)
  • 2023-0910 Port 与软件包
    • 回忆录:与 Warner Losh(@imp)的访谈
    • 在你自己的仓库中定制 Poudriere 源
    • Wazuh 和 MITRE Caldera 在 FreeBSD Jail 中的使用
    • PEP 517
    • CCCamp 2023 旅行报告
  • 2023-0708 容器与云
    • 在 Firecracker 上的 FreeBSD
    • 使用 pot 和 nomad 管理 Jail
    • 会议报告:C 与 BSD 正如拉丁语与我们——一位神学家的旅程
    • 抒怀之旅:与 Doug Rabson 的访谈
    • 基于 Jail 的广告拦截教程
    • 我们收到的来信
  • 2023-0506 FreeBSD 三十周年纪念特刊
    • CheriBSD 近十多年的历程
    • AArch64:成为 FreeBSD 新的一级架构
    • 岁月如梭:我个人的时间线
    • 安装 FreeBSD 1.0:回顾 30 年前
    • ZFS 是如何进入 FreeBSD 的呢?
    • 我不是来自约克郡的,我保证!
    • 回忆录:采访 David Greenman Lawrence
    • FreeBSD 和早期的 Unix 社区
    • 早期的 FreeBSD 移植
    • FreeBSD 30 周年:成功的秘诀
    • FreeBSD 在日本:回忆之旅与今日之实
  • 2023-0304 嵌入式
    • CheriBSD port 和软件包
    • 让我们来试试 ChatGPT
    • GPU 直通
  • 2023-0102 构建 FreEBSD Web 服务器
    • ZFS 的原子 I/O 与 PostgreSQL
    • 虚拟实验室——BSD 编程研讨会
    • ZFS 简介
    • 会议报告:落基山庆祝女性计算机科学家
    • 进行中的工作/征求反馈:数据包批处理
    • 基金会与 FreeBSD 桌面
  • 2022-1112 可观测性和衡量标准
    • 在 FreeBSD 的 DDB 内核调试器中编写自定义命令
    • DTrace:老式跟踪系统的新扩展
    • 基于证书的 Icinga 监控
    • 活动监控脚本(activitymonitor.sh)
    • 实用 IPv6(第四部分)
    • EuroBSDCon 会议报道
    • 实用 Port:Prometheus 的安装与配置
    • 书评:《用火解决问题:管理老化的计算机系统(并为现代系统保驾护航)》Kill It with Fire: Manage Aging Computer Systems (and Future Proof Modern Ones)
  • 2022-0910 安全性
    • CARP 简介
    • 重构内核加密服务框架
    • PAM 小窍门
    • SSH 小窍门
    • 实用 IPv6(第三部分)
    • 书评:Understanding Software Dynamics(深入理解软件性能——一种动态视角)—— Richard L. Sites 著
    • 访谈:保障 FreeBSD 安全性
    • MCH 2022 会议报告
  • 2022-0708 科研、系统与 FreeBSD
    • 在 FreeBSD 上构建 Loom 框架
    • 教授本科生 Unix 课程
    • FreeBSD 入门研讨会
    • 实用 IPv6(第二部分)
    • 在 2022 年及以后推广 FreeBSD
    • 进行中的工作/征求反馈:Socket 缓冲区
    • FreeBSD 开发者峰会报告
    • 支持 Electromagnetic Field 2022
  • 2022-0506 灾难恢复
    • 使用 FreeBSD 构建高弹性的私有云
    • LLDB 14 —— FreeBSD 新调试器
    • 实用 IPv6(第一部分)
    • 利用 netdump(4) 进行事后内核调试
    • 进行中的工作/征求反馈:FreeBSD 启动性能
    • 实用 Port:在 OpenZFS 上设置 NFSv4 文件服务器
  • 2022-0304 ARM64 是一级架构
    • FreeBSD/ARM64 上的数据科学
    • Pinebook Pro 上的 FreeBSD
    • 嵌入式控制器的 ACPI 支持
    • 进行中的工作/征求反馈:Lumina 桌面征集开发人员
    • 实用 Port:如何设置 Apple 时间机器
  • 2022-0102 软件与系统管理
    • 为 FreeBSD Ports 做贡献
    • 使用 Git 贡献到 FreeBSD Ports
    • CBSD:第一部分——生产环境
    • 将 OpenBSD 的 pf syncookie 代码移植到 FreeBSD 的 pf
    • 进行中的工作/征求反馈:mkjail
    • 《编程智慧:编程鬼才的经验和思考》(The Kollected Kode Vicious)书评
    • 会议报告:EuroBSDCon 2021 我的第一次 EuroBSDCon:一位新组织者的视角
  • 2021-1112 存储
    • 开放通道 SSD
    • 构建 FreeBSD 社区
    • 与完美操作系统同行 27 年
    • 进行中的工作/征求反馈:OccamBSD
    • 通过 iSCSI 导入 ZFS ZIL——不要在工作中这样做——就像我做的那样
  • 2021-0910 FreeBSD 开发
    • FreeBSD 代码审查与 git-arc
    • 如何为 FreeBSD 实现简单的 USB 驱动程序
    • 内核开发技巧
    • 程序员编程杂谈
  • 2021-0708 桌面/无线网
    • 通往 FreeBSD 桌面的直线路径
    • FreeBSD 13 中的人机接口设备 (HID) 支持
    • Panfrost 驱动程序
    • 用 Git 更新 FreeBSD
    • FreeBSD 的新面孔
    • 想给你的桌面加点佐料?
  • 2021-0506 安全
    • 七种提升新安装 FreeBSD 安全性的方法
    • copyinout 框架
    • 使用 TLS 改善 NFS 安全性
    • Capsicum 案例研究:Got
    • 对 Jail 进行安全扫描
  • 2021-0304 FreeBSD 13.0
    • 展望未来
    • FreeBSD 13.0 工具链
    • FreeBSD 13.0 中有新加载器吗?
    • TCP Cubic 准备起飞
    • OpenZFS 中的 Zstandard 压缩
    • 会议报告:FreeBSD 供应商峰会
    • Git 不够吗?
  • 2021-0102 案例研究
    • Tarsnap 的 FreeBSD 集群
    • BALLY WULFF
    • Netflix Open Connect
    • FreeBSD 的新面孔
    • 写作学者的 FreeBSD
    • 在世界之巅
  • 2020-1112 工作流/持续集成(CI)
    • FreeBSD Git 快速入门
    • 使用 syzkaller 进行内核 Fuzzing
    • Mastering Vim Quickly 书评
    • 线上会议实用技巧
    • 在控制台上进行网络监控
  • 2020-0910 贡献与入门
    • 采访:Warner Losh,第 2 部分
    • 代码审查
    • 撰写良好的提交消息
    • 如何在不是程序员的情况下做出贡献——成为 FreeBSD 译者
    • 如何成为文档提交者
    • 谷歌编程之夏
    • 为 FreeBSD 期刊撰写文章
    • 你为什么使用 FreeBSD
    • FreeBSD 的新面孔
  • 2020-0708 基准测试/调优
    • FreeBSD Friday
    • 采访:Warner Losh,第 1 部分
    • 构建和运行开源社区
    • 在 FreeBSD 上轻松搭建我的世界(Minecraft)服务器
    • FreeBSD 的新面孔
  • 2020-0506 网络性能
    • 内核中的 TLS 卸载
    • 访谈:Michael W Lucas
    • FreeBSD 桌面发行版
    • 使用 Poudriere 进行 Port 批量管理
    • FreeBSD 的新面孔
由 GitBook 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
  • HID 子系统架构
  • HID 传输驱动程序
  • hidbus
  • hidmap
  • 其他模块
  • 结论与后续工作
在GitHub上编辑
导出为 PDF
  1. 2021-0708 桌面/无线网

FreeBSD 13 中的人机接口设备 (HID) 支持

上一页通往 FreeBSD 桌面的直线路径下一页Panfrost 驱动程序

最后更新于1个月前

  • 原文链接:

  • 作者:VLADIMIR KONDRATYEV

HID 类主要由人类用来控制计算机系统操作的设备组成。HID 类设备的典型例子包括键盘、指点设备(如标准鼠标设备、轨迹球和游戏杆)。HID 类的采用主要是为了简化此类设备的安装过程。

在 HID 出现之前,设备通常遵循严格定义的协议。所有硬件设计的改进要么导致现有协议中的数据使用过载,要么需要创建自定义设备驱动程序并将新协议推广给开发人员。与此不同,所有由 HID 定义的设备都提供自描述包,这些包可以包含任何数量的数据类型和格式。关键思想是关于 HID 设备的信息存储在其 ROM(只读存储器)的段中。这些段被称为描述符。计算机上的单个 HID 驱动程序解析这些描述符,并实现数据与应用功能的动态关联,这促进了创新和开发的快速进展,并且带来了人机接口设备的广泛多样化。

在不同类型的描述符中,有一个是任何 HID 设备必须具备的,无论其物理传输方式如何。它被称为 HID 报告描述符。报告描述符规定了设备生成的每一块数据以及该数据所测量的内容。以下是一个 3 按钮鼠标(带滚轮和倾斜功能)的报告描述符示例:

0x05, 0x01, // 使用页(通用桌面)
0x09, 0x02, // 使用(鼠标)
0xa1, 0x01, // 集合(应用)
0x09, 0x01, // 使用(指针)
0xa1, 0x00, // 集合(物理)
0x05, 0x09, // 使用页(按钮)
0x19, 0x01, // 使用最小值(1)
0x29, 0x03, // 使用最大值(3)
0x15, 0x00, // 逻辑最小值(0)
0x25, 0x01, // 逻辑最大值(1)
0x95, 0x03, // 报告计数(3)
0x75, 0x01, // 报告大小(1)
0x81, 0x02, // 输入(数据、变量、绝对值)
0x95, 0x05, // 报告计数(5)
0x81, 0x03, // 输入(常量、变量、绝对值)
0x05, 0x01, // 使用页(通用桌面)
0x09, 0x30, // 使用(X 轴)
0x09, 0x31, // 使用(Y 轴)
0x09, 0x38, // 使用(滚轮)
0x15, 0x81, // 逻辑最小值(-127)
0x25, 0x7f, // 逻辑最大值(127)
0x75, 0x08, // 报告大小(8)
0x95, 0x03, // 报告计数(3)
0x81, 0x06, // 输入(数据、变量、相对值)
0x05, 0x0c, // 使用页(消费类设备)
0x0a, 0x38, 0x02, // 使用(AC 平移)
0x95, 0x01, // 报告计数(1)
0x81, 0x06, // 输入(数据、变量、相对值)
0xc0, // 结束集合
0xc0, // 结束集合

清单 1. 解码的 3 按钮鼠标报告描述符,带有滚轮和倾斜轴

HID 支持的最初导入来自 NetBSD,始于 1998 年,并与 USB 堆栈一起进行。它包括一个报告描述符解析器和基于此的 3 个驱动程序:ukbd(4)、ums(4) 和 uhid(4)。一个用户空间版本的报告描述符解析器,即 libusbhid(3),在 2000 年后期被导入。它成为了蓝牙堆栈中 HID 支持的基础,bthidd(8),并于 2004 年提交。虽然这样的驱动组合主要适用于桌面需求,但它并不适合笔记本电脑和手持设备。微软发布了 HID-over-I2C 规范,几乎所有的笔记本生产商(苹果是主要的例外)都采用了该规范。触摸设备获得了大量市场份额,许多复杂设备也应运而生,这些设备将两个或更多简单设备的功能结合在一起,例如带有鼠标的键盘,或者触摸屏与手写板的结合等。所有这些都促使 HID 子系统的修订。

HID 子系统架构

新的 HID 子系统被设计为总线。任何传输总线都可以提供 HID 设备并将其注册到 HID 核心。然后,HID 总线在其上加载通用设备驱动程序。传输驱动程序负责原始数据的传输和设备的设置/管理。HID 核心包含报告解析的辅助例程,并负责自动发现报告描述符中描述的每个顶级集合的子设备。通用设备驱动程序负责报告解释和用户空间 API。设备的具体情况和特性由 hidquirk 处理,原始访问则由 hidraw 驱动程序处理。hidmap 是 HID 项目到 evdev 事件转换器。通用的 HID 功能被移出 USB-HID,进入一个新的子系统,位于 dev/hid 目录下,并成为一个独立的内核模块。这是 Open/NetBSD 在 5 年前所做的。

HID 子系统架构

HID 传输驱动程序

传输总线通常为传输驱动程序提供热插拔检测或设备枚举的 KPI。传输驱动程序利用这些信息来查找任何合适的 HID 设备。它们分配 HID 设备资源并附加 hidbus。hidbus 永远不会知道哪些传输驱动程序可用,也不关心这个问题。它只关心子设备。

传输驱动程序实现了一个抽象的 HID 传输接口,通过设备树提供对 HID 功能和能力的独立访问。基于 kobj 的 HID 接口可以在 sys/dev/hid/hid_if.m 中找到。一旦 hidbus 子设备被附加,HID 核心使用总线方法与设备通信。目前,FreeBSD 内核支持 USB 和 I2C 驱动程序。

hidbus

hidbus 是一款驱动程序,提供对多个 HID 驱动程序附加到单个 HID 传输后端的支持。这个功能从一开始就存在于 Net/OpenBSD(uhidev 和 ihidev 驱动程序中),但从未移植到 FreeBSD。与 Net/OpenBSD 不同,我们不是仅仅使用报告编号来区分报告源,而是遵循微软的方式,使用一个顶级集合(TLC)使用来确定报告所属的功能。

TLC 是一个功能组,它面向特定软件消费者(或消费者类型)的功能。操作系统使用与此集合关联的 Usage,将设备与其控制应用程序或驱动程序关联起来。常见的例子有键盘或鼠标。一个带有集成指点设备的键盘可能包含两个不同的应用集合。HID 设备描述每个 TLC 的用途,以便 HID 功能的消费者识别他们可能感兴趣的 TLC。hidbus 为报告描述符中描述的每个 TLC 生成一个子设备,并添加 PnP 字符串以允许 devd/devmatch 检测适当的驱动程序。在运行时,hidbus 将传输驱动程序生成的数据广播到所有子设备。

0x05, 0x01, // 使用页面(通用桌面控制)  
0x09, 0x06, // 使用(键盘)  
0xA1, 0x01, // 集合(应用程序)  
0x05, 0x07, // 使用页面(键盘/键盘输入)  
0x85, 0x01, // 报告 ID(1)  
0x19, 0xE0, // 使用最小值(0xE0)  
0x29, 0xE7, // 使用最大值(0xE7)  
0x15, 0x00, // 逻辑最小值(0)  
0x25, 0x01, // 逻辑最大值(1)  
0x75, 0x01, // 报告大小(1)  
0x95, 0x08, // 报告计数(8)  
0x81, 0x02, // 输入(数据,可变,绝对)  
0x95, 0x01, // 报告计数(1)  
0x75, 0x08, // 报告大小(8)  
0x81, 0x01, // 输入(常量,数组,绝对)  
0x95, 0x06, // 报告计数(6)  
0x75, 0x08, // 报告大小(8)  
0x15, 0x00, // 逻辑最小值(0)  
0x26, 0xA4, 0x00, // 逻辑最大值(164)  
0x05, 0x07, // 使用页面(键盘/键盘输入)  
0x19, 0x00, // 使用最小值(0x00)  
0x29, 0xA4, // 使用最大值(0xA4)  
0x81, 0x00, // 输入(数据,数组,绝对)  
0xC0, // 结束集合  
0x05, 0x01, // 使用页面(通用桌面)  
0x09, 0x02, // 使用(鼠标)  
0xa1, 0x01, // 集合(应用程序)  
0x09, 0x01, // 使用(指针)  
0xa1, 0x00, // 集合(物理)  
0x85, 0x02, // 报告 ID(2)  
0x05, 0x09, // 使用页面(按钮)  
0x19, 0x01, // 使用最小值(1)  
0x29, 0x03, // 使用最大值(3)  
0x15, 0x00, // 逻辑最小值(0)  
0x25, 0x01, // 逻辑最大值(1)
0x95, 0x03, // 报告计数(3)  
0x75, 0x01, // 报告大小(1)  
0x81, 0x02, // 输入(数据,可变,绝对)  
0x95, 0x05, // 报告计数(5)  
0x81, 0x03, // 输入(常量,可变,绝对)  
0x05, 0x01, // 使用页面(通用桌面)  
0x09, 0x30, // 使用(X)  
0x09, 0x31, // 使用(Y)  
0x15, 0x81, // 逻辑最小值(-127)  
0x25, 0x7f, // 逻辑最大值(127)  
0x75, 0x08, // 报告大小(8)  
0x95, 0x02, // 报告计数(2)  
0x81, 0x06, // 输入(数据,可变,相对)  
0xc0, // 结束集合  
0xc0, // 结束集合

清单 2. 集成鼠标的键盘的 HID 报告描述符,包含 2 个 TLC。

hidmap

hidmap 是一个通用的 HID 项值到 evdev 事件转换引擎,它使得通过定义转换表以声明性方式编写 HID 驱动程序成为可能。创建它的动机是因为现有的 USB-HID 驱动程序由于以下因素而变得庞大:

  • USB 传输处理

  • 字符设备支持代码

  • 协议转换例程,例如 HID 到 sysmouse 或 HID 到 AT 键盘集 1

  • 报告解析器中的长链条 hid_locate() 和 hid_get_data()

p.1 通过传输抽象层得以消除。

为了解决 p.2 对传统支持的问题,鼠标接口被移除。我们使用内置于 evdev 的字符设备处理程序。

为了减少 p.3 和 p.4 所需的代码量,创建了 hidmap。它基于 HID 和 evdev 是密切相关的事实,我们可以直接将许多 HID 用法映射到 evdev 事件。Listing 3 展示了一个将 Listing 1 中的鼠标报告的 HID 用法映射到 evdev 事件的示例。

                HID Usage 映射到 evdev 事件  
                --------- ------------------  
0x05, 0x09, // 使用页 (按钮)  
0x19, 0x01, // 使用最小值 (1) BTN_LEFT (BTN_MOUSE+0)  
0x29, 0x08, // 使用最大值 (3) BTN_RIGHT (BTN_MOUSE+1)  
0x95, 0x08, // 报告计数 (3) BTN_MIDDLE (BTN_MOUSE+2)  
0x81, 0x02, // 输入 (数据,变量,绝对值)  
0x05, 0x01, // 使用页 (通用桌面)  
0x09, 0x30, // 使用 (X) REL_X  
0x09, 0x31, // 使用 (Y) REL_Y  
0x09, 0x38, // 使用 (滚轮) REL_WHEEL  
0x95, 0x03, // 报告计数 (3)  
0x81, 0x06, // 输入 (数据,变量,相对值)  
0x05, 0x0c, // 使用页 (消费设备)  
0x0a, 0x38, 0x02, // 使用 (AC 平移) REL_HWHEEL  
0x95, 0x01, // 报告计数 (1)  
0x81, 0x06, // 输入 (数据,变量,相对值)

清单 3. HID 使用映射到 evdev 事件的鼠标报告(来自 Listing 1)。

借助 hidmap,针对这种设备的鼠标驱动程序只需几行代码即可实现。参见 Listing 4。

/* my_mouse 的 HID 使用映射到 evdev 事件 */
static const struct hidmap_item my_mouse_map[] = {
	{ HIDMAP_REL( HUP_GENERIC_DESKTOP, HUG_X,      REL_X )	    },
	{ HIDMAP_REL( HUP_GENERIC_DESKTOP, HUG_Y,      REL_Y )	    },
	{ HIDMAP_REL( HUP_GENERIC_DESKTOP, HUG_WHEEL,  REL_WHEEL )  },
	{ HIDMAP_REL( HUP_CONSUMER,	   HUC_AC_PAN, REL_HWHEEL ) },
	{ HIDMAP_KEY_RANGE( HUP_BUTTON,	   1,	       3, BTN_MOUSE )},
};
/* 匹配这些条目将加载 my_mouse */
static const struct hid_device_id my_mouse_devs[] = {
	{ HID_TLC( HUP_GENERIC_DESKTOP, HUG_MOUSE ) },
};
static int
my_mouse_probe( device_t dev )
{
	return(HIDMAP_PROBE( device_get_softc( dev ), dev,
			     my_mouse_devs, my_mouse_map, “ My mouse ” ) );
}


static int
my_mouse_attach( device_t dev )
{
	return(hidmap_attach( device_get_softc( dev ) ) );
}


static int
my_mouse_detach( device_t dev )
{
	return(hidmap_detach( device_get_softc( dev ) ) );
}

清单 4. 基于 hidmap 的鼠标驱动示例(来自列表 1)。

例如,真正的 FreeBSD 鼠标驱动已从传统的 ums(4) 中的 ~1200 行代码减少到基于新 HID KPI 的 ~330 行代码。此外,它增加了 ums(4) 中缺失的 I2C 和绝对坐标支持,以及用于解决 FreeBSD 在 x86 上缺少 GPIO 中断支持所带来的问题的漂移抑制代码。这种简化使得作者和 Greg V 能够创建一系列基于 hidmap 的驱动程序,这些驱动程序捆绑在 FreeBSD 13+ 中,包括:

  • hms - HID 鼠标驱动

  • cons - 消费者页面,亦称为多媒体键驱动

  • hsctrl - 系统控制页面(电源/休眠键)驱动

  • hpen - 通用 / 与 MS Windows 兼容的 HID 手写板驱动

  • hgame - 游戏控制器和摇杆驱动

  • xb360gp - Xbox360 兼容游戏控制器驱动

  • ps4dshock - 索尼 DualShock 4 游戏手柄驱动

还有一些不是基于 hidmap 的驱动程序,如 hkbd(4) 和 hmt(4)。它们是现有 USB-HID 驱动程序(如 ukbd(4) 和 wmt(4))移植到新基础设施上的结果。它们为 I2C 键盘和 I2C 多点触控触摸板/触摸屏提供支持。

其他模块

HID 子系统包含另外两个可选加载的模块:

hidraw(4) - 提供对 HID 设备的原始访问的驱动程序,类似于 uhid(4)。与 uhid(4) 不同,它允许访问已被其他驱动程序占用的设备,并支持 uhid 和 Linux hidraw 接口。

Hidquirk(4) - 主要从现有 USB-HID 驱动程序复制的怪癖模块。

结论与后续工作

FreeBSD 的 HID 子系统仍在开发中,但已被许多人使用。最近的工作增加了对广泛使用的硬件的支持,例如 I2C 触摸板和触摸屏、USB 键盘上的多媒体键、许多虚拟机中使用的绝对鼠标等。这改善了我们在一些领域的用户体验,特别是我们在其他操作系统(包括其他 BSD 系统)中落后的地方。但仍有许多任务留在待办事项列表中,例如:

  • 实现 usrhid,一个用户空间的传输驱动程序,可以为连接到用户空间控制总线的每个设备创建内核 hid 设备。现有的 Linux uhid 协议可以作为起点。它定义了一个 API,用于从内核到用户空间以及反向提供 I/O 事件。

  • 将 bthidd(8) 转换为使用 usrhid,从而整合内核和用户空间之间的 HID 支持。

  • 完成 evdev-aware 的 WIP moused https://github.com/wulf7/moused,并用它替换我们内核和基础系统中的 moused(8)。这是必要的,因为新的 hms 和 hmt 驱动程序不支持我们的传统 sys/mouse.h 接口。

  • 默认启用 usbhid(4),并开始弃用 ums(4)、ukbd(4) 以及其他旧版 USB-HID 驱动程序,同时弃用内核和基础系统中的所有 mouse(4)/sysmouse(4) 内容。


VLADIMIR KONDRATYEV 是一名前 FreeBSD 系统管理员,目前是一名核心银行系统专家。自 2017 年以来,他一直是 FreeBSD 的提交者,并且已使用 FreeBSD 桌面系统近 20 年。在业余时间,他努力改善桌面体验,主要为输入设备驱动程序做贡献。

Human Interface Device (HID) Support in FreeBSD 13