xhci 寄存器学习

server/2025/2/22 1:13:37/

xhci 寄存器介绍

查看linux 代码:

1733 /* There is one xhci_hcd structure per controller */
1734 struct xhci_hcd {
1735     struct usb_hcd *main_hcd;
1736     struct usb_hcd *shared_hcd;
1737     /* glue to PCI and HCD framework */
1738     struct xhci_cap_regs __iomem *cap_regs;
1739     struct xhci_op_regs __iomem *op_regs;
1740     struct xhci_run_regs __iomem *run_regs;
1741     struct xhci_doorbell_array __iomem *dba;
1742     /* Our HCD's current interrupter register set */
1743     struct  xhci_intr_reg __iomem *ir_set;

主要寄存器是:xhci_cap_regs, xhci_op_regs, xhci_run_regs,xhci_doorbell_array

  50 struct xhci_cap_regs {51     __le32  hc_capbase;52     __le32  hcs_params1;53     __le32  hcs_params2;54     __le32  hcs_params3;55     __le32  hcc_params;56     __le32  db_off;57     __le32  run_regs_off;58     __le32  hcc_params2; /* xhci 1.1 */59     /* Reserved up to (CAPLENGTH - 0x1C) */60 };

对应手册是
在这里插入图片描述

 176 struct xhci_op_regs {177     __le32  command;178     __le32  status;179     __le32  page_size;180     __le32  reserved1;181     __le32  reserved2;182     __le32  dev_notification;183     __le64  cmd_ring;184     /* rsvd: offset 0x20-2F */185     __le32  reserved3[4];186     __le64  dcbaa_ptr;187     __le32  config_reg;188     /* rsvd: offset 0x3C-3FF */189     __le32  reserved4[241];190     /* port 1 registers, which serve as a base address for other ports */191     __le32  port_status_base;192     __le32  port_power_base;193     __le32  port_link_base;194     __le32  reserved5;195     /* registers for ports 2-255 */196     __le32  reserved6[NUM_PORT_REGS*254];197 };

对用手册是:

在这里插入图片描述
在这里插入图片描述
其中端口寄存器:
在这里插入图片描述
在这里插入图片描述

寄存器读写实操

root@raoxu-PC:/sys# lspci | grep -i usb
00:14.0 USB controller: Intel Corporation Comet Lake PCH-V USB Controller
root@raoxu-PC:/sys# lspci -s 00:14.0 -v
00:14.0 USB controller: Intel Corporation Comet Lake PCH-V USB Controller (prog-if 30 [XHCI])Subsystem: ASRock Incorporation Device a3afFlags: bus master, medium devsel, latency 0, IRQ 122Memory at 99330000 (64-bit, non-prefetchable) [size=64K]Capabilities: [70] Power Management version 2Capabilities: [80] MSI: Enable+ Count=1/8 Maskable- 64bit+Kernel driver in use: xhci_hcd

首先查看xhci 寄存器基地址为:0x99330000
也可以通过其他方式获取到:

cat /proc/iomem | grep xhci99330000-9933ffff : xhci-hcd

读取 Operational Register Space 首地址:
在这里插入图片描述
在这里插入图片描述
根据代码和手册可以找到,需要找到Host Controller Operational Registers的地址偏移为:

root@raoxu-PC:/sys# busybox devmem 0x99330000 
0x01000080

读出来的偏移值0x80
那么偏移地址就是0x99330080

那么如何得到port的地址呢:
在这里插入图片描述
根据介绍,我们只需要根据port num 进行计算就可以了。
以我插入的鼠标为例:

/:  Bus 02.Port 1: Dev 1, Class=root_hub, Driver=xhci_hcd/8p, 5000M
/:  Bus 01.Port 1: Dev 1, Class=root_hub, Driver=xhci_hcd/12p, 480M|__ Port 1: Dev 2, If 0, Class=Human Interface Device, Driver=usbhid, 1.5M|__ Port 5: Dev 3, If 0, Class=Human Interface Device, Driver=usbhid, 12M|__ Port 5: Dev 3, If 1, Class=Human Interface Device, Driver=usbhid, 12M|__ Port 10: Dev 4, If 0, Class=Hub, Driver=hub/4p, 480M|__ Port 3: Dev 8, If 0, Class=Human Interface Device, Driver=usbhid, 1.5M

如何port 为 10
那么基地址为:addr = 0x99330080 + (0x400 + 0x10 * (10 -1)) = 0x99330510
那么读取状态:

root@raoxu-PC:/sys# busybox devmem 0x99330510 
0x00000E03

在这里插入图片描述
最高位写1 进行复位

root@raoxu-PC:/sys# busybox devmem 0x99330510 32 0x80000E03
root@raoxu-PC:/sys# busybox devmem 0x99330510 
0x000006E1

输入命令可以看到设备复位了


http://www.ppmy.cn/server/39715.html

相关文章

【JavaEE精炼宝库】多线程1(认识线程 | 创建线程 | Thread 类)

目录 一、认识线程 1.1 线程的概念: 1.2 为什么需要线程: 1.3 面试题.谈谈进程和线程的区别: 1.4 Java的线程和操作系统线程的关系: 二、创建线程 2.1 创建线程的5种写法: 2.1.1 写法1.继承 Thread 类&#xf…

OceanBase学习1:分布式数据库与集中式数据库的差异

目录 1. 传统集中式数据库 2. 数据库中间件的分库分表 3. 分布式数据库的基本特点及对比分析 4. OceanBase和传统数据库的对比 5. 小结 1. 传统集中式数据库 优点 成熟稳定:经过近40年的发展,应用到各行各业,产品技术非常成熟稳定行业适配性强:适配…

AMD优化策略

FPGA,英文全称是 Field Programmable Gate Array,中文意思是现场可编程门阵列。基本架构:可配置逻辑模块(CLB: Configurable Logic Block)、开关矩阵(Switch Matrix,也称为 Switch B…

环信设置头像昵称(安卓android)版

在此真的要吐槽吐槽环信,那么大的公司,文档那么乱。。。真的像一坨屎一样,翻个demo东翻西翻,官网论坛看的眼瞎。。。几乎要放弃了,还好百度到别人的看了看弄出来了 1、首先,要确认自己用的是哪个环信的UI库…

Java基础(27)Web应用中web.xml文件中可以配置哪些内容

在Java Web应用中,web.xml文件(也被称为部署描述符)是一个核心的配置文件,它位于应用的WEB-INF目录下。web.xml文件中可以配置多种不同的组件和参数,它们用来定义和调整应用的行为。以下是一些web.xml中可以配置的内容…

如何与ChatGPT愉快地聊天

一、前言 在数字时代,与人工智能聊天已经成为我们日常生活的一部分。特别是OpenAI的ChatGPT,它以其强大的自然语言处理能力成为了人工智能领域的热门话题。本文将探讨如何有效并愉快地与ChatGPT进行交流,包括理解其工作机制和提出有效策略来…

MySQL查询所有数据库并导出命令过滤系统库

在MySQL数据库管理中,有时我们会有需求查询并导出所有非系统数据库,以备份或迁移数据。系统数据库一般包括但不限于​​mysql​​​, ​​information_schema​​​, ​​performance_schema​​等,它们存储着MySQL的元数据和系统信息,通常在日常的数据备份中不需要包含这些…

MyBatis——MyBatis入门程序

一、数据准备 二、开发步骤 1、引入依赖 <dependencies><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.15</version></dependency><dependency><groupId>c…