模组硬件通用丨模组USB电路设计指南

USB(全称:Universal Serial Bus)是一种串口总线标准,也是一种输入输出接口的技术规范,广泛应用于个人电脑和移动设备等信息通讯产品,并扩展至摄影器材、数字电视(机顶盒)、游戏机等相关领域。模组应用时,USB接口通常作为4G、5G模组与CPU的通信和固件升级的重要接口,性能直接影响通信数据传输的成功率。本文讲解了USB接口设计、差分阻抗控制以及固件下载常见问题。

一、USB接口设计

1.USB概念及速率

USB是一种外部总线标准,用于规范电脑与外部设备的连接和通讯。USB各版本的速率及功率1

表1 1USB版本及特点

USB 2.0物理接口采用4针脚设计(D+,D-,Vbus,GND),D+与D-是一对差分线。USB 3.0物理接口采用9针脚设计,增加了两对超高速差分信号SSTX+与SSTX-、SSRX+与SSRX-,共3对差分线。

2.一般设计原则

模组仅能作为设备(Device)工作,无法作为主机(Host)工作,不支持OTG模式。5G模组最高可支持USB 3.1 Gen2速率,其余模组最高支持USB 2.0的高速模式,向下兼容。

在原理图设计中,建议USB接口进行防静电保护,预留用于滤除共模和差模干扰的元件位置不贴实际值,仅贴0R短接即可预留元件位置便于测试中如果发现干扰,可以快速贴上电感电容进行调试这是硬件设计中的一种兼容策略有助于避免改板问题。

在PCB设计时,为保证数据传输的稳定性及可靠性,必须遵循差分线一般的设计原则:

  1. 根据PCB层叠关系,利用阻抗计算工具,控制差分90Ω阻抗
  2. 参考平面完整,不能出现跨分割
  3. 走线不能走90°直角,且需进行良好的包地处理
  4. 差分对走线等长,尽量避免过孔如果必须使用过孔,则应在附近放置回流地过孔
  5. 尽量减少布线长度
  6. 远离边沿陡峭的信号或高开关速率器件
  7. USB数据线上的ESD防护器件的寄生电容不能超过22pF
  8. 若USB仅用于固件下载预留,不用于数据传输,设计时可放宽要求

二、USB差分阻抗控制

USB差分走线阻抗需控制90Ω,设计时需保持阻抗连续,阻抗控制方式与射频的单端50Ω类似,通过阻抗计算软件SI9000选择合适的差分阻抗模型,计算出差分走线的线宽线距,实现90Ω阻抗控制。

阻抗的不连续会导致信号发生反射和衰减、通信速率降低,控制好高速信号的走线阻抗,是布线成功的关键。

图1 USB布线示例

三、USB固件升级下载

此问题主要出现在ML307系列模组的固件升级由于ML307系列模组强制进入下载模式需要把BOOT引脚拉低到地,客户前期使用其他模组未注意兼容性,会将BOOT预留上拉至VDD_EXT从而导致固件下载失败

1.BOOT上拉问题

问题:用户将BOOT错误上拉到VDD_EXT引脚

解决方法:参考上述方法进行修改

2.VBUS问题

问题:用户使用了USB功能,却没接USB_DET

解决方法需将USB_DET接至VBUS。

图2 VBUS设计问题

  • 总结

在模组固件下载和模组调试的关键环节中,USB接口的使用频率极高。为了确保操作的便捷性和高效性,强烈建议在电路设计时明确将模组的USB接口引出,并严格遵循文档中的建议进行相关的电路设计,以确保接口的稳定性和兼容性。

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

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

相关文章

本地可以Run大模型吗?Llama3?安排!

➡️ 前言 本地可以跑大模型吗? ChatGPT发布之后,引起了AI领域剧烈震动,从2023年3月百度发布新一代大预言模型文心一言开始,大模型如雨后春笋般不断涌现,国内阿里巴巴的通义千问、华为的盘古大模型、科大讯飞的星火认知大模型、…

木材容易发霉怎么办除霉处理方法

木材存放不当就容易出现发霉情况,那么可通过那些方法将木材表面的霉斑除掉呢?经ihaoer防霉人士介绍处理木材发霉处理方法如下: 木材发霉的原因主要包括木材本身的营养物质、环境湿度、温度以及空气流动性等因素。木材中含有蛋白质、淀粉、油类…

【面试题】Linux 下 MakeFile(第一篇)

