1、SOC 的软硬件协同设计方法和技术摘要:随着嵌入式系统与微电子技术的飞速发展,硬件的集成度越来越高,这使得将CPU 、存储器和I/O 设备集成到一个硅片上成为可能,SOC应运而生,并以其集成度高、可靠性好、产品问世周期短等特点逐步成为当前嵌入式系统设计技术的主流。传统的嵌入式系统设计开发方法无法满足Soc设计的特殊要求,这给系统设计人员带来了巨大的挑战和机遇,因此针对Soc的设计方法学己经成为当前研究的热点课题。论文首先分析了嵌入式系统设计的发展趋势,论述了传统设计开发方法和工具的局限性,针对Soc设计技术的特点探究了Soc软硬件协同设计方法的流程,并讨论了目前软硬件协同设计的现状。关键词:
2、软硬件协同设计,可重用设计,SOC背景:计算机从1946年诞生以来,经历了一个快速发展的过程,现在的计算机没有变成科幻片电影中那样贪婪、庞大的怪物,而是变得小巧玲珑、无处不在,它们藏身在任何地方,又消失在所有地方,功能强大,却又无影无踪,这就是嵌入式系统。嵌入式系统是以应用为中心、计算机技术为基础、软件硬件可剪裁、适应应用系统对功能、可靠性、成本、体积、功耗严格要求的专用计算机系统。嵌入式系统是将先进的计算机技术、微电子技术和现代电子系统技术与各个行业的具体应用相结合的产物,这一点决定了它必然是一个技术密集、高度分散、不断创新的知识集成系统。嵌入式系纫泛应用于国民经济和国防建设的各个领域,发展
3、非常迅速,调查数据表明,嵌入式系统的增长为每年18%,大约是整个信息技术产业平均增长的两倍1,目前世界上大约有2亿台通用计算机,而嵌入式处理器大约60亿个,嵌入式系统产业是二十一世纪信息产业的重要增长点。随着集成电路制造工艺的飞速发展,嵌入式系统硬件的集成度越来越高,这使得将嵌入式微处理器、存储器、I/O设备等硬件组成部件集成到单个芯片上成为可能,片上系统SoC (System on Chip)应运而生 2。SOC极大地缩小了系统体积; 减少了板级系统SoB(System on Board) 中芯片与芯片之间的互连延迟,从而提高了系统的性能; 强调设计重用思想,提高了设计效率,缩短了设计周期,
4、减少了产品的上市时间。因此SOC以其集成度高、体积小、功耗少、可靠性好、产品问世周期短等优点得到了越来越广泛地应用,并且正在逐渐成为当前嵌入式系统设计的主流技术3。但Soc设计不同于传统嵌入式系统的开发,如何快速、有效地开发和设计Soc产品是当前嵌入式设计开发方法学的一个十分重要的研究领域。传统设计方法的局限性:图 1-1 传统的嵌入式系统设计流程过去的嵌入式系统硬件部分设计相对于软件部分来说更容易,系统开发主要是在目标电路板上进行编程和交叉调试,所以那时的嵌入式系统开发很大精力都放在软件上,通常认为只要软件开发质量能够很好地保证,就可以很好地满足整个系统的功能和性能需求。传统的嵌入式系统设计
5、流程如图1-1所示。系统软件和硬件划分完成以后,首先进行硬件子系统的设计与实现,再进行软件子系统的设计与实现,因此整个系统的设计与实现过程基本上是一个串行过程。随着微电子技术的飞速发展,硬件的集成度越来越高,嵌入式产品大量采用soc技术,使得传统的嵌入式系统开发方法逐渐暴露出很多不足之处:软件和硬件的开发过程割裂、缺乏沟通;设计自动化层次低;设计过程串行化增加了设计周期;缺乏设计重用支持。系统需求描述划分软件和硬件硬件设计与实现软件设计与实现硬件设计错误软件硬件划分错误图 1-2 设计复杂度和设计生产率的增长趋势图1-2显示了设计复杂性和设计生产率的增长趋势,由此可知目前设计生产率的提高速度赶
6、不上设计复杂度增加的速度,设计方法和工具成为制约嵌入式系统发展的瓶颈,soc技术给嵌入式系统设计带来了巨大的挑战,嵌入式系统设计方法学期待革新。软硬件协同设计技术:根据目前计算机和IC设计技术的发展来看,系统软件的研制要落后于硬件,如果在芯片设计过程中,没有相应的软件支持,那么对芯片的验证和模拟仿真都将遇到极大的障碍4。针对嵌入式系统Soc设计面临的问题与挑战,研究者们开始探索新的设计方法学软硬件协同设计(Hardware/Software Co-Design)方法学。软硬件协同设计方法学的研究始于90年代初期,第一届International Workshop on Hardware/Sof
7、tware Codesign会议于1993年召开5,它标志着软硬件协同设计方法学的研究正式展开,软硬件协同设计领域正式确立。软硬件协同设计不仅是一种设计技术,同时也是种新的设计方法学,其核心问题是协调软件子系统和硬件子系统。与传统的嵌入式系统设计方法不同,软硬件协同设计强调软件和硬件设计开发的并行性和相互反馈,如图1-3所示,克服了传统方法中把软件和硬件分开设计所带来的种种弊端,协调软件和硬件之间的制约关系,达到系统高效工作的目的,软硬件协同设计提高了设计抽象的层次,拓展了设计覆盖的范围。与此同时,软硬件协同设计强调利用现有资源(已经过验证的IP 核和软件构件) ,缩短系统开发周期,降低系统成
8、本,提高系统性能,保证系统开发质量,适应Soc设计。Soc软硬件协同设计研究目前还处于发展阶段,许多技术仍未成熟和实用化,但是该技术将给嵌入式系统设计带来革命性的变化,能够极大地提高设计生产力,研究意义重大。SOC 软硬件协同设计流程:图 1-3 软硬件协同设计流程传统芯片的设计都是专注于某个特定功能模块的设计,比如CPU、存储器、I/O接口等,即使是这样的一些芯片在以往的设计中己经是很复杂的问题了,需要很多高级设计人员花费大量的时间和精力,然而soc要完成的功能通常包括了多个传统芯片的功能,甚至还要复杂,因此设计片上系统soc是一个极为复杂的问题,一方面要满足复杂的功能和较高的性能,另一方面
9、又要尽可能降低系统开发的成本,缩短产品问世周期,这给设计和开发soc带来了挑战。对于如此复杂的soc ,如果芯片的每个部分都重新设计,那么其工作量之巨大是可想而知的,因此片上系统soc一般采用基于核的设计,软件部分采用构件重用,硬件部分采用IP核重用6 ,即将一个系统按功能划分成若干个模块,然后直接利用设计好的软件构件和IP核搭建一个具有特定功能的芯片。 soc的设计重用使系统设计者可以更多地考虑系统结构,而不必深陷于模块实现,从而达到降低系统设计复杂性的目的。但是IP核和软件构件重用决不等同于集成电路设计中的单元库的使用,不是一些IP核和软件构件的简单堆砌,还包含着很多有待解决的问题,如软硬
10、件划分、验证、测试等,这也给soc设计方法学带来了巨大的挑战。软硬件协同设计的目的就是找到一种最优化的软硬件比例结构以实现系统规范,同时满足系统速度、面积、功耗、灵活性等要求。软硬件协同设计是一种自顶向下、自底向上的设计方法。具体流程如图1-4所示,在系统行为描述阶段,系统将被以最直接的方式描述出来。此时不涉及任何有关系统如何实现的问题,指描述系统外在的行为表现,更不涉及哪些是硬件、哪些是软件。在这个阶段,需要对整个系统的行为进行验证,以期在设计的开始阶段就发现系统行为要求中的错误。之后,要对系统行为描述进行功能划分。将系统划分为互连的模块,每个模块都执行功能相对独立的特定行为,并确定模块的互
11、连关系和接口标准,完成系统的结构模型描述。同样在完成系统的结构描述后,也需要进行验证,以确认结构描述与行为描述的一致。软硬件划分在结构描述完成后进行,以确定各个部分由软件或硬件实现。更重要的是,在进行完软硬件划分后,要对系统的性能、灵活性等参数进行预测,以评估软硬件划分,甚至功能划分的合理性。如果划分不合理,就需要重新进行软硬件划分或功能划分,再进行评估。如此反复,直至获得最优的解决系统需求描述软硬件协同划分硬件设计与实现软件设计与实现方案。在完成软硬件划分之后,就可以对各个模块进行细化、综合(Synthesis),直至虚拟器件原型( 包括软件)。在整个细化过程中,应多次进行软硬件的协同验证(
12、 Verification)7,以及时发现细化中的错误。在到达器件原型级后,需要对各硬件原型进行映射(mapping),完成最终的实现。对已经由厂商提供IP的器件,可直接进行例化;对自己设计的器件,还要进一步进行综合、布图等工作。值得注意的是有些厂商提供较高层次的IP,这样,在较高的层次上就可以用IP替代原型。在整个设计完毕之前还要对设计进行底层的软硬件协同验证和仿真。最终确认设计是否满足功能要求和条件约束。如果需要,还应对系统的性能、灵活性再次进行评估,以确定前面的先验估计是否准确。如果后验评估与先验评估相差太大,可能还需要重新进行结构划分和软硬件划分。需求分析和产品定义SOC 软硬件协同综
13、合SOC 软硬件协同验证正确系统功能组成SOC 设计结构正确的设计系统开发实现开发得到的 SOCSOC 测试正确最终 SOCIP 核和软件构件库NN图 1-4 SOC 软硬件协同设计流程与传统方法不同,此 Soc 软硬件协同设计流程具有以下特点: 充分考虑到片上系统Soc的可重用设计特点,建立了一个IP核和软件构件库,将可重用设计思想融入Soc的软硬件协同划分、物硬件协同验证、系统开发实现和测试阶段; 允许系统在开发实现以前评价和验证设计结构的功能要求和各项性能指标,避免了因系 统设计不当而导致的错误,达到了尽早纠错、排错的目的; 充分体现了基于soc技术开发的特点,明确了设计开发过程中各个阶
14、段的任务和目的,有效地缩短了产品设计开发周期,增加了产品的市场竞争能力,适应当前嵌入式电子产 品的要求,易于实现,对soc的设计实践有指导意义。软硬件协同设计的复杂度是相当之高的。因此,设计的重用(reuse)就显得尤为重要。软硬件协同设计的模块化特性为重用的实现创造了良好的条件。在任意一个层次上,目标模块都可以由一个已经实现的具有知识产权的模块(称为IP核) 代替。由于重用可以从任意一层开始,这对产品的升级和改型是极为有利的。虚拟元件的制造商所提供的虚元件描述通常也是多层次的。从行为描述,到结构描述,甚至到版图描述。这为软硬件协同设计提供了很大的便利,同时它也是缩短面市周期的一个重要因素。软
15、硬件协同设计的现状:关于目前SOC软硬件协同设计的现状和研究热点主要有以下四个方面:(1)系统行为和结构的描述问题。按照现有的软硬件协同设计方法,在确定系统结构并完成软硬件的划分之后,用行为模型和HDL语言描述和数据路径综合的方法来完成硬件设计,用汇编语言或者C语言和编译器来实现软件,系统参数的确定就通过对软硬件协同划分的模拟获得,因此系统结构的确定非常关键。单纯的面向较低抽象层次的硬件描述语言已经不能适应SoC设计的要求,必须尽快提出具有很强系统设计能力的语言。把现有的C或者C+语言进行扩展使之发展成为SoC包括嵌入式系统最主要的系统规范描述语言是一种思路,所以就出现了研制C到VHDL和Ve
16、rilog语言转化的工具8。(2)各种不同的IP模块的集成问题。SoC 中所使用的 IP核来自不同的供应商,有些还可能是自己设计的。所以IC设计工程师必须对它们进行必要的修改和描述,以解决不同模块在同一个仿真环境中仿真一致性问题。由于目前高层设计综合还没有商用化,所以还只是依靠系统工程师个人的经验和问题的特殊性进行集成。(3)协同仿真技术始终是 SoC 设计中的重中之重。 SoC 的仿真涉及到软件和硬件模块的交互仿真,比传统的仿真技术更加复杂。现在的主要研究方向是多层次模拟9 ,也就是模拟时综合使用不同层次的模拟技术,比如系统级和RTL 级一起进行仿真,这样对系统级的仿真完成之后就可以在 RT
17、L 级看到内部寄存器的状态了,这就大大加快了仿真过程。(4)软硬件划分的方法问题。软硬件的合理划分是确定系统哪些功能块由硬件实现,哪些由软件实现,哪些交给接口模块来做。显然,不同的设计,根据要达到的目的不同,就有不同的划分方法,如何判别是不是最优化的方法将直接关系到最后的系统性能和系统成本的问题,也会给最后的联合验证和仿真带来深刻的影响。随着学科的交叉和新的数学方法的提出,出现了诸如利用遗传算法和混沌分形叠代的方法来获得最佳划分方案的技术10。结论与展望:本文对Soc软硬件协同设计方法学进行了简要的分析,为了克服传统嵌入式系统软硬件协同设计方法和工具不足,重点研究了基于可重用技术的SOC设计特
18、点,讨论了设计开发过程各步的工作 ,为设计开发SOC提供了依据, 提出了一种Soc软硬件协同设计流程。该设计方法的基础是IP核和软件构件库,将可重用设计技术融入Soc的划分、验证、 开发实现和测试等各个阶段,同时还允许在系统实现以前评价和验证系统设计的功能要求和性能指标,避免了系统设计不当而产生的错误,达到了尽早纠错、排错的目的。软硬件协同设计技术和传统的IC设计流程有着比较大的差别。在这个设计过程中,软件和硬件必须自始至终都是交互状态。硬件为软件提供设计平台,反过来,软件也为硬件提供了设计平台,它们相互作用,实现交互设计。软硬件协同设计方法能够在宏观上把握复杂系统,对系统进行正确划分,并选取
19、合适的IP,在建立设计平台的同时,也提供了一个验证平台,从而推动了硬件和软件的并行研发,降低了设计风险,缩短了设计周期。随着SOC设计的不断成熟,越来越多的理论和方法将被提出。这将进一步充实和发展软硬件协同设计方法,最终建立完善的SOC设计及验证平台。参考文献:1 Haase. J. Design Methodology for IP Providers. In Proc. of Design, Automation and Test in Europe, 1 999:72 8-732.2 罗胜钦数字集成系统芯片(SOC)设计北京:北京希望电子出版社,2002,93 Jonas Lindgar
20、d. B asic Partitioning Algorithms. http:/wwwphysics.utu.f/ett/kurssi/xG 61 2/2 002/10esli ndgard.pdf,2002:3-5.4 金湘亮,陈杰,郭晓旭等,基于IP核复用技术的SOC设计半导体技术,2002.5 魏少军SOC设计方法学电子产品世界,2001,6 .6 何立民以SoC为中心的多学科融合与渗透单片机及嵌入式系统设计,2001,5 .7 Jan MRabaeyDigital Integrated Circuitsa Design Perspective(数字集成电路设计透视影印本)MPrenticeHall International,Inc北京:清华大学出版社.8 程宇复杂系统芯片的开发J电子产品世界,2001,09:70719 Kunle Oluotun,Mark Heinrich,David OfeltDigital system simulation:Methodologies and examplesCIn:DAC98San Fran cisco,California,1998,658663 .10 郑赞,黄国勇通过遗传算法进行系统级软硬件划分J计算机辅助设计与图形学学报,2002,08:731734 .
Copyright © 2018-2021 Wenke99.com All rights reserved
工信部备案号:浙ICP备20026746号-2
公安局备案号:浙公网安备33038302330469号
本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。