0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

面向任务关键型应用的FPGA

星星科技指导员 来源:嵌入式计算设计 作者:RAJIV JAIN 2022-11-14 15:46 次阅读

大多数FPGA技术都无法满足关键任务设计要求,但基于防熔断器的架构取得了成功,提供了抗辐射性和设计安全性等基本属性。

当今的高密度 FPGA 为设计人员提供了快速创建定制组件的机会,以实现最佳性能和任务关键型系统的快速部署。但对于军事和航空航天应用,众所周知,基于存储器的FPGA技术无法满足几个重要要求,包括抗辐射性和设计安全性。防熔断器FPGA技术成功地满足了这些要求,将可编程逻辑的优势带到关键任务系统设计中。

许多开发人员明白,任务关键型系统必须设计为在极端环境条件下可靠运行,但发现大多数FPGA技术都难以满足这些需求。此外,在确定设备是否适合大多数FPGA技术不足的关键任务服务时,还有其他要求同样重要。我们的讨论将集中在其他三个关键要求上:非易失性配置、辐射环境中的可靠运行和设计安全性(表1)。

表1

pYYBAGNx8lyABhukAAAfVjP2Vwk961.jpg

影响关键应用的三个因素

对非易失性配置的要求源于关键任务军用航空应用中电源中断的高概率。在维护或维修期间更换带电系统组件、从线路电源切换到电池电源时的失误以及掉电都可能触发系统从电源中断中恢复的需要。非易失性系统配置简化了恢复过程,无需重新加载系统设置和参数。这使得系统恢复比必须重新加载配置时更快、更不容易出错,从而提高了系统可用性以执行其任务。

此外,随着冷战的结束,对军用航空系统在辐射环境中运行的需求已经从普遍意识中消失了。然而,这一要求不仅仅来自在核事件中幸存下来的需要。即使在日常操作中,关键任务系统也可能暴露在高辐射水平下。辐射以宇宙射线和太阳风的形式出现,以及这些来源在高海拔地区产生的高能二次粒子(见图1[1])。

图1

poYBAGNx8l6AGT4lAAA96tfq1fE498.jpg

虽然辐射通量通常不足以损坏半导体器件,但它确实会对系统运行产生影响。辐射的典型效应是单事件翻转(SEU):一种能够改变存储单元位值的局部能量尖峰。如果这种变化发生在FPGA内的关键位置,可能会对系统运行造成严重破坏。

设计安全性是关键任务系统设计的第三个要求,特别是军事系统。如果设计不安全,敌人可以通过逆向工程和克隆捕获的设备供自己使用来迅速消除此类设计提供的任何技术优势。系统还可能嵌入敏感信息,例如密码、加密密钥和跳频算法。从捕获的系统中提取此类信息将允许敌人制造能够拦截和解释编码通信或生成模仿信号以混淆指挥和控制活动的设备。进行逆向工程困难、昂贵且耗时的设计可以通过延迟结果直到它们不再有用来防止这种妥协。

比较 FPGA 技术

在利用FPGA技术开发关键任务系统时,这些被忽视的设计要求尤为重要。使用 FPGA 器件可为开发人员提供与使用 ASIC 相当的设计灵活性和集成度,但成本要低得多,并且可用性更即时。然而,并非每种FPGA技术都适合任务关键型设计的需求。

例如,许多FPGA未能满足非易失性要求,因为它们以SRAM为基础。这些 FPGA 中的内部逻辑连接依赖于 SRAM 单元来保持开关晶体管的打开或关闭(图 2)。因此,存储在存储器中的数据决定了FPGA的配置,但SRAM单元在断电时将丢失其数据。

图2

pYYBAGNx8l-AACwaAAAw3JpiiXI777.jpg

基于 SRAM 的 FPGA 需要在上电时接收配置数据,以便为系统运行做好准备。典型的方法是采用小型外部非易失性存储器源(如串行EEPROM)来保存配置数据。上电后,FPGA从EEPROM检索数据并自行配置工作。根据存储器的大小和FPGA可以检索数据的时钟速率,FPGA可能需要上电后几百毫秒才能准备好使用。系统的其余部分必须等到FPGA准备就绪才能完全运行。

可编程逻辑的SRAM方法也有几个不幸的设计属性。一是每个连接点所需的威廉希尔官方网站 相当大,需要多个晶体管来形成SRAM单元,导致互连密度降低。开关晶体管的互连电容增加了FPGA的动态功耗,增加了结温并降低了器件可靠性,即使不计时,大存储单元的漏电流也会浪费功率。

一种非易失性可编程逻辑方法具有类似的开关结构,但使用EEPROM单元而不是SRAM来保持配置。这种方法解决了波动性问题,但仍与基于SRAM的FPGA共享许多其他属性。该架构仍然要求在每个连接点安装一个开关晶体管,从而限制了通过连接的互连密度和信号速度。

EEPROM单元的工作原理是在浮动栅极上保持电荷,以保持开关晶体管的打开或关闭。当高压编程信号通过穿过氧化层将电子驱动到栅极上或离开栅极时,浮动栅极接收或失去其电荷。在正常工作中,栅极没有可用的放威廉希尔官方网站 径,因此使得FPGA配置是非易失性的。

