[优秀毕业论文]基于单片机+PDIUSBD12芯片的USB协议转换系统设计_第1页
[优秀毕业论文]基于单片机+PDIUSBD12芯片的USB协议转换系统设计_第2页
[优秀毕业论文]基于单片机+PDIUSBD12芯片的USB协议转换系统设计_第3页
[优秀毕业论文]基于单片机+PDIUSBD12芯片的USB协议转换系统设计_第4页
[优秀毕业论文]基于单片机+PDIUSBD12芯片的USB协议转换系统设计_第5页
已阅读5页,还剩49页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、目录第1章绪论11.1概述11.1.1课题研究目的11.1.2国内外发展状况11.2usb接口及usb器件分析21.3系统方案设计41.4预期实现目标4第2章usb概述及协议62.1usb体系结构概述62.1.1usb系统描述62.1.2usb连接头及其供电方式82.1.3usb系统软硬件组成82.2usb编码方式与传输类型92.2.1usb的编码方式92.2.2usb传输92.3usb设备请求122.3.1usb标准请求格式122.3.2usb标准请求命令122.4usb设备的描述符132.4.1设备描述符132.4.2配置描述符142.4.3接口描述符142.4.4端点描述符162.4.5

2、字符串描述162.5总线协议192.6usb的枚举过程192.7usb主机接口及系统的功能202.8本章小结21第3章硬件特性及电路设计223.1单片机8051介绍223.2pdiusbd12器件与微控制器的连接243.2.1pdiusbd12功能描述243.2.2pdiusbd12管脚配置243.2.3单片机与pdiusbd12的连接253.3系统硬件设计263.3.1单片机电路设计263.3.2外围电路设计273.4本章小结29第4章程序设计及调试304.1概述304.1.1集成开发环境keil简介304.1.2程序概述304.2固件程序344.2.1固件程序组成344.2.2pdiusb

3、d12的底层操作354.2.3pdiusbdi2命令接口程序364.2.4pdiusbdi2的中断服务程序374.2.5主程序424.3程序调试454.3.1keil编译器的使用454.3.2系统调试484.4本章小结51结论52参考文献53致谢54附录55附录1电路原理图55附录2pcb图56第1章绪论1.1概述1.1.1课题研究目的随着电子科技的发展与应用,各种计算机外围接口不断推陈出新,usb接口已经成为现今个人计算机上最重要的接口之一,各种电子消费产品也逐渐配置这种接口。usb接口是速度比较高的串行接口,具有较广阔的发展前景和应用潜力。usb适用于低档外设与主机之间的高速数据传输。从u

4、sb问世至今,usb在不断的自我完善,并走向成熟。从普通计算机用户、计算机工程师、到硬件芯片生产厂商,都已经完全认可了usb。传统的设备主要是基于rs-232的串行接口,随着计算机速度的提升,已经明显不能适应发展的需要。不仅是速度上比较慢,而且由于其不支持热插拔。而usb接口由于支持热插拔,占有较少的系统软件硬件资源,厂商对于usb的硬件软件的支持也越来越完备,现在开发一个usb外设产品所需要的成本和时间大大降低了。usb技术取得了迅速的发展。单片机作为最典型的嵌入式系统,推动了嵌入式系统的发展,成为现代电子系统中重要的智能化器件。因此,usb i/o外围设备的设计已成为电子领域的主要技术之一

5、1。本课题就是利用单片机设计一个功能简单的嵌入式usb外设,将其与pc机连接,通过usb接口实现pc机与外设之间的相互通信。1.1.2国内外发展状况1994年,intel,compaq,digital,ibm,microsoft,nec,northern telecom等7家世界著名的计算机和通信公司成立了usb论坛,花了近两年的时间形成了统一的意见,于1995年11月正式制定了usb 0.9通用串行总线(universal serial bus)规范。在1996年,一些规模型经营的公司,他们的pc机、监视器,开始配备了usb接口。原有的所有接口和插槽依然保留,只增加一个usb接插件,其目的是

6、为了在扩展新的用途时使用。直到1997年,真正符合usb技术标准的外设才开始出现。直至windows98推出之前,推出的usb功能模块并不多,原因除了因为传统的通信接口,如rs232,ieee488等,一时难以退出应用领域外,一些早期的usb应用探索者步履艰难,抱怨的主因是宿主平台的实用性。windows98对usb驱动软件(usbd)完善,使其可提供对usb的强有力的支持,对usb技术的发展起到重要推进作用。自此,市场上涌现出大批的usb产品。usb1.0是目前推出的在支持usb的计算机与外设上普遍采用的标准。目前普遍采用的usb1协议主要应用在中低速外围设备上,它提供的传输速度有低速1.5

