本文共 1521 字,大约阅读时间需要 5 分钟。
这几日接接触SystemC,有些感触:
1. SystemC 是一套C++ Class Library,将C++扩展成了一门硬件描述语言(HDL)。我感觉,学习SystemC至少要懂两样东西:C++、一门硬件描述语言。我熟悉C++,并且熟悉Verilog,因此学SystemC能举一反三、触类旁通。
2. SystemC 使用了C++的很多特性:多重继承、虚拟继承、模板、RTTI (at least for dynamic_cast)、异常处理、操作符重载。似乎没有使用STL。
3. SystemC 是一套Application Framework,个人感觉,甚至和MFC颇有相似之处:
4. 从实现技术上看,SystemC有自己的garbage collector、自己的 memory pool、自己的容器(替代STL)。
个人体会:SystemC 在WinXP + VS.NET 2003下的使用步骤
1. SystemC 以源码方式发布,先使用VC7.1编译得到一个库文件:systemc.lib
2. 我们写的 SystemC 程序实际上是C++程序,写好一个SystemC程序(或者叫设计),用C++编译器编译为object文件,再与systemc.lib链接得到可执行文件。
3. 执行此exe文件,进行仿真。从输出(文件或stdout)得知仿真结果。
附:一个最简单的SystemC module
#include "systemc.h"
// 半加器
struct half_adder : sc_module{ sc_in a, b; sc_out sum, carry;
void prc_half_adder() { sum = a ^ b; carry = a & b; }
SC_CTOR(half_adder) { SC_METHOD(prc_half_adder); sensitive << a << b; // a, b 在敏感列表中 }};
等效的Verilog设计:
module half_adder(a, b, sum, carry);
input a, b; output sum, carry; reg sum, carry; always @(a or b) // a, b 在敏感列表中 begin sum = a ^ b; carry = a & b; end /* 以上五行可替换为: assign sum = a ^ b; assign carry = a & b; */
endmodule
我用的参考书:《SystemC 基础教程》 J.Bhasker著,孙海平等译,清华大学出版社。
平心而论,这本书翻译得还不错,基本可以放心阅读。
转载地址:http://hqvpi.baihongyu.com/