原创 51单片机控制SL811HS的USB主机底层驱动

2009-8-13 19:15 2286 3 3 分类: MCU/ 嵌入式

摘 要:本文介绍了51单片机控制SL811HS实现USB主机的硬件设计和底层驱动的编写。其中,底层驱动部分主要讲述了USB总线复位、设备插拔动作检测、设备速度检测以及USB传输事务的实现。电子园51单片机学习网f S6]{dRi

电子园51单片机学习网Ctr BZ_H~6G|

引言电子园51单片机学习网+v1xZ,~'yJ7?g%V
电子园51单片机学习网,Vb[\ ]$F+E0k
基于USB接口的设备使用方便,性价比高,因此在人们的工作和生活中得到了广泛的应用,如U盘、移动硬盘、移动光驱、USB摄像头、USB鼠标键盘等。同时,51 系列单片机以其成熟的技术和高性价比吸引了大量国内用户,被广泛应用于测控和自动化领域。因此,如果在51 单片机系统中增加USB 主机接口,实现对USB 从机设备的控制,则该单片机系统可充分利用现有的各种USB从机设备,大大扩展单片机系统的功能。电子园51单片机学习网#i[G4B w1y'_1H0}3O

&I5M/DRw+H44606本设计实现了在51单片机系统中增加USB主机功能,采用普通51单片机外接专用USB接口芯片的方案。这种方案虽然会使系统传输速度受到限制,而且在稳定性方面有所欠缺,但此方案设计灵活性高,且易于移植,为低成本产品的开发提供了广阔前景。设计中采用的51单片机是Atmel公司的AT89S52芯片,USB主机功能的扩展通过外接专用USB接口芯片SL811HS实现。CYPRESS公司的USB接口芯片SL811HS可以工作在主机或从机模式,支持 USB1.1的全速和低速数据传输。工作在主机模式时,SL811HS可以自动检测外设的插拔动作,可以按照外处理器(如单片机)的要求自动把数据整合为 USB协议数据包进行数据传输。
x;bFn/x}IC44606电子园51单片机学习网 n@#p7BCdU:D6h7S
电子园51单片机学习网o f{&]7`:Z



jL6kO^!CcD44606图 1 系统硬件示意图电子园51单片机学习网3^ _P_v!yH^


l&f6N'g'P!j44606本文将介绍单片机AT89S52控制SL811HS的硬件设计和底层驱动的编写,其中重点讲述底层驱动的设计。电子园51单片机学习网6yo&aM D6K^


:F%c)r&je$j4V"P44606硬件设计电子园51单片机学习网f'J&J p6Uu
电子园51单片机学习网 o9v;E6S%k j
系统的硬件原理图如图1所示。AT89S52的供电电压为5V,SL811HS的为3.3V。尽管供电电压不同,但根据芯片引脚的信号噪声容限参数分析可知,AT89S52与SL811HS之间的引脚可以直接相连,不需要电平转换或缓冲。电子园51单片机学习网P*l2V(iP9m h8b)c

&l ^$La(b44606电子园51单片机学习网U9^u3xp C


电子园51单片机学习网~'^]3cY;C0m/b2W
表1 USB主机枚举操作驱动的层次关系

%dKr-GP3@ T44606 电子园51单片机学习网4Op+M$Y[Xg

软件设计电子园51单片机学习网I#P j K a._P

0@0?*`2@[[Fr44606USB主机驱动是一个高低层子程序的组合,实现USB传输和控制的过程是较高层子程序调用较低层子程序的过程。编写USB主机驱动时,可接从低层往高层的顺序逐层进行。
gH/~.T!PX44606电子园51单片机学习网7Rgq/^Ul7G
以USB主机枚举从机设备的操作为例,实现该功能所需要的各层子程序层次关系如表1所示。本文将介绍较低层的几个子程序的实现,包括读写SL811HS内部寄存器、传输事务的实现、设备插拔检测、复位等,其中,“传输事务的实现”是关键和难点,同时也是本文的重点。
'T/y)k)o1M5E44606
3Zji,v } z"e44606单片机读写SL811HS
.M$pX P%UM!n44606内部寄存器
f1P;C{8\)cO6E44606电子园51单片机学习网2X}1v/@E
读写SL811HS内部寄存器子程序是最低层的子程序,系统所进行的各种操作主要都是通过调用这些子程序读写SL811HS内部寄存器实现的。例如,通过读取SL811HS的状态寄存器获取SL811HS的状态信息可以实现设备插拔检测、设备速度检测等,通过向SL811HS的相关控制寄存器写入控制字节可以实现USB总线复位以及USB数据传输等操作。电子园51单片机学习网5x\zPr/M X l }&`
电子园51单片机学习网4C x7y/CC!d
SL811HS内部寄存器电子园51单片机学习网 OMM}V3wA`
电子园51单片机学习网:EE p Rw
从编程结构的角度来看,SL811HS内部寄存器一共有256个单元,每个单元是一个字节,其中地址为[00H]~[0FH]的前16个单元是SL811HS的状态寄存器或控制寄存器(统称为特殊寄存器),其余的是数据缓冲寄存器。表2列出了16个特殊寄存器的名称和主要功能含义。
z9Oi9R8B(u5_d44606
+S D8D)}p8N44606电子园51单片机学习网^'p.A.K z0F C b(Lb,?



)ed+E I|.G(AoE44606表2 SL811HS内部特殊寄存器简介
]u5P0U |(aS{44606电子园51单片机学习网'|-}Z3dEf mCGH#w

电子园51单片机学习网4vB;w3ja~

单片机读写SL811HS
8y%t6P6^d Q#t{8Z2L"D a44606内部寄存器的实现
电子园51单片机学习网9tku R*^@9SA)x
按照SL811HS的读写控制信号时序图编写单片机读写SL811HS内部寄存器的子程序,使各控制引脚上按照规定的时序给出符合要求的信号脉冲。 在这个程序中,单片机指令周期的大小将直接影响输出信号的保持时长和时序关系。电子园51单片机学习网,n#?? fL%s)Q[\5n
电子园51单片机学习网mq.~9Rpbb
初始化
xV~ }['F6l44606初始化操作主要包括SL811HS芯片复位、USB总线复位、设备插拔检测和设备USB数据传输速度检测等。通过这些初始化操作,SL811HS将作为USB主机与从机之间建立一个底层协议连接关系,为后续的数据通信做好准备。电子园51单片机学习网zt(|EO Qm {f1Za
电子园51单片机学习网LY3l;e5P:U
SL811HS芯片复位电子园51单片机学习网}L?4~8p.]2c
USB接口芯片SL811HS的复位是对芯片的状态进行复位,包括了对芯片内部寄存器值的复位。实现该操作不需要读写接口芯片内部寄存器,只需向接口芯片的复位引脚输入一个有效的复位脉冲即可。
3vzvW-S[T44606电子园51单片机学习网/p l*Rj4C
USB总线复位电子园51单片机学习网C| ] N,Y3S0N2rN
按照USB协议,USB总线复位是指在USB数据线上输出SE0态,并保持10ms以上,接在USB总线上的从机设备收到这个复位信号后就会进行自身的复位操作,为接下来的USB数据传输做好准备。通过设置接口芯片的CtrlReg[05H]寄存器的第4、3位为逻辑”01”,并保持10ms,然后再把它们恢复为逻辑”00”,就可以让接口芯片产生USB总线复位信号。电子园51单片机学习网!nw9C'S W0N1^{W
电子园51单片机学习网S3E/t)_.v,})i1L
设备拔插检测和设备速度检测
xD{O@9E44606在USB 协议的物理层上,USB从机设备是否接在USB总线上是通过检测总线的电压得知的。根据该电压的高低,还可获知USB总线上的设备所支持的速度(例如,在 USB1.1协议中,分有低速和全速)。 USB主机接口芯片SL811HS把这个物理层的电压检测结果反映到状态寄存器的取值上,通过读取这些状态寄存器的值,可以获知当前的设备插拔状态和设备速度。
]{X Ea;ZQ ?b44606电子园51单片机学习网 }4U'SV7t7} C:H\
USB主机所进行的初始化操作除了上述3项外,还包括帧起始包启动/禁止的设置、帧同步设置、帧定时初值的设置等,它们都是通过对接口芯片特殊寄存器进行读写而实现的。
r'mE!]x3A#S{[nV44606
o@L"B b`V$F44606传输事务的实现电子园51单片机学习网k7d"J3p6Q
根据USB1.1协议,一个传输事务一般包含3个包(Packet)的传输,分别是标记包(Token Packet)、数据包(Data Packet)和握手包(Handshake Packet)。USB数据传输方式一共有四种,分别是控制传输(Control Transfer)、同步传输(Isochronous Transfer)、中断传输(Interrupt Transfer)和批传输(Bulk Transfer)。其中,控制传输方式至少由2个传输事务构成,其它三种传输方式则都各由1个传输事务构成。可见,传输事务在USB传输中至关重要。电子园51单片机学习网w\\d2wX

