当前位置:首页 > 单片机 > 单片机
[导读] PIC18FX455/X550 系列器件包含全速和低速兼容的USB串行接口引擎(Serial Interface Engine,SIE),它允许在任何USB主机和PIC单片机之间进行高速通信。 可以利用内部收发器或通过外部收发器将SIE 直接连接到USB。内

PIC18FX455/X550 系列器件包含全速和低速兼容的USB串行接口引擎(Serial Interface Engine,SIE),它允许在任何USB主机和PIC单片机之间进行高速通信。 可以利用内部收发器或通过外部收发器将SIE 直接连接到USB。内部的3.3V稳压器也可以在5V的应用中被用作内部收发器的电源。

USB模块还包含了某些特殊硬件以提高其工作性能。在器件的数据存储空间(USB RAM)中提供了双端口存储器,以便单片机和 SIE 之间可以直接进行存储器访问。 此外,还提供了缓冲器描述符,允许用户任意设置USB RAM 空间中供端点使用的存储区。 此外还提供了并行通信端口以方便大量数据的不间断传输,比如将数据等时传送到外部存储器缓冲器。

USB 状态和控制

? USB控制寄存器(UCON ):用于控制模块在传输过程中的操作, 此寄存器包含控制行为的配置位。USBEN,将此位置1 前还是需要预先对模块进行全面的配置。PKTDIS位,当接受到SETUP令牌时,此位被SIE置1,以允许处理SETUP。单片机不能将此位置1,只能将此位清零,以允许SIE继续发送和或接收。RESUME位,允许外设通过执行恢复信令来进行远程唤醒。 要进行有效的远程唤醒,固件必须将RESUME位置1 并保持此状态10 ms ,然后将此位清零。SUSPND 位将模块和支持电路(即稳压器)置于低功耗模式。SIE 的输入时钟也被禁止。响应IDLEIF 中断时,该位必须由软件置位。 在产生ACTVIF 中断之后,由固件将此位复位。 当此位有效时,设备与与总线处于连接状态,但是收发器输出处于空闲状态。 VUSB引脚上的电压根据此位值的不同而变化。在 IDLEIF 请求之前将此位置1,将导致不可预料的总线行为。

? USB配置寄存器(UCFG ):在通过 USB通信之前,必须对与模块相关的内部和 / 或外部硬件进行配置。 大部分配置是使用UCFG 寄存器独立的。USB稳压器也是通过此配置寄存器控制的。UFCG 寄存器中的控制位可用于控制USB模块的绝大部分系统级行为,包括:? 总线速度(全速和低速)? 片上上拉电阻使能? 片上收发器使能 ? 乒乓缓冲器的使用。

内部收发器,USB外设有一个内置的USB 2.0 全速和低速兼容的收发器,在USB内部与SIE 相连。 此功能部件在低成本的单芯片应用中很有用。UTRDIS 位控制收发器,它在默认情况下是使能的(UTRDIS=0)。FSEN 位控制收发器的速度,将此位置1将使能全速工作模式。片上USB上拉电阻由UPUEN 位控制。

外部收发器,此模块为片外收发器提供支持。 在因为物理条件限制而要求收发器远离SIE 的应用中要用到片外收发器。例如,需要与USB电气隔离的应用可以通过某些隔离元件将外部收发器连接到单片机的SIE。通过将UTRDIS 位置1 可以使能外部收发器。模块中有6 条信号线用来与外部收发器进行通信并控制外部收发器:

? VM :单端D-线路输入 (VM 和VP 信号将串行总线上不能用RCV 信号捕捉的情况报告给SIE。这些信号的组合状态和它们的说明在表17-1 和表17-2中列出。)

? VP: 单端D+线路输入
? RCV:差分接收器输入 (RCV信号是由外部收发器输出到SIE 的,它表示将串行总线上的差分信号转换为一串单脉冲序列)

? VMO:差分线路驱动器输出 (VPO和VMO信号是由SIE 输出到外部收发器的)
? VPO:差分线路驱动器输出
? OE : 输出使能