7、mbps和全速12mbps两种。可分别支持显示器、modem、鼠标、键盘、扫描仪、打印机、光驱及大范围的多媒体设备。从国外的发展来看,人们对usb有着极大的重视程度,这从usb规范的改进速度之快及国际市场上基于usb的产品普及的范围可见一斑。从1994年公布v1.0fdr版本,短短一年时间版本增订了五次。说明技术人员正大力研究改善usb的性能。市场上基于usb的外设己囊括了所有的数字产品。可见国外在这方面已作了很多工作,并且目前也正以很快的速度发展2。 国内对于usb的研究在这几年才刚刚起步。市场上也可以见到各种usb产品,也有少量的专门讨论usb开发的国内网站。比较专业的稳定的网站有usb开

8、发网(),但因为在前几年还很少有人做这方面的工作,所以在相关网站上开发usb的文章量少,更新速度慢;国内知名高校的bbs(比如水木华:),上面相关的文章询问usb的人多,但回答问题的人仅限于几个。对usb芯片进行开发、技术服务和应用方案设计的公司更是寥寥无几。虽然在网上做调研所得到的信息并不完全,但由此可以看出国内对usb技术研究的需求及欠缺。1.2usb接口及usb器件分析usb(universal serial bus通用串行总线),是一种快速、灵活的总线接口。与其它通信接口比较,usb接口的最大特点是易于使用,这也是usb的主要设计目标。作为一种高速总线接口,usb适用于多种设备,如数码

9、相机、mp3播放机、高速数据采集设备等。易于使用还表现在usb接口支持热插拔,并且所有的配置过程都由系统自动完成,无需用户干预。usb接口支持1.5mb/s(低速)和12mb/s(全速)的数据传输速率,扣除用于总线状态、控制和错误监测等的数据传输,usb的最大理论传输速率仍达1.2mb/s或9.6mb/s,远高于一般的串行总线接口。usb接口芯片价格低廉,这也大大促进usb设备的开发与应用。在进行一个usb设备开发之前,首先要根据具体使用要求选择合适的usb控制器。目前,市场上供应的usb控制器主要有两种:带usb接口的单片机(mcu)或纯粹的usb接口芯片。带usb接口的单片机从应用上又可以

10、分成两类,一类是从底层设计专用于usb控制的单片机,另一类是增加了usb接口的普通单片机,如cypress公司的ezusb(基于8051),选择这类usb控制器的最大好处在于开发者对系统结构和指令集非常熟悉,开发工具简单,但对于简单或低成本系统。其价格因素也是在实际选择过程中需要考虑的因素。纯粹的usb接口芯片仅处理usb通信,必须有一个外部微处理器来进行协议处理和数据交换。这类典型产品有philips公司的pdiusbd12(并行接口),ns公司usbn9603/9604(并行接口),netchip公司的net2888等。usb接口芯片的主要特点是价格便宜、接口方便、可靠性高,尤其适合于产品

11、的改型设计(硬件上仅需对并行总线和中断进行改动,软件则需要增加微处理器的usb中断处理和数据交换程序,pc机的usb接口通信程序,无需对原有产品系统结构作很大的改动)2。pdiusbd12是在usb协议设备端使用最多的芯片之一。此芯片是带有并行总线的全速usb接口器件,可与任何微控制器实现高速并行接口(2mb/s),并用于许多外设。这种实现usb接口的标准组件,可以使设计者在不同类型的微控制器中选择最合适的微控制器,使用已有的结构和减少固件上的投资,从而用最快捷的方法实现最经济的usb设备,它具有以下特性:1、符合usb1.0版规范;2、高性能usb接口器件,集成了sie, fifo存储器,收

12、发器以及电压调整器;3、可以与任何外部微控制器/微处理起实现高速并行接(2mb/s);4、集成320b多结构的fifo存储器;5、完全自治的直接内存存取(dma)操作;6、可以通过软件控制与usb的连接;7、采用goodlink技术的连接指示器,在通信时使led闪烁;8、可编程的时钟频率输出;9、多中断模式实现批量和同步传输3。1.3系统方案设计以单片机原理,硬件资源的功能应用,pdiusbd12芯片功能与接口设计,usb1.0协议等理论知识为基础,设计出完整的系统原理图。根据原理图,将硬件系统资源焊接成pcb板。根据系统功能,设计编写固件程序,下载后进行调试,实验板在单片机控制下能单独工作后

13、,然后和上位机进行联机调试,通过usb接口实现与上位机的相互通信。本课题涉及的理论知识主要是usb1.0协议,重点在于硬件设计,难点在于编程和整机的调试。经过论证,在实现设计要求的前提下,为了降低系统的成本,选用接口级芯片pdiusbd12,控制器选取8051,它有64k的存储容量,对于固件程序已经足够使用了;而且这款单片机支持在线编程,通过串口下载程序,这给程序的下载和使用带来来方便。程序设计采用c语言进行编程,软件仿真采用keil c51。1.4预期实现目标通过硬件电路和驱动程序(包括设备端和上位机端的驱动程序)实现以下目的:1、保证电路连接的正确性和可行性。完成以单片机与usb接口芯片为