1.请简单介绍Makefile是什么? Makefile是用于编译和管理项目的一组规则和指令。它保存了编译器和连接器的参数选项,还表述了所有源文件之间的关系(如源代码文件需要的特定包含文件,可执行文件要求包含的目标文件模块及库等&#x…

CPR曲面重建代码

废话不说,直接上代码: #include "vtkAutoInit.h" #include "vtkPolyData.h" #include "vtkProbeFilter.h" #include "vtkParametricFunctionSource.h" #include "vtkParametricSpline.h" #include &…

基于Java微信小程序校园自助打印系统设计和实现(源码+LW+调试文档+讲解等)

💗博主介绍:✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者,博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 🌟文末获取源码数据库🌟感兴趣的可以先收藏起来,还…

2024年江苏省13市科技企业上市培育计划入库企业申报条件程序和截止时间

一、江苏省13市科技企业上市培育计划入库企业申报条件 1.企业属于有效期内高新技术企业,申报时须在我省行政区域内成立三年以上,经营状况良好,已设立或拟设立为股份有限公司,且尚未在主板、创业板、科创板、北证上市或在“新三板…

计算机网络知识点(八)

目录 一、简述HTTP常见的响应状态码及其含义 1、解析 2、分类 二、简述GET请求和POST请求的区别 三、简述Cookie和Session的区别 四、简述HTTPS的加密与认证过程 一、简述HTTP常见的响应状态码及其含义 1、解析 ①200:从状态码发出的请求被服务器正常处理。 …

【开源项目】智慧北京案例~超经典实景三维数字孪生智慧城市CIM/BIM数字孪生可视化项目——开源工程及源码!

飞渡科技数字孪生北京管理平台, 依托实景数字孪生底座,以城市感知网络为硬件基础,以城市大数据为核心资源,以数字孪生、云计算、人工智能为关键技术,实现城市产业规划、资产安全管理、城市能耗监控等一体化空间融合。 …

CP AUTOSAR标准之FlexRayStateManager(AUTOSAR_CP_SWS_FlexRayStateManager)(更新中……)

1 简介和功能概述 该规范描述了AUTOSAR基础软件模块FlexRay状态管理器(FrSM)的功能、API和配置。   AUTOSAR BSW堆栈为每条通信总线指定一个总线特定状态管理器。该模块应实现相应总线的控制流。FrSM是通信服务层的成员。它与通信硬件抽象层和系统服务层交互。 3 相关文献 …

基于电商模式的性能测试(2) —— 使用Jmeter参数化功能+JSR223 PreProcessor+JSON Extractor完成注册登录的数据驱动

1、前置条件 此例使用的是GitHub上一个开源的电商项目mall,需要的可以去GitHub上下载部署,有详细的部署教程: GitHub地址:github.com/macrozheng/…部署教程:macrozheng.github.io/mall-learni… 2、场景抽离 首先要…

C#的无边框窗体项目模板 - 开源研究系列文章

继续整理和编写代码及博文。 这次将笔者自己整理的C#的无边框窗体项目的基本模板进行总结,得出了基于C#的.net framework的Winform的4个项目模板,这些模板具有基本的功能,即已经初步将代码写了,直接在其基础上添加业务代码即可&am…

java实现一个图的最短路径算法

import java.util.*; //java实现一个图的最短路径算法 public class Test_34 { // 定义一个常量INF,表示无穷大。private static final int INF Integer.MAX_VALUE; // 定义一个方法dijkstra,接受一个二维数组图和一个起始节点作为参数。public s…

七牛云 Miku 快直播,陪你一起看球!

足球,作为全球最受欢迎的运动之一,每一次大赛都是球迷心中的狂欢,每一场比赛都记录着足球历史的精彩。 2000 年,特雷泽盖的金球,照亮了法兰西的足球梦想。 2004 年,查理斯特亚斯的头槌破门,成就…

小甲鱼——集合

一什么是集合 type({}) <class dict> #字典 type({"one"}) <class set> #集合type({"one":1}) <class dict> #字典 跟集合一样&#xff0c;字典最大的特性就是——唯一性 即&#xff1a;集合中的所有元素&#xff0c;都应该是独…

第15天:Vue.js应用的测试和调试

第15天&#xff1a;Vue.js应用的测试和调试 目标 学习Vue.js应用的测试和调试方法&#xff0c;包括E2E&#xff08;端到端&#xff09;测试和单元测试。 任务概览 学习单元测试基础。探索E2E测试框架。实现Vue组件的测试。 详细步骤 1. 单元测试基础 单元测试是对应用中…

浅谈逻辑控制器之while控制器

浅谈逻辑控制器之while控制器 “While控制器”是一种高级控制结构&#xff0c;它允许用户基于特定条件来循环执行其下的子采样器或控制器&#xff0c;直至该条件不再满足。本文旨在详细介绍While控制器的功能、配置方法、使用场景以及实践示例&#xff0c;帮助测试工程师高效利…

上海市计算机学会竞赛平台2023年8月月赛丙组下降幂多项式

题目描述 &#x1d465;x 的 &#x1d458;k 次下降幂定义为 &#x1d465;(&#x1d458;)(&#x1d465;)(&#x1d465;−1)(&#x1d465;−2)⋯(&#x1d465;−&#x1d458;1)x(k)(x)(x−1)(x−2)⋯(x−k1) &#x1d465;x 的下降幂多项式是由 &#x1d465;x 的一组…

工信部中小企业局一行莅临盘古信息调研指导

近日&#xff0c;中小企业数字化转型城市试点调研交流活动在广东东莞举行&#xff0c;工业和信息化部中小企业局副局长商超&#xff0c;广东工业和信息化厅二级巡视员张振祥&#xff0c;工业和信息化部中小企业局创业创新处处长李海涛&#xff0c;东莞市委常委、副市长刘光滨&a…

泵设备的监测控制和智慧运维

泵是一种输送流体或使流体增压的机械。它通过各种工作原理&#xff08;如离心、柱塞等&#xff09;将机械能转换为流体的动能或压力能&#xff0c;从而实现液体的输送、提升、循环等操作。 泵的一些具体应用场景&#xff1a; 1.智能水务&#xff1a;在城市供水管网中&#xff…

【vuejs】 $on、$once、$off、$emit 事件监听方法详解以及项目实战

1. Vue实例方法概述 1.1 vm.$on vm.$on是Vue实例用来监听自定义事件的方法。它允许开发者在Vue实例上注册事件监听器&#xff0c;当事件被触发时&#xff0c;指定的回调函数会被执行。 事件监听&#xff1a;vm.$on允许开发者绑定一个或多个事件到Vue实例上&#xff0c;并且可…