USB接口小巧便携,支持热插拔,传输可靠,速度快,其广泛应用于计算机周边,工业设备等等。目前集成USB1.1全速接口MCU大多数将收发器一并设计了进去,但到了USB2.0接口,因为传输速度提升到了480Mbps,可能是因为设计难度,或者IP授权成本的增加,大部分MCU厂家选择了分立方案,MCU只集成USB2.0控制器,通过外加USB2.0 PHY(比如USB3320,USB3300,CH132)收发器芯片来实现USB2.0通讯接口,比如典型产品,比如ST的32F407,32F405等等,也有一些USB接口专注度比较高的厂家将USB2.0 PHY内置,比如Cypress的68013,沁恒的CH32V307等。USB PHY内置外置区别到底有多大,刚好拿手上的几个芯片测试下,集成USB2.0控制器(不含收发器)MCU 32F407,32H743,集成USB2.0接口(含收发器和控制器)CH32V307,USB2.0收发器USB3320,CH132。
主控(32F407,32H743,CH32V307)基本参数对比如下表:
| MCU型号 | 主频 | Flash(KB) | RAM(KB) | USB 全速 12Mbps | USB高速 480Mbps | 供电电压 |
|---|---|---|---|---|---|---|
| 32F407 | 168MHz | 1024 | 192 | OTG | USB控制 | 1.8-3.6V |
| 32H743 | 480MHz | 1024 | 1024 | OTG | USB控制 | 1.7-3.6V |
| CH32V307 | 144MHz | 256 | 64 | OTG | USB控制+内置收发器 | 2.4-3.6V |
使用外置USB PHY连接示意图如下:

如上图,MCU通过ULPI接口与高速USB PHY连接。ULPI为标准USB PHY接口, DATA0-7为双向数据线;CLK为时钟信号输出引脚;NXT为Next信号输出引脚,STP停止信号输入。实现外置PHY实现一个USB2.0接口连线还是蛮多的,足足12根。
假如芯片把USB2.0高速PHY集成了,电路简单了很多,2根信号线直连即可。

首先使用32F407 + USB3320测试,使用官方USB2.0库函数,在MSC例程上进行修改,测试USB2.0批量传输速度,写速度(从PC到MCU)16.6M Byte/s,读速度(MCU到PC)16.2M Byte/s。
将USB3320板子上USB3320直接替换为CH132 ,根据手册两者硬件兼容,可以直接替换,软件不用修改,直接测试,写速度16.6M Byte/s,读速度16.2M Byte/s。和USB3320速度差不多。
将主控32F407改用性能更高的32H743测试+3320测试,写速度21.8M Byte/s,读速度24.1M Byte/s,速度差别不大。虽然32H743性能比407 强不少,主频提升3倍,但是USB传输提升并不大,速度仅快了25%左右,这样看使用外置PHY且使用USB2.0库函数操作的速度瓶颈大致就在这里了,而且这瓶颈看起来和MCU的性能关系不大,当然看网上大神测试,假如改用寄存器操作的话,读速度可以提升至39.1M Byte/s。
继续使用CH32V307 采用相同的方式测试,测试例程为官方EVT USB批量传输设备例程,读速度45M Byte/s、写速度53M Byte/s,都有了较大幅度的提升。看来不是简单将ULPI PHY内置、省掉12根信号线这么简单,估计沁恒也对MCU内部总线架构做了改进,难怪沁恒USB3.0芯片文档中提到多层DMA架构和RISC-V内核的中断响应速度问题,听说这个自研的PHY最远还支持10米距离通讯。
整理测试接口速度如下,供参考。
USB2.0高速批量传输速度测试,上传数据由MCU到计算机,下传数据计算机到MCU
| USB2.0高速方案 | 下传速度 | 上传速度 |
|---|---|---|
| STM32F407+USB3320(USB2.0 PHY) | 16.6M Byte/s | 16.2M Byte/s |
| STM32F407+CH132(USB2.0 PHY) | 16.6M Byte/s | 16.2M Byte/s |
| CH32V307(内高速PHY) | 53M Byte/s | 44M Byte/s |
在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,
说在前面这部分我本来是合为一篇来写的,因为目的是一样的,都是通过独立按键来控制LED闪灭本质上是起到开关的作用,即调用函数和中断函数。但是写一篇太累了,我还是决定分为两篇写,这篇是调用函数篇。在本篇中你主要看到这些东西!!!1.调用函数的方法(主要讲语法和格式)2.独立按键如何控制LED亮灭3.程序中的一些细节(软件消抖等)1.调用函数的方法思路还是比较清晰地,就是通过按下按键来控制LED闪灭,即每按下一次,LED取反一次。重要的是,把按键与LED联系在一起。我打算用K1来作为开关,看了一下开发板原理图,K1连接的是单片机的P31口,当按下K1时,P31是与GND相连的,也就是说,当我按下去时
MIMO技术的优缺点优点通过下面三个增益来总体概括:阵列增益。阵列增益是指由于接收机通过对接收信号的相干合并而活得的平均SNR的提高。在发射机不知道信道信息的情况下,MIMO系统可以获得的阵列增益与接收天线数成正比复用增益。在采用空间复用方案的MIMO系统中,可以获得复用增益,即信道容量成倍增加。信道容量的增加与min(Nt,Nr)成正比分集增益。在采用空间分集方案的MIMO系统中,可以获得分集增益,即可靠性性能的改善。分集增益用独立衰落支路数来描述,即分集指数。在使用了空时编码的MIMO系统中,由于接收天线或发射天线之间的间距较远,可认为它们各自的大尺度衰落是相互独立的,因此分布式MIMO
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
通常,数组被实现为内存块,集合被实现为HashMap,有序集合被实现为跳跃列表。在Ruby中也是如此吗?我正在尝试从性能和内存占用方面评估Ruby中不同容器的使用情况 最佳答案 数组是Ruby核心库的一部分。每个Ruby实现都有自己的数组实现。Ruby语言规范只规定了Ruby数组的行为,并没有规定任何特定的实现策略。它甚至没有指定任何会强制或至少建议特定实现策略的性能约束。然而,大多数Rubyist对数组的性能特征有一些期望,这会迫使不符合它们的实现变得默默无闻,因为实际上没有人会使用它:插入、前置或追加以及删除元素的最坏情况步骤复
在ruby中,你可以这样做:classThingpublicdeff1puts"f1"endprivatedeff2puts"f2"endpublicdeff3puts"f3"endprivatedeff4puts"f4"endend现在f1和f3是公共(public)的,f2和f4是私有(private)的。内部发生了什么,允许您调用一个类方法,然后更改方法定义?我怎样才能实现相同的功能(表面上是创建我自己的java之类的注释)例如...classThingfundeff1puts"hey"endnotfundeff2puts"hey"endendfun和notfun将更改以下函数定