当前位置: 首页 > article >正文

嵌入式开发:硬件和软件越来越接近

  从前,硬件和软件工程师大多生活在自己的世界里。硬件团队设计了芯片,调试了从铸造厂返回的第一批样本,让软件团队测试他们的代码。随着虚拟平台和其他可执行模型变得越来越普遍,软件团队可以在芯片制造之前开始,有时甚至在嵌入式开发过程的早期。日程安排有更多的重叠,但团队之间的互动仍然有限。

  采用嵌入式处理器的片上系统(SoC)设计的兴起给硬件和软件的开发方式带来了巨大的变化。由于处理器控制着SoC的大部分功能,验证团队通常会模拟在这些处理器上运行的代码。由于RTL仿真速度较慢,业界已经看到仿真和FPGA原型的使用大幅增加。现代验证技术,包括Accellera内部正在开发的便携式刺激标准,跨越了多个验证平台。

  编写验证期间在嵌入式处理器上运行的代码是一个关键挑战。嵌入式程序员经常加入硬件验证团队来执行这项任务。这种组织变革的一个结果是嵌入式软件和硬件团队之间更早、更强的互动。SoC中出现的通用CPU、卸载引擎和其他可编程内核越多,嵌入式软件团队的参与就越多。他们与设计和验证工程师一起开发SoC。

  

 

  嵌入式开发程序员在模拟之外仍然密切参与;他们在硬件平台或实际芯片上的测试通常看起来与模拟测试平台代码非常不同。应该对测试进行调整,以利用每个平台的独特特征。例如,慢速模拟支持持续检查结果的短测试,而silicon最适合长测试和累积结果。这种调整可以防止代码下载时间或结果上传时间影响处理器的惊人速度。

  当然,最终SoC必须运行生产软件,因此通常会努力尽快运行该软件。这可能早在虚拟平台和RTL仿真时就发生了,并且在仿真或FPGA原型制作期间很常见。可移植的激励技术可以为所有的验证和确认平台生成嵌入式测试用例,并且在生产软件运行之前有效地发现硬件缺陷。调试失败的测试用例比操作系统或应用程序中的挂起更容易。

  虽然对于许多嵌入式开发工程师来说,硬件和软件开发可能仍然是独立的学科,但他们的团队比以往任何时候都更加紧密地合作。对早期生产软件验证的需求、面向SoC验证和确认的软件驱动测试以及跨验证平台的可移植性都在推动同一方向的发展。现有标准(如UVM)可能会有相应的发展,新标准(包括便携式刺激)也会有相应的发展。


http://www.kler.cn/news/10393.html

相关文章:

  • Linux 进程管理之四大名捕
  • 什么是汽车以太网?
  • 测试基础知识
  • TensorFlow 深度学习第二版:6~10
  • 如何在 Windows10 下运行 Tensorflow 的目标检测?
  • 行业认可,知道创宇入选安全牛第十版全景图30个细分领域
  • Baumer工业相机堡盟工业相机如何通过BGAPI SDK和微软图像压缩算法进行图像压缩保存(C#)
  • Android开发环境搭建
  • 什么是谓词?什么是行为参数化?
  • FreeRTOS 任务基础知识
  • windows系统管理_windows server 2016 用户管理
  • 利用 ELK 处理 Percona 审计日志
  • 「Cpolar」使用Typecho搭建个人博客网站【内网穿透实现公网访问】
  • 互联网摸鱼日报(2023-04-12)
  • Netty的线程模型
  • 这样也行,在lambda表达式中优雅的处理checked exception
  • 大数据系列——Hive理论
  • Faster-RCNN代码解读2:快速上手使用
  • 【数据结构与算法】栈和队列(StackQueue)
  • 【BAT】查询局域内所有的IP
  • 2023 年十大 API 管理趋势
  • 基于matlab进行雷达信号模拟
  • 朝花夕拾 - 卷王的自白(光头祭天,法力无边》
  • 独立看门狗(IWDG)实验
  • 第十三届蓝桥杯大赛软件赛省赛 C/C++ 大学 B 组思考+总结
  • ChatGPT宝藏插件丨装上之后,上网、语音聊天、一键分享对话……简直让你爽到起飞!
  • Java题目训练——年终奖和迷宫问题
  • 自己再造一个大规模预训练语言模型?可以的
  • 【C++】Vector
  • 软件测试培训