热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

软件也能解决静电的问题

软件设计也能解决一部分静电放电静电放电固件和软件设计原则在对付静电放电方面,除了众所周知的硬件方法以外,固件和软件也起着重要的作用。虽然固件设计不能防止系统中器件的损坏,但是能
 软件设计也能解决一部分静电放电

静电放电固件和软件设计原则在对付静电放电方面,除了众所周知的硬件方法以外,固件和软件也起着重要的作用。
  虽然固件设计不能防止系统中器件的损坏,但是能够有效地避免一些非永久性的损坏。通过适当写入的固件,不可恢复的设备故障(死锁)通常可以避免,可恢复的故障也可以减少10倍。
  如同硬件上的静电放电措施一样,抗静电放电的固件也是有代价的。通常,程序会更大一些,这意味着需要更长的编程时间和存储单元。权衡得失时,要将这种代价与单纯依靠硬件解决静电放电问题时的成本做对比。在许多微处理器的应用中,固件措施的成本要比硬件低。
  在编写静电放电抗扰性强的固件时一定要树立的的一个观念是“不确定性”。也就是,一定不能认为端口、寄存器等的状态是一定的。例如,当使用一个索引寄存器时,应该问一下,如果这个索引发生错误时,会发生什么问题。如果仅是仅发生一些暂时的或无关紧要的问题,如发光二极管闪烁,则不需要什么特殊的处理。如果会发生很严重的问题,例如系统发生死锁,则必须采取措施来避免问题的发生。
  固件(软件)静电放电措施可以分为两类:
    * 刷新
    * 检验和重新写入
  下面从概念上讨论每种措施,并给出一些例子。由于不可能预见到所有的特殊情况,要使固件能够抵抗静电放电,设计人员必须对整个系统有一个全面的了解。虽然下面的讨论主要针对固件,但是其中的许多概念对于软件设计也是适用的。
  刷新:
  进行刷新时,程序员不关心过去的情况,而仅是用确定的数据来保证今后的状态。例如,在从8409的端口读取数据时,一定要先向端口写入数据。即使这个端口从上次更新以后一直没有改写,也要进行这个步骤。绝不要认为端口上还保留着上次写入的数据。刷新时需要考虑的其它因素包括:
  A) 按照一定的时间间隔打开中断使能端(在8049中是RETR,在8051中是RETI)
  B) 当端口用于串行数据输出时,刷新停止位的电平。
  C) 刷新锁存器和端口输出状态。
  D) 定期读取控制和选择输入,保证系统工作在适当状态。
  E) 对于8049和8051处理器,每个程序环路中至少有一条寄存器选择指令。

  在进行刷新时,另一个需要考虑的因素是刷新的顺序。有时,刷新的顺序十分重要。例如,在同步输入/输出中,数据线一定要在时钟线之前刷新。否则,经过刷新的时钟会使数据位丢失。如前所述,一定要考虑在错误条件下每条指令的顺序。
  检验和复位:
  有时,单纯刷新还是不够的。在有些情况下,刷新甚至会掩盖一些严重的问题。在这些情况下,寄存器、端口等需要通过检验来确认其状态。如果状态不对,程序应该试图对其进行更正。
  进行复位(或初始化)时一定要非常谨慎。虽然系统的状态可能有疑问,但是将系统彻底初始化并不是一个好方法。这会丢失所有过去的数据。应该遵守的原则是,使系统处于最可能的状态,而这个状态应该使问题的危害最小。如果有些关键的项目没有最可能的状态,则应该将其状态保留起来。这便于以后采用投票的方式来确定当前状态。通常,“3取2”的投票方式就可以了。
  检验函数通常可以分为3类。特别要做以下检验,如果发现错误,需要初始化。
  A) 检验程序流是否正确:
   1) 在主程序中,在子程序返回前,要定期检验子程序堆栈指针,以确认子程序在预定的范围内运行。
   2) 如果不检查堆栈指针(或在检查堆栈指针的基础上),可以使用“标牌”来帮助发现程序运行中的问题。当进入一个子程序时,保存标牌,当离开子程序时,检查这个标牌。
   3) 在禁用区域中安排“陷阱”码,例如编码表或无用的中断矢量。当程序要执行这些码时,就被抓住(例如在未使用的表格中安排返回指令)。