14、主要芯片的电路板;2、完成程序的编写,主要是设备端的固件编程;3、通过硬件调试,单片机能独立控制电路板上元件工作;4、实现电路板与上位pc机双向传输。这需要与上位机进行联机调试,主要在软件部分实现。第2章usb概述及协议usb以usb主机为核心,以外围的usb设备为功能,组成了usb系统模型。主机是usb的核心,每次usb数据通信都必须是由usb主机来发起的,主机管理着usb设备。usb物理上是一个含有两条电源线(vcc,gnd)和两条以差分方式产生信号的线(d+,d-),传输率可达12mbps的串行接口,一个pc主机可以连接多达127个外围设备。usb协议是以令牌包为主的通信协议,12mbp

15、s的总线带宽被分割成1ms的帧,所有任务以时分传输(tdm)来分享总线。2.1usb体系结构概述2.1.1usb系统描述一个usb系统主要被定义为三个部分: usb的互连; usb的设备; usb的主机。 usb的互连是指usb设备与主机之间进行连接和通信的操作,主要包括以下几方面: 总线的拓扑结构:usb设备与主机之间的各种连接方式; 内部层次关系:根据性能叠置,usb的任务被分配到系统的每一个层次; 数据流模式:描述了数据在系统中通过usb从产生方到使用方的流动方式;usb的调度:usb提供了一个共享的连接。对可以使用的连接进行了调度以支持同步数据传输,并且避免的优先级判别的开销。usb连

16、接了usb设备和usb主机,usb的物理连接是有层次性的星型结构。每个网络集线器是在星型的中心,每条线段是点点连接。从主机到集线器或其功能部件,或从集线器到集线器或其功能部件,从图2.1中可看出何usb系图2.1 总线的拓扑结构拓扑结构。其中,usb集线器hub是一组设备的连接点,主机中有一个被嵌入的hub叫根hub(root hub)。主机端通常是指pc主机或是另外再附加usb端口的扩充卡,主机通过根hub提供若干个连接点。集线器除了扩增系统的连接点外,还负责中继(repeat)上游或下游的信号以及控制各个下游端口的电源管理。当pc上电时,所有usb设备与hub都默认地址为0,pc机启动程序

17、向usb查询,地址1分配给发现的第一个设备,地址2分配给第二个设备或hub,如此重复寻找并分配地址,直到所有设备赋完地址,并加载相应的的驱动程序。当设备突然被拔移后,pc机通过d+或d-的电压变化检测到设备被移除掉后,将其地址收回,并列入可使用的地址名单中。在任何usb系统中,只有一个主机。usb和主机系统的接口称作主机控制器,主机控制器可由硬件、固件和软件综合实现。根集线器是由主机系统整合的,用以提供更多的连接点。usb的设备如下所示: 网络集线器,向usb提供了更多的连接点;功能器件:为系统提供具体功能,如isdn的连接,数字的游戏杆或扬声器。usb设备提供的usb标准接口的主要依据: 对

18、usb协议的运用; 对标准usb操作的反馈,如设置和复位;标准性能的描述性信息。2.1.2usb连接头及其供电方式为了避免连接错误,usb定义了两种不同规格的星形usb连接头:序列a与b连接头,其中序列a接头用来连接下游的设备。每个连接头内拥有4个针脚,其中两个是用来传递差分数据的,另两个则用于usb设备的电源供给。usb的供电方式有两种:1、总线供电集线器电源由上游连接端口供应,最多只能从上游端消耗500ma。一个4个连接端口的集线器,每个下游端口最多消耗为100ma,外围电路消耗100ma。2、自我供电集线器集线器本身有电源,可以提供给本身的控制器以及下游端口至少500ma的电流,集线器最

19、多可从上游端消耗100ma。2.1.3usb系统软硬件组成usb系统的软硬件资源可以分为3个层次:功能层、设备层和接口层。功能层提供usb设备所需的特定的功能,主机端的这个功能由用户软件和设备类驱动程序提供,而设备就由功能单元来实现。设备层主要提供usb基本的协议栈,执行通用的usb的各种操作和请求命令。从逻辑上讲,就是usb系统软件与usb逻辑设备之间的数据交换。接口层涉及的是具体的物理层,其主要实现物理信号和数据包的交互,即在主机端的usb主控制器和设备的usb总线接口之间传输实际的数据流。无论在软件还是硬件层次上,usb主机都处于usb系统的核心。主机系统不仅包含了用于和usb外设进行通