? USB传输状态寄存器(USTAT):USB 状态寄存器报告SIE 中的事务状态。 当SIE 发出USB传输完成中断信号时,应该读USTAT以确定传输的状态。 USTAT 包含传输端点编号、传输方向和乒乓缓冲器指针值(如果使用的话)。当SIE使用缓冲器读写数据结束后,它将更新USTAT寄存器。 如果在为事务完成中断提供服务之前进行了另一次USB传输,SIE 将把下一次传输的状态保存到状态FIFO中。


? USB设备地址寄存器(UADDR):USB地址寄存器包含唯一的USB地址,当此地址有效时,可被外设识别。 当接收到由URSTIF 表示的USB复位信号,或接收到来自单片机的复位信息时,UADDR 复位为00h。单片机必须在USB启动阶段(枚举)写入USB地址,该操作受Microchip USB固件支持。

? 帧编号寄存器(UFRMH:UFRML):帧编号寄存器包含 11 位帧编号。低字节被保存在UFRML中,而高3 位则被保存在UFRMH 中。 不管是否接收到SOF令牌,都用当前帧编号更新该寄存器对。对于单片机而言,这些寄存器是只读的。帧编号寄存器主要用于同步传输。

? 端点使能寄存器0 到15(UEPn):

USB 端点控制:16个可用的双向端点中的每一个都有自己独立的控制寄存器UEPn(其中n 表示端点编号)。每个寄存器相应控制位的功能都是相同的。EPHSHK位控制端点握手,将此位置1将使能USB握手。 通常,除使用同步端点以外,此位总是置1 的。EPCONDIS位用于使能或禁止通过端点进行的USB控制操作(SETUP)。清零此位将使能SETUP 事务;注意必须将相应的EPINEN和EPOUTEN 位置1 以使能IN和OUT事务。 因为USB规范中端点0是默认控制端点,所以对于端点0 ,此位将总是被清零的。EPOUTEN 位用于使能或禁止主机的USBOUT事务。 将此位置1 则使能OUT事务。 同样,EPINEN 位将使能或禁止主机的 USB IN事务。EPSTALL 位用于指示端点的 STALL 状态。如果一个特殊的端点发出了一个STALL ,那么SIE 将把这对端点的EPSTALL位置1。 此位将保持置1 直到由固件清零或SIE 复位。

USB RAM:USB数据通过称为USB RAM的存储空间在单片机内核和SIE之间传送。 USB RAM 是一个特殊的双端口存储器,被映射到普通数据存储空间的Bank 4到Bank 7(400h到7FFh),总容量为 1KB。Bank 4 (400h到4FFh)专用于端点缓冲控制,而Bank 5到Bank7 可用于USB数据。根据所使用的缓冲类型,除了Bank 4的8 个字节之外,所有字节都可用作USB缓冲器空间。虽然USB RAM 可用作单片机的数据存储器,但由SIE访问的区域不能被单片机访问。这里采用了一种信号机制来确定任意给定时间内对专用缓冲器的访问。

帧:总线上的通信信息被划分为多个1ms的时隙,称为帧。每帧都包含多个设备和端点的多种事务。

USB规范中定义了四种传输类型:

?同步:这种传输类型可确保及时传递大量数据(最大为1023字节),但是不能保证数据的完整性。 它适用于丢失少量数据无关紧要的通信应用,比如音频数据。

? 批量:这种传输类型允许在传输大量数据的同时确保数据的完整性,但是传输时限不能保证。
? 中断:这种传输类型可以确保及时传输少量数据,并确保数据的完整性。
? 控制:这种类型提供设备启动控制。全速设备支持所有传输类型,而低速设备只能使用中断和控制传输方式。

缓冲器描述符和缓冲器描述符表

Bank 4 中的寄存器组成称为“缓冲器描述符表”(Buffer Descriptor Table,BDT)的结构,专门用于控制端点缓冲器。 这为用户构建和控制各种长度和配置的端点缓冲器提供了灵活的方法。BDT 由缓冲描述符(Buffer Descriptor,BD)组成,它用于定义和控制USB RAM 空间中的实际缓冲器。 每个BD由四个寄存器组成,其中 n 代表64个可能的BD中的一个(范围是0 到63):

      ? BDnSTAT: BD 状态寄存器
      ? BDnCNT : BD 字节计数寄存器
      ? BDnADRL :BD低地址寄存器
      ? BDnADRH :BD高地址寄存器

