USB_xHCI协议(三) —— 操作示例

1. 命令操作

        只有命令环用于发出特定于xHC的命令或与设备槽相关的命令。 命令环控制寄存器定义在操作寄存器空间中。所有xHC命令都是通过将所需的命令TRB放置在命令环上, 然后响铃xHC命令门铃寄存器, 即将主机控制器命令代码写入门铃寄存器0的DB目标字段来发出的。

2. 主机控制器初始化

        当系统启动时, 枚举主机控制器, 为xHC寄存器空间分配一个基地址, 系统软件将帧长度调整(FLADJ)寄存器设置为系统特定的值。

        以下是系统软件使用MSI(Message Signaled Interrupts)-X作为中断机制来初始化xHC的操作:

  • 如果支持的话,初始化系统I/O内存映射。
  • 芯片复位后,等待USBSTS寄存器中的Controller Not Ready(CNR)标准置为0,然后再对xHC进行操作。
  • 编辑CONFIG寄存器中的Max Device Slots Enable(MaxSlotsEn)域,使能软件将要用到的device slots。
  • 编辑Device Context Base Address Array Pointer(DCBAAP)寄存器,写入指向Device Context Base Address Array所在位置的64位的地址。
  • 定义 Command Ring Dequeue 指针,编辑Command Ring Control 寄存器,写入指向控制环的第一个TRB的64位起始地址。
  • 初始化中断:
    • 初始化并分配MSI-X信息表,设置信息地址和信息数据,并使能向量。
    • 初始化并分配MSI-X Pending Bit Array。
    • 将 MSI-X Capability Structure 中的 Table 偏移地址和 P
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值