提供非易失性的另一种方法是使用防熔断技术。防保险丝是FPGA中每个可配置威廉希尔官方网站 结处的非晶硅过孔。未经编程,过孔是绝缘体,在该站点没有连接。通过对其施加高压来编程过孔,将其状态更改为导体,从而在该站点进行连接。因此,过孔的物理状态与FPGA的配置保持一致。状态变化是永久性的,使防熔断器FPGA非易失性。由于没有晶体管参与维持逻辑连接,因此互连密度高且没有漏电流。互连电容低,降低了动态功耗。

解决辐射问题

除了波动性问题之外,在辐射环境中工作的需求是对基于存储器的FPGA技术的第二次打击。通过有源半导体器件的高能粒子在硅中产生临时电离路径。这些通路可以短暂地短路晶体管,产生称为SEU的瞬态脉冲。

在SRAM中,SEU可以反转单个位的状态,然后存储器威廉希尔官方网站 将保持该状态。在EEPROM中,SEU可能会对浮动栅极放电,从而导致永久性的位变化。虽然处理器应用中使用的存储器通常包括纠错和检测来处理此类事件,但FPGA的配置存储器没有这种保护。因此,SEU 可以在基于存储器的 FPGA 中引入持久的逻辑更改。

反保险丝FPGA没有这样的漏洞。SEU的能量不足以对过孔进行编程,瞬态脉冲对逻辑没有显着影响。在NASA/戈达德进行的测试表明,在辐射能量高达193 MeV的反保险丝FPGA操作中没有错误,而存储设备开始出现低至100 MeV的位错误。

防熔丝 FPGA 还比基于存储器的 FPGA 更有效地解决设计安全性问题。要完整表征编程的FPGA,需要两条信息:配置细节和底层结构。配置细节在基于存储器的FPGA中最容易捕获。对于实时系统,无源探测可以在配置期间移动到基于 SRAM 的 FPGA 时捕获编程数据。电子探测可以确定威廉希尔官方网站 处于活动状态时EEPROM构型电池的电荷状态。这两种方法的执行速度都相对较快,实施成本也很低。

确定FPGA的逻辑结构需要更多的努力,但逆向工程方法可以提取器件的设计细节,价格低于10万美元。方法是使用等离子体(用于钝化和氧化层)或化学(用于金属层)蚀刻剥离逻辑器件的每一层,一次一层,然后在显示每一层时拍摄高分辨率照片(图 3)。这些照片可以重建用于制造设备的掩模组。然后,这允许分析甚至克隆设备。

图 3:3A 和 3B

poYBAGNx8mCAUbSmAABYB_oJ8SY151.jpg

然而,研究反熔断器FPGA的编程需要更精细的措施。这部分是因为可编程元件位于多层结构中,因此表面扫描无效。此外,没有信号或存储电荷进行探测;程序存储是影响电阻的结构变化,而不是电荷的积累。

只有体检才能显示反引信的编程状态,剥层法不会有效工作。反引信中改变区域的横截面太小,无法从上方观察,因此可靠地看到结构的唯一方法是从侧面(再次参见图 3)。获得此视图需要使用聚焦离子束 (FIB) 在设备中创建沟槽,然后铣削边缘以逐步扩展沟槽。在每一步拍摄照片可以创建威廉希尔官方网站 的3D图像。然而,这个过程需要昂贵的设备,而且在不知道去哪里寻找的情况下非常耗时。即使有先见之明,需要检查的反引信数量也使这项任务变得不切实际。对编程反熔丝FPGA(如QuickLogic的QL1P075和QL1P100‘Äì)进行逆向工程所需的时间实际上使它们绝对安全。

防熔断器满足关键任务需求

军用航空应用的设计安全需求,以及耐辐射性和非易失性,在文献中经常被忽视,但设计人员也不容忽视。在寻求FPGA在设计中的优势时,开发人员习惯性地寻找能够解决mil temp操作的器件,但他们也应该考虑基础技术满足上述需求的能力。在FPGA技术中,反熔断器可编程性是唯一满足关键任务设计所有要求的技术。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1629

    文章

    21746

    浏览量

    603760
  • 存储器
    +关注

    关注

    38

    文章

    7494

    浏览量

    163899
  • sram
    +关注

    关注

    6

    文章

    768

    浏览量

    114702
