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.

[SOLVED] Getting each output twice from LFSR

Status
Not open for further replies.

Utshash

Newbie level 3
Newbie level 3
Joined
Oct 15, 2014
Messages
3
Helped
1
Reputation
2
Reaction score
1
Trophy points
3
Visit site
Activity points
24
Hi.
I am trying to make a 32'bit LFSR with a given initial state. I am posting the code and stimulus below.


Code Verilog - [expand]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/*------------------------------------------*/
module lfsr (clock, reset, out);
  
  input clock, reset;
  output [31:0] out;
  
  reg [31:0] temp;
  wire newbit;
  
  xor (newbit,temp[0],temp[10],temp[30],temp[31]);
  
  initial
  temp = 32'hffffffff;
  
  always @(posedge clock)
  begin
    temp <= {newbit,temp[31:1]};
  end
  
  assign out = temp;
     
endmodule
 
/*------------------------------------*/
 
 
//Stimulus
 
module lfsrstimulus;
  reg CLOCK, RESET;
  wire [31:0] OUT;
  
  lfsr l1 (CLOCK, RESET, OUT);
  
  initial
  $monitor($time, "Clock = %b, Output = %b\n", CLOCK,OUT);
  
  initial
  begin
  CLOCK = 1'b1;  
  forever #10 CLOCK = ~CLOCK;
  end
  
  initial
  #100 $finish;
  
endmodule
 
/*--------------------------------------------*/


The problem I am having is that when I run the stimulus, each output comes twice. Is this because of timing delays?

Thanks in advance for any help. :)
 
Last edited by a moderator:

No. It is because you choose to confuse yourself. The simulation looks okay. The lfsr gets a new value at every positive going edge of clock. The monitor statement in this case prints the contents of the lfsr registers both when clock is low, and when clock is high. Which is why you perceive it as "double".
 
use something like:

Code Verilog - [expand]
1
@(posedge CLOCK) $display("%t, Output = %b\n", $time, OUT);


then you'll only see one output each clock
 

Another missed learning opportunity of reading the $monitor man page. :( But yes, that is probably the kind of output he's expecting. :)
 

Homo sapiens + path of least resistance equals exactly. ;-)

But I agree. He would do well to read the $monitor documentation. It has a key sentence in it that explains why it shows things the way it does.
 

Thank you all. I see my mistake now and as suggested by all of you, I'll read the $monitor documentation. Thanks again. :)

- - - Updated - - -

Thank you all for replying and pointing out my stupidity. As suggested by most of you, I'll try to read the $monitor documentation as soon as possible. Thanks again. :)
 
Status
Not open for further replies.

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top