20、信的usb主机控制器及用于连接的 usb接口(sie),更重要的是,主机系统是usb系统软件和usb客户软件的载体。usb主机软件系统可以分为三个部分: 1、客户软件部分(csw),在逻辑上和外设功能部件部分进行资料的交换;2、usb系统软件部分(即hcdi),在逻辑和实际中作为hcd和usbd之间的接口;3、usb主机控制器软件部分(即hcd和usbd),用于对外设和主机的所有usb有关部分的控制和管理,包括外设的sie部分、usb资料发送接收器(transreceiver)部分及外设的协议层等2。2.2usb编码方式与传输类型2.2.1usb的编码方式usb采用不归零翻转(non retu

21、rn to zero invert,简称nrzi)编码方式,对于不同步的脉冲信号也能产生同步的数据存取,能有效地解决usb缆线信号延迟产生的误差。nrzi的编码规则是:当数据位为“1”时电平保持不变,为“0”时电平翻转。如果原始的串行数据中含有连续6个“1,就在其后填充一个“0。在nrzi解码的过程中发现连续的6个“1”时,则移走其后原填入的“0。nrzi编码、位填充过程分析如下:原数据 0 1 1 0 0 0 1 1 0 1 1 1 1 1 1 1 1位填充 0 1 1 0 0 0 1 1 0 1 1 1 1 1 1 0 1 1nrzi码 0 1 1 1 0 1 0 0 0 1 1 1 1

22、1 1 1 0 0 0 2.2.2usb传输usb总线是一种串行总线,即它的资料是一个bit一个bit来传送的。虽然usb总线是把这些bit形式的资料打成资料包来传送,但资料的同步也是必不可少的。usb1.0协议规定,usb的标准脉冲时钟为12mhz,而其总线时钟为1ms,即每隔1ms,usb器件应为usb线缆产生一个时钟脉冲序列。这个脉冲序列称为帧开始资料包(sof),主机利用sof来同步usb资料的发送和接收。为实现多外设、多信道地同时工作,usb总线使用资料包的方式来传输资料和控制信息。usb数据传输中的每一个资料包都以一个同步字段开始,它的最后两个bit作为pid字段开始的标志。紧跟在

23、同步字段之后的一段8bit的脉冲序列称为pid(资料包标识字段),pid字段的前四位用来标记该资料包的类型,后四位则作为对前四位的校验。pid字段被分为标记pid(共有in、out、setup或sof四种)、资料pid(data0或data1)、握手pid(ack、nak或stall)及特殊pid等。主机根据pid字段的类型来判断一个资料包中所包含的数据类型,并执行相应的操作。当一个usb外设初次连接时,usb系统会为这台外设分配唯一的usb地址,这个地址通过地址寄存器(addr)来标记,以保证资料包不会传送到别的usb外设。7bit的addr使得usb系统最大寻址为127台设备(addr字段

24、)。由于一台usb外设可能具有多个信道,因而在addr字段后会有一个附加的端点字段(endpointfield,简标为endp)来标记不同的信道。所有的usb外设都必须支持endpoint0信道,用0000来标记。对于高速设备,可以最大支持16个信道,而低速设备在endpoint0之外仅能有一个信道。数据域位作为一次usb数据传输的中心目的,在一个usb资料包中可以包含01203byte的资料。而帧数量字段则包含在帧开始资料包中,对有的应用场合,可以用帧数量字段作为资料的同步信号。为保证控制、块传送及中断传送中资料包的正确性,crc校验字段被引用到如标记、资料、帧开始(sof)这样的资料包中。

25、crc校验(资料冗余校验)可以给予资料以100% 的正确性检验。在usb系统中,有四种形式的资料包:信令包(token packets)、data 资料包(data packets)、帧开始包(sof packets)和握手包(handshake packets)。每个资料包的结束都会有两个bit宽的eop字段作为资料包结束的标志(图7-18),eop在差模信号中表现为d+和d-都处于“0”状态。对于高速usb外设而言,这个脉冲宽度在160175ns之间,而低速设备则在1.251.50s之间。无论其后是否有其它的资料包,usb线缆都会在eop字段后紧跟1bit的总线空闲位。usb主机或外设利用

26、eop来判断一个资料包的结束。为了满足不同外设和用户的要求,usb提供了四种传输方式:控制传输;同步传输;中断传输;批传输。它们在数据格式、传输方向、数据包容量限制、总线访问限制等方面有着各自不同的特征:1、控制传输(control transfer):可靠的,非周期的,由主机软件发起的请求或者回应的传送,通常用于命令事务和状态事务。2、同步传输(isochronous transfer);在主机和设备之间的周期性的,连续的通信,一般用于传送与时间相关的信息。这种类型保留了将时间概念包含于数据中的能力。但并不意味着用于同步传送的数据的时间是很重要的,即传送并不一定很急。3、中断传输(inter

27、rupt transfer):小规模数据的,低速的,固定延迟的传送。4、批量传输(bulk transfer):非周期的,大包的,可靠的传送。典型用于传送可以利用任何带宽的数据,这些数据没有带宽时,是可以容忍等待。对于pdiusbd12,端点的工作方式可通过set mode命令配置为4种不同的模式,分别为:1、模式0(non-iso模式):非同步传输;2、模式1(iso-out模式):同步输出传输;3、模式2(iso-in模式):同步输入传输;4、模式3(iso-io模式): 同步输入输出传输。端点2在有些方面是比较特别的,端点2是进行吞吐大量数据的主要端点,一般称其为主端点,主端点执行主机的