BD 在序列中总是以一个四字节的数据块BDnSTAT:BDnCNT:BDnADRL:BDnADRH)出现, BDnSTAT的地址总是一个相对于400h的偏移量4n(以十六进制数表示),其中 n 是缓冲器描述符编号。根据所使用的缓冲配置(第17.4.4 节“乒乓缓冲”),最多可以有32、33或64组缓冲器描述符。 BDT 至少要8 字节长,因为USB规范规定,每个设备必须具有初始启动所需的输入和输出端点0。 根据端点和缓冲配置,BDT 可以有256 个字节。

虽然可以被看作特殊功能控制寄存器,缓冲器描述符的状态和地址寄存器并不是硬件映射的,这与 Bank 15 中的传统单片机SFR不同。 如果与特定BD对应的端点未被使能,则该端点的寄存器将不被使用。它表现为可用的RAM 空间,而不是未实现的地址。只能通过将UEPn<1>位置1 使能端点,才能将这些地址作为BD寄存器使用。 如同数据存储区的任何单元一样,BD寄存器的值在器件复位时都会是不确定的。

图17-6 所示为一个BD的示例,该 BD用于从500h开始的40字节缓冲器。 如果已经使用UEPn 寄存器使能了对应的端点,就只有特定的BD寄存器组有效。 USBRAM中所有BD寄存器都可用。 在使能端点之前应该设置好每个端点的BD。

BD状态和配置:缓冲器描述符不仅仅定义端点缓冲器的大小,还决定了它的配置和控制。 大部分配置都是通过BD状态寄存器BDnSTAT完成的。 每个BD都有与自己一一对应的、带编号的BDnSTAT寄存器。和其他控制寄存器不同,BDnSTAT 寄存器内的位的设置与具体应用息息相关。 有两种不同的配置,决定特定时间修改BD和缓冲区的是单片机还是USB模块。 只有一个位是这两种配置共享的。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

该系列产品有助于嵌入式设计人员在更广泛的系统中轻松实现USB功能

关键字: 单片机 嵌入式设计 USB

在这篇文章中,小编将对usb的相关内容和情况加以介绍以帮助大家增进对它的了解程度,和小编一起来阅读以下内容吧。

关键字: USB USB隔离诊断

今天,小编将在这篇文章中为大家带来Type-C接口的有关报道,通过阅读这篇文章,大家可以对Type-C接口具备清晰的认识,主要内容如下。

关键字: Type-C USB

一直以来,Type-C接口都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来Type-C接口的相关介绍,详细内容请看下文。

关键字: Type-C USB

随着科技的飞速发展和智能手机的普及,USB调试模式已成为许多科技爱好者和开发者不可或缺的工具。通过USB调试模式,用户可以连接手机与电脑,实现数据传输、应用安装、系统调试等多种功能。本文将深入探讨USB调试模式的打开方法...

关键字: USB 智能手机

USB 2.0与USB 3.0到底有什么不同,今天来深入探索两者之间的区别。随着科技的不断进步和设备的不断升级,USB接口作为连接设备的重要桥梁,也在不断发展。USB 2.0和USB 3.0是两种广泛使用的USB接口标准...

关键字: USB 智能手机 USB 3.0

随着科技的飞速发展,智能手机已成为我们日常生活中不可或缺的一部分。作为手机与电脑或其他设备之间的桥梁,USB(通用串行总线)连接在我们的日常生活中扮演着重要的角色。本文将深入探讨USB如何连接手机,并详细介绍USB连接手...

关键字: USB 智能手机

虽然 USB 几乎完全取代那些旧电缆和连接器,但 UART 绝对不会成为过去。您会发现许多 DIY 电子项目都使用 UART。

关键字: UART 串口通信 USB

USB(Universal Serial Bus)是一种通用的串行总线标准,它被广泛应用于连接计算机及其外部设备。USB通信系统具有以下特点:

关键字: USB 串行总线 计算机

USB Type-C接口将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对它的相关情况以及信息有所认识和了解,详细内容如下。

关键字: USB Type-C
关闭
关闭