硬件开发基础知识(三):电流倒灌、热拔插、上电时序问题及其解决方法

本文主要是介绍硬件开发基础知识(三):电流倒灌、热拔插、上电时序问题及其解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在实验室工作呢,结果两个学弟一阵惊呼,说闻到糊味了。
这个时候我心里一惊:忙问道
在这里插入图片描述
结果他们说是在调STM32单片机,然后一边烧程序,一边又把板子的电源线接到插排上,结果就把电脑主板烧了。我拿起电源线一看,12V,完了,学弟的主板怕是要换了。

这种事情之前也遇到过,有做Buck电路的同学,以单片机作为PWM输出,在烧好程序后并没有拔掉接线,直接打开了Buck电路的开关,结果电脑也烧了。

这其实就是由于电压差引起的倒灌现象了。

不知道大家在生活中有没有体会:有的时候,临近马桶的洗手池水龙头,会把马桶里面的污水抽出来,其实这就和今天要说的电流倒灌是一个原理:

在这里插入图片描述
实际上,我们的水网,要想正常工作,那就是出水站的水压比我们用户水网高,这也是水站一般都建造城市附近高地的原因。
当停水的时候,马桶里原本储存的水的水压就比外面(空的管子)大,这样水就倒灌了。
这里我们可以看出,水(电流)的倒灌需要两个因素:

1.回流路径
2.水(电)压差

电流倒灌

为了彻底弄清楚,我们要知道现行的集成电路的接口电路模型,也就是马桶、水站、倒灌管道分别对应着电路里的何种组分。

在这里插入图片描述
D1是CMOS电路中防静电的常见二极管,也有输入限幅的作用
D2是晶体管的寄生二极管,有一定的放电保护功能
D3用于保护CMOS电路放电时的干扰,一般的双极性晶体管也具有这个寄生二极管
D4是晶体管的集电极(双极性)或漏极(场效应管)的寄生电容,有放电作用
这些等效或者原本就存在的二极管首先就为电流倒灌提供了回路,这就相当于马桶倒灌事件里的水管。
在这里插入图片描述
在一个具有先后上电顺序的情况下(或者可以看作右侧突然停电,或者拔插动作),左侧的电压如果足够大,那么就会通过二极管向右侧的VCC冲的充电,其实也就是去耦电容的充电,这样就会使二极管急速过载损坏,电容本身也可能损坏,瞬时的大电流甚至也会直接击毁元件本身。最好的情况也就是使得逻辑器件工作不正常。

解决方法有如下几种:
在这里插入图片描述
我们可以看到,分别是加限流电阻(但无法防止电压的建立)、接上拉(会降低噪声容限)和在前级电路的电源加二极管(但压降会使供电电压下降)。
最有效的办法是使用双极性晶体管(不存在寄生电容D1)作为接口输入。
当然,在FPGA这种有着多种参考电平的系统设计的时候,考虑上电顺序也是一种解决办法。

热拔插问题
和刚刚叙述的原理一样,在已经通电的系统上进行拔插,无疑就会产生一个很大的拉电流,导致系统中组件的损坏。其实也就是防止大容性负载时的浪涌电流。

当然我们小时候也用过类似的东西,就是保险丝,当电流过大保险丝熔断断开电路,但是在集成电路中我们肯定不希望这样,第一我们希望最大限度地保护系统,第二我们希望保护电路在动作后能够自恢复,电路继续工作。

如图所示是常用的防浪涌电路:
在这里插入图片描述
在C1放电时,mos管维持开路,不影响负载。C1充电时,Q1则会缓慢打开,从而不产生一个浪涌电压,其结果如下:
在这里插入图片描述
可见一个突然的电压差,并没有导致一个瞬时值很大的电流峰值出现。

今天就说到这里。
在这里插入图片描述
谢谢朋友们!

这篇关于硬件开发基础知识(三):电流倒灌、热拔插、上电时序问题及其解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/208941

相关文章

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到

MySQL磁盘空间不足问题解决

《MySQL磁盘空间不足问题解决》本文介绍查看空间使用情况的方式,以及各种空间问题的原因和解决方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录查看空间使用情况Binlog日志文件占用过多表上的索引太多导致空间不足大字段导致空间不足表空间碎片太多导致空间不足临时表空间

Java Stream流以及常用方法操作实例

《JavaStream流以及常用方法操作实例》Stream是对Java中集合的一种增强方式,使用它可以将集合的处理过程变得更加简洁、高效和易读,:本文主要介绍JavaStream流以及常用方法... 目录一、Stream流是什么?二、stream的操作2.1、stream流创建2.2、stream的使用2.

MySQL数据脱敏的实现方法

《MySQL数据脱敏的实现方法》本文主要介绍了MySQL数据脱敏的实现方法,包括字符替换、加密等方法,通过工具类和数据库服务整合,确保敏感信息在查询结果中被掩码处理,感兴趣的可以了解一下... 目录一. 数据脱敏的方法二. 字符替换脱敏1. 创建数据脱敏工具类三. 整合到数据库操作1. 创建服务类进行数据库

Mybatis-Plus 3.5.12 分页拦截器消失的问题及快速解决方法

《Mybatis-Plus3.5.12分页拦截器消失的问题及快速解决方法》作为Java开发者,我们都爱用Mybatis-Plus简化CRUD操作,尤其是它的分页功能,几行代码就能搞定复杂的分页查询... 目录一、问题场景:分页拦截器突然 “失踪”二、问题根源:依赖拆分惹的祸三、解决办法:添加扩展依赖四、分页

Java中InputStream重复使用问题的几种解决方案

《Java中InputStream重复使用问题的几种解决方案》在Java开发中,InputStream是用于读取字节流的类,在许多场景下,我们可能需要重复读取InputStream中的数据,这篇文章主... 目录前言1. 使用mark()和reset()方法(适用于支持标记的流)2. 将流内容缓存到字节数组

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

SQLServer中生成雪花ID(Snowflake ID)的实现方法

《SQLServer中生成雪花ID(SnowflakeID)的实现方法》:本文主要介绍在SQLServer中生成雪花ID(SnowflakeID)的实现方法,文中通过示例代码介绍的非常详细,... 目录前言认识雪花ID雪花ID的核心特点雪花ID的结构(64位)雪花ID的优势雪花ID的局限性雪花ID的应用场景

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

解决Failed to get nested archive for entry BOOT-INF/lib/xxx.jar问题

《解决FailedtogetnestedarchiveforentryBOOT-INF/lib/xxx.jar问题》解决BOOT-INF/lib/xxx.jar替换异常需确保路径正确:解... 目录Failed to get nested archive for entry BOOT-INF/lib/xxx