片机控制sl811hs的usb主机底层驱动

片机控制sl811hs的usb主机底层驱动

ID:23101420

大小:137.51 KB

页数:6页

时间:2018-11-04

片机控制sl811hs的usb主机底层驱动_第1页
片机控制sl811hs的usb主机底层驱动_第2页
片机控制sl811hs的usb主机底层驱动_第3页
片机控制sl811hs的usb主机底层驱动_第4页
片机控制sl811hs的usb主机底层驱动_第5页
资源描述:

《片机控制sl811hs的usb主机底层驱动》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、51单片机控制SL811HS的USB主机底层驱动技术分类:通信 微处理器与DSP 消费电子设计 

2、2006-08-14来源:电子设计应用

3、作者:华南理工大学微电子研究所 陈智荣 李斌      引言      基于USB接口的设备使用方便,性价比高,因此在人们的工作和生活中得到了广泛的应用,如U盘、移动硬盘、移动光驱、USB摄像头、USB鼠标键盘等。同时,51系列单片机以其成熟的技术和高性价比吸引了大量国内用户,被广泛应用于测控和自动化领域。因此,如果在51单片机系统中增加USB主机接口,实现对USB从机设备的控制,则该单片机系统可充分利用现有的各种USB从

4、机设备,大大扩展单片机系统的功能。      本设计实现了在51单片机系统中增加USB主机功能,采用普通51单片机外接专用USB接口芯片的方案。这种方案虽然会使系统传输速度受到限制,而且在稳定性方面有所欠缺,但此方案设计灵活性高,且易于移植,为低成本产品的开发提供了广阔前景。设计中采用的51单片机是Atmel公司的AT89S52芯片,USB主机功能的扩展通过外接专用USB接口芯片SL811HS实现。CYPRESS公司的USB接口芯片SL811HS可以工作在主机或从机模式,支持USB1.1的全速和低速数据传输。工作在主机模式时,SL811HS可以自动检测外设的

5、插拔动作,可以按照外处理器(如单片机)的要求自动把数据整合为USB协议数据包进行数据传输。图1系统硬件示意图      本文将介绍单片机AT89S52控制SL811HS的硬件设计和底层驱动的编写,其中重点讲述底层驱动的设计。      硬件设计      系统的硬件原理图如图1所示。AT89S52的供电电压为5V,SL811HS的为3.3V。尽管供电电压不同,但根据芯片引脚的信号噪声容限参数分析可知,AT89S52与SL811HS之间的引脚可以直接相连,不需要电平转换或缓冲。表1USB主机枚举操作驱动的层次关系      软件设计      USB主机驱动是

6、一个高低层子程序的组合,实现USB传输和控制的过程是较高层子程序调用较低层子程序的过程。编写USB主机驱动时,可接从低层往高层的顺序逐层进行。      以USB主机枚举从机设备的操作为例,实现该功能所需要的各层子程序层次关系如表1所示。本文将介绍较低层的几个子程序的实现,包括读写SL811HS内部寄存器、传输事务的实现、设备插拔检测、复位等,其中,“传输事务的实现”是关键和难点,同时也是本文的重点。      单片机读写SL811HS      内部寄存器      读写SL811HS内部寄存器子程序是最低层的子程序,系统所进行的各种操作主要都是通过调用这

7、些子程序读写SL811HS内部寄存器实现的。例如,通过读取SL811HS的状态寄存器获取SL811HS的状态信息可以实现设备插拔检测、设备速度检测等,通过向SL811HS的相关控制寄存器写入控制字节可以实现USB总线复位以及USB数据传输等操作。      SL811HS内部寄存器      从编程结构的角度来看,SL811HS内部寄存器一共有256个单元,每个单元是一个字节,其中地址为[00H]~[0FH]的前16个单元是SL811HS的状态寄存器或控制寄存器(统称为特殊寄存器),其余的是数据缓冲寄存器。表2列出了16个特殊寄存器的名称和主要功能含义。表2

8、SL811HS内部特殊寄存器简介      单片机读写SL811HS      内部寄存器的实现      按照SL811HS的读写控制信号时序图编写单片机读写SL811HS内部寄存器的子程序,使各控制引脚上按照规定的时序给出符合要求的信号脉冲。 初始化      初始化操作主要包括SL811HS芯片复位、USB总线复位、设备插拔检测和设备USB数据传输速度检测等。通过这些初始化操作,SL811HS将作为USB主机与从机之间建立一个底层协议连接关系,为后续的数据通信做好准备。      SL811HS芯片复位      USB接口芯片SL811HS的复位是对

9、芯片的状态进行复位,包括了对芯片内部寄存器值的复位。实现该操作不需要读写接口芯片内部寄存器,只需向接口芯片的复位引脚输入一个有效的复位脉冲即可。      USB总线复位      按照USB协议,USB总线复位是指在USB数据线上输出SE0态,并保持10ms以上,接在USB总线上的从机设备收到这个复位信号后就会进行自身的复位操作,为接下来的USB数据传输做好准备。通过设置接口芯片的CtrlReg[05H]寄存器的第4、3位为逻辑”01”,并保持10ms,然后再把它们恢复为逻辑”00”,就可以让接口芯片产生USB总线复位信号。      设备拔插检测和设备速

10、度检测      在USB协议的物理层上,USB从机

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。