嵌入式系统实践实验报告--USB接口.docx

上传人:夺命阿水 文档编号:850483 上传时间:2023-12-27 格式:DOCX 页数:15 大小:73.20KB
返回 下载 相关 举报
嵌入式系统实践实验报告--USB接口.docx_第1页
第1页 / 共15页
嵌入式系统实践实验报告--USB接口.docx_第2页
第2页 / 共15页
嵌入式系统实践实验报告--USB接口.docx_第3页
第3页 / 共15页
嵌入式系统实践实验报告--USB接口.docx_第4页
第4页 / 共15页
嵌入式系统实践实验报告--USB接口.docx_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《嵌入式系统实践实验报告--USB接口.docx》由会员分享,可在线阅读,更多相关《嵌入式系统实践实验报告--USB接口.docx(15页珍藏版)》请在课桌文档上搜索。

1、计算机科学技术系上机实践报告课程名称:嵌入式系统实践年级:上机实践成绩:指导教师:姓名:创新实践成绩:上机实践名称:USB接口学号:上机实践日期:上机实践编号:No.10组号上机实践时间:一、实验目的1、了解USB接口基本原理;2、掌握通过USB接口与PC通讯的编程技术。二、实验设备a) 硬件:EmbestEduKit-III实验平台,EmbestARM标准/增强型仿真器套件,PC机。b) 软件:EmbestIDEProARM集成开发环境,Windows982000NTXPo三、实验内容编写USB通信程序,基于已有的USB驱动程序接口,完成与PC端的USB测试程序之间数据接收与发送四、实验原理

2、1. USB基础0定义通用串行总线协议USB(UniversalSerialBus)是由Intel、CompaqMicrosoft等公司联合提出的一种新的串行总线标准,主要用于PC机与外围设备的互联。1994年11月发布第一个草案,1996年2月发布第一个规范版本1.0,2000年4月发布高速模式版本2.0,对应的设备传输速度也从L5Mbs的低速和12Mbs的全速提高到如今的480Mbs的高速。其主要特点是:支持即插即用。允许外设在主机和其它外设工作时进行连接配置使用及移除。传输速度快。USB支持三种设备传输速率:低速设备1.5Mb/s、中速设备12Mb/s和高速设备480Mb/so连接方便。

3、USB可以通过串行连接或者使用集线器Hub连接127个USB设备,从而以一个串行通道取代PC上其他I/O端口如串行口、并行口等,使PC与外设之间的连接更容易。独立供电。USB接口提供了内置电源。低成本。USB使用一个4针插头作为标准插头,通过这个标准插头,采用菊花链形式可以把多达127个的USB外设连接起来,所有的外设通过协议来共享USB的带宽。S组成USB规范中将USB分为五个部分:控制器、控制器驱动程序、USB芯片驱动程序、USB设备以及针对不同USB设备的客户驱动程序。控制器(HoStController),主要负责执行由控制器驱动程序发出的命令,如位于PC主板的USB控制芯片。控制器驱

4、动程序(HoStControllerDriver),在控制器与USB设备之间建立通信信道,一般由操作系统或控制器厂商提供。USB芯片驱动程序(USBDriver),提供对USB芯片的支持,设备上的固件(Firmware)oUSB设备(USBDevice),包括与PC相连的USB外围设备。设备驱动程序(CIientDriverSoftware),驱动USB设备的程序,一般由USB设备制造商提供。0传输方式针对设备对系统资源需求的不同,在USB规范中规定了四种不同的数据传输方式:同步传输(Isochronous),该方式用来联接需要连续传输数据,且对数据的正确性要求不高而对时间极为敏感的外部设备,

