DWC USB2.0协议学习1--产品概述

news2024/10/7 20:29:42

本章开始学习记录DWC_otg控制器(新思USB2.0)的特点、功能和应用。

新思USB 2.0 IP主要有两个文档需要参考:

《DesignWare Cores USB 2.0 Hi-Speed On-TheGo (OTG) Data book》

《DesignWare Cores USB 2.0 Hi-Speed On-TheGo (OTG) Programming Guide》

前者是描述IP的架构信号、配置寄存器等,后者是编程指导驱动编写主要参考这一部分进行。

1. 系统概述

首先是系统概述,站在系统层面来分析DWC_otg控制器,对DWC_otg控制器的功能做简单概述,典型的系统框架结构图如下图1-1所示,其中浅蓝色部分是根据配置决定,黑色部分是所有配置都有的。

1.1 AHB总线接口

上图1-1左边部分是AHB总线接口,这一部分主要是实现CPU和DWC_otg控制器信息交互功能。

AHB Slave I/F:AHB slave接口,此时DWC_otg控制器是从设备,CPU通过该接口对DWC_otg的控制和状态寄存器(CSR)、数据FIFO和队列进行读写访问。

AHB Master I/F(可选的):AHB master接口,对应DMA部分描述,使能DMA时,DMA是主设备,负责在系统的memory和内部的RAM之间搬运数据。

1.2 Data RAM接口

Data FIFO RAM/IF上图1-1下面部分是Data RAM接口,连接一个外部单端口FIFO RAM(SPRAM)用于数据存储

1.3 PHY 接口

DWC_otg控制器支持3种PHY接口,如上图1-1右边部分所示:

(1)UTMI+ Level 3 PHY 接口(Revision 1.0 or HSIC)

UTMI+PHY可以是单向或双向的,可以配置为8、16或8/16位数据总线(软件可配置)。UTMI+接口可以配置为与符合修订版1.0的PHY或符合HSIC的PHY一起工作。

(2)ULPI PHY 接口 (Revision 1.1)

ULPI PHY可以是单向或双向的,具有8位SDR或4位DDR总线(软件可配置)。

(3)USB 1.1全速串行收发器接口

USB 1.1全速串行收发器可以作为专用接口,也可以在芯片外部PHY的UTMI+或ULPI接口上共享引脚(软件可配)。

1.4 外部DMA控制器接口

当前DWC_otg控制器已经不支持外部DMA接口,不展开。

1.5 其他可选接口

  • AHB Master 接口(使能内部DMA时,DMA是主设备,负责发送和接收数据到AHB总线上)。
  • 供应商控制接口可以访问ULPI和UTMI+ PHY寄存器
  • I2C接口,用于USB 1.1 FS模式下的OTG控制
  • 通用I/O (GPIO)接口
  • SOF更新翻转接口(不用于DWC otg)
  • SOF输入计数接口(不用于DWC otg)
  • 设备和主机模式下支持Scatter/Gather DMA
  • 设备模式下支持多处理器中断

1.6 发送和接收FIFO

DWC_otg控制器上的发送和接收FIFO接口用于将数据移入和移出数据FIFO RAM。这些分为周期性(用于同步和中断传输)或非周期性(用于批量传输和控制传输),总结如下:

  • 非周期性主机OUT传输公用一个Tx FIFO。
  • 周期性主机OUT传输,可以选择一个独立周期传输FIFO。
  • 设备模式下IN端点可选公用非周期性Tx FIFO,和多个周期性TxFIFO
  • 用于周期性/非周期性设备IN传输的每个IN端点可选专用Tx FIFO
  • 主机模式中断OUT和设备模式中断IN(仅在Shared FIFO 操作模式)传输可以编程为通过非周期传输FIFO或周期传输FIFO。

2. 功能列表

