Behavioral modeling in verilog

Status
Not open for further replies.

ashwini jayaraman

Member level 2
Joined
Jan 17, 2013
Messages
49
Helped
0
Reputation
0
Reaction score
0
Trophy points
1,286
Visit site
Activity points
1,601
Hi,

I tried wring a behavioral description of two-to-one-line multiplexer.While writing its rtl code, I mentioned the target output as reg.

In its testbench, how should I declare o/p and i/p??

In other 2 types of modeling, we used to declare, wire for an o/p and reg for an i/p.

I did the same for this also. My compilation is successful ,but I am not getting the anticipated o/p.

Here is the code below:

1.RTL:
module mux_2x1_behave(y,a,b,s);
output y;
input a,b,s;
reg y;
always @(a or b or s)
if(s==1)y=b;
else y=a;
endmodule

2. testbench:

module tb_mux_2x1_behave;
wire y;
reg a,b,s;
mux_2x1_behave M1(y,a,b,s);
initial
begin
#10 s=1;a=0;b=0;
#30 s=0;a=0;b=1;
#50 s=1;a=1;b=0;
#100 s=0;a=1;b=1;
#1;
end
endmodule

I am getting y=0 for all the inputs except for the last input. Plz do help me out.

Thanks.
 

even your output is correct.....at 10 ns s=1 b=0 so ...y gets value of b which is 0
at 40 ns s=0 a=0 so ...y gets value of a which is 0
at 90 ns s=1 b=0 so ...y gets value of b which is 0
at 190 ns s=0 a=1 so ...y gets value of a which is 1
 
Status
Not open for further replies.
Cookies are required to use this site. You must accept them to continue using the site. Learn more…