• 设计中隐藏bug记录


    从今天开始,记录本人在设计中留下的隐藏bug,时常翻阅,谨记于心。

    1. 项目中有一些保护事件,其中一个保护事件的级别最高。当该事件发生时,系统状态机进入保护模式,直到事件消失,再回到其他状态。

        然而,因为一些其他原因,在该最高级别的事件发生时,引起了power on 复位,致使内部所有trimming值复位成0。如果要恢复这些trimming值,

        就必须重新进行OTP(efuse)load,而正常的OTP load过程需要状态机从IDLE进入。虽然power on复位产生了,状态机也复位成IDLE了,但是

        由于该事件的最高优先级性,致使当power on 复位释放后,状态机又立即进入了保护模式,跳过了OTP load状态。最终导致,即使该事件消失,

        power on复位释放了,电路也不能正常工作。

         解法:考虑在该事件释放时,触发一次OTP load,或者修改系统状态机。

    2. 设计中为了防止异常状况出现,增加了一个软复位功能,也就是通过通讯接口(I2C、SPI或者UART等)写入命令,来触发一次复位。

        设计中的做法是,当通讯接口写入命令后,一个中间变量有效,再用内部时钟打三拍进行同步处理,用第二、第三拍做一个上升沿pulse,将这个pulse取反,并入

        全局复位rst_n,组成了新的全局复位rst_n。按道理,这样做是没有问题的。但实际上忽略了一个问题。因为全局复位rst_n,既用于通讯接口电路,

        也用于上述三拍同步电路,所以当进行软复位时,既复位了其他电路,也把同步电路复位了,这会造成综合后的电路,那个pulse引起的复位时间(即取反后的低

        电平维持时间)很短,有可能不能产生有效的复位。

        解法:更换上述三拍同步电路的复位源。

  • 相关阅读:
    Missing Ranges
    springboot整合quartz
    Quartz01
    springboot整合jap
    springboot集成redis
    springboot整合drui、mybatis、pagehelper
    springboot模板
    SpringBoot入门
    Java注解简介
    Git02(ssh key的配置和使用、idea配置并使用Git)
  • 原文地址:https://www.cnblogs.com/hxing/p/14423948.html
Copyright © 2020-2023  润新知