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

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

3天内不再提示

利用虚拟硬件平台缩短开发周期

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

扫码添加小助手

加入工程师交流群

软件开发人员对硬件开发板又爱又恨。一方面,它们使软件变得栩栩如生。另一方面,它们可能会让人头疼,特别是因为开发计划取决于它们的可用性。开发板对软件调试和分析行为的有限可见性通常迫使开发人员使用更复杂的方法。有时它们根本不像开发人员期望的那样工作。虚拟硬件平台可以通过快速执行软件来帮助解决开发人员的挫败感,从而缩短开发周期。

复杂的多核平台(例如用于设计蜂窝基站的平台)越来越多地为软件开发人员带来挑战,这也加剧了他们倾向于鄙视硬件开发板的原因。

替代开发方法

在最初的硬件规范之后,开发团队考虑使用与初步硬件设计略有相似的参考开发板。没有任何设计外设或 DDR RAM 控制器与开发板匹配;但是,当时没有其他可用的东西。一旦最终硬件可用,开发人员将不得不盲目地编写然后修改软件,因为他们没有参考板上的所有硬件组件。这是他们认为可以用来完成工作的唯一方法。

然后,开发团队遇到了用于软件开发的虚拟平台,这是一种模拟硬件模型并以接近实时的速度执行软件的技术。尽管开发人员对这个概念很感兴趣,但由于对用于创建虚拟硬件平台的建模技术和方法缺乏了解,他们有所保留。开发人员想知道闪存模型是否与通用闪存接口/可扩展命令集兼容,以及新的 MAC 控制器功能是否足以为开发驱动程序提供先机。由于为 ASIC 选择的 ARM 内核没有使用完整的 ARM 指令集,因此开发人员希望虚拟硬件平台能够捕获内核尝试的非法指令,并捕获和报告非法寄存器写入。

随着团队开始项目,很明显有些担忧是没有根据的。他们很快了解到建模使用称为 SystemC 的标准语言、专门为建模硬件而设计的 C++ 子集以及称为事务级建模的方法。SystemC 中的概念对开发人员来说非常自然。因此,在这个项目中对闪光灯进行建模不是问题。

使用这项技术保存了会话之间的修改。尽管本案例中的特定内核没有建模,但开发人员仍然可以控制仿真并在出现非法指令时停止执行,这是他们通过使用工具命令语言 (Tcl) 脚本功能完成的。

在初始建模期间,开发人员发现软件和建模团队之间的沟通对于了解使用虚拟硬件平台可以实现什么至关重要。他们了解到,他们需要考虑虚拟硬件平台建模本身,并注意外围模型及其支持的功能。开发虚拟硬件平台涉及 IP 和工具供应商之间的交互。经过几周的建模,开发人员开始使用虚拟硬件平台开始软件开发。

快速反馈,模拟

最初的软件开发任务是开发 Linux 支持包和 U-Boot 监视器。从一开始,虚拟硬件平台就提供了宝贵的反馈,使开发人员能够确定他们是否走在正确的轨道上。开发板支持包开发的初始假设中的疏忽很快就被捕获并解决了。

一个具体问题涉及先进的高性能总线控制器。必须包括在初始引导期间交换闪存和 DDR RAM 的支持。虚拟平台快速帮助开发人员识别和纠正跳转的设置方式,这是虚拟平台中的一个简单功能,但需要 JTAG 工具才能在物理硬件中捕获它。在平台中完成的建模使开发人员不仅可以检测代码,还可以检测平台。如果需要,虚拟硬件平台提供了任何和所有外围设备状态的视图,而不会影响操作。

在软件开发过程中,CoWare 的 Virtual Platform Analyzer(图 1)允许开发人员观察和控制虚拟硬件平台,并使用它来有效地跟踪发起方对外围块的访问。特别是,断点可以放置在外设块访问上,并且可以通过 Tcl 应用程序编程接口使用特定的调试消息。相同的 Tcl 脚本功能还使开发人员能够使虚拟硬件平台适应他们的开发需求,从而通过模拟与时序相关的配置来验证固件中硬件配置的编程,而无需模型是时间准确的。因此,该团队享受了快速的仿真速度,并且无需等待物理硬件。