2.1 一般功能

  • 支持OTG2.0和OTG1.3,软件可配.OTG2.0支持ADP (Attach detection Protocol)。
  • 支持3种速率:
  1. High-Speed (HS, 480-Mbps)
  2. Full-Speed (FS, 12-Mbps)
  3. Low-Speed (LS, 1.5-Mbps)。
  • 支持多种低功耗相关配置选项。
  • 支持DMA和非DMA操作方式。
  • MAC-Phy支持多种接口。
  • AHB和PHY接口支持使用不同的时钟,以简化集成。
  • 包括控制端0在内,一共最多支持16个双向端点。
  • DWC_otg作为设备使用时,UTMI+ PHY时不支持低速模式。
  • 最多支持16个主机通道。在主机模式下,当需要支持的设备的端点数量大于支持的主机通道数,软件可以重新编程通道来支持多达127个设备,每个设备有32个端点(IN + OUT),最多4064个端点。
  • Host Buffer DMA模式, Slave模式支持外部HUB连接。
  • 包括自动ping功能。
  • 支持低速模式下的Keep-Alive和高速/全速模式下的SOFs。

2.2 可配置功能

  • 可根据用户需求,使用coreConsultant utility配置控制器。
  • 能够为低功耗模式选择多个电源轨
  • 可选择多种DMA操作模式
  • 可根据需求,选择Mac-Phy接口类型

2.3 应用接口功能

  • AHB的应用程序接口:
  1. AHB从接口,用于访问控制和状态寄存器(CSRs)、数据FIFO和队列。
  2. 可选的AHB主接口,内部DMA使能时给Data FIFO访问使用。
  3. 特定配置下AHB时钟最高可达270MHz。
  • AHB总线上只支持32位数据。
  • 支持通过pin配置小端或者大端模式。
  • AHB从接口支持INCR4,INCR8,INCR16,INCR和SINGLE传输。
  • AHB主接口支持拆分、重试和错误AHB响应。AHB从机接口上不产生拆分和重试响应。
  • DMA模式AHB主接口支持软件配置AHB Burst类型。
  • 只能处理固定的burst address对齐,比如INCR16则地址的位[5:0]都要是0
  • 在AHB主接口上可生成AHB忙周期。
  • 可处理1KB的边界。

2.4 MAC-PHY接口特征

  • 支持以下MAC-PHY接口
  1. UTMI 8/16
  2. ULPI
  3. HSIC
  4. IC_USB (Low/Full速)
  5. FS 和UTMI共享
  • 支持UTMI+ Level 3 接口(Revision 1.0, February 25th, 2004). 8, 16, 和 8/16位数据总线。
  • 支持ULPI接口 (Revision 1.1rc, September 1st, 2004), 8-位 SDR, 4-bit DDR, 6-pin Serial, 3-pin Serial 和 Carkit。
  • UTMI+ L3 和 ULPI可同时存在,由软件选择,或者直接配置只使用一种。
  • 只有在选择了UTMI+的情况下,才能选择HSIC接口。否则无法选择HSIC接口
  • I2C接口。
  • 支持UTMI-to-UTMI Bridge。

2.5 系统Memory体系结构

  • 支持Slave,内部DMA 模式。
  • 使用内部DMA模式时还支持Descriptor-Based Scatter/Gather DMA。

2.6 Non-DWORD对齐支持

  • 主机模式:

     Scatter Gather DMA模式,IN和OUT传输,支持缓冲区的Non-DWORD对齐。

     Buffer DMA和Slave模式,IN和OUT传输,不支持缓冲区的Non-DWORD对齐。

  • 设备模式:

    Scatter Gather DMA模式,IN和OUT传输,支持缓冲区的Non-DWORD对齐。

    Buffer DMA和Slave模式,IN和OUT传输,不支持缓冲区的Non-DWORD对齐。

2.7 内部Memory特征

  • 在Slave和DMA模式,可以给设备的每个IN端点都配置一个专用的传输FIFO。每个FIFO可以保存多个包。
  • 包括可选的Remote Memory Support接口,用于向控制器发出DMA写入完成事件的信号。
  • 利用单端口RAM替代双端口RAM以减少面积和功耗。
  • 支持传输时动态修改端点FIFO的大小。
  • 支持端点FIFO可不是2的指数倍对齐,以利用连续的存储位置。
  • 在主机和设备模式下共享硬件寄存器,以减少门控数量。
  • 设备模式时如果启用DMA并选择专用的Tx FIFO,DMA收发阈值可配,阈值可以通过全局寄存器配置,为了支持配置阈值AHB时钟必须60MHz以上。

2.8 软件功能