28、特性以减轻传输大量数据的任务,具体包括:1、双缓冲;2、支持dma;3、可以配置为同步传输或非同步(批量和中断)传输。2.3usb设备请求usb的标准设备请求是用来完成usb设备枚举的命令,usb设备必须对标准设备请求作出响应,不管该设备是否已经被分配了一个默认的地址或者该设备目前正在被配置。所有的标准设备请求都是使用默认的管道来传输的。2.3.1usb标准请求格式usb的设备请求由八个字节组成,格式定义如表2.1所示。2.3.2usb标准请求命令usb标准请求有11个命令,如下:1、 获取状态请求:该命令用于返回特定接受者的状态。2、 清除特性请求:该命令用于清除或禁用接受者的某些特性。3、

29、 设置特性请求:该命令是主机用来启用或激活命令接受者某些特性。4、 设置地址请求:该命令用于主机给设备分配地址。5、 获取描述请求:该命令用于主机获取设备的特定描述符。6、 设置描述符请求:主机利用该命令来修改设备中的有关描述或增加新的描述符等。7、 获取配置请求:主机利用该命令获得设备当前的配置值。8、 设置配置请求:主机通过该命令来指示设备采用要求的配置。9、 获取接口请求:主机利用该命令来获取当前的某个接口的接口描述符的编号。10、 设置接口请求:主机可以通过该命令来要求设备用某个接口描述符来描述接口。11、 同步帧请求:该命令用于设备设置和报告一个端点的同步帧。表2.1usb设备请求格

30、式偏移值字段名称字段长度字段取值说明0设备请求类型1位图请求特性:d7:数据传输方向0=主机到设备1=设备到主机d6.5:类型0=标准;1=类型2=厂商;3=保留d4.0:接受方0=设备;1=接口2=端点;3=其他4.31=保留1设备请求1数值usb设备请求2值2值根据不同的请求,以字节为单位来定义4索引2字段编号索引根据不同的请求,以字节为单位来定义6长度2计数如果传输一组数据,指出要传输的字节数2.4usb设备的描述符usb设备描述符是说明设备的通用信息,这包括对设备及所有设备设置全程起作用的信息。2.4.1设备描述符一个usb总线设备只能有一个设备描述表。设备描述表的结构如表2.2所示:

31、表2.2设备描述符偏移值字段名称字段大小字段取值说明0blength1数字描述符的大小=12h1bdescriptortype1常数设备描述符类型=01h2bcdusb2bcdusb规划发布号4bdeviceclass1类型类型代码(由usb指定)5bdevicesubclass1子类型子类型代码(由usb分配)6bdeviceprotocol1协议协议代码(由usb分配)7bmaxpacketsize01数字端点0最大分组大小(只有8,16,32或64有效)8idvendor2id供应商id(由usb分配)10idproduct2id产品id(由厂商分配)12bcddevice2bcd设备出

32、厂编码14imanufacture1索引厂商描述符字符串索引15iproduct1索引产品描述符字符串索引16iserialnumber1索引设备序列号字符串索引17bnumconfiguations1数字可能的配置数2.4.2配置描述符配置描述符定义了设备的配置信息,结构如表2.3所示。2.4.3接口描述符接口描述符说明了接口所提供的配置,接口描述符的结构如表2.4所示。表2.3配置描述符偏移值字段名称字段大小字段取值说明0blength1数字描述符的大小=09h1bdescriptortype1常数配置描述符类型=02 h2wtotallength2数字此设置信息的总长(包括设置,接口,端

33、点和设备类及厂商定义的描述表)4bnuminterfaces1数字此设置所支持的接口个数5bconfigurationvalue1数字作为set configuration的一个参数选择配置值6iconfiguration1索引用于描述该配置字符串描述符的索引7bmttributes1位图配置特性:d7:总线供电d6:自供电d5:远程唤醒d40;保留(复位为0)8maxpower1ma在此设置下的总线电源耗费量,以2ma为一个单位表2.4接口描述符偏移值字段名称字段大小字段取值说明0blength1数字描述符的大小=09h1bdescriptortype1常数接口描述符的类型=04h2bnum

34、interfaces1数字接口的编号3balternate setting1数字用于为上一个字段选择可供替换的设置4bnumendpoint1数字使用的端点数目(端点0除外)5binterface class1类型类型代码(由usb分配)6binterfacesubclass1子类型子类型代码(由usb分配)7binterface protocal1协议协议代码(由usb分配)8iinterface1索引字符串描述符的索引2.4.4端点描述符端点描述符包括了端点的类型,大小等信息。usb设备中的每一个端点都有自己的描述符。端点描述符的结构如表2.5所示。2.4.5字符串描述字符串描述是可选的。

35、如果一个设备不支持字符串描述符,在设备,配置和接口描述符内的所用字符串描述符的索引都必须为0。字符串描述符的结构如表2.6所示。表2.5端点描述符偏移值字段名称字段大小字段取值说明0blength1数字描述符的大小=07h1bdescriptortype1常数接口描述符的类型=05h2bendpointaddress1端点usb设备的端点地址:bit 0.3: 端点号bit 4.6: 保留,复位为0bit 7:方向,对于控制端点可以忽略0:out端点; 1:in端点3bmattributes1位图端点属性,当进行配置时采用以下的配置值bit0.1 传输类型00 控制01 同步02 批量03 中

