2.1 基于OHCI的USB主机 —— 寄存器层(说明)

转载 2012年03月22日 09:41:45
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://lancelot.blog.51cto.com/393579/228813

AM9200支持标准的OHCI规范,在其开发文档中对于USB主机部分的说明干脆就直接说参见OHCI规范。

阅读AM9200的例程《AT91RM9200-BasicUHP》代码,发现系统已经提供了访问OHCI寄存器的指针pUhp,使用该指针就可以访问到所有的OHCI寄存器,因此读写寄存器的操作就是对pUhp指针进行操作。

按照面向对象的编程思想,将所有寄存器看作是一个对象,对其操作都是通过接口来完成,在外部不会使用到OHCI寄存器。这样对于嵌入式系统来说,性能上稍微受到一些影响(主要是增加了函数调用的开销),但是代码清晰、易于维护。

OHCI规范种提供了很多的寄存器,在U盘处理的程序只使用了其中的一部分,如下:

名称

功能

HcBulkCurrentED

该寄存器用于设置批量列表的当前端点变量的地址

HcBulkDoneHead

OHCI文档中没有,使用例程中缺省设置。

HcBulkHeadED

该寄存器用于设置批量列表的第一个端点变量的地址

HccaDoneHead

存放最近完成传输的TD变量的地址,用于确定TD对列是否发送完毕。

HcCommandStatus

该寄存器可被HC用来接收HCD发送的指令,也可反映HC的当前状态。

HcControl

定义了HC的操作模式。

HcControlCurrentED

该寄存器用于设置控制列表的当前端点变量的地址

HcControlHeadED

该寄存器用于设置控制列表的第一个端点变量的地址

HcFmInterval

HcFmInterval寄存器包含一个14位值[FrameInteral,FI](用于表示一帧之内所占用的比特时间,2个连续的SOFs)和一个15位的值 [FSLargestDataPacket,PSMPS](用于表示在没有引发调度溢出下可发送或接收全速最大包大小),FI,PSMPS的推荐值为 0x2EDF和0x2778。

HcHCCA

用来设置HCCA数据区的地址,由于该寄存器的要求,HCCA变量地址的低8位必须为0,例如变量定义为:

__align(256) AT91S_UHP_HCCA HCCA;

HcInterruptEnable

该寄存器的使能位与HcInterruptStatus寄存器中的中断位相对应,用来控制事件产生的硬件中断。

HcInterruptStatus

该寄存器提供所有事件状态,并将产生硬件中断。

HcPeriodicStart

The HcPeriodicStart register has a 14-bit programmable value which determines when is the earliest time HC should start processing the periodic list.

HcRhDescriptorA

对根集线器特性进行描述的寄存器。

HcRhPortStatus[1:2]

用来控制和报告每个端口上的事件。

HcRhStatus

该寄存器分为两个部分,低字部分为集线器状态域,高字部分为集线器状态更改域。

关于上述寄存器的详细说明,请参考OHCI规范《Open Host Controller Interface Specification for USB》。想看中文说明的,可以参考《ARM嵌入式系统软件开发实例》(二)(北京航空航天大学出版社,周立功等编著)中的1.7节,虽然不全,但是也包含了上述大部分寄存器的说明。

不过我还是建议仔细阅读OHCI规范,毕竟这是第一手的资料。另外例程AT91RM9200-BasicUHP也很重要,这是第一手的代码,是未来继续深入工作的基础。

USB EHCI和OHCI端口切换原理分析

USB EHCI和OHCI端口切换原理分析
  • zoosenpin
  • zoosenpin
  • 2014年11月14日 12:28
  • 1612

USB主机控制器驱动——OHCI分析

首先,整个驱动框架的开始,是基于 platform 平台总线的。 struct platform_device s3c_device_usb = { .name = "s3c2410-ohci...
  • lizuobin2
  • lizuobin2
  • 2016年07月18日 22:34
  • 4357

基于栈虚拟机和基于寄存器虚拟机的比较

基于寄存器的虚拟机和基于栈的虚拟机有什么不同?
  • u012481172
  • u012481172
  • 2016年03月16日 14:04
  • 2812

3.8 基于OHCI的USB主机 —— OHCI(TD结构说明)

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://lancelot.blog.51cto.com/393579/241926 ...
  • landishu
  • landishu
  • 2012年03月22日 10:00
  • 429

USB主机控制器驱动——OHCI分析

首先,整个驱动框架的开始,是基于 platform 平台总线的。 struct platform_device s3c_device_usb = { .name = "s3c2410-ohci...
  • lizuobin2
  • lizuobin2
  • 2016年07月18日 22:34
  • 4357

3.6 基于OHCI的USB主机 —— OHCI(ED结构说明)

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://lancelot.blog.51cto.com/393579/240821 ED...
  • landishu
  • landishu
  • 2012年03月22日 09:59
  • 338

3.16 基于OHCI的USB主机 —— 中断向量处理

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://lancelot.blog.51cto.com/393579/261143 ...
  • landishu
  • landishu
  • 2013年10月25日 17:42
  • 419

1.3 基于OHCI的USB主机 —— 总体构架

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://lancelot.blog.51cto.com/393579/228153 ...
  • landishu
  • landishu
  • 2012年03月22日 09:40
  • 277

基于OHCI的USB主机 —— 目录

我的《基于OHCI的USB主机》系列文章已经完毕了,我觉得需要建立一个目录,以便需要的人可以迅速找到所需要的文章。本文档的目标就是建立一个该系列文章的目录,可能还会对每个部分进行简单介绍。 第一...
  • landishu
  • landishu
  • 2012年03月22日 09:36
  • 388

3.17 基于OHCI的USB主机 —— 中断处理程序

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://lancelot.blog.51cto.com/393579/261181 ...
  • landishu
  • landishu
  • 2013年10月25日 17:43
  • 420
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:2.1 基于OHCI的USB主机 —— 寄存器层(说明)
举报原因:
原因补充:

(最多只允许输入30个字)