为了减少门数和提供灵活性,一些功能由软件去实现:

  • 设备模式,软件协助硬件实现非周期IN时序(仅适用Shared FIFO操作)。
  • 软件处理USB命令(检测SETUP事务,并将其命令有效载荷转发给应用程序进行解析)。
  • 软件处理USB错误。

2.9 功耗优化

  • 有源时钟门控功能:允许控制器在USB和AHB通信的IDLE时段内关闭AHB和PHY时钟,来降低动态功耗。同样也可以在SPRAM未使用时关闭RAM的时钟输出。
  • 支持Link Power Management (LPM)。
  • 几个节能功能,包括两个用于高级电源管理的电源轨。可以根据自己的要求选择以下节能选项:
  1. 关闭时钟门控
  2. 部分断电
  3. 休眠
  • USB Suspend,LPM和Session-Off模式支持PHY时钟门控。
  • USB Suspend和Session-Off模式支持AHB时钟门控。
  • USB Suspend和 Session-Off模式支持部分掉电。
  • 层次结构支持多个电源轨,以便在挂起期间启用休眠功能。
  • 输入信号需要powered-off的块驱动到safe 0
  • Data FIFO RAM不使用时关闭片选。
  • Data FIFO RAM支持时钟门控。
  • 设备和主机模式都支持在USB Suspend,LPM和Session-Off 模式时切换到32-KHz低频时钟。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1862026.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数值分析笔记(三)函数逼近