36、断其他位保留4wmaxpacketsize2数字本端点接受或发送的最大信息包的大小6binterval1数字轮询数据传传送端点的时间间隔。 表2.6字符串描述符偏移值字段名称字段大小字段取值说明0blength1数字描述符的大小1bdescriptortype1常数字符串描述符的类型2bstringn数字unicode编码字符串各个描述符的树状结构如图2.2所示:图2.2usb描述符层次结构所有的usb设备都有缺省控制管道,缺省控制管道的最大包长在描述表中得到了说明。设置描述表中包括设置与接口的定义,但其中不包括端点描述表。除了最大包长度信息外,缺省管道的特性由usb规范定义,并且对所有的us

37、b总线设备都一样4。2.5总线协议usb总线属一种轮讯方式的总线,主机控制端口初始化所有的数据传输。 每一总线执行动作最多传送三个数据包。按照传输前制定好的原则,在每次传送开始时,主机控制器发送一个描述传输运作的种类、方向,usb设备地址和终端号的usb数据包,这个数据包通常称为标志包(token packet)。usb设备从解码后的数据包的适当位置取出属于自己的数据。数据传输方向不是从主机到设备就是从设备到主机。在传输开始时,由标志包来标志数据的传输方向,然后发送端开始发送包含信息的数据包或表明没有数据传送。接收端也要相应发送一个握手的数据包表明是否传送成功。发送端和接收端之间的usb数据传

38、输,在主机和设备的端口之间,可视为一个通道。存在两种类型的通道:流和消息。流的数据不像消息的数据,它没有usb所定义的结构,而且通道与数据带宽、传送服务类型,端口特性(如方向和缓冲区大小)有关。多数通道在usb设备设置完成后即存在。usb中有一个特殊的通道缺省控制通道,它属于消息通道,当设备一启动即存在,从而为设备的设置、查询状况和输入控制信息提供一个入口。 事务预处理允许对一些数据流的通道进行控制,从而在硬件级上防止了对缓冲区的高估或低估,通过发送不确认握手信号从而阻塞了数据的传输速度。当不确认信号发过后,若总线有空闲,数据传输将再做一次。这种流控制机制允许灵活的任务安排,可使不同性质的流通

39、道同时正常工作,这样多种流通常可在不同间隔进行工作,传送不同大小的数据包5。2.6usb的枚举过程usb设备接入计算机后,设备需要经过初始化和枚举才能被计算机识别,初始化主要有mcu完成,而枚举是在计算机的控制下完成的。枚举过程如下:1、设备连接。usb设备接入usb总线。2、设备上电。usb设备可以使用总线供电,也可以使用外部总线供电。3、主机检测到设备,发出复位。设备连接到总线后,主机拉电阻检测到有新的设备接入,然后向端口发送一个复位信号。4、设备默认状态。设备要从总线上接收到一个复位的信号后,才可以对总线的处理操作作出响应。设备接收到复位信号后,使用默认的地址(00h)来对其进行寻址。5

40、、地址分配。当主机接收到有设备对默认地址(00h)响应的时候,就对设备分配一个空闲的地址。以后设备就只对该地址进行响应。6、读取usb设备描述符。主机读取usb设备描述符,确认usb设备的属性。7、设备配置。主机依照读取的usb设备描述符来进行配置,如果设备所需的usb资源得以满足,就发送配置命令给usb设备,表示配置完成。8、挂起。为了节省电源,当总线保持空闲状态超过3ms以后,设备驱动程序就会进入挂起状态。完成以上步骤后,usb设备即可以使用。在枚举过程中,设备不一定要求进入挂起状态。2.7usb主机接口及系统的功能从具体的usb主机的实现角度上来讲,在遵行usb协议1.0的基础上,目前有

41、2套工业标准:1、通用式主机控制器接口(简写成uhci),由inter公司提出。2、开放式主机控制器接口(简写成ohci或open hci),由compaq等公司提出。uhci和ohci实现usb主机的功能基本上是一样的。只是具体的实现过程有些不同,两者均由2部分组成,即主机控制器(host control,简写成hc)和主机控制器驱动(host control driver,简写成hcd)。主机控制器更多的是面向硬件部分及其厂商,怪顶了主机控制器硬件与pc系统内存之间的接口、主机控制器在pci总线上的接口定义、主机usb事务的各种功能模块以及提供给用户交互的各种寄存器定义等;主机控制器驱动更