5、如麦克风、嗽叭以及电话等。同步传输方式以固定的传输速率,连续不断地在主机与USB设备之间传输数据,在传送数据发生错误时,USB并不处理这些错误,而是继续传送新的数据。同步传输方式的发送方和接收方都必须保证传输速率的匹配,不然会造成数据的丢失。中断传输(Interrupt),该方式用来传送数据量较小,但需要及时处理,以达到实时效果的设备,此方式主要用在偶然需要少量数据通信,但服务时间受限制的键盘、鼠标以及操纵杆等设备上。控制传输(Control),该方式用来处理主机到USB设备的数据传输,包括设备控制指令、设备状态查询及确认命令,当USB设备收到这些数据和命令后,将依据先进先出的原则处理到达的数

6、据。主要用于主机把命令传给设备、及设备把状态返回给主机。任何一个USB设备都必须支持一个与控制类型相对应的端点Oo批量传输(Bulk),该方式不能保证传输的速率,但可保证数据的可靠性,当出现错误时,会要求发送方重发。通常打印机、扫描仪和数字相机以这种方式与主机联接。0关键定义USB主机(HoSt)USB主机控制总线上所有的USB设备和所有集线器的数据通信过程,一个USB系统中只有一个USB主机,USB主机检测USB设备的连接和断开、管理主机和设备之间的标准控制管道、管理主机和设备之间的数据流、收集设备的状态和统计总线的活动、控制和管理主机控制器与设备之间的电气接口,每一亳秒产生一帧数据,同时对

7、总线上的错误进行管理和恢复。USB设备(Device)通过总线与USB主机相连的称为USB设备。USB设备接收USB总线上的所有数据包,根据数据包的地址域来判断是否接收;接收后通过响应USB主机的数据包与USB主机进行数据传输。端点(Endpoint)端点是位于USB设备中与USB主机进行通信的基本单元。每个设备允许有多个端点,主机只能通过端点与设备进行通讯,各个端点由设备地址和端点号确定在USB系统中唯一的地址。每个端点都包含一些属性:传输方式、总线访问频率、带宽、端点号、数据包的最大容量等。除控制端点0外的其他端点必须在设备配置后才能生效,控制端点0通常用于设备初始化参数。USB芯片中,每

8、个端点实际上就是一个一定大小的数据缓冲区。管道(Pipe)管道是USB设备和USB主机之间数据通信的逻辑通道,一个USB管道对应一个设备端点,各端点通过自己的管道与主机通信。所有设备都支持对应端点0的控制管道,通过控制管道主机可以获取USB设备的信息,包括:设备类型、电源管理、配置、端点描述等。2. USB设备开发USB设备开发包括硬件电路设计和软件设计二部分内容,其中软件部分又包括USB芯片驱动程序和应用程序二部分。USB设备在硬件上通过USB芯片实现,USB芯片负责:管理和实现USB物理层差分信号;通过配置和管理寄存器初始化设备。提供连接的端点;电源管理;通过寄存器管理端点;USB芯片驱动

9、程序基于以上硬件资源实现USB的功能。USB芯片提供多个标准的端点,每个端点都支持单一的总线传输方式。端点O支持控制传输,其他端点支持同步传输、批量传输或中断传输中的任意一种。管理和使用这些端点,实际上就是通过操作相应的控制寄存器、状态寄存器、中断寄存器和数据寄存器来实现。其中,控制寄存器用于设置端点的工作模式、启用端点的功能等;状态寄存器用于查询端点的当前状态;中断寄存器则用于设置端点的中断触发和响应功能;数据寄存器则是设备与主机交换数据用的缓冲区。S电路设计原理EmbestEduKit-ITIUSB接口模块采用美国国家半导体公司的USBN9603USB控制器,该控制器是全速USB节点器件,

10、完全兼容USBl.O,USBl.1通信规范。USBN9603/4-28M芯片引脚图如下:US _RD 丽SK _INTR _DRQ-daCk-A0ALESI DO/SO _Dl 一D2 一D3 D4 D5 D6 一227326425524623728-PI SO 2282192010191116121713161415-CLKOUT-XOUT-XlN _ MODEO一 MODE1一GNDVcc-GND 一D-D+V3.3一AGND RESET一D7USBN9603/4-28MUSBN9603与MCU的接口模式分为两种:团8位并行总线模式(ParaIIelInterface),使用并行总线方式时

