当前位置:首页 > 单片机 > 单片机
[导读] 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模块。 只有一个位是这两种配置共享的。

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

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