|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?注册
x
本人是modelsim初学者。遇到了很棘手的问题,希望大侠们给点帮助吧。
我的问题是关于调用xilinx内核的问题,使用内核的话,每次仿真,要在几千个时钟以后才会出现结果,我以乘法器来举例吧。
如果我直接用内核程序如下:
module cmult(clk,a,b,d,reset);
input clk,reset;
input [15:0] a,b;
output [31:0] d;
wire [31:0] d_t;
wire [31:0] d;
mult mult1(.sclr(!reset),.clk(clk),.a(a),.b(b),.p(d_t));
assign d=d_t;
endmodule
用这个仿真的话,前面上千个时钟,输入a,b都有,但是输出d一直为零,直到两千多个时钟以后,出现稍微正常的输出,但是还不是每个时钟都有输出。
而我把上面的乘法器内核用“*”(乘号)代替的话,下面是代码:
module cmult(clk,a,b,d,reset);
input clk,reset;
input [15:0] a,b;
output [31:0] d;
wire [31:0] d_t;
wire [31:0] d;
always@(posedge clk)
if(!reset) begin
b<=0;
a<=0;
end
else
d_t=a*b;
assign d=d_t;
endmodule
这样的语句形式,出现的结果就正常了,乘积在每个输入的下个时钟正确输出。
现在最郁闷的是,乘法器可用乘号,但是其他内核我就真没办法了,这个问题是个必须解决的问题,要不然以后仿真都不行了。希望大侠们给指导指导啊,实在是没办法了。 |
|