11、又可选择复用(MUltiPIeXed)或非复用(NOnTUltiPIeXed)模式,其中地址/数据线的复用方式电路设计稍显复杂。0微总线模式(MICROWIREinterface)o以上模式的选择由管脚MODEO,MODEl决定。在使用复用的8位并行总线模式下,USBN9603支持与MCU之间的增强型DMA方式传输,使用DMA方式传输使MCU和USBN9603之间交换数据的速度成倍提高,最终可以显著提高PC与USB的通讯速度。USBN9603在EmbestEduKit-III评估板与CPU连接图如下:D(7.0)lID(7.0)A1AOUSBPORE3nOEre44B0XUSBN960;11R

12、ESETVvLL褊窃GXOUT1rEXINTOINTRri11Oc2-CSlcsXINEduKit-III的电路设计中采用的是非复用的8位并行总线模式,该模式中没有使用DMA方式,因此DACK接高电平。CPU通过译码器生成的片选信号CSl对USB控制器进行选通,USBN9603通过EXINTl对CPU发出中断请求。设备驱动程序设计USB读写EmbestEduKit-III的USB控制器USBN9603用户寄存器有两个,分别为只写的内部地址寄存器,与可读写的数据寄存器,内部地址寄存器的地址为0x02000002,数据寄存器地址为0x02000000o对USB控制器进行读操作(包括读USB内部寄存

13、器及数据)时,第一步是设置USB6bits宽的内部地址寄存器,指明将要从USB某个内部地址读一个字节,第二步是从数据寄存器读出8bits宽的数据。对USB进行写操作类似读操作,第一步同样是设置USB的内部地址寄存器,指明将要写一个字节数据到USB内部某个地址中去。USB中断EmbestEduKit-III的USB控制器中断请求引脚连接S3C44B0X外部中断引脚EXINTl,对应的中断向量为1,初始化USB中断的步骤是:使EINTl中断使能。安装USB中断服程序入口到中断向量中去。初始化IO端口G组控制器PCONG,PUPG指明EXINTl是作为中断输入引脚使用。设置外部中断寄存器EXTINT

14、,指明触发中断方式。初始化USB初始化USB需要使用USB读写函数对USB控制器内部的控制寄存器进行设置。需要设置的USB控制寄存器如下:首先,通过设置主控制寄存器MCNTRL软件复位位(SRST),复位USB控制器。设置主控制寄存器MCNTRL,电压调整位(VGE),及中断输出(INTOC)位,以禁止中断输出。写时钟寄存器CCONF,设置USB控制器工作频率。初始化功能地址寄存器FAR(FunctionAddressRegister),及EPCO寄存器(EndPoint0ControlRegister),端点号0为双向端点,作控制使用。设置中断掩码寄存器,有主掩码寄存器(MAMSK),无应答

15、事件寄存器(NAKMSK),发送事件寄存器(TXMSK),接收事件寄存器(RXMSK),Alternate事件寄存器(ALTMSK)。最后允许USB控制器中信号输出,使控制器附加到USB总线上。USB中断服务例程中断服务程序处理USB控制器产生的中断,它将数据从USB内部FIFO读出,并建立正确的事件标志,以通知主循环程序处理。基本步骤如下:从主事件寄存器(MAEV)读出产生中断的事件。根据主事件寄存器某位状态判别事件,接着读取相应的事件寄存器:接收事件寄存器(RXEV),或发送事件寄存器(TXEV),或无应答事件寄存器(NAKEV),或Alternate事件寄存器(ALTEV)o进一步判别事

