关于DWC OTG2.0中PFC的理解

news2024/11/27 16:09:32

在DWC OTG2.0 Controller手册中,有一章节专门介绍了PFC,Packet FIFO Controller。其内部分为共享FIFO(shared FIFO)以及专用FIFO(Dedicated FIFO),并针对dev和host两种模式,并且还要对周期传输数据的FIFO和非周期数据传输的FIFO进行了不同的解读,还是挺复杂的。以下为总结。

复杂的原因无外乎要功耗低、要面积开销小。

首先,PFC模块针对的是收发数据的FIFO。当otg设置为host模式,仅有发送out数据的时候才能使用它,这里的host out数据包括四种传输形式的传输:bulk out、control out、intr out以及isoc out传输。当otg设置为dev模式时,dev模式永远是个被动的模式,只有主机发起IN操作时,例如bulk in,dev才会将数据搬到FIFO中发送出去(当主机发起out操作时,dev只是接收)。

这些FIFO都是store-and-forward,即发送数据前必须保证所有数据已经在FIFO里了,MAC层才会去取数据。不能边存边取。有一种情况比较特殊,对于专用FIFO手册里说对于高带宽的周期IN端点,在保证FIFO中至少有一个包的数据时,可以发送数据,此时可以边发送第一个数据包,边存储第二个数据包,可以不完全等待数据全部存完再发送。这里说的”高带宽的周期IN端点“,没有具体说明是什么,但根据下图中TxFNum的定义可知,可以将intr in端点作为大容量


 其次,对周期传输数据的FIFO,也就是intr和isoc传输,其dev和host下为:

dev:

对于shared FIFO,每个周期端点都会有一个FIFO,并且其在生成RTL的时候已经确定好了(也就是在新思的coreConsult中进行配置,具体参数为OTG_NUM_PERIO_EPS。注意,这个参数只在shared FIFO中使用,当使用专用FIFO时,即OTG_EN_DED_TX_FIFO=1时,这个参数无效,为0)。当使用shared FIFO发送数据时,具体使用多少个,取决于每个端点的TxFNum参数。例如,当端点1有很多数据要发送,则可以在编程的时候,对DIEPCTL1.TxFNum进行设置。本来一个周期IN端点对应一个FIFO,但是端点1把其它周期IN端点的FIFO也给用了,这应该就是shared FIFO的含义。

 另外需注意,dev模式下第一个周期FIFO复用了host模式下的周期FIFO。下图为shared FIFO的示意图。

对于Dedicated FIFO,在dev模式下,FIFO的数量取决于参数OTG_NUM_IN_EPS,该参数说明最大的专用FIFO数量是多少个。在专用FIFO模式下,没有周期FIFO和非周期FIFO之分,使能的in端点对应一个指定的FIFO,且需要在编程的时候设置FIFO深度(当时看例程的时候没看懂,现在知道为什么要设置了,但是不知道设置多少深度合适)。

下图为专用FIFO示意图。

 另外需注意,dev模式下与host的FIFO也有复用的情况。

host:

对于host来说,shared FIFO情况较为简单,只需要一个周期FIFO,便可以存储所有收发给周期端点的数据。且该FIFO只需配置一个周期request队列。

手册中没写host的dedicated FIFO。


再次,对非周期传输数据的FIFO,也就是control和bulk传输,其dev和host下为:

对于shared FIFO来说,dev和host用一个非周期FIFO来存取数据,FIFO旁挂在一个request队列。

对于dedicated FIFO来说,host模式下与shared FIFO一致;在dev模式下,无周期和非周期之分,FIFO的数量取决于参数OTG_NUM_IN_EPS,使能的in端点对应一个指定的FIFO。


最后,对于接收FIFO,一个接收FIFO存储所有的dev out端点的数据,或者存储所有的host in传输的数据。

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

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

相关文章

IT行业软件数据文件传输安全与高效是如何保障的?

在当今迅速发展的科技世界中,云计算、大数据、移动互联网等信息技术正迎来蓬勃发展,IT行业正置身于一个全新的世界。数据不仅是最重要的资产,也是企业竞争力的核心所在。然而,如何缩短信息共享时间、高速流转数据、跨部门/跨区域协…

智能优化算法应用:基于鹰栖息算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于鹰栖息算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于鹰栖息算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.鹰栖息算法4.实验参数设定5.算法结果6.参考文献7.…

Linux--文件权限与shell外壳的理解

目录 一.Linux的用户与用户切换,提权 二.对文件权限的理解 1.文件权限角色的权限文件属性 2.Linux中的三种角色 3.为什么会存在所属组这个角色 4.文件属性的意义 4.1.第一个字母的意义 4.2 第2——第10个字母的意义 4.3修改文件权限的方法 三.目录权限 四…

记录 | linux手动清理 buff/cache

linux下手动清理 buff/cache 切换到 root 权限 # 这个drop_caches文件可以设置的值分别为1、2、3 echo 1 > /proc/sys/vm/drop_caches # 表示清除pagecache echo 2 > /proc/sys/vm/drop_caches # 表示清除回收slab分配器中的对象(包括目录项缓存和inode缓…

idea报错——Access denied for user ‘root‘@‘localhost‘ (using password: YES)

