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

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

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

相关文章

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

电脑死机无反应怎么强制重启? 一文读懂方法及注意事项

《电脑死机无反应怎么强制重启?一文读懂方法及注意事项》在日常使用电脑的过程中,我们难免会遇到电脑无法正常启动的情况,本文将详细介绍几种常见的电脑强制开机方法,并探讨在强制开机后应注意的事项,以及如何... 在日常生活和工作中,我们经常会遇到电脑突然无反应的情况,这时候强制重启就成了解决问题的“救命稻草”。那

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F