16、件寄存器的某位状态,根据具体事件,分别做相应的操作。通道0(端点0)用于控制传输,在驱动程序中调用rxevent(),txcvcnt()处理端点0的事件。通道1中由Txeventl()处理端点1(单向发送)的事件,rxevent1()处理端点2(单向接收)的事件。通道2中由Txevent2()处理端点3(单向发送)的事件,rxevent2()处理端点4(单向接收)的事件。通道3中由Txevent3()处理端点5的事件,*XeVent3()处理端点6的事件。五、实验步骤1)拷贝光盘CDlSoftwareEduKit44b文件夹到EnlbeStlDEExamplesSamsung目录下;2)实验环

17、境准备。使用USB连接线连接EduKit-III的USB接口和PC主机的USB接口;通过Embest仿真器连接PC主机并行口和目标板JTAG接口。3)编译、链接、运行USB例程。使用EmbestIDE打开USB_TestUSB_Test.pjf工作区,直接编译链接输出可执行文件USBjreSt.elf,下载到EduKit-III上运行。4)安装USB设备驱动程序。运行USB例程后,Windows弹出发现新硬件的提示对话框,按照安装向导安装驱动程序EmbestEduKit-ITTUSBDriver,驱动程序安装文件位于USB_TestDriver目录。5)运行USB数据传送演示软件。运行位于US

18、BTest目录下demo,exe,出现如下窗口:6)发送和接收数据。在传送数据窗口里输入要发送的数据,点发送按钮,在接收数据窗口里,显示目标板USB控制器返回的数据。7)在PC机上观察超级终端程序主窗口,可以看到如下界面:bootsuccess.USBN9603TestExampleReceivedata.ReceiveOK.六、调试过程、结果和分析使用USB连接线连接USB接口和主机的USB接口,打开实验例程调试运行,出现安装USB驱动程序的提示对话框,按照安装向导安装,选择高级选项,再选择驱动程序安装文件的路径即可。之后运行demo.exe,在发送数据窗口编辑发送内容,发送,接收数据窗口即

19、显示USB传输内容,并与编辑发送的呢内容相同。七、总结本次实验无其他习题要求,按照教材例程一步步运行,观察实验结果,熟悉步骤,无须对程序进行改动,因此完成得非常顺利,也没有遇到特殊的问题。八、附件/* name:writeusb* func:writes9603controls/conditions/dataregister* para:addrregisteraddress* datdata*/voidwrite_usb(unsignedcharaddr,unsignedchardat)(volatileunsignedchar*)0x02000002)=addr;(volatileunsi

20、gnedchar*)0x02000000)=dat;)* name:readusb* func:reads9603controls/conditions/dataregister* para:addrregisteraddress* ret:dataunsignedcharreadusb(unsignedcharaddr)(*(volatileunsignedchar*)0x02000002)=addr;return(*(volatileunsignedchar*)0x02000000);* name:Isr_Init* func:Theseveranceinitialization,inst

21、allstheUSBseveranceservicefunctionvoidIsr_Init(void)(rINTMOD&=BIT_EINT1;/EINTlinterruptrINTMSK&=BIT_GLOBAL;/GLOBALvalidplSR_EINTl=(int)_Eintllsr;rPCONG=rPCONG(32);rPUPG=rPUPG&OxFD;rEXTINT=0x00;rINTMSK=rINTMSKBIT_EINT1;)/* name:Init_9603* func:theinitializationUSBN9603,initialization9603interiorregis

22、ters,attach9063toarriveonUSBHUB*/voidInit9603(void)StatUS_GETDESC=O;USb_Cfg=0;/giveasoftreset,thensetintstopushpull,activehiorIowrite.usb(MCNTRL,SRST);whiIe(read_usb(MCNTRL)&SRST);write_usb(MCNTRL,VGE+INT_H_P);/initializetheclockgeneratorwrite_usb(CCONF,C0DIS+0x0c);/setdefaultaddress,enableEPOonlywr

