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

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

3天内不再提示

安全关键应用中异构臂芯的软件注意事项

星星科技指导员 来源:嵌入式计算设计 作者:嵌入式计算设计 2022-11-23 16:12 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

对于实时系统,尤其是安全关键型系统,由于处理器内核之间共享的资源争用,多核处理器对严格的确定性提出了重大挑战。

嵌入式系统受益于多核处理器的使用,具有更高的吞吐量和更好的尺寸、重量和功耗(SWaP)。具有异构处理器内核的处理器增加了将应用程序与每种内核类型的功能相匹配的能力,从而进一步提高了吞吐量和 SWaP。多核处理器的优势伴随着软件架构复杂性的增加,以最大限度地提高处理器内核的利用率。对于实时系统,尤其是安全关键型系统,由于处理器内核之间共享的资源争用,多核处理器对严格的确定性提出了重大挑战。这种挑战随着异构内核的增加而增加,因为最坏情况的执行时间可能因应用程序执行的内核而异。

为了更详细地探讨这种权衡,请考虑恩智浦® i.MX 8QuadMax应用处理器中的异构内核。i.MX 8QuadMax 具有四个 Arm® Cortex-A53 内核和两个 Cortex-A72® 内核,通过将每个应用任务的性能要求与不同内核的性能容量相匹配,实现功耗优化。与 A53 内核相比,A72 内核提供大约两倍的性能,但功耗更高。

为了实现多核解决方案的吞吐量和 SWaP 优势,软件架构需要支持可用处理器内核的高利用率。必须支持所有多核功能,从启用内核的并发操作(相对于可用内核在启动时被迫进入空闲状态或保持重置状态)到提供确定性负载平衡机制。软件多处理架构越灵活,系统架构师实现高利用率的工具就越多。

软件多处理架构

与多处理器系统一样,多核处理器上的软件架构可以根据内核之间的共享和协调量进行分类。对于基于多核的系统,最简单的软件架构是非对称多处理 (AMP),其中每个内核独立运行,每个内核都有自己的操作系统或虚拟机管理程序/来宾操作系统对。每个内核运行不同的应用程序,在调度方面内核之间很少或根本没有有意义的协调。由于缺乏负载均衡、难以缓解共享资源争用以及无法跨内核执行协调活动(如全面内置测试所需的活动),这种解耦可能会导致利用率不足。

AMP的现代替代方案是对称多处理(SMP),其中单个操作系统控制所有资源,包括哪些应用程序线程在哪些内核上运行。这种架构易于编程,因为所有内核都“对称”访问资源,从而使操作系统能够将任何线程分配给任何内核。对于具有异构内核的处理器(如 8QuadMax i.MX),不知道应用程序将在哪种类型的内核上运行可能会导致执行时间范围很长,从而显著影响确定性性能。

直接解决了这个问题,绑定多处理 (BMP) 是一种增强且受限的 SMP 形式,它将应用程序的任务/线程静态绑定到特定内核。这种静态绑定允许系统架构师严格控制多个内核的并发操作。

确保确定性行为

除了实现多核处理器的吞吐量和SWaP目标外,安全关键型系统还需要为每个应用保持可预测的最坏情况执行时间(WCET)。使用 BMP 限制与应用程序配对的内核类型是确保异构系统中确定性行为的重要组成部分。确保确定性的其他技术是时间和空间分区以及管理共享资源的争用。

在单核处理器中,通过在托管应用程序之间对内存空间进行可靠分区,可以在同一处理器上执行多个安全关键型应用程序。内存空间分区将内存的非重叠部分专用于在给定时间运行的每个应用程序,由处理器的内存管理单元 (MMU) 强制执行。通过使用时间分区可以进一步增强确定性,时间分区将固定时间间隔(称为主帧)划分为一系列固定的子间隔,称为分区时间窗口。为每个应用程序分配一个或多个分区时间窗口,窗口的长度和数量由应用程序的 WCET 和所需的重复率驱动。

多核干扰挑战确定性

在多核环境中,可以有多个应用程序跨不同内核同时运行。这些并发应用程序都需要访问处理器的资源。每个处理内核都有一些专用资源,但大多数资源在处理器内核之间共享,包括内存控制器、I/O、共享缓存和连接它们的内部结构。当多个处理器内核尝试同时访问同一资源时,会导致对这些共享资源的争用。在安全关键型应用(如航空电子设备)中,主要关注点是这种共享资源争用如何导致在一个内核上运行的应用程序干扰在另一个内核上运行的应用程序,从而对确定性、服务质量以及最终的安全性产生负面影响。

如果不加以缓解,共享资源争用的影响可能会很大。仅检查其中一个共享资源(DDR 内存),人们可能会猜测,当另一个内核尝试访问同一内存并且两个内核都运行内存受限的应用程序时,WCET 可能会加倍。实际上,由于共享资源仲裁和调度算法中的非线性行为,WCET 可以增加 8 倍,而不仅仅是 2 倍。尝试访问 DDR 内存或争用其他资源(如片上互连)的其他内核可能会导致 WCET 增长更显著。