图1

poYBAGKsPCyAOSRHAAKrs8pTn2A714.png

对代码的宝贵见解

在该项目中,与使用物理硬件相比,使用虚拟硬件平台将开发周期缩短了 33%。虚拟硬件平台提供了硅前软件开发测试环境。此外,其独特的调试和分析能力使其优于物理硬件上提供的类似调试和分析能力。

鉴于该项目的成功,很明显虚拟硬件平台可以显着提高软件开发团队的生产力。随着多核平台开发的快速增长,虚拟硬件平台提供的可见性水平可以让应用程序开发人员深入了解他们以前在没有专门设备的情况下无法看到的代码。

因此,开发人员应考虑使用虚拟硬件平台来纠正代码。这样做的价值远远超过了最初的建模投资。从 CoWare 等虚拟硬件平台技术供应商处获得的交流、教育、专业知识和其他优势可以减轻任何担忧。

要欣赏这项技术,请考虑白盒测试与黑盒测试的优势。使硬件设置日志级别允许开发人员记录操作系统和应用程序执行的各种访问。设计人员还可以将硬件断点设置在寄存器访问上,直至位级别,直观地验证中断和其他离散信号的变化状态,并通过设置硬件观察点和断点等 Tcl 脚本程序扩展虚拟硬件平台的功能。最重要的是,开发人员可以在他们的工作站上完成所有这些工作,而无需复杂的硬件设置、电缆和不稳定的硬件板。

不再等待硬件

虚拟硬件平台为开发人员带来了光明的未来,免除了他们等待硬件可用性的痛苦,并提供了硬件开发板无法提供的调试功能。虚拟硬件平台对于这十年及以后的软件开发人员来说,绝对是经过生产力验证的、可用于生产的工具。

