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

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

3天内不再提示

虚拟硬件平台为开发人员带来光明的未来

星星科技指导员 来源:嵌入式计算设计 作者:James Clough 2022-06-28 14:42 次阅读

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

复杂的多核平台(例如用于设计蜂窝基站的平台)越来越多地为软件开发人员带来挑战,这也加剧了他们倾向于鄙视硬件开发板的原因。 RadioFrame Networks 设计项目证明了这种两难境地,这导致了开发人员与硬件的双刃剑关系。

替代开发方法

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

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

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

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

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

快速反馈,模拟

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

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

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

对代码的宝贵见解

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

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

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

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

不再等待硬件

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

审核编辑:郭婷

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

    关注

    134

    文章

    8648

    浏览量

    361747
  • asic
    +关注

    关注

    34

    文章

    1153

    浏览量

    119257
  • Linux
    +关注

    关注

    87

    文章

    10988

    浏览量

    206724
收藏 人收藏

    评论

    相关推荐

    开关电源开发人员必看

    电子发烧友网站提供《开关电源开发人员必看.pdf》资料免费下载
    发表于 11-08 15:41 0次下载
    开关电源<b class='flag-5'>开发人员</b>必看

    Zynq UltraScale+ MPSoC软件开发人员指南

    电子发烧友网站提供《Zynq UltraScale+ MPSoC软件开发人员指南.pdf》资料免费下载
    发表于 09-15 10:16 8次下载
    Zynq UltraScale+ MPSoC软件<b class='flag-5'>开发人员</b>指南

    Versal ACAP系统软件开发人员指南

    电子发烧友网站提供《Versal ACAP系统软件开发人员指南.pdf》资料免费下载
    发表于 09-13 15:20 0次下载
    Versal ACAP系统软件<b class='flag-5'>开发人员</b>指南

    ARM开发人员套件1.2版汇编指南

    功能是有限制的。 有关内联汇编器的更多信息,请参阅ADS开发人员指南中的混合C、C++和汇编语言一章。 这本书的其余部分主要是关于手臂的。
    发表于 09-01 10:41

    ARM Mali-T600系列GPU OpenCL开发人员指南

    。 GPU被设计同时执行多个线程。 它们并行运行包含相对较少控制代码的计算密集型数据处理任务。 GPU通常包含比应用程序处理器多得多的处理元素,因此计算速度比应用程序处理器高得多。 OpenCL是第一种开放标准语言,使开发人员能够在GPU、应用程序处理器和其他类型的处理
    发表于 08-24 07:07

    ARM开发人员套件1.2版开发人员指南

    本书包含的信息将帮助您解决基于ARM的处理器开发代码时的特定问题。 一般来说,本书中的章节假定您正在使用ARM开发人员套件(ADS)来开发代码。 ADS由一套应用程序以及支持文档和示
    发表于 08-23 07:29

    GitHub陆续封杀位于“美国贸易制裁国家”的开发人员

    Github 陆续封杀受美国制裁的国家或地区的开发人员账户,如果你在遭受美国制裁的国家/地区使用GitHub的在线服务,只能享用最基本的服务。
    的头像 发表于 08-21 10:34 533次阅读
    GitHub陆续封杀位于“美国贸易制裁国家”的<b class='flag-5'>开发人员</b>

    ARM GPU最佳实践开发人员指南

    我们的指南提供了在为Arm Immortalis和Mali GPU开发时如何优化应用程序的建议。这些建议是那些希望开始使用Arm GPU的成熟开发人员准备的。
    发表于 08-10 06:58

    FAST型号固定虚拟平台(FVP)参考指南

    固定虚拟平台(FVP)支持无需实际硬件的软件开发。 它们可用于Linux和Windows主机,或者: ·作为Fast Models包中的源代码示例,以及定制和构建它们所需的工具。有
    发表于 08-09 06:50

    Arm虚拟硬件用户指南

    用于第三方板的Arm虚拟硬件(AVH)流行的物联网开发套件提供基于云的功能准确的虚拟模型,模拟CPU、外围设备、传感器和板组件。它允许
    发表于 08-08 07:45

    Splashtop开发人员远程桌面:随时随地进行安全编码

    开发人员不再需要被束缚在特定的物理位置即可访问其自定义开发环境。借助远程桌面解决方案,他们可以随时从任何位置连接到工作站。这意味着无论身在何处,他们都可以无缝地继续工作。当他们对需要立即关注的关键问题进行故障排除或修复时,这尤其有用。
    的头像 发表于 08-01 16:42 452次阅读

    UM-B-101:DA14585 IoT 多传感器开发套件开发人员指南

    UM-B-101:DA14585 IoT 多传感器开发套件开发人员指南
    发表于 07-05 20:59 0次下载
    UM-B-101:DA14585 IoT 多传感器<b class='flag-5'>开发</b>套件<b class='flag-5'>开发人员</b>指南

    UM-B-056:DA1468x 软件开发人员指南

    UM-B-056:DA1468x 软件开发人员指南
    发表于 07-05 20:36 0次下载
    UM-B-056:DA1468x 软件<b class='flag-5'>开发人员</b>指南

    IzoT BACnet 开发人员指南

    IzoT BACnet 开发人员指南
    发表于 07-04 20:48 0次下载
    IzoT BACnet <b class='flag-5'>开发人员</b>指南

    通过使用AI改善开发人员体验的13种令人印象深刻的方法

    在当今快速发展的技术环境中,人工智能 (AI) 正在全面改变行业,软件开发也不例外。AI 可以通过简化流程、自动执行重复性任务以及使开发人员能够构建创新应用程序来显著增强开发人员体验。
    发表于 06-09 09:24 499次阅读