d z8e Q"h+xP44606一个典型的传输事务含有3个包的传送,这连续的3个包数据流如表3所示。
C"rD y(@TL*M'hT44606电子园51单片机学习网R/t Z6g| a:@/j
电子园51单片机学习网#Z|` CYcc'D



W&@ ~S W ]l7G44606表3 一个传输事务的数据流示意电子园51单片机学习网X/L |w)f#wx@7h

电子园51单片机学习网7{6S;V8s Yg

使用SL811HS设计USB主机系统时,用户只需让单片机设置SL811HS内部几个相关的特殊寄存器,然后把传输事务启动位使能(置为逻辑 ’1’),就可以让接口芯片自动完成这个包的发送与接收。在表3所示的例子中,第n个包(标记包)和第n+2个包(握手包)都是由主机发送给从机的,第n +1个包(数据包)是由从机发送给主机的。这个传送方向和第n+2个包的传送方向都是由标记包中的标识域取值决定的,其规则可参考USB协议。
4@^%f-HN ?4}4f44606
u z-C!~ ok+yr44606如果传输事务的数据包是由从机发送给主机,则该传输事务属于输入类型,称为输入传输事务,反之则称为输出传输事务。可见,表3例子是一个输入传输事务。对于一个输入传输事务,单片机通过设置SL811HS内部特殊寄存器就可以决定其取值的包域主要有:标记包中的标识域、地址域和端点域,数据包中的标识域。在输入传输事务中,虽然数据包并不是由主机发送的,但之所以仍需要单片机设置与数据包标识域相关的寄存器,是因为主机在该传输事务中将只认可标识域符合所设置值的数据包。其余部分,如标记包中的其它域及握手包的内容则都是SL811HS根据情况自动产生的。
/]2g8Pl Bp&}'l44606
4}*i E U1BtE"P44606主机接口芯片SL811HS完成一次输入传输事务后,如果传输成功,单片机就可以从SL811HS的数据缓冲寄存器读到从机发送过来的数据。此处,数据缓冲区的首地址是由单片机预先通过设置控制寄存器指定的。电子园51单片机学习网2I@)ek6RstI}3He
电子园51单片机学习网)cT `SD"G(z7N
对于输出传输事务,单片机同样需要设置相关的寄存器以确定标记包的标识域、地址域、端点域和数据包的标识域,以及存放发送数据的缓冲区首地址,并且,这个缓冲区中的数据也是由单片机写入的。
3E i7g+}r~ {DV~44606
U$wu!_.e44606具体地,单片机控制USB主机接口芯片进行一次传输事务所需要执行的操作步骤如下:
;e+[7E&} W?r[44606首先,如果是输出传输事务,则需要把将在数据包中发送给从机的数据存放到SL811HS的数据缓冲区中。
#t,y;N!A5Ha+T44606电子园51单片机学习网l/eK,R^7Vi.@s*ORK
其次,做好相关的传输准备工作,即设置接口芯片中的4个特殊寄存器。这4个寄存器的名称及其在传输事务中的作用如表4的前4项所列。
c3ZgM4uQ+PF] @44606
7Z.fy8S$E]8R44606电子园51单片机学习网 Ac'E2J5u



n `A!h/t44606表4 与传输事务直接相关的SL811HS特殊寄存器电子园51单片机学习网_-euh&Qc


