论文关键词:asic 硬件描述语言 芯片系统
论文摘要:从数字系统设计的性质出发,结合目前迅速发展的芯片系统,比较、研究各种硬件描述语言;详细阐述各种语言的发展历史、体系结构和设计方法;探讨未来硬件描述语言的发展趋势,同时针对国内eda基础薄弱的现状,在硬件描述语言方面作了一些有益的思考。
现在,随着系统级fpga以及系统芯片的出现。软硬件协调设计和系统设计变得越来越重要。传统意义上的硬件设计越来越倾向于与系统设计和软件设计结合。硬件描述语言为适应新的情况,迅速发展,出现了很多新的硬件描述语言,像superlog、systemc、cynlib c++等等。究交选择哪种语言进行设计,整个业界正在进行激烈的讨论。因此,完全有必要在这方面作一些比较研究,为eda设计做一些有意义的工作,也为发展我们未来的芯片设计技术打好基础。
1、目前hdl发展状况
目前,硬件描述语言可谓是百花齐放,有vhdl、superlog、verilog、systemc、cynlib c++、c level等等。虽然各种语言各有所长,但业界对到底使用哪一种语言进行设计,却莫衷一是,难有定论。
而比较一致的意见是,hdl和c/c++语言在设计流程中实现级和系统级都具有各自的用武之地。问题出现在系统级和实现级相连接的地方:什么时候将使用中的一种语言停下来,而开始使用另外一种语言?或者干脆就直接使用一种语言?现在看来得出结论仍为时过早。WwW.133229.COM
在2001年举行的国际hdl会议上,与会者就使用何种设计语言展开了生动、激烈的辩论。各方人士各持己见:为verilog辩护者认为,开发一种新的设计语言是一种浪费;为systemc辩护者认为,系统级芯片soc快速增长的复杂性需要新的设计方法;c语言的赞扬者认为,verilog是硬件设计的汇编语言,而编程的标准很快就会是高级语言,cynlib c++是最佳的选择,它速度快、代码精简;supedog的捍卫者认为,superlog是verilog的扩展,可以在整个设计流程中仅提供一种语言和一个仿真器,与现有的方法兼容,是一种进化,而不是一场革命。
当然,以上所有的讨论都没有提及模拟设计。如果想设计带有模拟电路的芯片,硬件描述语言必须有模拟扩展部分,像verilog hdl-a,既要求能够描述门级开关级,又要求具有描述物理特性的能力。
2、几种代表性的hdl语言
2.1 vhdl
早在1980年,因为美国军事工业需要描述电子系统的方法,美国国防部开始进行vhdl的开发。1987年。由ieee(in,stitute of electrical and electro-nics engineers)将vhdl制定为标准。参考手册为ieee vhdl语言参考手册标准草案1076/8版,于1987年批准,称为ieee 1076-1987。应当注意,起初vhdl只是作为系统规范的一个标滞,而不足为设计而制定的。第二个版本是在1993年制定的,称为vhdl-93,增加了一些新的命令和属性。
虽然有“vhdl是一个4亿美元的错误”这样的说法。但vhdl毕竟是1995年以前唯一制订为标准的硬件描述语言,这是它不争的事实和优势;但同时它确实比较麻烦,而且其综合库至今也没有标准化,不具有晶体管开关级的描述能力和模拟设计的描述能力。目前的看法是,对于特大型的系统级数字电路设计,vhdl是较为合适的。
实质上,在底层的vhdl设计环境是由verilog hdl描述的器件库支持的,因此,它们之间的互操作性十分重要。目前,verilog和vdhl的两个国际组织ovi、ⅵ正在筹划这一工作,准备成立专门的工作组来协调vhdl和verilog hdl语言的互操作性。ovi也支持不需要翻译,由vhdl到verilog的自由表达。
2.2 verilog hdl
venlog hdl是在1983年,由gda(gateway design au-tomation)公司的phil moorby首创的。phil moorby后来成为verilog-xl的主要设计者和cadence公司的第一合伙人。在1984“1985年,phil moorby设计出了第一个名为venlog-xl的仿真器;1986年,他对verilog hdl的发展义作出了另一个巨大的贡献:提出了用于快速门级仿真的xl算法。
随着verilog-xl算法的成功,verilog hdl语言得到迅速发展。1989年,cadence公司收购了gda公司,verilog hdl语言成为cadence公司的私有财产。1990年,cadence公司决定公开verilog hdl语言,于是成立了ovi(open verilog internauonal)组织,负责促进verilog hdl语言的发展。基于verilog hdl的优越性,ieee于1995年制定了verilog hdl的ieee标准,即verilog hdl 1364-1995;2001年发布了verilog hdl 1364-2001标准。在这个标准中,加入了verilog hdl-a标准,使verilog有了模拟设计描述的能力。
2.3 superlog
开发一种新的硬件设计语言,总是有些冒险,而且未必能够利用原来对硬件开发的经验。能不能在原有硬件描述语言的基础上,结合高级语言c、c++甚至java等语言的特点,进行扩展,达到一种新的系统级设计语言标准呢?
superlog就是在这样的背景下研制开发的系统级硬件描述语言。verilog语言的首创者phil moorby和peter flake等硬什描述语言专家,在一家叫co-design automation的eda公司进行合作,开始对verilog进行扩展研究。1999年,co-design公司发布了superlogtm系统设计语言,同时发布了两个开发工具:systemsimtm和systemextm。一个用于系统级开发,一个用于高级验证。2001年,co-design公司向电子产业标准化组织accellera发布了superlog扩展综合子集ess,这样它就可以在今天verilog语言的rtl级综合子集的基础上,提供更多级别的硬件综合抽象级,为各种系统级的eda软件工具所利用,
至今为止。已超过15家芯片设计公司用superlog来进行芯片设计和硬件开发。superlog是一种具有良好前景的系统级硬件描述语言。但是不久前,由于整个it产业的滑坡,eda公司进行大的整合,co-design公司被synopsys公司兼并,形势又变得扑朔迷离。 2.4 systemc
随着半导体技术的迅猛发展,soc已经成为当今集成电路设计的发展方向。在系统芯片的各个设计中,像系统定义、软硬件划分、设计实现等,集成电路设计界一直在考虑如何满足soc的设计要求,一直在寻找一种能同时实现较高层次的软件和硬件描述的系统级设计语言。
systemc正是在这种情况下,由synopsys公司和coware公司积极响应目前各方对系统级设计语言的需求而合作开发的。1999年9月27日,40多家世界著名的eda公司、lp公司、半导体公司和嵌入式软件公司宣布成立“开放式systemc联盟”。著名公司cadence也于2001年加入了systemc联盟。systemc从1999年9月联盟建立初期的0.9版本开始更新,从1.0版到1.1版,一直到2001年10月推出了最新的2,0版。
3、各种hdl语言的体系结构和设计方法