收藏 人收藏

    评论

    相关推荐

    使用任务通知提高RTOS应用的效率

    在实时嵌入式系统中,性能和资源效率是决定设计成败的关键因素。传统的实时操作系统(RTOS)提供了如队列、信号量和事件组机制,实现任务之间的同步和通信。FreeRTOS/SAFERTOS还提供一种方法可以使这些过程更快、更轻量化,即任务
    的头像 发表于 12-27 14:54 196次阅读

    借助增强航天塑料产品降低近地轨道任务的风险应用说明

    电子发烧友网站提供《借助增强航天塑料产品降低近地轨道任务的风险应用说明.pdf》资料免费下载
    发表于 09-11 09:53 0次下载
    借助增强<b class='flag-5'>型</b>航天塑料产品降低近地轨道<b class='flag-5'>任务</b>的风险应用说明

    FPGA如何消除时钟抖动

    FPGA(现场可编程门阵列)设计中,消除时钟抖动是一个关键任务,因为时钟抖动会直接影响系统的时序性能、稳定性和可靠性。以下将详细阐述FPGA中消除时钟抖动的多种方法,这些方法涵盖了从
    的头像 发表于 08-19 17:58 1387次阅读

    FPGA设计面临的挑战和解决方案

    设计可靠的可编程逻辑门阵列(FPGA)对于不容故障的系统来说是一项具有挑战性的任务。本文介绍FPGA设计的复杂性,重点关注如何在提高可靠性的同时管理随之带来的功耗增加、设计复杂性和潜在性能影响的
    的头像 发表于 08-06 11:33 475次阅读

    面向手机直连的星载相控阵:关键技术与未来展望

    电子发烧友网站提供《面向手机直连的星载相控阵:关键技术与未来展望.pdf》资料免费下载
    发表于 07-23 12:39 0次下载

    面向企业关键业务场景的分布式存储软件ExponTech WDS

    面向企业关键业务场景的分布式存储软件ExponTech WDS
    的头像 发表于 06-05 09:41 339次阅读
    <b class='flag-5'>面向</b>企业<b class='flag-5'>关键</b>业务场景的分布式存储软件ExponTech WDS

    FPGA学习笔记-电源电压

    。每种电压都需要通过独立的电源来提供。实际上,虽然也有FPGA允许核心电压和IO口电压保持一致,但由于FPGA面向低电压内核和高电压IO设计的,所以这两个电压通常是不一样的。 内核电压越低,功耗
    发表于 05-22 18:42

    罗德与施瓦茨测试解决方案助力向宽带关键任务通信成功迁移

    TETRA 或 P25 传统窄带技术已无法满足当今应急响应人员的连接需求。随着任务关键网络需求的增长,宽带连接是解决之道。
    的头像 发表于 05-15 16:38 422次阅读

    鸿蒙OS开发实例:【ArkTS类库多线程CPU密集任务TaskPool】

    CPU密集任务是指需要占用系统资源处理大量计算能力的任务,需要长时间运行,这段时间会阻塞线程其它事件的处理,不适宜放在主线程进行。例如图像处理、视频编码、数据分析等。 基于多线程并发机制处理CPU密集
    的头像 发表于 04-01 22:25 851次阅读
    鸿蒙OS开发实例:【ArkTS类库多线程CPU密集<b class='flag-5'>型</b><b class='flag-5'>任务</b>TaskPool】

    鸿蒙OS开发实例:【ArkTS类库多线程I/O密集任务开发】

    使用异步并发可以解决单次I/O任务阻塞的问题,但是如果遇到I/O密集任务,同样会阻塞线程中其它任务的执行,这时需要使用多线程并发能力来进行解决。 I/O密集
    的头像 发表于 04-01 16:32 523次阅读
    鸿蒙OS开发实例:【ArkTS类库多线程I/O密集<b class='flag-5'>型</b><b class='flag-5'>任务</b>开发】

    鸿蒙原生应用开发-ArkTS语言基础类库多线程I/O密集任务开发

    使用异步并发可以解决单次I/O任务阻塞的问题,但是如果遇到I/O密集任务,同样会阻塞线程中其它任务的执行,这时需要使用多线程并发能力来进行解决。 I/O密集
    发表于 03-21 14:57

    鸿蒙原生应用开发-ArkTS语言基础类库多线程CPU密集任务TaskPool

    CPU密集任务是指需要占用系统资源处理大量计算能力的任务,需要长时间运行,这段时间会阻塞线程其它事件的处理,不适宜放在主线程进行。例如图像处理、视频编码、数据分析等。 基于多线程并发机制处理CPU
    发表于 03-19 14:14

    fpga开发是什么意思

    配置内部的逻辑门和连接关系来实现特定的威廉希尔官方网站 功能。因此,FPGA开发实质上是一种将软件算法或硬件威廉希尔官方网站 转化为可编程逻辑结构的过程,以实现各种复杂的逻辑和数据处理任务
    的头像 发表于 03-15 14:28 1205次阅读

    什么是FPGA?带你初步揭开它的面纱

    计算密集任务,如矩阵运算、图像处理、机器学习等。与CPU相比,FPGA在这些任务上具有更高的性能和更低的延迟。 此外,FPGA在通信密集
    发表于 02-21 16:10

    HarmonyOS CPU与I/O密集任务开发指导

    一、CPU密集任务开发指导 CPU密集任务是指需要占用系统资源处理大量计算能力的任务,需要长时间运行,这段时间会阻塞线程其它事件的处理,
    的头像 发表于 02-18 10:17 981次阅读
    HarmonyOS CPU与I/O密集<b class='flag-5'>型</b><b class='flag-5'>任务</b>开发指导