多核干扰缓解

缓解多核干扰的一种方法是手动计划应用程序,以最大程度地减少资源争用。这种方法不会消除所有干扰,并且每当修改任何单个应用程序或添加新应用程序时,都需要重新测试和验证所有应用程序。另一种方法是一次只安排一个多任务应用程序运行。任务之间仍会发生干扰,但不会干扰其他应用程序。这种方法在具有异构内核的处理器上特别无效,因为不同内核类型的执行时间会有所不同。

更通用的方法是让 OS 管理共享资源争用。与操作系统使用硬件 MMU 通过将不同的内存区域分配给不同的应用程序来实现空间分区的方式相同,操作系统可以基于每个核心为共享资源分配带宽。解决操作系统中的多核干扰可为系统集成商提供有效、灵活且敏捷的解决方案。它还简化了新应用程序的添加,而无需对系统架构进行重大更改,并减少了重新验证活动。

航空电子设备中异构内核的解决方案示例

恩智浦 i.MX 8QuadMax应用处理器包括四个共享1MB二级缓存的Arm Cortex-A53内核和两个共享另一个1MB二级缓存的Arm Cortex-A72内核。该处理器还包括两个用于卸载系统功能的Cortex-M4F内核和两个能够运行OpenCL,Vulkan和OpenVX视觉加速的GPU。i.MX 8的一个独特功能是硬件资源分区,其中系统控制器将外设和内存区域提交到特定的客户定义域中。域之间的任何通信都强制使用通过硬件消息传递单元运行的消息传递协议。i.MX8QuadMax面向广泛的应用,包括工业HMI(人机界面)和控制、电子驾驶舱(eCockpit)、平视显示器、楼宇自动化和单板计算机。

Green Hill 的 INTEGRITY-178 tuMP™ 多核 RTOS 是一个统一的操作系统,可在 i.MX 8 中的所有 64 位处理器内核上运行,并支持 AMP、SMP 和 BMP 的同时组合。RTOS 的时变统一多处理 (tuMP) 方法为将安全关键型和安全关键型应用移植、扩展和优化到多核架构提供了最大的灵活性。INTEGRITY-178 tuMP 使用跨所有内核运行的时间分区内核,该内核允许应用程序绑定到称为关联组的一个或多个内核组。如果需要,可以进一步限制地缘组中应用程序的每个任务,使其在特定核心上运行。对于 i.MX 8QuadMax 处理器,系统架构师可以使用关联组来确保给定应用程序的任务仅在 Cortex-A72 内核上执行或仅在 Cortex-A53 内核上执行(图 3)。®

图 3:使用关联组,一个应用程序绑定到两个 Cortex-A72 内核,而另外两个应用程序绑定到 Cortex-A53 内核集。

INTEGRITY-178 tuMP直接解决多核干扰,包括带宽分配和监控(BAM)功能,已开发到最严格的安全级别。BAM 功能监视并强制实施从每个处理器核心到共享资源的带宽分配。BAM 模拟基于硬件的高速率方法,以确保持续分配强制实施每个核心对共享资源的使用。BAM 在整个应用程序的执行时间窗口中平稳地调节带宽,从而允许同一执行时间窗口中的其他应用程序获取其分配的共享资源部分。使用前面的内存访问干扰示例,将 50% 的内存带宽分配给高关键性应用程序会导致近乎恒定的 WCET,即使干扰内核的数量增加,当有多个干扰内核时,WCET 也会降低 8 倍(图 4)。此功能可有效缓解多核干扰,大大降低集成和认证风险,同时还使集成商能够获得多核处理器的最大性能优势。

图 4:在使用 BAM 将 50% 的共享资源带宽分配给关键应用程序后,WCET 几乎保持不变,并且大大减少。

恩智浦 i.MX 8QuadMax为优化航空电子设备和其他嵌入式实时系统中的SWaP提供了重要机会。Cortex-A72 和 Cortex-A53 内核的组合使系统架构师能够强调性能或能效,以创建最佳的系统级解决方案。相应的软件架构需要具有灵活性和控制力,以充分利用这些异构应用程序内核,同时保持严格的确定性。结合使用亲和组或其他形式的 BMP 的能力以及多核干扰缓解解决方案(如 BAM)相结合,8QuadMax i.MX 可在安全关键型应用中有效使用。

