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

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

最近在实验室工作呢,结果两个学弟一阵惊呼,说闻到糊味了。
这个时候我心里一惊:忙问道
在这里插入图片描述
结果他们说是在调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

相关文章

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Conda虚拟环境的复制和迁移的四种方法实现

《Conda虚拟环境的复制和迁移的四种方法实现》本文主要介绍了Conda虚拟环境的复制和迁移的四种方法实现,包括requirements.txt,environment.yml,conda-pack,... 目录在本机复制Conda虚拟环境相同操作系统之间复制环境方法一:requirements.txt方法

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求

MySQL 打开binlog日志的方法及注意事项

《MySQL打开binlog日志的方法及注意事项》本文给大家介绍MySQL打开binlog日志的方法及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、默认状态二、如何检查 binlog 状态三、如何开启 binlog3.1 临时开启(重启后失效)

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错