Continue to Site

Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

SISO design using behaviourial modeling in verilog

Status
Not open for further replies.

dkvlsi

Newbie level 2
Newbie level 2
Joined
Sep 19, 2013
Messages
2
Helped
0
Reputation
0
Reaction score
0
Trophy points
1
Visit site
Activity points
17
I have written verilog code for 4 bit Serial in serial out.

module siso(
input clk,reset,in,
output reg [3:0] out);
reg [3:0]temp;
always @ (posedge clk)
begin
if (reset)
begin
out <= 0;
temp <= 0;
end
else
begin
temp[0] <= in;
temp <= temp << 1;

out <= temp[3];
end
end
endmodule

output is coming 0000 and even in temp input is not loading. I am not understanding why its happening like this. :oops:

if i swap the statements
temp[0] <= in;
temp <= temp << 1;
as
temp <= temp << 1;
temp[0] <= in;
output is coming.
PLZ tell me why its not working with the previous structure. :idea:

Thanks in advance
 

Code:
temp <= temp << 1;
Shifts a 0 into the LSB.
You should code a shift register like this...
Code:
temp <= {temp[2:0], in};
Which does the exact same thing as this...
Code:
temp[0] <= in;
temp[1] <= temp[0];
temp[2] <= temp[1];
temp[3] <= temp[2];
Which will work regardless of the ordering of the assignments.

Regards
 

Code:
temp <= temp << 1;
Shifts a 0 into the LSB.
You should code a shift register like this...
Code:
temp <= {temp[2:0], in};
Which does the exact same thing as this...
Code:
temp[0] <= in;
temp[1] <= temp[0];
temp[2] <= temp[1];
temp[3] <= temp[2];
Which will work regardless of the ordering of the assignments.

Regards

thanks for the reply but i have checked with the same after swapping both the statement it is not giving the output.
 

ads-ee is correct....
just check this code.....

always @ (posedge clk)
begin
if (reset)
begin
out <= 0;
temp <= 0;
in <= 1'b1; //just for testing make it "1"...
end
else
begin
//$display(" value of in %d",in);
//temp[0] <= in;
//$display(" value of temp[0] %d",temp[0]);
//temp <= (temp << 1);
temp <= {temp[2:0], in};
$display("value of temp %b",temp);
out <= temp[0];
end
end

it's working very fine.....
 

I think to reflect SISO operation...

module siso(
input clk,reset,in,
output reg out );
reg [3:0]temp;


always @ (posedge clk)
begin
if (reset)
begin
out <= 0;
temp <= 0;
//in <= 1'b1; //just for testing make it "1"...
end
else
begin
temp <= {temp[2:0], in};
//$display("value of temp %b",temp);
out <= temp[3];
end
end
endmodule
 

Status
Not open for further replies.

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top