最佳平方逼近 函数逼近是使用一种简单易算的函数来近似表示一个复杂函数。 该问题可转化为求解线性方程组 G n C F n ​ G_{n}CF_{n}​ Gn​CFn​​ 其中,系数 C ( c 0 , c 1 , ⋯ , c n ) T , F n ( ( f , φ 0 ) , ( f , φ 1 ) , ⋯ , ( f , φ n ) ) T C(c…

私域电商的新篇章:构建深度连接与高效生态

大家好,我是电商领域的探索者,今天我想和大家分享关于私域电商的一些心得与洞见。在这个数字化飞速发展的时代,如何构建与用户之间更为紧密、深入的连接,以及如何通过私域生态来挖掘用户的更大价值,成为了我们关注的焦…

Studio One 6.6.2中文破解版安装图文激活教程

Studio One 6.6.2中文破解版做为新生代音乐工作站,凭借更低的价格和完备的功能,获得了音乐人和直播行业工作者的青睐,尤其是对硬件声卡的适配支持更好,特别适合用来配合线上教学和电商带货。 最近网上出现不少关于StudioOne不能用…

springboot民宿信息管理系统-计算机毕业设计源码08818

摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对民宿信息管理系统等问题,对民宿…

Nuxt3 的生命周期和钩子函数(一)

title: Nuxt3 的生命周期和钩子函数(一) date: 2024/6/25 updated: 2024/6/25 author: cmdragon excerpt: 摘要:本文是关于Nuxt3的系列文章之一,主要探讨Nuxt3的生命周期和钩子函数,引导读者深入了解其在前端开发中…

Windows server 由于没有远程桌面授权服务器可以提供许可证,远程会话连接已断开。

问题现象: 解决办法 临时远程方式1: 打开 mstsc 时带上 /admin 等参数,如下图所示: 使用“mstsc /admin /v:目标ip”来强制登录服务器,但只能是管理员身份。 远程方式2: 通过VM远程登陆系统后,运行输入R…

如何将本地的Django项目部署到阿里云服务器上?

场景:在本地的pycharm上已经写好了一个Django架构的网站,现在要把它放到公网上 一、阿里云服务器 选择云服务器ECS,新用户可以免费使用三个月 购买时选择预装宝塔面板 买好后,进入云服务器控制台 重置实例密码 远程连接至服务…

【ACM出版】第13届亚洲膜计算会议(ACMC2024)暨 2024年机器学习、模式识别与自动化工程国际学术会议(MLPRAE 2024,8月7日-9)

第13届亚洲膜计算会议(ACMC2024)暨2024年机器学习、模式识别与自动化工程国际学术会议(MLPRAE 2024) 将于2024年8月7日-9日在新加坡举行。它致力于为机器学习、模式识别与自动化工程领域的专家和学者之间的学术交流创造一个平台。 会议的理念是让来自世…

JVM专题十:JVM中的垃圾回收机制

在JVM专题九:JVM分代知识点梳理中,我们主要介绍了JVM为什么采用分代算法,以及相关的概念,本篇我们将详细拆分各个算法。 垃圾回收的概念 垃圾回收(Garbage Collection,GC)确实是计算机编程中的…

视频录制软件哪个好用?5款简单好用软件推荐

在我们的日常生活中,都有哪些好用的视频录制软件?在很多场合中我们都会用电脑记录下重要的时刻。比如,在电脑上听老师讲解一道难题的方法时,怕自己会忘记,想要录制下来进行重复的观看。这时,选择一款好用的…

震惊!CURRENT_TIMESTAMP不能乱用

事情发生在签到和查询签到记录. 设置mysql时间默认值为CURRENT_TIMESTAMP可以随系统生成默认时间戳,即生成该数据的时间戳, 但是有些特殊场景要避免由mysql给我们生成默认时间: 1、首先签到成功之后返回给前端, 2、前端收到执行成功之后立马去查询签到记录, 3、发现并没有…

【软件工具】Xshell安装教程

1、安装软件:Xshell-5.0.1337p.exe,双击安装即可,可以选择安装到D盘; 2、在D盘安装完成后,将文件nslicense.dll拷贝到对应的安装目录下; 3、打开快捷方式即可打开应用软件。

“代码规范”这样做【高级前端必备软技能之一】

✨在前端开发领域,良好的代码规范是团队协作、项目可维护性的基石。最近在梳理我们团队关于代码规范相关的一些文档,顺便给大家分享一下我们是从哪些方面入手来从一个草台班子,到开发规范的高效团队。 ✨本文旨在提供一份详尽的前端代码规范指…

Linux的免交互

交互:我们发出指令控制程序的运行,程序在接收到指令之后按照指令的效果做出对应的反应。 免交互:间接的通过第三方的方式把指令传送给程序,不用直接的下达指令。 1、here document免交互 ere document免交互:是命令…

Studying-代码随想录训练营day20| 235.二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作、450.删除二叉搜索树中的节点

第二十天,二叉树part07,二叉树搜索树加油加油💪 目录 235.二叉搜索树的最近公共祖先 701.二叉搜索树中的插入操作 450.删除二叉搜索树中的节点 拓展:普通二叉树的删除方式 总结 235.二叉搜索树的最近公共祖先 文档讲解&…

在FlowUs息流,让知识库为你所用|如何打造个人知识库|如何打造企业知识库

🎉 在 FlowUs 的世界中,知识绽放出无限的可能!🚀 在当今信息爆炸的时代,知识的更新换代速度极快,我们每天都面临着海量的信息冲击。拥有一个属于自己的知识库变得至关重要。 首先,打造自己的知…

Linux_应用篇(27) CMake 入门与进阶

在前面章节内容中,我们编写了很多示例程序,但这些示例程序都只有一个.c 源文件,非常简单。 所以,编译这些示例代码其实都非常简单,直接使用 GCC 编译器编译即可,连 Makefile 都不需要。但是,在实…

解决IMX6ULL GPIO扩展板PWM7/8中的pwm0/period后卡死问题

前言 本篇文章主要是记录解决百问网论坛上面设置 IMX6ULL GPIO扩展板PWM7/8中的pwm0/period后卡死问题,如下图: 一、查看原理图,找出对应引脚 在这里我们如何确定哪个扩展口中的引脚输出PWM波呢?我们可以通过查看原理图。 查看…

【Java】解决Java报错:IllegalMonitorStateException in Synchronization

文章目录 引言一、IllegalMonitorStateException的定义与概述1. 什么是IllegalMonitorStateException?2. IllegalMonitorStateException的常见触发场景3. 示例代码 二、解决方案1. 确保在同步代码块或方法中调用wait()、notify()和notifyAll()2. 使用同步方法3. 使用…

办公人导航-上网导航,找网站,下软件,找资源!

办公人导航是一个专门为办公人员设计的实用导航网站,旨在帮助用户高效地找到各种优质的办公资源和工具。无论是需要查找办公软件、学习资源还是娱乐工具,在办公人导航上都能找到你需要的内容。 办公人导航-实用的办公生活导航网站!https://ww…