42、多的是基于软件层次的标准,是usb协议栈与usb主机控制器硬件之间联系的接口,直接负责主机控制器硬件的配置和管理,一般这部分软件厂商提供。按照usb的规定以及usb系统的组成的需要,usb主机完成的主要功能包括以下几个方面:1、检测usb设备的连接和断开。通过usb电缆信号线的电平变换来实现该功能,并得到主机控制器的处理。2、管理主机和设备之间标准的控制管道。以保证端点0和缺损管道的正常通信。3、收集设备的状态,统计总线的活动。usb的总线上最多可以同时挂接127个设备,这么多的设备都要正常的工作,就是靠主机来进行管理的,同时主机会根据收集到的各种设备和总线信息来执行某些操作。4、控制和管理主

43、机控制器与设备之间的电器接口,包括为端口提供一点数量的电流1。2.8本章小结在本章中,简要的介绍了相关的usb1.0协议内容,根据本次课题设计的要求,重点介绍了usb体系,软硬件组成、编码方式与传输类型、总线协议以及主机系统功能等内容。它们是开发usb设备,进行通信的应用的基础。实际应用中,这里的大部分工作由控制器完成。第3章硬件特性及电路设计3.1单片机8051介绍本课题设计usb系统比较简单,单片机执行的功能不多,在确保实验功能的情况下,为了降低成本,因此选用性价比高的8051单片机。 mcs-51是intel公司生产的一个单片机系列名称。属于这一系列的单片机有多种。8051便是其中一种性

44、价比高的单片机。8051单片机内部结构按其功能部件划分可以看出由8大部分组成的。这8大部分是: 1、一个8位中央处理机cpu。 2、128个字节的片内数据存储器ram。3、4kb的片内程序只读存储器rom或eprom。4、18个特殊功能寄存器sfr。 5、4个8位并行输入输出i/o接口: p0口、 p1口、 p2口、 p3口(共32线), 用于并行输入或输出数据。 6、1个串行i/o接口。 7、2个16位定时器/计数器。 8、1个具有5个中断源, 可编程为2个优先级的中断系统。 它可以接收外部中断申请, 定时器/计数器中断申请和串行口中断申请。本课题选用的8051单片机芯片为40个引脚,它是h

45、mos工艺制造的芯片,采用双列直插(dip)方式封装。1、主电源引脚vcc和vss vcc(40脚):接+5v电源正端; vss(20脚):接+5v电源地端。 2、外接晶体引脚xtal1和xtal2xtal1(19脚):接外部石英晶体的一端。在单片机内部, 它是一个反相放大器的输入端,这个放大器构成了片内振荡器。当采用外部时钟时,对于hmos单片机,该引脚接地;xtal2(18脚):接外部晶体的另一端。在单片机内部,接至片内振荡器的反相放大器的输出端。当采用外部时钟时,对于hmos单片机,该引脚作为外部振荡信号的输入端。3、控制信号或与其它电源复用引脚4、i/o口线引脚排列(1)p0口8位、漏

46、极开路的双向i/o口。.当使用片外储存器及外扩i/o口时,p0口做为低字节地址/数据复线。在编程时,p0口可用于接收指令代码字节;在程序校检时,p0口可输出指令字节(这是需要外加上拉电阻)。(2)p0口也可作为通用i/o使用,变成准双向口。当作为普通输入时,应将输出锁存器置1。p0口可驱动8个ttl负载。p1口8位、准双口i/o,具有内部上拉电阻。 p1口是为用户准备的i/o双向口。在编程和校检时,可用做输入低8位地址;用做输入时,应先将输出锁存器置1;p1口可驱动4个ttl负载。 p1口的p1.0和p1.1具有替代功能。(3)p2口8位、准双向i/o口,具有内部上拉电阻。当使用片外储存器或外

47、扩i/o端口时,p2口输出高8位地址;在编程校检时,p2口可接收高字节地址和某些控制信号;p2口也可作为i/o口使用。用做输入时,应先将输出锁存器置1;p2口可驱动4个ttl负载。(4)p3口8位、准双向i/o口,具有内部上拉电阻。p3口可作为普通i/o口。用作输入时,应先将输出锁存器置1;在编程校检时,p3口接收某些控制信号;可驱动4个ttl。p3口还提供各种替代功能。整个perom阵列和三个锁定位的电擦除可通过正确的控制信号组合,并保持ale管脚处于低电平10ms来完成。在芯片擦操作中,代码阵列全被写“1”且在任何非空存储字节被重复编程以前,该操作必须被执行。此外,8051设有稳态逻辑,可

48、以在低到零频率的条件下静态逻辑,支持两种软件可选的掉电模式。在闲置模式下,cpu停止工作。但ram,定时器,计数器,串口和中断系统仍在工作。在掉电模式下,保存ram的内容并且冻结振荡器,禁止所用其他芯片功能,直到下一个硬件复位为止6。3.2pdiusbd12器件与微控制器的连接3.2.1pdiusbd12功能描述philips公司推出的pdiusbd12是一款性价比很高的usb器件。它通常用做微控制器系统中实现与微控制器进行通信的高速通用并行接口,而且还支持本地的dma传输。pdiusbd12完全符合usb1.0协议规范。pdiusbd12所具有的低挂起功耗连同lazyclock输出可以满足使