23、ite_usb(FAR,AD_EN+O);/FAR=FUNCTIONADDRESSREGISTERWrite_usb(EPeO,0x00);/setupinterruptmaskswrite_usb(NAKMSK,NAK_OO);/NAKevntswrite_usb(TXMSK,TXFIF00+TXFIF01+TXFIF02+TXFIF03);/TXeventswrite_usb(RXMSK,RXFIF00+RXFIF01+RXFIF02+RXFIF03);/RXeventswrite.usb(ALTMSK,SD3+RESET_A);/ALTevntswrite_usb(MMSK,INTR_E

24、+RXEV+NAK+TXEV+ALT);/enablethereceiverandgooperationalFLUSHTXO;/flushTXOanddisableWrite_usb(RXCo,RXEN);/enablethereceiverWritC_usb(NFSR,OPRST);/gooperationalWrite_USb(MCNTRL,VGE+INT_L_P+NAT);/setNODEATTACHdelay(100);)*name:EintOIsr* func:TheUSBinterruptserviceisr,processestheUSBseverance,disposesthe

25、equipment,transmitsthedatavoidEintOlsr(void)(rINTMSK=rINTMSKBIT.EINT0;rI_ISPC=BIT-EINTO;evnt=readusb(MAEV);/checktheeventsif(evnt&RX_EV)(evnt=readusb(RXEV);/checktheRXeventsif(evnt&RXFIFOO)rxevent();/endpoint0elseif(evnt&RXFIFOl)rxevent_l();/endpoint2elseif(evnt&RXFIF02)rxevent_2O;/endpoint4elseif(e

26、vntRXFIFO3)rxevent_3();/endpoint6)elseif(evnt&TX_EV)(evnt=readusb(TXEV);/checktheTXeventsif(evnt&TXFIFOO)txevent();/endpoint0elseif(evnt&TXFIF01)txevent_l();/endpoint1elseif(evnUTXFIF02)txevent2();/endpoint3elseif(evntTXFIFO3)txevent3();/endpoint5)elseif(evnt&ALT)usb_alt();/alternateevent?/NAKscanco

27、mesofastandfurious(especiallywithOHCIhosts)/thattheyMUSThavealowerprioritythantheotherevents.If/theydidnot,theothereventscouldgetstarvedout.elseif(evnt&NAK)(evnt=readusb(NAKEV);/checktheNAKeventsif(evnt&NAK_00)nak();elseif(evnt&NAKOl)onakl();elseif(evnt&NAK_02)onak2();elseif(evnt&NAK13)inak3();)rINT

28、MSK=rINTMSK&(BIT_EINTO);)* name:txevent_3* func:ThissubroutinehandlesTXeventsforFIF03(endpoint6)*/voidtxevent3(void)txstat=read_usb(TXS3);/gettransmitterstatusif(txstat&ACK_STAT)(/previousdatapacketfromcurrentepwasreceivedsuccessfullybyhostFLUSHTX3;)else(/thereisnoACKretransmitthepreviousdatapacketi

29、f(dtaPiCLTGL3PID)write_usb(TXC3,TX_TOGL+TX_LAST+TX_EN+RFF);elsewrite_usb(TXC3,TX_LAST+TXEN+RFF);dtapid_TGL3PID=!dtapid_TGL3PID;)/* name:rxevent_3* func:ThissubroutinehandlesRXeventsforFIFO3(endpoint5)*/voidrxevent_3(void)(U8i,bytes_count;rxstat=readusb(RXS3);/getreceiverstatusif(rxstat&SETUP_R)elsei

30、f(rxstat&RX_ERR)FLUSHRX3;/flushRX2anddisableWritejJSb(RXC3,RX_EN);/re-enablethereceiver)else(dobytes_count=read_usb(RXS3)0x0f;(volatileunsignedchar*)0x02000002)=RXD3;for(i=0;i64)(COMfront2=0;if(COMfront2=COMtail2)(COMtail2+;if(COMtail264)COMtail2=0;)whiIe(bytes_count=OxOf);FLUSHRX3;/flushRX2anddisablewrite_usb(RXC3,RX_EN);/re-enablethereceiver)

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 在线阅读 > 生活休闲


备案号:宁ICP备20000045号-1

经营许可证:宁B2-20210002

宁公网安备 64010402000986号