审核编辑:郭婷

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

    关注

    68

    文章

    20381

    浏览量

    255631
  • 嵌入式
    +关注

    关注

    5212

    文章

    20771

    浏览量

    338852
  • 恩智浦
    +关注

    关注

    14

    文章

    6144

    浏览量

    155287
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    电子设计关键参数与注意事项

    电子设计关键参数与注意事项 一、整体参数概述 在本次电子设计,有几个关键的整体参数需要关注。整体尺寸方面,有一个重要的数值是 8.50 ± 0.15 ,这个参数可能代表着某个
    的头像 发表于 05-14 11:40 273次阅读

    光伏产品 CE 认证注意事项

    光伏产品 CE 认证是进入欧盟市场的强制准入门槛,核心覆盖LVD、EMC、RoHS、ErP四大指令,同时需满足IEC 61215、IEC 61730等核心标准。认证不仅是合规要求,更是产品安全、性能与环保的权威背书,以下为关键注意事项
    的头像 发表于 03-27 16:06 4777次阅读
    光伏产品 CE 认证<b class='flag-5'>注意事项</b>

    关于变压器无载分接开关调节的关键步骤和注意事项

    无载分接开关(又称无励磁分接开关)作为变压器调压的关键部件,在电力系统中发挥着不可替代的作用。关于变压器无载分接开关的调节,以下是一些关键步骤和注意事项
    的头像 发表于 03-12 17:01 976次阅读

    不同产品做 METI 备案的注意事项

    METI 备案是日本《电气用品安全法(DENAN)》下的强制性行政申报。但在实际操作,并不是所有产品都“按同一套逻辑”备案。不同产品类别,在资料、责任划分、平台审核重点上差异明显。本文将从产品类型维度,系统梳理 METI 备案的关键
    的头像 发表于 02-10 12:00 317次阅读
    不同产品做 METI 备案的<b class='flag-5'>注意事项</b>

    BNC转接头接线注意事项

    本文从工程角度总结BNC转接头接线过程关键注意事项,涵盖阻抗匹配、接线规范、工艺选择及检测要点,帮助用户避免常见接线问题。
    的头像 发表于 12-19 14:04 722次阅读
    BNC转接头接线<b class='flag-5'>注意事项</b>

    驱动板PCB布线的注意事项

    PCB Layout 注意事项 1)布局注意事项: ●● 整体布局遵循功率回路与小信号控制回路分开布局原则,功率部分和控制部分的 GND 分开回流到输入 GND。 ●● 芯片的放置方向优先考虑驱动
    发表于 12-02 07:40

    源的MCU使用电池过程中有哪些注意事项

    目前大多数MCU都是用电池进行供电,源的MCU使用电池过程中有哪些注意事项?应该如何设计电池供电呢?
    发表于 11-20 07:24

    CW32F030在使用注意事项有哪些?

    CW32F030在使用注意事项有哪些?
    发表于 11-18 06:20

    电机维修安全注意事项

    电机维修涉及电、机械、高温等多种危险,必须严格遵守安全规程。以下注意事项分为维修前、维修中和维修后三个阶段。 一、 维修前准备阶段 绝对断电,安全隔离 彻底断电:不仅要断开开关,还必须断开电机的主
    发表于 10-29 13:14

    emWin AppWizard 开发注意事项有哪些?

    emWin AppWizard 开发注意事项
    发表于 09-04 06:18

    确保PCBA打样顺利的关键注意事项

    在电子制造业里,PCBA贴片加工是极为关键的环节,其质量优劣直接决定着最终产品的性能与可靠性。PCBA打样作为正式生产前的关键步骤,为保证其顺利推进以及最终产品质量达标,以下这些关键注意事项
    的头像 发表于 08-07 10:41 997次阅读

    别让这些细节毁了PCBA!焊接注意事项清单

    一站式PCBA加工厂家今天为大家讲讲PCBA加工电子元器件焊接注意事项有哪些?PCBA加工电子元器件焊接注意事项。 电子元器件焊接关键
    的头像 发表于 07-23 09:26 1611次阅读

    波峰焊机日常开启及注意事项

    波峰焊机作为电子制造行业的关键设备,其稳定运行直接影响产品质量和生产效率。掌握科学的日常开启流程和操作注意事项,是保障设备性能和生产安全的基础。以下从开机准备、开机流程、运行监控、关机操作及日常维护五个方面详细说明。
    的头像 发表于 07-18 16:52 4419次阅读

    智多晶PLL使用注意事项

    在FPGA设计,PLL(锁相环)模块作为核心时钟管理单元,通过灵活的倍频、分频和相位调整功能,为系统提供多路高精度时钟信号。它不仅解决了时序同步问题,还能有效消除时钟偏移,提升系统稳定性。本文将深入探讨智多晶PLL在实际应用关键
    的头像 发表于 06-13 16:37 1851次阅读
    智多晶PLL使用<b class='flag-5'>注意事项</b>

    请问从哪里可以获取CCG5 软件开发及Layout注意事项?

    我们准备开发一款雷电4的拓展坞 请问从哪里可以获取CCG5 软件开发及Layout注意事项
    发表于 05-30 06:21