UG1085也提到,PS_MODE1/PS_MODE2也可以作为外部USB Phy的复位信号。 ? PG201也提到了外部USB Phy的复位信号的相关设置。 ? 2....Vivado工具 在Vivado里,可以指定外部USB Phy的复位信号的来源和极性。 ? 3. USB Phy的复位信号 USB Phy是否需要复位信号,由外部的Phy决定。...一般来说,单板复位后,建议把外部USB Phy复位一次,保证USB Phy处于干净的状态。...MPSoC既可以使用MIO管脚、也可以使用PS_MODE(BOOT_PIN)管脚来作为USB Phy的复位信号。 3.1. 使用MIO管脚作为USB Phy复位信号 MPSoC有两个USB控制器。...如果找到,会调用Linux的GPIO框架来复位外部USB Phy。 3.2.
输入端口中D为数据端口,SR为复位/置位端口,CE为使能端口。这里置位和复位共用一个端口,意味着触发器不能同时具有置位和复位功能。 ? 当配置为寄存器时,有四种形式,如下表所示。...可以看到复位和置位可以是同步也可以是异步,但建议采用同步(表中的名称称之为触发器的REF_NAME,打开综合后的设计在Property窗口中可看到) ?...这是因为异步复位/置位不受时钟控制,如果该信号出现毛刺会导致触发器误操作。...此外,异步复位的释放可能会因为线延迟的不同又加上不受时钟控制而出现在不同时刻,从而导致控制电路部分例如状态机运行到无效状态或者不期望的状态,如下图所示。 ?...从RTL代码角度来看,相应的同步复位与异步复位描述方式如下图所示。 ? ? 上期内容: 本周回顾--2018/03/23 下期内容: 高效使用触发器:触发器的初始值
一系列相互独立的端点在一起构成了USB逻辑设备,在系统结构中,位于下方红色方框内: 二、端点的分类 每个USB设备都有一个唯一的设备地址,设备地址是设备连接上主机时由主机分配的,主机主要依靠这个设备地址对...USB设备进行访问。...五、端点与管道 1、管道的概念 管道是主机软件(数据缓存区),和USB设备各各端点之间的数据传输连接,他是两者之间通信流的抽象(实际上数据传输是USB总线接口完成)。...1)、“流”指不具有USB定义格式的数据流,流通道中的数据是流的形式,也就是该数据内容不具有USB要求的结构。...2)、“消息”指具有某种USB定义格式的数据流。消息通道与端点的关系同流通道与端点的关系是不同的。
今天给大侠带来如何区分同步复位和异步复位?,话不多说,上货。 如何区分同步复位和异步复位?...可以理解为同步复位是作用于状态,然后通过状态来驱动电路复位的吗(这样理解的话,复位键作为激励拉高到响应拉高,是不是最少要2拍啊)?...以上问题可以理解为: 1、何时采用同步复位,何时采用异步复位; 2、复位电路是用来干嘛的; 3、激励和响应的分析(单拍潜伏期)是否适用于复位逻辑。...一般而言:高速逻辑应该采用同步复位,低速逻辑可以采用异步复位;涉及人机交互的复位,适合异步复位;涉及机器之间的握手交互,应该采用同步;涉及到全局作用域的复位信号,作用于高速逻辑时,应该采用同步复位,作用于低速逻辑时...,应该采用异步复位。
Xilinx 复位准则:Xilinx FPGA复位策略 (1)尽量少使用复位,特别是少用全局复位,能不用复位就不用,一定要用复位的使用局部复位; (2)如果必须要复位,在同步和异步复位上,则尽量使用同步复位...,一定要用异步复位的地方,采用“异步复位、同步释放”; (3)复位电平选择高电平复位; (这里说明,由于 Altera 和 Xilinx 器件内部结构的不同,Altera 的 FPGA 推荐低电平复位)...一、异步复位同步释放 针对异步复位、同步释放,一直没搞明白在使用同步化以后的复位信号时,到底是使用同步复位还是异步复位?...; (2)根据Xilinx复位准则,我们知道同步复位相比异步复位有很多好处,具体参见:Xilinx FPGA 复位策略白皮书,既然两者对后级复位没有功能上的差别,那么优先选择同步复位; 经过异步复位同步释放处理后...,相比于纯粹的异步复位,降低了异步复位信号释放导致亚稳态的可能性;相比同步复位,能够识别到同步复位中检测不到的复位信号(如上图所示的rst_async在同步复位是检测不到的);综合两者的优势,异步复位同步释放
1 Aurora 8B / 10B复位 复位信号用于将Aurora 8B / 10B IPCORE 设置为已知的启动状态。在复位时,内核停止任何当前操作并重新初始化新通道。...在全双工模块上,复位信号复位通道的TX 和RX 侧。在单工模块中,tx_system_reset复位TX 通道,rx_system_reset 复位RX 通道。...5 Aurora 8B/10B 单工正常工作复位顺序 对于单工配置,建议TX 侧复位序列与RX 侧复位序列紧密耦合,因为TX 和RX 链路没有通信反馈路径。...请注意,如果RX 侧被复位,则没有直接机制来通知TX 侧的复位。因此,对于Aurora8B / 10B 单工内核,需要在系统级别处理复位耦合。...每个TX 侧的复位必须在RX 侧后面,如下图所示,RX 端复位失效和TX 侧复位失效之间的时间必须保持尽可能的最小。
Linux 内核源码:include\linux\usb.h Linux 内核源码:drivers\hid\usbhid\usbmouse.c 1....BUS/DEV/DRV 模型 "USB 接口"是逻辑上的 USB 设备,编写的 usb_driver 驱动程序,支持的是"USB 接口": USB 控制器或 Hub 识别出 USB 设备后,会创建、...注册 usb_device usb_device 被"drivers\usb\core\generic.c" 驱动认领后,会选择、设置某个配置 这个配置下面的接口,都会分配、设置、注册一个 usb_interface...左边的 usb_driver 和右边的 usb_interface 如果匹配,则调用 usb_driver.probe 2....接口函数 在 USB 设备驱动程序中,能使用的 USB 函数都在这个头文件里:include\linux\usb.h。
gadget 功能前关闭 adb 功能时却报异常的解决办法 4 附录 4.1 Linux-4.x/Linux-5.4 Gadget 配置示例 4.1.1 小机做 mass storage 4.1.2...1.3 适用范围 表 1-1: 适用产品列表 内核版本 驱动文件 Linux-4.9 drivers/usb/* Linux-5.4 drivers/usb/* 2 模块介绍 2.1 模块功能介绍...USB 总线采用树形结构,在一条总线上只能有唯一的主机设备。Linux 内核从主机和设备两个角度观察 USB 总线结构。...Linux 有原生 gadget 框架,通用的配置流程可参考下文。...图 2-11: linux-4.x usb gadget 配置选择 2.6.2 linux-4.x/linux-5.4 USB Gadget 配置流程 Linux-4.x/Linux-5.4 使用 configfs
先给出 Xilinx 复位准则: (1)尽量少使用复位,特别是少用全局复位,能不用复位就不用,一定要用复位的使用局部复位; (2)如果必须要复位,在同步和异步复位上,则尽量使用同步复位,一定要用异步复位的地方...,采用“异步复位、同步释放”; (3)复位电平选择高电平复位; (这里说明,由于 Altera 和 Xilinx 器件内部结构的不同,Altera 的 FPGA 推荐低电平复位) Global Reset...虽然复位脉冲可以用比时钟周期更长的持续时间,并保证所有触发器都可以被成功复位,但是复位信号的释放应该被认为是一个时间关键事件。...很明显,当时钟频率上升时,可以用来分配给复位信号释放的时间就会减少。考虑到复位信号是一个高扇出网络,所以复位释放的时序不易收敛。...随着全局置位/复位(GSR)或者异步复位的释放,移位寄存器链开始在每个时钟周期填满0。 链中触发器的数量决定了传输到局部复位网络的复位脉冲的最小持续时间。
CPLL复位 CPLL必须使用CPLLPD端口断电,直到FPGA结构中检测到参考时钟边沿。在CPLLPD无效后,CPLL必须在使用前进行复位。...每个GTX/GTH收发器通道有三个专用端口用于CPLL复位。如下图所示,CPLLRESET是一个复位CPLL的输入。CPLLLOCK是一个输出,表示复位过程已经完成。...CPLL复位时序 这个异步CPLLRESET脉冲宽度的指导原则是参考时钟的一个周期。由内部GTX/GTH收发器电路产生的真正的CPLL复位要比CPLLRESET高脉冲持续时间长得多。...QPLL复位 QPLL复位描述和CPLL几乎一致,就是名词替换: 在使用QPLL之前,必须对其进行复位。每个GTX/GTH收发器Quad有三个专用端口用于QPLL复位。...如下图所示,QPLLRESET是一个输入,用于复位QPLL。QPLLLOCK是一个输出,表示复位过程已经完成。 这个异步QPLLRESET 脉冲宽度的指导原则是参考时钟的一个周期。
四、 linux内核下USB相关的API函数与数据结构 前面介绍了USB相关一些基础概念与重要的数据结构,接下来就分析在linux内核中如何编写一个USB 驱动程序,编写与一个USB设备驱动程序的方法和其他总线驱动方式类似.../usb.h> 4.2 USB设备注册框架示例 #include linux/init.h> #include linux/module.h> #include linux/usb.h> //定义...鼠标驱动(中断传输方式) 5.1 USB驱动注册框架代码 #include linux/init.h> #include linux/module.h> #include linux/usb.h>...#include linux/init.h> #include linux/module.h> #include linux/usb.h> #include linux/usb/input.h>.../init.h> #include linux/module.h> #include linux/usb.h> #include linux/sched.h> #include linux/slab.h
在上一章分析完USB总线驱动程序后, 接下来开始写一个USB驱动: 本节目的: 将USB鼠标的左键当作L按键,将USB鼠标的右键当作S按键,中键当作回车按键 参考/drivers/hid/usbhid/...: usb_deregister(struct usb_driver *driver); 注册一个usb_driver驱动,然后内核会通过usb_driver的成员.id_table函数匹配一次USB设备...释放input_device 3.5在出口函数中 1)通过usb_deregister ()函数注销usb_driver结构体 4.代码如下: #include linux/kernel.h> #include...linux/slab.h> #include linux/module.h> #include linux/init.h> #include linux/usb/input.h> #include...linux/hid.h> static struct input_dev *myusb_mouse_dev; //input_dev static char *myusb_mouse_buf
xilinx 的触发器是 高电平触发,所以建议使用 rst, 如果是 rst_n,则会增加额外的非逻辑
通过扫描以下目录获取物理节点所有 USB 设备: /sys/bus/usb/devices/usb* /sys/bus/usb/devices/usb*/$busnum-* 从该文件系统收集某一个设备的主要信息如下..."level": 1, "manufacturer": "QEMU", "port": 0, "prodid": "0001", "product": "QEMU USB...: 产品 serial: USB 硬件设备序列号 ,例如 0000:00:01.2 定位方法# 定位某一个 USB 设备的方法有两种: busnum + devnum idVendor + idProduct...设备类bDeviceClass、bDeviceSubClass、bDeviceProtocol By USB 中文网 USB设备描述符中的idVendor、idProduct和bcdDevice By...USB 中文网 USB 硬件设备的序列号 By IBM 注:本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。
[ 0.513302] usb usb1: New USB device found, idVendor=1d6b, idProduct=0002 [ 0.513303] usb usb1...Controller [ 0.513304] usb usb1: Manufacturer: Linux 3.10.0-327.el7.x86_64 xhci-hcd [ 0.513305...] usb usb1: SerialNumber: 0000:00:14.0 [ 0.518700] usb usb2: New USB device found, idVendor=1d6b,...0.518702] usb usb2: Product: xHCI Host Controller [ 0.518702] usb usb2: Manufacturer: Linux 3.10.0...] usb 1-4: New USB device found, idVendor=413c, idProduct=301a [ 1.040348] usb 1-4: New USB device
Linux3.11版本引入了基于configfs的usb gadget configfs。.../bcdDevice # USB 1.1: 0x0110 # USB 2.0: 0x0200, USB 2.1: 0x0210, USB 2.5: 0x0250 # USB 3.0: 0x0300...(gadget_strings, gadget_info); [include/linux/usb/gadget_configfs.h] #define USB_CONFIG_STRINGS_LANG(...其主要的工作内容如下: 分配端点的usb_request、分配缓冲区、设置usb_request的回调函数、复位所有端点,并将gadget的端点数量清零。...调用UDC驱动接口usb_udc_connect_control连接USB主机控制器,这样USB主机就能识别并枚举USB设备。
是因为windows自带了USB总线驱动程序, USB总线驱动程序负责: 识别USB设备,给USB设备找到对应的驱动程序 新接入的USB设备的默认地址(编号)是0,在未分配新编号前,PC主机使用0地址和它通信...然后USB总线驱动程序都会给它分配一个地址(编号) PC机想访问USB总线上某个USB设备时,发出的命令都含有对应的地址(编号) USB是一种主从结构。...主机叫做Host,从机叫做Device,所有的USB传输,都是从USB主机这方发起;USB设备没有"主动"通知USB主机的能力。..., 比如:鼠标的数据是从鼠标传到PC机, 对应的端点称为"中断输入端点" 其中端点0是设备的默认控制端点, 既能输出也能输入,用于USB设备的识别过程 同样linux内核也自带了USB总线驱动程序,框架如下...其中usb_bus_type是一个全局变量, 它和我们之前学的platform平台总线相似,属于USB总线, 是Linux中bus的一种.
为了消除这种可能性,机构会限制和监测访问互联网,同时禁用 USB 存储设备。 在本教程中,我们将讨论三种不同的方法来禁用 Linux 机器上的 USB 存储设备。...方法 2:删除 USB 驱动 这种方法要求我们将 USB 存储的驱动程序(usb_storage.ko)删掉或者移走,从而达到无法再访问 USB 存储设备的目的。...方法 3:将 USB 存储器纳入黑名单 我们也可以通过 /etc/modprobe.d/blacklist.conf 文件将 usb-storage 纳入黑名单。...usb-storage 保存文件并退出。...usb-storage 就在就会被系统阻止加载,但这种方法有一个很大的缺点,即任何特权用户都可以通过执行以下命令来加载 usb-storage 模块, $ sudo modprobe usb-storage
2.Gadget Function驱动 Linux内核的USB Gadget Function驱动都在drivers/usb/gadget/function/目录下,有通讯设备类(Communication...[include/linux/usb/composite.h] struct usb_function_driver { const char *name; struct module...// disable gadget function驱动,主机复位、主机重新配置gadget、断开连接时使用 void (*disable)(struct usb_function *);...Linux 3.11版本引入了USB Gadget Configfs。在用户层可以通过暴漏出来的API定义USB Gadget设备的任意功能和配置,极大的方便了USB复合设备的配置和使用。...*); // usb总线复位时调用,必须实现,在中断中调用 void (*reset)(struct usb_gadget *); struct device_driver driver;
图 2 SRVAL 和 INIT 属性定义触发器复位和初始化:这里用 VHDL 代码来推断异步 (a) 和同步 (b) 复位 在同步复位的情况下,综合工具推断出的触发器,其 SR 端口被配置为置位或复位端口...复位方法 不管使用哪种复位类型( 同步或是异步),一般都需要让复位与时钟同步。只要全局复位脉冲的持续时间足够长,器件上所有的触发器都会进入复位状态。...图 3 所示的复位桥接电路提供了一种机制,可以对复位进行异步断言(故在无有效时钟的情况下也可以进行)以及对复位进行同步取消断言。...器件中的每个时钟域仍需要一个单独的、经过同步的、由单独复位桥生成的全局复位。 技巧 2:复位桥接电路实现了一种安全的机制,可以同步地对异步复位取消断言。...在使用 GSR 设置整个设计的初始状态之后,对需要同步复位的逻辑单元(比如状态机)使用显式复位。可使用标准的亚稳态解决电路或者复位桥来生成同步的显式复位。
领取专属 10元无门槛券
手把手带您无忧上云