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 脚本程序扩展虚拟硬件平台的功能。最重要的是,开发人员可以在他们的工作站上完成所有这些工作,而无需复杂的硬件设置、电缆和不稳定的硬件板。

不再等待硬件

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

审核编辑:郭婷

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

    关注

    112

    文章

    15223

    浏览量

    171172
  • 寄存器
    +关注

    关注

    30

    文章

    5028

    浏览量

    117719
  • C++
    C++
    +关注

    关注

    21

    文章

    2066

    浏览量

    72899
收藏 人收藏

    评论

    相关推荐

    SC171开发套件V1 硬件平台介绍及使用

    课程类别 课程名称 视频课程时长 视频课程链接 课件链接 硬件 硬件平台介绍 6分29秒 https://t.elecfans.com/v/25510.html *附件:硬件
    发表于 04-01 10:35

    Arm 宣布推出全新汽车技术,可缩短多达两年的人工智能汽车开发周期

    开发时间、降低成本,并带来最大的灵活性 Arm 生态系统首次实现在物理芯片就绪前就可基于虚拟原型解决方案启动软件开发,由此可缩短多达两年的开发
    发表于 03-14 13:34 86次阅读

    Arm宣布推出全新汽车技术,可缩短多达两年的人工智能汽车开发周期

    Arm 携手生态伙伴推出了最新的 Arm 汽车增强 (AE) 处理器和虚拟平台,让汽车行业在开发伊始便可应用,助力缩短多达两年的开发
    的头像 发表于 03-14 12:17 541次阅读

    MZ7100/045FC 开发平台硬件手册

    电子发烧友网站提供《MZ7100/045FC 开发平台硬件手册.pdf》资料免费下载
    发表于 02-26 09:11 0次下载

    英伟达大幅缩短AI GPU交付周期

    根据瑞银分析师最近提供给投资者的备忘录,英伟达已经显著缩短了其AI GPU的交付周期。这一周期已经从去年年底的8-11个月迅速缩短至目前的3-4个月。这一变化引发了市场的广泛关注,分析
    的头像 发表于 02-18 17:31 506次阅读

    芯华章与芯擎科技合作助力大规模缩短产品上市周期

    大规模缩短产品上市周期,加速新一代智能驾驶芯片创新。 随着中国智能汽车产业蓬勃发展,车规级芯片也迎来了发展的“黄金时代”。作为国内唯一实现7纳米车规芯片量产的厂商,芯擎科技的产品“龍鹰一号”已规模化应用于吉利领克08等多款车
    的头像 发表于 12-04 09:09 1102次阅读

    使用英特尔Simics仿真器创建软件开发虚拟平台

    虚拟化。HPS 的设计支持将硬件虚拟化扩展到 FPGA SoC 可编程逻辑结构中的实例化外设,并为早期软件开发创建虚拟
    的头像 发表于 11-24 12:27 693次阅读

    利用onenet平台远程控制开发板的LED 灯

    电子发烧友网站提供《利用onenet平台远程控制开发板的LED 灯.pdf》资料免费下载
    发表于 10-20 11:33 0次下载
    <b class='flag-5'>利用</b>onenet<b class='flag-5'>平台</b>远程控制<b class='flag-5'>开发</b>板的LED 灯

    Versal ACAP硬件、IP和平台开发方法指南

    电子发烧友网站提供《Versal ACAP硬件、IP和平台开发方法指南.pdf》资料免费下载
    发表于 09-13 15:24 0次下载
    Versal ACAP<b class='flag-5'>硬件</b>、IP和<b class='flag-5'>平台</b><b class='flag-5'>开发</b>方法指南

    如何向ARM DS-5 Development Studio添加新的固定虚拟平台

    了解如何向ARM DS-5 Development Studio添加新的固定虚拟平台。 使用ARM固定虚拟平台(FVP)的环境是一种将项目缩短
    发表于 08-24 08:05

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

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

    Arm虚拟硬件用户指南

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

    边缘AI开发,需要什么样的硬件平台开发环境?

    ☞ 活动预告 物联网和人工智能(AI)的发展,让边缘AI的应用开发驶入了快车道。对于嵌入式开发者来讲,如何整合硬件平台和软件开发工具资源,构
    的头像 发表于 07-07 08:15 412次阅读

    如何利用莱迪思宏设计流程缩短FPGA设计周期

    随着FPGA密度和复杂性的提高,设计团队会将之前由其他类型的半导体(如ASIC和MCU)处理的设计迁移到这些更复杂的FPGA上。
    发表于 07-06 17:44 435次阅读
    如何<b class='flag-5'>利用</b>莱迪思宏设计流程<b class='flag-5'>缩短</b>FPGA设计<b class='flag-5'>周期</b>