最后编辑于: 2010-11-16 21:50 | 分类: FPGA | 标签: verilog | 浏览数: 689 | 评论数: 0
总结的不错,原文作者虽是新手但很细致,
http://hi.baidu.com/publiclass/blog/item/f9bf6f64bd1003f8f73654de.html
always,assign,begin,end,case,wire,tri,aupply0,supply1,reg,integer,default,for,function,and,nand,or,nor,xor,xnor,buf,not,bufif0,bufif1,notif0,notif1,if,inout,input,instantitation,module,negedge,posedge,operators,output,parameter
。time,defparam,$finish,fork,join,initial,delays,UDP,wait
。casex,casez,wand,triand,wor,trior,real,disable,forever,arrays,memories,repeat,task,while
。要保证Verilog HDL赋值语句的可综合性,在建模时应注意以下要点:
@ 2009-04-14 19:33
只能在test bench中使用,不能综合。(我用ISE9.1综合时,有的简单的initial也可以综合,不知道为什么)
event在同步test bench时更有用,不能综合。
不支持real数据类型的综合。
不支持time数据类型的综合。
不支持force和release的综合。
不支持对reg 数据类型的assign或deassign进行综合,支持对wire数据类型的assign或deassign进行综合。
不可综合,可以使用非块语句达到同样的效果。
支持门级原语的综合,不支持非门级原语的综合。
不支持UDP 和table的综合。
如:always @(posedge clk or negedge clk) begin...end
这个always块不可综合。
以#开头的延时不可综合成硬件电路延时,综合工具会忽略所有延时代码,但不会报错。
如:a=#10 b;
这里的#10是用于仿真时的延时,在综合的时候综合工具会忽略它。也就是说,在综合的时候上式等同于a=b;
可能会有人喜欢在条件表达式中把数据和X(或Z)进行比较,殊不知这是不可综合的,综合工具同样会忽略。所以要确保信号只有两个状态:0或1。
如:
1 module synthesis_compare_xz (a,b);
2 output a;
3 input b;
4 reg a;
5
6 always @ (b)
7 begin
8 if ((b == 1'bz) || (b == 1'bx)) begin
9 a = 1;
10 end else begin
11 a = 0;
12 end
13 end
14
15 endmodule