审核编辑:郭婷

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

    关注

    114

    文章

    17646

    浏览量

    190261
  • 寄存器
    +关注

    关注

    31

    文章

    5589

    浏览量

    129068
  • C++
    C++
    +关注

    关注

    22

    文章

    2122

    浏览量

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    复合机器人“开箱即用”,交付调试周期大幅缩短至分钟级

    在工业自动化飞速发展的今天,企业引入新设备时最关心的问题之一就是:“复合机器人交付调试周期要多久?”传统方案往往耗时数周甚至数月,而富唯智能推出的新一代复合机器人,以“开箱即用” 为核心理念,将这一周期缩短至前所未有的水平——最
    的头像 发表于 11-24 16:18 127次阅读
    复合机器人“开箱即用”,交付调试<b class='flag-5'>周期</b>大幅<b class='flag-5'>缩短</b>至分钟级

    主流低代码开发平台有哪些:加速数字化转型的核心力量

    。无论是大型企业还是中小企业,都在通过低代码开发平台缩短项目周期、降低开发成本,让业务人员也能深度参与到应用构建中,推动业务与技术的深度融合
    的头像 发表于 11-03 16:53 425次阅读

    量产周期缩短至4个月,亿境虚拟全链路方案领跑AI眼镜赛道

    强大的硬件设计与系统级开发实力,亿境虚拟面向行业伙伴开放能力,提供从结构设计、光学模组到AI算法集成的一站式ODM解决方案。在AI智能眼镜还面临量产难题的当下,亿境虚拟优势如何将自身技
    的头像 发表于 10-30 09:17 5919次阅读
    量产<b class='flag-5'>周期</b><b class='flag-5'>缩短</b>至4个月,亿境<b class='flag-5'>虚拟</b>全链路方案领跑AI眼镜赛道

    硬件协同技术分享 - 任务划分 + 自定义指令集

    Level , ESL)得到催生,然而ESL设计依赖于复杂的高层次建模以及庞大的数据支持,且其工具链的发展仍不是十分完善。 在现阶段的开发氛围中,软硬件协同开发是一种能够缩短
    发表于 10-28 08:03

    EMC电路怎么整改:如何缩短整改周期的实战案例

    EMC电路怎么整改:如何缩短整改周期的实战案例|南柯电子
    的头像 发表于 10-20 10:17 252次阅读

    季丰电子新增K8000芯片测试平台硬件开发设计能力

    在半导体测试领域,高性能、高可靠性的测试设备是保障芯片品质与量产效率的核心关键。目前上海季丰电子已经具备上海御渡K8000芯片测试平台硬件开发设计能力。
    的头像 发表于 08-28 16:59 1562次阅读

    Arm Zena CSS加速软件和芯片开发进程

    ,Arm Zena CSS 能够显著缩短开发周期,使软件团队能够在物理硬件推出前就启动开发工作,进而助力车厂至少提前一年将新款车型推向市场。
    的头像 发表于 08-25 16:22 1813次阅读

    解锁思尔芯Genesis芯神匠虚拟原型平台:混合仿真与多元应用实践

    1、虚拟原型:芯片设计领域的革新利器芯片设计公司长期面临双重挑战:既要研发高性能芯片方案,又得缩短周期抢先推新。当下,系统与软件的复杂度与日俱增,传统软件开发方法在当下复杂形势中弊端渐
    的头像 发表于 07-15 10:13 1840次阅读
    解锁思尔芯Genesis芯神匠<b class='flag-5'>虚拟</b>原型<b class='flag-5'>平台</b>:混合仿真与多元应用实践

    什么是零代码平台

    控制器、光源等工业硬件即插即用,GraniStudio作为零代码核心价值体现在以下六个方面:1. 快速响应业务需求 可视化拖拽和预置功能模块,将传统开发周期从数月缩短至数天,快速原型设
    发表于 07-12 20:28

    佩特科技RK3588开发板产品介绍

    在AIoT(人工智能物联网)与边缘计算浪潮席卷全球的今天,企业对硬件平台的性能、灵活性、开发效率提出了更高要求。如何缩短产品从原型到量产的周期
    的头像 发表于 06-14 09:57 654次阅读
    佩特科技RK3588<b class='flag-5'>开发</b>板产品介绍

    如何在Centos系统中部署KVM虚拟平台

    KVM 通过将 Linux 内核转换为一个裸机(bare-metal)管理程序(hypervisor),使得用户可以在单一物理主机上运行多个虚拟机(VM),每个虚拟机都拥有独立的操作系统和资源。这样的架构不仅提高了硬件资源的
    的头像 发表于 05-09 13:40 740次阅读
    如何在Centos系统中部署KVM<b class='flag-5'>虚拟</b>化<b class='flag-5'>平台</b>

    【Simcenter FLOEFD】利用完全嵌入CAD的CFD软件,帮助设计师尽早评估流体流动和传热,从而缩短开发时间

    解决方案优势利用完全嵌入CAD的CFD软件,帮助设计师在NX软件、SolidEdge软件、CATIA和Creo中尽早评估流体流动和传热,从而缩短开发时间。前置CFD仿真以缩短
    的头像 发表于 03-19 16:33 803次阅读
    【Simcenter FLOEFD】<b class='flag-5'>利用</b>完全嵌入CAD的CFD软件,帮助设计师尽早评估流体流动和传热,从而<b class='flag-5'>缩短</b><b class='flag-5'>开发</b>时间

    加速电机控制器开发:EasyGo硬件在环测试平台一站式解决方案

    开发的需求,提供了硬件在环测试平台一站式解决方案。该方案运用前沿仿真架构,目前具备种类最为齐全、覆盖最为全面的电机模型、编码器的实时仿真,以及非线性变参处理能力,既能高精度模拟电机特性,又可模拟故障
    发表于 01-16 11:48

    Arm Corstone-320 FVP仿真平台介绍

    开发机器学习 (ML) 应用颇具挑战,尤其是涉及专用硬件时。好消息是,Arm Corstone-320 固定虚拟平台 (Fixed Virtual Platform, FVP) 简化了
    的头像 发表于 12-24 14:20 1355次阅读

    什么是云原生MLOps平台

    云原生MLOps平台,是指利用云计算的基础设施和开发工具,来构建、部署和管理机器学习模型的全生命周期平台。以下,是对云原生MLOps
    的头像 发表于 12-12 13:13 843次阅读