为了检查程序流是否正常,在程序中还应该包含以下两个子程序:
   4) 为了确认主程序运行正常,应该有一个永远不会停止和失效的计时程序。
   5) 主程序应定时检查上面的定时程序,确认其是否运行正常(如果微处理器没有内置的计时器,可以使用外置的硬件“看门狗”电路。当处理器没有按时将计时器复位时,外置电路会将处理器复位)。

  B) 检验存储的数据和信息是否正确
   1) 定期对保留的项目进行表决,如果没有一致性,进行初始化。特别,状态标志(特别是使能标志)要保留有备份。除了备份以外,还可以使用纠错码。
   2) 对于索引和其它一些十分重要的寄存器,在使用其所存储的数据之前,要对其数值或范围先进行检查。
   3) 如果关键数据很多而不适合备份,或者无法检验所有信息时,可以用检验和或周期性冗余检验(CRC)来对数据块检验。

  C) 对输入和输出进行检验
   1) 利用各种方法,如奇偶校验、检验和等,对输入进行检验
   2) 确认输入数据的合理性,有些数据可能有明显的错误。
   3) 对所有输入级电平至少取样两次以实现对噪声的“软件滤波”
   4) 通过使接收机响应输出级来进行校验输出端
   5) 接收装置应能识别所有有效的输入信号,如果接收装置不能识别,那么发送装置应具有再传输能力。
  如果以上措施均不能正确检查,则要求能自动恢复。当然,这种恢复能力通常不能与加电(或硬件)复位过程中的初始化程序不同,RAM不应清除掉。实际上,由于静电放电(ESD)而使错误程序反向复位时,执行硬件初始化程序不应妨碍处理器的工作。这通常可以通过检查执行硬件复位程序的标志寄存器的优先级来完成。如果已经设定标志,则应避免完全复位。当主程序执行时,此标将被重新设定,一般仅被处理器的实际硬件复位所清除。特别地,通常应按以下步骤来完成复位:
  1、复位子程序堆栈指针。
  2、复位FIFO指针。
  3、复位计数器。
  4、阻止可疑码的传输。
  5、在复位完成时才允许中断,然后再重新启动计数器。
  6、复位中断不确定的标志
  7、刷新输出。
  8、如果主机系统接受复位,最好使其发磅一代码以通知复位已完成。那么,主机就可以采取措施来确保系统的所有部分都谐调一致地工作。
  9、当然,复位程序必须清除引起复位动作的具体问题。

  上述大部分讨论假定系统正处于执行程序的状态中(尽管不一定正确),`如果程序包括表格,处理器可能会尽力去执行这些单元值并将其作为指令。从理论上讲,内存单元值可能会引起看门狗计数器停止计数,从而使处理器进入死循环。对于这种情况,可将逻辑分析仪接到地址总线,这样有可能找到问题的症结所在。循环期间的一个内存单元值应由一个返回指令来代替。这一般会使处理器跳出循环,于是程序可能会发生变化,因此,被替换的单元值便经过特殊方式进行了处理。(如果有可能的话,空闲的内存单元地址应用于控制这个返回操作码。实际上,如前处述,将返回码填满所有空闲地址是极有可能的。)当然,这个逻辑分析仪也能够发现程序其他部分的死循环。然而,如利用带有伪程序的单片微处理器来进行设计,那么地址总线将变得无效。这种情况下,在调试后,程序可以在仿真系统中具有“静电放电加固”的性质。一旦程序被调试好且运行正常的话,它就可随意改变寄存器的值以模拟静电放电效果。
  程序计数器是很关键的,应被设置成随意值。而且,子程序堆栈指针应设置成变量值。通过在仿真过程中作这些变化且不影响结果,许多潜在的问题都可以得以发现。这种方法并不总是有效的,但带有特殊问题的系统是不允许的。应用这些原理,与固件相关的静电放电问题相对来说会很少的。


推荐阅读
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 利用存储过程构建年度日历表的详细指南
    本文将介绍如何使用SQL存储过程创建一个完整的年度日历表。通过实例演示,帮助读者掌握存储过程的应用技巧,并提供详细的代码解析和执行步骤。 ... [详细]
  • 自学编程与计算机专业背景者的差异分析
    本文探讨了自学编程者和计算机专业毕业生在技能、知识结构及职业发展上的不同之处,结合实际案例分析两者的优势与劣势。 ... [详细]
  • SQLite 动态创建多个表的需求在网络上有不少讨论,但很少有详细的解决方案。本文将介绍如何在 Qt 环境中使用 QString 类轻松实现 SQLite 表的动态创建,并提供详细的步骤和示例代码。 ... [详细]
  • 作为一名程序员,从大学步入职场后,常常感受到一种难以言喻的空虚感。这种感觉或许源于对生活的不满、职业发展的瓶颈,或是日常琐事带来的压力。本文将深入探讨这种复杂的情感,并尝试寻找解决之道。 ... [详细]
  • 深入解析:阿里实战 SpringCloud 微服务架构与应用
    本文将详细介绍 SpringCloud 在微服务架构中的应用,涵盖入门、实战和案例分析。通过丰富的代码示例和实际项目经验,帮助读者全面掌握 SpringCloud 的核心技术和最佳实践。 ... [详细]
  • LeetCode 540:有序数组中的唯一元素
    来源:力扣(LeetCode),链接:https://leetcode-cn.com/problems/single-element-in-a-sorted-array。题目要求在仅包含整数的有序数组中,找到唯一出现一次的元素,并确保算法的时间复杂度为 O(log n) 和空间复杂度为 O(1)。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 阅读本文大约需要3分钟。微信8.0版本的发布带来了许多令人振奋的新功能,如烟花特效和改进的悬浮窗,引发了用户的热烈反响。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
author-avatar
rhp3465483
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有