精华内容
下载资源
问答
  • 开机的时候为什么为复位电路图中,电容的的大小是10uf,电阻的大小是10k。所以根据公式,可以算出电容充电到电源电压的0.7倍(单片机的电源是5V,所以充电到0.7倍即为3.5V),需要的时间是10K*10UF=0.1S。也就是说...

    复位原理:

    开机的时候为什么为复位在电路图中,电容的的大小是10uf,电阻的大小是10k。所以根据公式,可以算出电容充电到电源电压的0.7倍(单片机的电源是5V,所以充电到0.7倍即为3.5V),需要的时间是10K*10UF=0.1S。也就是说在电脑启动的0.1S内,电容两端的电压时在0~3.5V增加。这个时候10K电阻两端的电压为从5~1.5V减少(串联电路各处电压之和为总电压)。所以在0.1S内,RST引脚所接收到的电压是5V~1.5V。在5V正常工作的51单片机中小于1.5V的电压信号为低电平信号,而大于1.5V的电压信号为高电平信号。所以在开机0.1S内,单片机系统自动复位(RST引脚接收到的高电平信号时间为0.1S左右)。

    按键按下的时候为什么会复位在单片机启动0.1S后,电容C两端的电压持续充电为5V,这是时候10K电阻两端的电压接近于0V,RST处于低电平所以系统正常工作。当按键按下的时候,开关导通,这个时候电容两端形成了一个回路,电容被短路,所以在按键按下的这个过程中,电容开始释放之前充的电量。随着时间的推移,电容的电压在0.1S内,从5V释放到变为了1.5V,甚至更小。根据串联电路电压为各处之和,这个时候10K电阻两端的电压为3.5V,甚至更大,所以RST引脚又接收到高电平。单片机系统自动复位。

    单片机上电复位电路图大全

    总结:

    1、复位电路的原理是单片机RST引脚接收到2US以上的电平信号,只要保证电容的充放电时间大于2US,即可实现复位,所以电路中的电容值是可以改变的。

    2、按键按下系统复位,是电容处于一个短路电路中,释放了所有的电能,电阻两端的电压增加引起的。

    单片机上电复位电路图(一)

    下面几种延时复位电路,都是利用在单片机RST引脚上外接一个RC支路的充电时间而形成的。典型复位电路如图(a)所示,其中的阻容值是原始手册中提供的。图(b)是简化后的复位电路,图(c)在图(a)的基础上加上一个二极管D,有助于电容C的快速放电,为下一次上电复位延时做准备。在经历了一系列延时之后,单片机才开始按照时钟源的工作频率,进入到正常的程序运行状态。

    单片机上电复位电路图大全

    单片机上电复位电路图(二)

    复位电路由按键复位和上电复位两部分组成。

    (1)上电复位:STC89系列单片及为高电平复位,通常在复位引脚RST上连接一个电容到VCC,再连接一个电阻到GND,由此形成一个RC充放电回路保证单片机在上电时RST脚上有足够时间的高电平进行复位,随后回归到低电平进入正常工作状态,这个电阻和电容的典型值为10K和10uF。

    (2)按键复位:按键复位就是在复位电容上并联一个开关,当开关按下时电容被放电、RST也被拉到高电平,而且由于电容的充电,会保持一段时间的高电平来使单片机复位。

    单片机上电复位电路图大全

    单片机上电复位电路图(三)

    单片机上电复位电路如图3所示,请回答下列问题:

    (1) 该复位电路适用于高电平复位还是低电平复位?

    (2) 试述复位原理,画出上电时Vc的波形;

    (3) 试述二极管D的作用。

    单片机上电复位电路图大全

    图3 RC复位电路

    答案:(1)低电平复位。

    (2)在图3中,CPU上电时,但由于电容C两端的电压VC不能突变,因此VC保持低电平。但随着电容C的充电,VC不断上升,上升曲线如图4所示。只要选择合适的R和C,VC就可以在CPU复位电压以下持续足够的时间使CPU复位。复位之后,VC上升至电源电压,CPU开始正常工作。相当于在CPU上电时,自动产生了一个一定宽度的低电平脉冲信号,使CPU复位。

    单片机上电复位电路图大全

    图4 RC充放电曲线

    (3) 当电源电压消失时,二极管D为电容C提供一个迅速放电的回路,使/RESET端迅速回零,以便下次上电时CPU能可靠复位。

    这是一个非常重要的知识点,如果CPU的复位电路设计得不合理将会导致CPU严重死机,并且影响与CPU有关的外围器件的稳定性,比如存储器上电丢失数据。

    单片机上电复位电路图(四)

    (1)复位电路原理图:

    单片机上电复位电路图大全

    (2)原理:

    复位条件:RST引脚高电平(大于1.5v)时间大于0.1s后复位

    两种复位的原理:

    a:开机时复位原理

    单片机接上电源后,电容会开始充电,两边的电压会从0v上升到5v,同时电阻两边的电压(RST引脚电压)会从5v下降到0v。电容两边电压从0v上升到3.5v(电源电压的0.7倍)所用的时间为10k*10uF=0.1s,在这0.1s内引脚为高电平,之后就会一直是低电平。开机因为满足复位条件,所以单片机复位。

    b:复位按钮复位

    假如按住复位按钮的时间是0.1s,则电容两边电压会从5v下降到1.5v。之后因为按钮松开段路,电容又从1.5v上升到5v。只要电容电压小于3.5v,RST引脚便是高电平,所以理论上只要开关闭合0.1s,就足够使单片机复位了。

    单片机上电复位电路图(五)

    复位电路设计

    AT89S51的复位是由外部的复位电路实现的。AT89S51片内复位电路结构如图2-17所示。

    单片机上电复位电路图大全

    复位引脚RST通过一个施密特触发器与复位电路相连,施密特触发器用来抑制噪声,在每个机器周期的S5P2:施密特触发器的输出电平由复位电路采样一次,然后才能得到内部复位操作所需要的信号。

    复位电路通常采用上电自动复位和按钮复位两种方式。

    最简单的上电自动复位电路如图2-18所示。对于CMOS型单片机,由于在RST引脚内部有一个下拉电阻,故可将电阻R去掉,而将电容C选为10 μF。

    单片机上电复位电路图大全

    上电自动复位是通过外部复位电路给电容C充电加至RST引脚一个短的高电平信号,此信号随着VCC对电容C的充电过程而逐渐回落,即RST引脚上的高电平持续时间取决于电容C的充电时间。因此为保证系统能可靠地复位,RST引脚上的高电平必须维持足够长的时间。

    除了上电复位外,有时还需要按键手动复位。按键手动复位有电平和脉冲两种方式。

    按键手动电平复位是通过RST端经电阻与电源Vcc接通来实现,具体电路如图2-19所示。当时钟频率选用6 MHz时,C的典型取值为10μF,R取值为2kΩ。

    单片机上电复位电路图大全

    脉冲复位是利用RC微分电路产生的正脉冲来实现的,脉冲复位电路如图2-20所示。图中的阻容参数适于6 MHz时钟。

    单片机上电复位电路图大全

    图2-21所示电路能输出高、低两种电平的复位控制信号,以适应外围I/O接口芯片所要求的不同复位电平信号。图2-21中,74LS122为单稳电路。实验表明,电容C选择约为0.1μF较好。

    单片机上电复位电路图大全

    在实际应用系统设计中,若有外部扩展的I/O接口电路也需初始复位,如果它们的复位端和AT89S51的复位端相连,复位电路中的R、C参数要受到影响,这时复位电路中的R、C参数要统一考虑,以保证可靠复位。如果AT89S51与外围I/O接口电路的复位电路和复位时间不完全一致,使单片机初始化程序不能正常运行,外围I/O接口电路的复位也可以不与AT89S51复位端相连,采用独立的上电复位电路。若RC上电复位电路接施密特电路输入端,施密特电路输出接AT89S51和外围电路复位端,则能使系统可靠地同步复位。一般来说,单片机的复位速度比外围I/O接口电路快些。为保证系统可靠复位,在初始化程序中应安排一定的复位延迟时间。

    单片机上电复位电路图(六)

    积分型上电复位

    常用的上电或开关复位电路如图3所示。上电后,由于电容C3的充电和反相门的作用,使RST持续一段时间的高电平。当单片机已在运行当中时,按下复位键K后松开,也能使RST为一段时间的高电平,从而实现上电或开关复位的操作。

    根据实际操作的经验,下面给出这种复位电路的电容、电阻参考值。

    图3中:C:=1uF,Rl=lk,R2=10k

    单片机上电复位电路图大全

    专用芯片复位电路

    上电复位电路 在控制系统中的作用是启动单片机开始工作。但在电源上电以及在正常工作时电压异常或干扰时,电源会有一些不稳定的因素,为单片机工作的稳定性可能带来严重的影响。因此,在电源上电时延时输出给芯片输出一复位信号。上复位电路另一个作用是,*正常工作时电源电压。若电源有异常则会进行强制复位。复位输出脚输出低电平需要持续三个(12/fc s)或者更多的指令周期,复位程序开始初始化芯片内部的初始状态。等待接受输入信号(若如遥控器的信号等)。

    单片机上电复位电路图大全

    上电复位电路原理分析

    5V电源通过MC34064的2脚输入,1脚便可输出一个上升沿,触发芯片的复位脚。电解电容C13是调节复位延时时间的。当电源关断时,电解电容C13上的残留电荷通过D13和MC34064内部电路构成回路,释放掉电荷。以备下次复位启用。

    单片机上电复位电路图(七)

    比较器型复位电路

    比较器型复位电路的基本原理如图8所示。上电复位时,由于组成了一个RC低通网络,所以比较器的正相输入端的电压比负相端输入电压延迟一定时间。而比较器的负相端网络的时间常数远远小于正相端RC网络的时间常数,因此在正端电压还没有超过负端电压时,比较器输出低电平,经反相器后产生高电平。复位脉冲的宽度主要取决于正常电压上升的速度。由于负端电压放电回路时间常数较大,因此对电源电压的波动不敏感。但是容易产生以下二种不利现象:(1)电源二次开关间隔太短时,复位不可靠;(2)当电源电压中有浪涌现象时,可能在浪涌消失后不能产生复位脉冲。为此,将改进比较器重定电路,如图9所示。这个改进电路可以消除第一种现象,并减少第二种现象的产生。为了彻底消除这二种现象,可以利用数字逻辑的方法与比较器配合,设计如图9所示的比较器重定电路。此电路稍加改进即可作为上电复位与看门狗复位电路共同复位的电路,大大提高了复位的可靠性。

    单片机上电复位电路图大全

    改进型比较器型复位电路

    单片机上电复位电路图(八):手动按钮复位

    手动按钮复位需要人为在复位输入端RST上加入高电平(图1)。一般采用的办法是在RST端和正电源Vcc之间接一个按钮。当人为按下按钮时,则Vcc的+5V电平就会直接加到RST端。手动按钮复位的电路如所示。由于人的动作再快也会使按钮保持接通达数十毫秒,所以,完全能够满足复位的时间要求。

    单片机上电复位电路图大全

    单片机上电复位电路图大全

    单片机上电复位电路图(九):看门狗型复位电路

    看门狗型复位电路主要利用CPU正常工作时,定时复位计数器,使得计数器的值不超过某一值;当CPU不能正常工作时,由于计数器不能被复位,因此其计数会超过某一值,从而产生复位脉冲,使得CPU恢复正常工作状态。典型应用的Watchdog复位电路如图7所示。此复位电路的可靠性主要取决于软件设计,即将定时向复位电路发出脉冲的程序放在何处。一般设计,将此段程序放在定时器中断服务子程序中。然而,有时这种设计仍然会引起程序走飞或工作不正常。原因主要是:当程序“走飞”发生时定时器初始化以及开中断之后的话,这种“走飞”情况就有可能不能由Watchdog复位电路校正回来。因为定时器中断一真在产生,即使程序不正常,Watchdog也能被正常复位。为此提出定时器加预设的设计方法。即在初始化时压入堆栈一个地址,在此地址内执行的是一条关中断和一条死循环语句。在所有不被程序代码占用的地址尽可能地用子程序返回指令RET代替。这样,当程序走飞后,其进入陷阱的可能性将大大增加。而一旦进入陷阱,定时器停止工作并且关闭中断,从而使Watchdog复位电路会产生一个复位脉冲将CPU复位。当然这种技术用于实时性较强的控制或处理软件中有一定的困难。

    单片机上电复位电路图大全

    展开全文
  • 本文介绍的就是单片机按键复位电路原理和电路图解析。 复位电路 在单片机系统中,系统上电启动的时候复位一次,当按键按下的时候系统再次复位,如果释放后再按下,系统还会复位。所以可以通过按键的断开和闭合在...
  • 本文主要为看门狗型复位电路原理,希望对你的学习有所帮助。
  • 王工小板中对于stm32f411芯片的复位电路如下:    实际上这个电路是错误的,经过实测,stm32f411芯片运行时复位引脚为高电平,而在这个电路图里,实际上是把stm32f411芯片运行时复位引脚的电平看为了低电平,...
         王工小板中对于stm32f411芯片的复位电路如下:
    
     
        实际上这个电路是错误的,经过实测,stm32f411芯片运行时复位引脚为高电平,而在这个电路图里,实际上是把stm32f411芯片运行时复位引脚的电平看为了低电平,按照这个电路,按下按键,会引起电平跳转到高电平从而触发复位,然而实际上并不是这样,stm32f411复位引脚内接上拉电阻(经过实测),所以即使按键松开,其实RST引脚也是高电平,按键按下后,依然是高电平,故这个电路无法触发一个电平的跳变引发复位中断。
     
     
        对上面说法的证明:目前复位按键无法触发复位,我把C11打掉,整个电路不受影响。
     
     
         我找了一个stm32f4芯片正确的的复位电路,下面分析其原理:
       
        上电之后,RESET引脚电平从低变为高,芯片开始工作,当按下按键,VCC3.3到GND实现通路,电压被R7分去,从而,RESET引脚变为低电平,松开按键,RESET重新变为高电平。由于C7充电放电的能力,实际上避免了电压的突变。





    展开全文
  • 复位电路

    千次阅读 2019-02-22 18:02:00
    复位电路  时钟电路我第一篇博客已经说讲过了,今天我们来聊聊复位电路。当然,复位电路博大精深,并不是三言两语就能说清楚的,因此这里也是聊聊复位电路的基础,更深的研究需要在实际的项目中才能深有体会。...

      时钟电路我第一篇博客已经说讲过了,今天我们来聊聊复位电路。当然,复位电路博大精深,并不是三言两语就能说清楚的,因此这里也是聊聊复位电路的基础,更深的研究需要在实际的项目中才能深有体会。本文的主要内容有:

        ·复位电路概述

        ·同步复位电路

        ·异步复位电路

        ·复位策略——复位网络

    1.复位电路概述

      复位信号在数字电路里面的重要性仅次于时钟信号。对电路的复位往往是指对触发器的复位,也就是说电路的复位中的这个“电路”,往往是指触发器,这是需要注意的。有的电路需要复位信号,就像是有的电路需要时钟信号那样,而有的电路是不需要复位信号的。复位又分为同步复位和异步复位,这两种各有优缺点。下面我们主要来说说复位信号的用途和不需要复位信号的情况

    (1)复位的目的

      复位最基本的目的就是使电路(主要是触发器)进入一个能稳定操作的确定状态(主要是触发器在在某个确定的状态),主要表现为下面两点:

    ①使电路在复位后从确定的初始状态运行:

      ·上电的时候,为了避免上电后进入随机状态而使电路紊乱,这个时候你就需要上电复位了。

      ·有时候,电路在某个状态下,你想或者别人要求你从电路的初始状态开始进行延时你的电路功能,这个时候你就要对你的电路进行复位,让它从最初的状态开始运行。

    ②使电路从错误状态回到可以控制的确定状态:

      有的时候,你的电路发生了异常,比如说状态机跑飞了、系统供电炸了之类的,总之就是电路运行得不正常了,这个时候你就要对电路进行复位,让它从错误的状态回到一个正常的状态。

    上面说的都是和实际电路有关的,下面我们就从电路仿真的角度看一下复位信号的重要性。

      ·仿真的要求

      复位信号在仿真里面主要是使电路仿真时具有可知的初始值:

      在仿真的时候,信号在初始状态是未知状态(也就是所谓的x,不过对信号初始化之后的这种情况除外,因为仿真的时候对信号初始化就使信号有了初始值,这就不是x了)。

      对于数据通路(数字系统一般分为数据通路和控制通路,数据通路一般是对输入的数据进行处理,控制通路则是对运行的情况进行操作),在实际电路中,只要输入是有效数据(开始的时候可能不是有效的),输出后的状态也是确定的;在仿真的时候,也是输入数据有效了,输出也就确定了。也就是说,初始不定态对数据通路的影响不明显。

      对于控制通路,在实际电路中,只要控制通路完备(比如说控制通路的状态机是完备的),即使初始状态即使是不定态,在经过一定的循环后,还是能回到正确的状态上;然而在仿真的时候就不行了,仿真的时候由于初始状态为未知态,控制电路一开始就陷入了未知态;仿真跟实际电路不同,仿真是“串行”的,仿真时控制信号的初始不定态会导致后续的控制信号结果都是不定态,也就是说,初始的不定态对控制通道是致命的。

     

    (2)不需要复位信号的一些情况

      复位信号很重要,但是并不是每一部分的电路都需要复位电路,一方面是复位电路也消耗逻辑资源、占用芯片面积,另一方面是复位信号会增加电路设计的复杂性(比如要考虑复位的策略、复位的布局布线等等)

      当某个电路的输出在任何时刻都可以不受到复位信号的控制就有正确的值时,比如说数据通路中的对数据进行处理的部分。在某些情况下,当流水线的寄存器(移位寄存触发器)在高速应用中时,应该去掉某些寄存器的复位信号以使设计达到更高的性能,因为带复位的触发器比不带复位的触发器更复杂,反应也更慢。

    对复位信号/电路有一定的概念后,下面我们就来说说复位的方式,也就是同步电路和异步电路以及它们的优缺点。

     

    2.同步复位

    (1)同步复位电路

    同步复位是指复位信号在时钟有效沿到来时才复位电路(主要是复位触发器)。因此同步复位的复位信号受到时钟信号的控制。同步复位的触发器RTL代码和电路如下所示:

         

    上面的电路在FPGA中容易综合得到;也有可能综合得到下面这样的电路:

                          

     

    (2)同步复位的优点

      ①首先同步复位一般能确保电路是100%同步的,因为电路都是由同步时钟触发。

      ②同步复位会综合为更小的触发器。从前面电路中我们也可以看到,复位电路仅仅是由一个普通的触发器和一个与门够吃。

      ③由于同步复位仅仅发生在时钟的有效沿,当外部的复位信号由毛刺时,时钟可以当做过滤毛刺的手段,也就是说同步复位受到复位信号的毛刺影响小。

      ④当复位信号是由内部电路产生时,此时复位信号就有可能有毛刺,时钟就可以过滤毛刺。也就是说,可以在那些使用内部信号当做复位信号的设计中,使用同步复位

     

    (3)同步复位的缺点

      ①使用同步复位可能使综合工具无法分辨分辨复位信号和其他控制信号,导致进行复位的控制逻辑远离触发器(也就是说,并不是所以的ASIC库都有内置的同步复位逻辑,综合工具可能把符合逻辑综合到触发器自身之外)。例如对于带同步复位和加载使能的触发器,代码如下所示:

                       

    综合得到的电路图如下所示,左边是理想的电路,右边是可能综合出的电路:

       

    这两个电路的功能完全一样,只不过右边电路的复位控制逻辑(即复位与门)在多路复用器之外,也就是远离了触发器。这在门级仿真的时候(注意这是仿真),当....

      解决方法就是:一方面这个只是综合工具的问题,一般综合工具会自动识别在敏感列表里面又在条件表达式信号中的第一个信号为复位信号;另一方面,可以在RTL代码编写的时候,加入相关的综合指令,让综合的时候把复位逻辑靠近触发器。

      

      ②由于同步复位需要在时钟沿的触发下才能起作用,复位信号是以短脉冲的方式出现时,时钟沿就有可能错失这个复位信号,导致复位脉冲丢失,同步复位电路没有起到作用,时序图如下所示:

                     

      解决办法:一方面,可以采用脉冲捕捉电路,这个电路在我的跨时钟域控制信号传输中有讲到。;另一方面,可以将复位信号进行脉冲扩展,维持足够长的时间,这个可以通过一个小的计数器实现,如下图所示:

                     

     

     

      ③同步复位可能有组合逻辑延时,当复位逻辑距离触发器比较远时,这个时候就不能把触发器当做即时响应复位信号的触发器,而是有一定延时的触发器,这个时候就有了复位信号偏移的问题,关于复位信号偏移的描述,我们将在异步复位中进行描述。

      解决方法:使用内置的同步复位触发器;综合的时候加入相关的综合指令,这个和①类似。

     

      ④我们前面说过,在由内部组合逻辑的产生复位信号的设计中,推荐使用同步复位。其实这也是有缺点的,这是因为这样产生复位信号的组合逻辑一方面在仿真的时候容易出现x态,另一方面在实际电路中,这样的复位信号容易被外部(多个)信号影响。

      解决方法:不建议使用内部产生的复位信号;使用异步复位。

     

      ⑤门控时钟的同步复位可能无效:

      使用门控时钟的时候,由于复位信号依赖于时钟,在复位信号发出的时候,时钟可能关闭了,这个时候就会导致实际的电路没有被复位,如下图所示:

          

      解决方法:只能使用异步复位,并在时钟恢复前移除异步复位。

     

      ⑥总线设计中的同步复位问题:

      在总线控制中,系统上电复位的时候,我们要求不同芯片之间的总线工作在合理的状态上(比如处于高阻态或者输出);然而上电之后,由于系统时钟可能仍未正常工作,上电(同步)复位就可能无效,这个时候各个模块(芯片)就可能不会把总线接口设置为特定的状态,(当多个模块同时输出数据到总线上时)就可能导致电平冲突,严重的话会烧坏接口。

      解决办法:为了防止芯片上电时内部总线出现竞争,有一下两种解决办法,一种是采用异步上电复位,如下图所示:

                 

              这个时候使用了异步复位,使能信号oe输出0,也就是有了初始的状态

      另一种方法是使用复位信号能直接撤销三态使能的电路,如下所示:

               

    从电路图中可以看到复位信号一方面控制了复位逻辑,另一方面控制了三态的使能端;这种技术简化了复位-高阻这个条路径的时序分析。

     

     

    3.异步复位

    (1)异步复位电路

      异步复位触发器则是在设计触发器的时候加入了一个复位引脚,也就是说复位逻辑集成在触发器里面。(一般情况下)低电平的复位信号到达触发器的复位端时,触发器进入复位状态,直到复位信号撤离。带异步复位的触发器电路图和RTL代码如下所示:

     

     

     

    (2)异步复位的优点

      ①使用异步复位的最大好处就是复位路径上没有延时,如上面的图所示,复位信号一直连接到触发器的复位端口,而不是像同步复位那样需要经过一个复位控制逻辑(如与门)。这样子就减少了外界信号的影响。

      ②与时钟没有关系,不管时钟上升沿有没有到来,只要复位信号一有效,触发器就会复位,也就是基本上做到实时性;由于与时钟没有关系,因此也可以用在门控时钟里面

      ③综合工具能自动推断出异步复位而不必加入任何综合指令

     

    (3)异步复位的缺点

      ①复位撤离问题

      在介绍复位撤离问题之前,先说一下复位恢复时间和去除时间。所谓的复位恢复时间是指撤离一个复位信号时,复位信号从有效跳变为无效的时刻  与  下一个有效时钟沿  之间的这段时间去除时间是指撤离一个复位信号时,复位信号从有效跳变为无效的时刻  与  上一个有效时钟沿  之间的这段时间(可以类比于触发器的建立时间和保持时间)。如下图所示:

               

          上图中,rst_n1是要求的复位恢复时间,rst_n2满足复位恢复时间,rst_n3复位恢复时间不足。

               

          上图中,rst_nA是要求的复位去除时间,rst_n2满足复位去除时间,rst_n3复位去除时间不足。

      从上面的两个图中可以知道,如果你想让某个时钟沿起作用(也就是采数据),那么你就应该在“恢复时间”之前让异步控制信号变无效;如果你想让某个时钟沿不起作用(也就是在这个时钟沿依旧复位),那么你就应该在“去除时间”过后使控制信号变无效。异步复位信号的恢复和去除时间需要大于一定的时间,如果你的异步复位信号在这两种情况之间(撤离),那么就没法确定时钟沿是否起作用了,即判断不出是复位还是不复位(不复位即是D触发器才输入端的数据)

      介绍了复位恢复时间和去除时间之后,我们就可以看看异步复位信号的问题了。由于异步复位信号与系统时钟毫无关系,复位可以在随时施加,也可以随时撤离。在施加的时候复位信号的时候,不存在任何问题,因为这跟复位恢复时间扯不上关系。但是,在撤离复位信号的情况下就有问题了,主要有两个问题:

      ·当异步复位信号的撤离时刻在时钟有有效沿附近时,就可能导致恢复时间或去除时间不足,即这个时候违背了复位恢复时间或去除时间,这时就可能导致触发器的输出端为亚稳态(注意是可能),如下所示:

               

      但是并不是所有情况都会产生亚稳态,当复位值和此时的的输出相同时,就不会产生亚稳态,如下图所示:

               

    这是因为:复位信号翻转的时候,如果复位信号判断是低电平输出就复位即一定是低电平;如果判断复位信号是高电平输出信号就等于对输入信号的采样值。图里面输入信号就是低电平,不管你是复位还是不复位,输出一直是低电平,没有亚稳态。

     

      ·复位状态不一致的问题:

      复位信号很时钟信号一样,复位通过复位网络到达各个触发器。一方面,复位网络具有非常大的扇出和负载,到达不同的触发器存在不同的延时,也就是存在复位偏移,因此撤离异步复位的时刻也是不一样的;另一方面,由于时钟网络也存在时钟偏移。这个时候异步复位信号就有可能在不同的触发器的不同时钟周期内进行撤离,也就是说异步复位的信号不一致,如下图所示:

               

      异步复位信号a是异步复位信号源,异步复位信号b、c、d是到达触发器的异步信号。我们可以看到,b信号是在本周期就撤离了复位;c信号则由于复位恢复时间不满足,则可能导致触发器输出亚稳态;而d信号则由于延时太长(但是满足了复位去除时间),在下一个周期才撤离复位

      

      撤离问题的解决方法:异步复位的同步释放

      异步复位的同步释放电路也称为复位同步器,这个方法是将外部输入的异步复位信号进行处理,产生另外一个适合用于后面电路的复位信号,这个处理后的复位信号能够异步复位电路中的触发器,又不会存在撤离问题(因为经过了同步);这个异步复位同步释放的处理电路和RTL代码如下所示:

                     

          

    从图中可以看到,这是用外部异步复位信号来复位一对触发器,这对触发器异步地驱动主复位信号,也就是这对触发器产生电路需要的复位信号,这些复位信号再到达各个触发器,然后进行复位,理想的异步复位同步释放的时序如下所示:

             

     

    上图中,在理想的情况下,复位信号在两级D触发器上面的撤离时间可能不一样,这个和复位信号传输到的触发器位置和触发器的时钟沿有关。理想情况下的复位信号传输到目标触发器都能够同时撤离,并且不在时钟有效沿附近

      实际情况一般不是那么理想的,当不是理想的情况下,也就是说复位信号到达目标寄存器存在时钟偏移,并且复位信号有可能在时钟有效沿附近撤离,这个时候复位器出现的问题就有三种:第一级OK,第二级出现问题;第一级出现问题,第二级OK;两级都出现问题。下面我们就来看看这三种情况下产生的复位信号是什么情况:

      第一级的撤离没有问题,第二级的撤离出现在时钟的有效沿附近,也就是说第二级的D触发器的撤离时间不满足复位恢复时间或者去除时间,这时候的时序图如下所示:

             

    我们可以看到无论是触发器判断此刻是复位还是不复位,输出都是一样的,也就是说,输出rst_n不是亚稳态,而是确定的值。

     

      第一级的撤离出现问题,第二级的撤离没有问题,这时候的时序图如下所示:

           

    我们可以看到,第一级触发器虽然产生了亚稳态,但是由于第二级触发器的存在,亚稳态并没有传播下去,得到的复位信号依然是干净的,只不过这个复位信号可能延长多一个周期而已(这是因为亚稳态稳定后的可能态引起的)。

     

      最极端的一种情况是,两级的撤离都不满足复位恢复时间或者去除时间,这时候的时序图如下所示:

           

    我们可以看到第一级触发器产生了亚稳态,但是由于第二级触发器的存在,亚稳态没有传播下去;虽然第二级触发器的复位信号撤离也在时钟有效沿附近,但是跟第一种情况一样,第二级触发器是不会产生亚稳态的。因此即使是极端状态,输出的复位信号也是干净的。

      由此我们可以看到,异步复位的同步撤离能够有效地解决撤离导致的复位恢复时间或者去除时间不足的问题,同时把复位信号同步化,解决了复位撤离偏移的问题。

     

      ②异步复位的抖动问题

      当外部输入的异步复位信号产生毛刺时,任何满足触发器最小复位脉冲宽度的输入都有可能引起触发器复位,这问题是源头上的问题,即使是使用上面的同步器,也还是有同样的敏感问题,时序图如下所示:

                   

      解决方法:一个是使用同步复位,另一个就是过滤毛刺了,过滤毛刺和消抖的思路有点像,主要就是经过一段延时之后,在经过逻辑门判断产生外部来的是不是真正复位信号,加上过滤毛刺信号部分的同步撤离电路和时序如下所示:

                 

                       

    在上图中,我们可以看到,抖动问题得到了解决。然而这种方法还是有缺点的,主要就是这个延时电路的延时控制可能随着环境而变化,而且延时的时间要合适长才行,绝对不能太短。

     

      ③DFT的问题

      在DFT的时候,如果异步复位信号不能直接被I/O引脚驱动,就必须将异步复位线和后面的的被驱动电路断开,用来保证DFT扫描和测试能够正确进行。总之异步复位增加了DFT的复杂性

     

     

    4.复位策略——复位网络

      在数字电路里面,复位信号驱动了很多触发器,仅次于时钟,因此复位也往往形成或者使用复位网络。复位网络的设计也是有值得斟酌的地方,例如,由于复位的扇出太大,全部的复位不能仅仅由一个端口驱动,也就是不能像下面一样:

                     

      既然上面的不行,那就改成下面的呗,也就是使用多各“并联”的同步释放,分担一下负载压力:

                     

      然而这种方案还是有问题的,这是第一级的撤离出现问题,第二级的撤离没有问题的时候,亚稳态稳定后的状态可能不一样,导致rst_n的复位不一致,有的复位可能会快/慢一个周期。

      最后的方案是,先进行同步释放之后,同步后的复位信号又当做各个部分的异步信号,然后进行同步释放,如下所示:

                 

    这样先经过前级的同步释放之后,就不存在亚稳态稳定好导致的输出rst_n不一致的问题了。

     

      最后说一下多时钟域的复位:在多时钟域复位中,外部的异步复位信号的同步释放应该各自的时钟进行同步,比如异步FIFO中,写时钟域就用写时钟进行同步释放;读时钟域就用读时钟进行同步释放。

    展开全文
  • 单片机复位电路详解

    千次阅读 2017-06-04 21:34:43
    复位电路工作原理: 51单片机复位只需要在第9引脚接个高电平持续2us就可以实现复位。也就是说 单片机RST引脚接收到2US以上的电平信号,只要保证电容的充放电时间大于2US... 复位电路图.1 在图1中,电容的的大小是10

    上电复位电路工作原理:

    51单片机复位只需要在第9引脚接个高电平持续2us就可以实现复位。也就是说 单片机RST引脚接收到2US以上的电平信号,只要保证电容的充放电时间大于2US,即可实现复位

                                        

                                                                                                                                                   复位电路图

    上电复位过程分析:

    图1(高电平复位):当单片机上电瞬间由于电容电压不能突变会使电容两边的电位相同既 Uc1 = 0V,由VCC = Uc + Ur(电源电压等于电阻与电容两边电压之和)可得出RST为高电平,之后随着时间推移电源对电容充电完成 Uc1 = VCC ,Ur1 = 0V(此时 R1 相当于一根导线)则RST为低电平。正常工作为低电平,高电平复位。(51中常用)

    图2(低电平复位):当单片机上电瞬间由于电容电压不能突变会使电容两边的电位相同既Uc2 = 0V,由VCC = Uc + Ur(电源电压等于电阻与电容两边电压之和)可得出此时RST为低电平,之后随着时间推移电源通过电阻对电容充电完成Uc2 = VCC, Ur2 = 0V(此时 R1 相当于一根导线)则充满电时RST为高电平。正常工作为高电平,低电平复位。(32中常用)


    复位时间求解分析:

    在图1中,电容的的大小是10uf,电阻的大小是10k。所以根据公式(电容充放电公式及求解过程见附录1),可以算出电容充电到电源电压的0.7倍(单片机的电源是5V,所以充电到0.7倍即为3.5V),需要的时间是 1.2*10K*10UF=0.12S。也就是说在单片机启动的0.12S内,电容两端的电压时在0~3.5V增加。这个时候10K电阻两端的电压为从5~1.5V减少(串联电路各处电压之和为总电压)。所以在0.12S内,RST引脚所接收到的电压是5V~1.5V。在5V正常工作的51单片机中小于1.5V的电压信号为低电平信号,而大于1.5V的电压信号为高电平信号。所以在开机0.12S内,单片机系统自动复位(RST引脚接收到的高电平信号时间为0.12S左右)。


    附录1

    电容充电公式:

                       Vt="V0"+(V1-V0)* [1-exp(-t/RC)]     (公式1)

                          

    V0 为电容上的初始电压值

    V1 为电容最终可充到或放到的电压值

    Vt 为t时刻电容上的电压值 

    exp():是以e为底的指数  exp(-t/RC) = e(-t/RC)

    由公式1 推出 t = RC*Ln[(V1-V0)/(V1-Vt)]

    例题:初始电压V0 = 0, 为电容最终可充到或放到的电压值V1 = VCC,求充电到Vt = 70%VCC的时间t。(V0=0,V1=VCC,Vt=0.9VCC) 

    解答:代入上式: 0.7VCC = 0+VCC*[[1-exp(-t/RC)] 

                     [[1-exp(-t/RC)]=0.7 

                     exp(-t/RC)=0.3 

                      - t/RC=ln(0.3)

                      ln(0.3 )约等于 -1.2    也就是t=1.2RC。 带入R=10k   C=10uf得。求得 t=1.2*10k*10uf=120ms 


    参考连接:http://www.eepw.com.cn/article/201604/290211.htm

    https://wenku.baidu.com/view/2cb8b8e75ef7ba0d4a733b36.html

    http://www.51hei.com/bbs/dpj-27603-1.html


    展开全文
  • 不错的protel文件以后的毕业设计或者课程设计都会用到的时钟及复位电路原理
  • FPGA怎么搭复位电路 fpga复位电路设计方案
  • 复位电路的Multisim仿真结果如所示。在中,当电源电压上升到一定值时,复位信号跳高使控制部分正常工作。中,处于上方的信号是电压信号,处于下方的信号是复位信号。 复位电路波形  欢迎转载,信息维库...
  • 本文主要讲了51单片机复位电路原理,下面一起来学习一下
  • STM32复位电路

    万次阅读 2019-03-06 19:05:14
    ** STM32复位电路 **
  • 复位电路 时钟电路我第一篇博客已经说讲过了,今天我们来聊聊复位电路。当然,复位电路博大精深,并不是三言两语就能说清楚的,因此这里也是聊聊复位电路的基础,更深的研究需要在实际的项目中才能...
  • 说到复位,我们都不会陌生,系统基本都有一个复位按键。复位的种类有很多:上电复位、掉电复位、复位引脚复位、看门狗复位、软件复位等。本文探讨的就是在stm32中复位电路如何设计。
  • 复位电路设计

    2021-03-06 22:09:02
    复位电路是数字逻辑设计中非常常用的电路,不管是 FPGA 还是 ASIC 设计,都会涉及到复位,一般 FPGA或者 ASIC 的复位需要我们自己设计复位方案。复位指的是将寄存器恢复到默认值。一般复位功能包括同步复位和异步...
  • 复位电路的设计

    千次阅读 2020-06-05 13:44:47
    1 RC复位电路 1.1低电平复位 1.2高电平复位 2 MAX809 复位电路,就是利用它把电路恢复到起始状态。就像计算器的清零按钮的作用一样,以便回到原始状态,重新进行计算。和计算器清零按钮有所不同的是,复位电路...
  • avr单片机复位电路

    千次阅读 2014-05-20 10:57:30
    avr单片机复位电路 AVR复位电路的设计 ... 若是系统需要设置按键复位电路,那么注意,AVR单片机是低电平复位,如下,设计按键复位电路: 复位线路的设计  Mega16已经内置了上电复位设
  • 复位电路工作原理

    千次阅读 2019-10-07 07:07:52
    复位电路的作用 在上电或复位过程中,控制CPU的复位状态:这段时间内让CPU保持复位状态,而不是一上电或刚复位完毕就工作,防止CPU发出错误的指令、执行错误操作,也可以提高电磁兼容性能。无论用户使用哪种类型的...
  • SOC中的复位电路

    千次阅读 2019-11-19 14:38:07
    1.复位电路概述  复位信号在数字电路里面的重要性仅次于时钟信号。对电路的复位往往是指对触发器的复位,也就是说电路的复位中的这个“电路”,往往是指触发器,这是需要注意的。有的电路需要复位信号,就像是有的...
  • 一般的单片机都要具备两个外围电路:时钟电路和复位电路 时钟电路 主要由一个晶振和两个电容组成。晶振的大小决定这单片机的时钟信号 (按我的理解就是:单片机编程时,同一个延时函数,晶振决定着它们的延时时间...
  • 复位电路设计问题

    千次阅读 2017-09-15 12:14:11
    最近看advanced fpga 以及fpga设计实战演练中有讲到复位电路的设计,才知道复位电路有这么多的门道,而不是简单的外界信号输入系统复位。 流程: 1.同步复位: 优点:同步的典型优点是确保电路100%是同步电路;...
  • AT89C51常见的复位电路

    2011-05-18 10:30:43
    本资源提供所有单片机用的复位电路原理,欢迎下载
  • 详解单片机复位电路

    千次阅读 2019-09-23 17:52:58
    1.复位电路的工作原理 在书本上有介绍,51单片机要复位只需要在第9引脚接个高电平持续2us就可以实现,那这个过程是如何实现的呢?在单片机系统中,系统上电启动的时候复位一次,当按键按下的时候系统再次复位,如果...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 21,252
精华内容 8,500
关键字:

复位电路图