项目场景: 使用idea启动SpringBoot项目报错,可以根据提示看到是数据库的原因,显示使用了密码,具体报错信息如下: 解决方案: 第一步:先去配置文件里面查看连接MySQL的url是否正确,如果…

代码随想录算法训练营第四十二天 _ 动态规划_01背包问题、416.分割等和子集。

学习目标: 动态规划五部曲: ① 确定dp[i]的含义 ② 求递推公式 ③ dp数组如何初始化 ④ 确定遍历顺序 ⑤ 打印递归数组 ---- 调试 引用自代码随想录! 60天训练营打卡计划! 学习内容: 二维数组处理01背包问题 听起来…

Node.js快速搭建简单的HTTP服务器并发布公网远程访问

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

基于ssm校园美食交流系统论文

目 录 摘 要 1 前 言 3 第1章 概述 4 1.1 研究背景 4 1.2 研究目的 4 1.3 研究内容 4 第二章 开发技术介绍 5 2.1Java技术 6 2.2 Mysql数据库 6 2.3 B/S结构 7 2.4 SSM框架 8 第三章 系统分析 9 3.1 可行性分析 9 3.1.1 技术可行性 9 3.1.2 经济可行性 10 3.1.3 操作可行性 10…

CentOS 7.9 安装 k8s(详细教程)

文章目录 安装步骤安装前准备事项安装docker准备环境安装kubelet、kubeadm、kubectl初始化master节点安装网络插件calicowork 加入集群 k8s集群测试 安装步骤 安装前准备事项 一台或多台机器,操作系统 CentOS7.x-86_x64硬件配置:2GB或更多RAM&#xff0…

order排序方式研究

请直接看原文: 链接:https://juejin.cn/post/7258182427306197051 --------------------------------------------------------------------------------------------------------------------------------- 一.前言 在MySQL世界中,排序是一个常见而重…

了解linux网络时间服务器

本章主要介绍网络时间服务器。 使用chrony配置时间服务器 配置chrony客户端向服务器同步时间 20.1 时间同步的必要性 些服务对时间要求非常严格,例如,图20-1所示的由三台服务器搭建的ceph集群。 这三台服务器的时间必须保持一致,如果不一致…

10 单词接龙

题目描述 单词接龙的规则是: 可用于接龙的单词首字母必须要前一个单词的尾字母相同; 当存在多个首字母相同的单词时,取长度最长的单词,如果长度也相等,则取字典序最小的单词;已经参与接龙的单词不能重复使用。 现给定一组全部由小写字母组成…

【开发技能】-解决visio交叉线(跨线)交叉点弯曲问题

问题 平时工作中使用visio作图时,经常会遇到交叉线在相交时会形成一个弯曲弓形,这十分影响视图效果。可以采用下面的方法消除弓形。 方法 第一步:菜单栏--设计---连接线 第二步:选中这条交叉线---点击显示跨线 最终问题得到解决…

C#图像处理OpenCV开发指南(CVStar,09)——边缘识别之Scharr算法的实例代码

1 边缘识别之Scharr算法 算法文章很多,不再论述。 1.1 函数原型 void Cv2.Scharr(src,dst,ddepth,dx,dy,scale,delta,borderType) 1.2 参数说明 src 代表原始图像。dst 代表目标图像。ddepth 代表输出图像的深度。CV_16Sdx 代表x方向上的求导阶数…

23款奔驰E350eL升级小柏林音响 13个扬声器 590w

小柏林之声音响是13个喇叭1个功放,功率是590W,对应普通音响来说,已经是上等了。像著名的哈曼卡顿音响,还是丹拿音响,或者是BOSE音响,论地位,论音质柏林之声也是名列前茅。 升级小柏林音响&#…

java多人聊天

服务端 package 多人聊天;import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.io.PrintStream; import java.net.ServerSocket; import java.net.Socket; import java.util.ArrayList;…

qt 5.15.2 主窗体菜单工具栏树控件功能

qt 5.15.2 主窗体菜单工具栏树控件功能 显示主窗体效果&#xff1a; mainwindow.h文件内容&#xff1a; #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QFileDialog> #include <QString> #include <QMessageBox>#inc…

深入理解Sentinel系列-2.Sentinel原理及核心源码分析

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱吃芝士的土豆倪&#xff0c;24届校招生Java选手&#xff0c;很高兴认识大家&#x1f4d5;系列专栏&#xff1a;Spring源码、JUC源码、Kafka原理、分布式技术原理&#x1f525;如果感觉博主的文章还不错的话&#xff…

CAP理论详解

引言 随着分布式系统在现代应用中的广泛应用&#xff0c;工程师们不得不面对诸如数据一致性、可用性和分区容错性等问题。CAP定理作为分布式系统设计的基石之一&#xff0c;为我们提供了在这些问题之间做出权衡的理论依据。本文将深入探讨CAP定理的技术细节、先进性&#xff0…

深度学习记录--广播(Broadcasting)

什么是广播&#xff1f; 广播(Broadcasting)&#xff0c;在python中是一种矩阵初等运算的手段&#xff0c;用于将一个常数扩展成一个矩阵&#xff0c;使得运算可行 广播的作用 比如&#xff1a; 一个1*n的矩阵要和常数b相加&#xff0c;广播使得常数b扩展成一个1*n的矩阵 …