然而随着嵌入式系统日益普及,设计危机也逐渐凸现。统计数据显示,近40%的嵌入式系统开发延迟,还有超过9%的开发最终被取消。
这些统计数据的矛头都指向基本工程方法的失败。在传统的开发步骤中,硬件设计要超前软件开发,而嵌入式系统中软件正日益占据关键地位。因而,传统开发步骤在嵌入式系统开发中遭遇失败并不让人意外。何况一个产品的上市时间也越来越短(后文举出的手机开发的例子总开发时间还不到一年),这又给嵌入式系统的开发雪上加霜。很明显,嵌入式设计的方法和工具需要进行一次革 命。
也就是说,系统架构、硬件实现和软件实现各阶段之间的关系需要调整,而这种需求恰好正是目前的电子系统级设计(ESL)中最受关注的问题。然而,现有的大多数基于ESL的方法都只能提供部分解决方案。我们需要的是一套全新的设计模式,一套能够对全系统建模的方法,以促进系统架构研究并实现软硬件协同设计,以允许设计人员从原始设计不断改进,直到最终实现系统。
至今为止,大多数将SoC系统级设计自动化为RTL实现的尝试都存在设计精确度和设计生产力不足的缺陷。早期那些力图将C、C++和SystemC自动化为硬件建模语言(能将顺序软件语义翻译为基于状态机的并行硬件语言) 的工具,不但要求开发人员创建并维护功能事务级模型的多个“视角”,而且要添加定时还需要更多的“视角”。维护这些“多视角”本身就有问题,而这些视角之间在时序和功能方面的不一致还会导致验证错误。此外,最终将其转为RTL的过程主要仍是一个手工操作的过程。
要使SoC设计走出困境,很重要的一点就是让设计师们能够采用一种在系统架构阶段设计的定时精确的高性能系统级模型,然后随着开发人员从架构阶段进入软硬件协同开发和验证阶段,改进而不是丢弃这个模型。尽管暂时还没有一种全自动化的工具链能够实现从系统架构到RTL实现这一系列完整的设计任务,但一些嵌入式设计方案供应商已经开始了成功的尝试,其中一种很有前途的技术就是虚拟系统原型技术。
图1:每个公司一年里启动的项目提前完成,推迟完成,按时完成和取消所占的百分比(平均每个公司启动项目所占百分比)。
虚拟系统原型(VSP)是一种基于软件仿真的电子系统模型,其中可以包含一个或多个处理器、总线、硬件外设,甚至可以包含作为整个系统一部分的机械或模拟子系统模型。但最重要的是,VSP运行的是与真实硬件相同的经过编译和链接的目标代码,因而能够准确预测系统在实际情况下的表现。此外,VSP还是一种周期精确(cycle-accurate)的模型,因此,被设计的系统可以根据对实时性的要求建模。
一旦模型建立,硬件和软件开发就可以同时启动,这样一来,既减少了开发所用的总资源,也缩短了开发周期。
文章评论(0条评论)
登录后参与讨论