1m2f#T*z t&?|9O`!`44606第三,启动传输事务:把寄存器EP0Control[00H]或EP1Control[08H]的第0位(即传输事务启动位)置为逻辑’1’即可启动传输事务。但在此之前必须把这个寄存器中其它位设置好(或与启动位同时设置),与这个寄存器相关的包域如表4中最后一项所列。
r9t&U2QV%F|44606电子园51单片机学习网2o:{%s)rz,S5i"Y
第四,单片机读取寄存器EP0Status[03H]或EP1Status[0BH]的值,以获知此次事务传输的完成情况。电子园51单片机学习网J `Vm:l2Y

M-yuWg%Ju[44606最后,如果传输成功,而且该传输事务是输入性质的,则单片机可读取数据缓冲区,获得由从机发送过来的数据。电子园51单片机学习网S#R;u_.h


#C a E.\F44606结语
C`?PA1N"a+e'd/C44606

TR[J$y6s a44606在51单片机控制USB接口芯片SL811HS的底层驱动中,读写SL811HS内部寄存器的子程序是最低层的,各种USB传输的较低层操作,如总线复位、插拔检测、速度检测以及传输事务等,都主要是通过读写SL811HS内部特殊寄存器实现的。其中,传输事务的实现就直接涉及了5个特殊寄存器的读写。电子园51单片机学习网3?2l;{9A pk1NL
电子园51单片机学习网;q._X!t`ew0[s3Z
在本文所述的底层驱动基础上,添加相关的高层程序,使该51单片机系统实现了对各种USB从机设备的枚举控制和对U盘的数据交换,为51单片机系统的开发提供了广阔的应用前景,同时也对其它平台的USB主机设计有一定的参考价值。

3{e:CK:I/?0jU$G6V44606
PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
3
关闭 站长推荐上一条 /3 下一条