49、用acpi、onnow和usb电源管理的要求。低的操作功耗可以应用于使用总线供电的外设。1、philips串行接口引擎psie实现了全部的usb协议层,且完全由硬件实现而不需要固件的参与。该模块的功能包括:同步模式的识别,并行/串行的转换,位填充/解除填充,crc校验/产生,pid校验/产生,地址识别和握手评估/产生。2、softconnect技术softconnect与usb的连接是通过1.5k上拉电阻将d+设置为高电平实现的。1.5k上拉电阻集成在pdiusbd12片内,默认状态下不与电源相连,其连接的建立是通过外部/系统微控制器发送命令实现的。3、goodlink技术goodlink技术

50、可以提供良好的usb连接指示。在枚举过程中,led指示灯根据通信状况间歇闪烁。配置完成并装安驱动程序后指示灯将一直亮7。3.2.2pdiusbd12管脚配置pdiusbd12的管脚排列如图3.1所示: 图3.1pdiusbd12管脚排列图3.2.3单片机与pdiusbd12的连接单片机与pdiusbd12的连接如图3.2所示:对上图中的电路说明如下:1、电路中使用a0作为命令数据选择位2、端点2使用批量传输(bulk),所以dmack_n和eot_n接上拉电阻,否则,pdiusbd12将不能接受任何数据;3、单片机外接晶振,所以pdiusbd12的clkout脚空;4、从图上可以看出,当选择命

51、令时,pdiusbd12的地址为0xf1ff;当选择数据时pdiusbd12的地址为0xf0ff;5、单片机使用p0口进行输入输出,由于p0是开漏的,所以,需要接上拉电阻,在电路中使用排阻;6、gl_n通过一个电阻和led串接到vcc,在usb设备枚举期间,灯一直闪烁,当usb设备枚举成功后,灯会灭,安装完驱动程序后,灯一直亮着,传送数据期间,灯会闪烁;图3.2 pdiusbd12与单片机连接图7、usb_d+,usb_d-线上的1m上拉电阻下拉电阻对实际没有什么影响,它们主要在噪声比较大的情况下,起到抗干扰的作用;8、采用总线供电,总开关s1负责电源的连接与断开,led指示整个电路是否有电。

52、在这种方式下,确保电路的正确连接很重要,否则,容易损坏计算机4。在使用的同时,应注意一个问题。由于philips公司生产的pdiusbd12芯片自身存在一个小小的问题,即当片选没有选中时它的第14角仍然会输出低电平的中断信号,由于它接单片机的p3.3,所以与矩阵键盘共用的p3.3口有冲突,使用pdiusbd12芯片时请将该芯片左边的int1两线柱短接。在不使用该芯片时不用接。3.3系统硬件设计3.3.1单片机电路设计单片机最小系统主要包括其供电系统,时钟电路和复位电路。本次单片机的系统供电电路和时钟电路都做了简化处理,单片机的系统复位电路采用手动复位。单片机电路如图3.4所示。对电路说明如下:

53、1、单片机采用外接晶振的方法,是外接晶振,频率为11.0592mhz;2、复位电路采用按键复位;3、pdiusbd12使用单片机的外部中断0。在程序里将单片机和pdiusbd12设置为相同的中断方式,即电平中断。然后由pdiusbd12自动清除中断脚上的低电平,以便接受下次中断8。3.3.2外围电路设计本次课题的外围硬硬件系统资源包括:串口通信、6位动态数码显示、8位流水灯、蜂鸣器、4*4矩阵键盘、温度传感器、液晶显示器接口、pdiusbd12芯片接口等。每个元件与单片机都有单独的电路连接,他们均以单片机为控制核心。使单片机能独立的控制每个元件的正常工作。再通过pdiusbd12芯片,usb接

54、口,上位机能与单片机实现通信,上位机发送信息到单片机,单片机根据上位机信息控制外围电路的工作;外围设备发送信息到单片机,单片机反馈到上位机,在上位机的控制界面上显示状态信息。其整体框图如图3.5所示。根据整体框图,将每个分块电路设计成整体电路原理图,生成pcb图(见附录)。整个电路图的设计是在protel 99的软件环境下完成的。图3.4 单片机电路上位机usb接口pdiusbd128051单片机4*4矩阵键盘串口通信蜂鸣器8位流水灯液晶显示器6位动态数码显示温度传感器图3.5整体框图3.4本章小结本章介绍了单片机,pdiusbd12芯片的基础知识,根据课题需求,重点讨论了pdiusbd12芯片在批量传输时与单片机的接法。外围硬件资源根据框图设计出实验电路图,这些电路是做出单片机实验板,上位机软件能够正确运行的基础。 第4章程序设计及调试4.1概述4.1.1集成开发环境keil简介单片机开发中出必要的硬件外,同样离不开软件,我们写的汇编语言源程序要边成cpu可以执行的机器码有两种方法,一中是手工汇编,另一种是机器汇编,目前已经极少使用汇编的方法了。机器汇编是通过汇编软件将源程序变成机器码,用于mcs-51单片机的汇编

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论