



## **Lab 7 Report**

**Name:** Muhammad Somaan

**ID:** 2528404

# FSM)

State diagram:



**State Table:**

| States          | Inputs         |                 |                 |                | Outputs |        |     |     | ↓ |
|-----------------|----------------|-----------------|-----------------|----------------|---------|--------|-----|-----|---|
|                 | 0,x,x,1        | 1,1,1,0         | 1,0,1,0         | x,x,1,1        | Done    | opcode | op2 | op1 |   |
| S <sub>0</sub>  | S <sub>0</sub> | S <sub>1</sub>  | S <sub>1</sub>  | S <sub>0</sub> | 0       | 000    | 00  | 00  | ↑ |
| S <sub>1</sub>  | S <sub>0</sub> | S <sub>2</sub>  | S <sub>2</sub>  | S <sub>0</sub> | 0       | 100    | 00  | XX  | ↑ |
| S <sub>2</sub>  | S <sub>0</sub> | S <sub>3</sub>  | S <sub>3</sub>  | S <sub>0</sub> | 0       | 001    | 01  | XX  | ↑ |
| S <sub>3</sub>  | S <sub>0</sub> | S <sub>4</sub>  | S <sub>4</sub>  | S <sub>0</sub> | 0       | 001    | 10  | XX  | ↑ |
| S <sub>4</sub>  | S <sub>0</sub> | S <sub>5</sub>  | S <sub>5</sub>  | S <sub>0</sub> | 0       | 101    | 00  | XX  | ↑ |
| S <sub>5</sub>  | S <sub>0</sub> | S <sub>6</sub>  | S <sub>6</sub>  | S <sub>0</sub> | 0       | 111    | 11  | 01  | ↑ |
| S <sub>6</sub>  | S <sub>0</sub> | S <sub>7</sub>  | S <sub>7</sub>  | S <sub>0</sub> | 0       | 110    | 01  | 10  | ↑ |
| S <sub>7</sub>  | S <sub>0</sub> | S <sub>8</sub>  | S <sub>8</sub>  | S <sub>0</sub> | 0       | 111    | 10  | 11  | ↑ |
| S <sub>8</sub>  | S <sub>0</sub> | S <sub>9</sub>  | S <sub>9</sub>  | S <sub>0</sub> | 0       | 011    | 00  | XX  | ↑ |
| S <sub>9</sub>  | S <sub>0</sub> | S <sub>10</sub> | S <sub>5</sub>  | S <sub>0</sub> | 0       | 101    | 00  | XX  | ↑ |
| S <sub>10</sub> | S <sub>0</sub> | S <sub>10</sub> | S <sub>10</sub> | S <sub>0</sub> | 1       | XXX    | XX  | XX  | ↑ |

## Verilog code:

```
1  module FSM(START, ZERO_FLAG, CLK, RST, DONE, opcode, operand1, operand2);
2
3  parameter size = 4;
4
5  input START, ZERO_FLAG, CLK, RST;
6  output reg [size-2:0] opcode;
7  output reg [size-3:0] operand1, operand2;
8  output reg DONE;
9
10 reg [size-1:0] state, nextState;
11 parameter S0=0, S1=1, S2=2, S3=3, S4=4, S5=5, S6=6, S7=7, S8=8, S9=9, S10=10;
12
13 initial begin
14     state <= S0;
15     nextState <= S0;
16 end
17
18 always @(posedge CLK or posedge RST) begin
19
20     if(RST)
21         state <= S0;
22     else
23         state <= nextState;
24 end
25
26 always @(state) begin
27
28     DONE = 0;
29     opcode = 3'b000;
30     operand1 = 2'b00;
31     operand2 = 2'b00;
32
33     case(state)
34         S0: begin
35             opcode = 3'b000;
36         end
37         S1: begin
38             opcode = 3'b100;
39             operand1 = 2'b00;
40         end
41         S2: begin
42             opcode = 3'b001;
43             operand1 = 2'b01;
44         end

```

```
44      end
45      begin
46          opcode = 3'b001;
47          operand1 = 2'b10;
48      end
49      begin
50          opcode = 3'b101;
51          operand1 = 2'b00;
52      end
53      begin
54          opcode = 3'b111;
55          operand1 = 2'b11;
56          operand2 = 2'b01;
57      end
58      begin
59          opcode = 3'b110;
60          operand1 = 2'b01;
61          operand2 = 2'b10;
62      end
63      begin
64          opcode = 3'b111;
65          operand1 = 2'b10;
66          operand2 = 2'b11;
67      end
68      begin
69          opcode = 3'b011;
70          operand1 = 2'b00;
71      end
72      begin
73          opcode = 3'b101;
74          operand1 = 2'b00;
75      end
76      begin
77          DONE = 1;
78      end
79  endcase
80 end
81
82 always @ (state or START or ZERO_FLAG) begin
83
84     nextState = S0;
85
```

```
86      case(state)
87      S0: begin
88          if(START)
89              nextState = S1;
90      end
91      S1: begin
92          nextState = S2;
93      end
94      S2: begin
95          nextState = S3;
96      end
97      S3: begin
98          nextState = S4;
99      end
100     S4: begin
101         if(ZERO_FLAG)
102             nextState = S1;
103         else
104             nextState = S5;
105     end
106     S5: begin
107         nextState = S6;
108     end
109     S6: begin
110         nextState = S7;
111     end
112     S7: begin
113         nextState = S8;
114     end
115     S8: begin
116         nextState = S9;
117     end
118     S9: begin
119         if(ZERO_FLAG)
120             nextState = S10;
121         else
122             nextState = S5;
123     end
124     S10: begin
125         nextState = S10;
126     end
127 endcase
128 end
129 endmodule
```

## ModelSim Testbench:

```
1  module FSM_TB();
2
3  parameter size = 4;
4
5  reg START, ZERO_FLAG, CLK, RST;
6  wire [size-2:0] opcode;
7  wire [size-3:0] operand1, operand2;
8  wire DONE;
9
10
11
12  always begin
13      CLK = 0; #50;
14      CLK = 1; #50;
15  end
16
17  initial begin
18      START = 0; ZERO_FLAG = 0; RST = 0; #100;
19      START = 1; ZERO_FLAG = 0; RST = 0; #100;
20      START = 0; ZERO_FLAG = 0; RST = 0; #100;
21      START = 0; ZERO_FLAG = 0; RST = 0; #100;
22      START = 0; ZERO_FLAG = 0; RST = 0; #100;
23      START = 0; ZERO_FLAG = 0; RST = 0; #100;
24      START = 0; ZERO_FLAG = 1; RST = 0; #100;
25      START = 0; ZERO_FLAG = 0; RST = 0; #100;
26      START = 0; ZERO_FLAG = 0; RST = 0; #100;
27      START = 0; ZERO_FLAG = 0; RST = 0; #100;
28      START = 0; ZERO_FLAG = 0; RST = 0; #100;
29      START = 0; ZERO_FLAG = 0; RST = 0; #100;
30      START = 0; ZERO_FLAG = 0; RST = 0; #100;
31      START = 0; ZERO_FLAG = 0; RST = 0; #100;
32      START = 0; ZERO_FLAG = 0; RST = 0; #100;
33      START = 0; ZERO_FLAG = 0; RST = 0; #100;
34      START = 0; ZERO_FLAG = 0; RST = 0; #100;
35      START = 0; ZERO_FLAG = 0; RST = 0; #100;
36      START = 0; ZERO_FLAG = 0; RST = 0; #100;
37      START = 0; ZERO_FLAG = 1; RST = 0; #100;
38      START = 0; ZERO_FLAG = 0; RST = 1; #100;
39
40      START = 1; ZERO_FLAG = 0; RST = 0; #100;
41      START = 0; ZERO_FLAG = 0; RST = 0; #100;
42
43
44
45  endmodule;
```

## ModelSim Simulation:



Comments: By using the flowchart provided in the lab manual, I first drew a state table followed by a state table. Then using the state diagram and table, I used the Moore Model provided in the manual and wrote all the verilog code according to it. For the modelsim testbench I followed the flowchart making sure to make sure to include both decisions yes and no for the decision box “count == 0”. The modesim simulation completely verifies my state diagram and agree with the flowchart as well.

# FSM\_DECO)

## Verilog code:

```
1  module FSM_DECO(opcode, operand1, operand2, alu_opcode, rd_addr1, rd_addr2, wrt_addr, wrt_en, load_data);
2
3  parameter size = 4;
4
5  input [size-2:0] opcode;
6  input [size-3:0] operand1, operand2;
7
8  output reg [size-2:0] alu_opcode;
9  output reg [size-3:0] rd_addr1, rd_addr2, wrt_addr;
10 output reg wrt_en, load_data;
11
12 always @(opcode or operand1 or operand2) begin
13
14     alu_opcode = opcode;
15     wrt_addr = operand1;
16     rd_addr1 = operand1;
17     rd_addr2 = operand2;
18     wrt_en = 1;
19     load_data = 0;
20
21     if(opcode == 3'b000 || opcode == 3'b101)
22         wrt_en = 0;
23     if(opcode == 3'b100)
24         load_data = 1;
25
26 end
27 endmodule
```

## ModelSim Testbench:

```
1  module FSM_DECO_TB();
2
3  parameter size = 4;
4
5  reg [size-2:0] opcode;
6  reg [size-3:0] operand1, operand2;
7
8  wire [size-2:0] alu_opcode;
9  wire [size-3:0] rd_addr1, rd_addr2, wrt_addr;
10 wire wrt_en, load_data;
11
12 FSM_DECO DUT(opcode, operand1, operand2, alu_opcode, rd_addr1, rd_addr2, wrt_addr, wrt_en, load_data);
13
14 initial begin
15     opcode = 3'b000; operand1 = 2'b00; operand2 = 2'b01; #100;
16     opcode = 3'b001; operand1 = 2'b00; operand2 = 2'b01; #100;
17     opcode = 3'b010; operand1 = 2'b00; operand2 = 2'b01; #100;
18     opcode = 3'b011; operand1 = 2'b00; operand2 = 2'b01; #100;
19     opcode = 3'b100; operand1 = 2'b00; operand2 = 2'b01; #100;
20     opcode = 3'b101; operand1 = 2'b00; operand2 = 2'b01; #100;
21     opcode = 3'b110; operand1 = 2'b00; operand2 = 2'b01; #100;
22     opcode = 3'b111; operand1 = 2'b00; operand2 = 2'b01; #100;
23
24 end
25 endmodule
26
```

## ModelSim Simulation:



Comments: FSM\_DECO is designed according to the table provided in the lab manual. The verilog code is first written and then the modelsim testbench to simulate all combinations of the table. The simulation shows that the FSM\_DECO works according to the table.

# FIBO\_FSM)

## Verilog code:

```
1 module FIBO_FSM(START, CLK, RST, ZERO_FLAG, wrt_addr, wrt_en, clk, load_data, rd_addr1, rd_addr2, alu_opcode, DONE);
2
3 parameter size = 4;
4
5 input START, ZERO_FLAG, CLK, RST;
6
7 output [size-2:0] alu_opcode;
8 output [size-3:0] rd_addr1, rd_addr2, wrt_addr;
9 output clk, wrt_en, load_data, DONE;
10
11 wire [size-2:0] opcode;
12 wire [size-3:0] operand1, operand2;
13
14 FSM F1(START, ZERO_FLAG, CLK, RST, DONE, opcode, operand1, operand2);
15 FSM_DECO F2(opcode, operand1, operand2, alu_opcode, rd_addr1, rd_addr2, wrt_addr, wrt_en, load_data);
16
17 assign clk = CLK;
18
19 endmodule
20
```

## ModelSim Testbench:

```
1 module FIBO_FSM_TB();
2
3 parameter size = 4;
4
5 reg START, ZERO_FLAG, CLK, RST;
6 wire [size-2:0] alu_opcode;
7 wire [size-3:0] rd_addr1, rd_addr2, wrt_addr;
8 wire clk, wrt_en, load_data, DONE;
9
10 FIBO_FSM DUT(START, CLK, RST, ZERO_FLAG, wrt_addr, wrt_en, clk, load_data, rd_addr1, rd_addr2, alu_opcode, DONE);
11
12
13 always begin
14     CLK = 0; #50;
15     CLK = 1; #50;
16 end
17
18 initial begin
19     START = 0; ZERO_FLAG = 0; RST = 0; #100;
20     START = 1; ZERO_FLAG = 0; RST = 0; #100;
21     START = 0; ZERO_FLAG = 0; RST = 0; #100;
22     START = 0; ZERO_FLAG = 0; RST = 0; #100;
23     START = 0; ZERO_FLAG = 0; RST = 0; #100;
24     START = 0; ZERO_FLAG = 1; RST = 0; #100;
25     START = 0; ZERO_FLAG = 0; RST = 0; #100;
26     START = 0; ZERO_FLAG = 0; RST = 0; #100;
27     START = 0; ZERO_FLAG = 0; RST = 0; #100;
28     START = 0; ZERO_FLAG = 0; RST = 0; #100;
29     START = 0; ZERO_FLAG = 0; RST = 0; #100;
30     START = 0; ZERO_FLAG = 0; RST = 0; #100;
31     START = 0; ZERO_FLAG = 0; RST = 0; #100;
32     START = 0; ZERO_FLAG = 0; RST = 0; #100;
33     START = 0; ZERO_FLAG = 0; RST = 0; #100;
34     START = 0; ZERO_FLAG = 0; RST = 0; #100;
35     START = 0; ZERO_FLAG = 0; RST = 0; #100;
36     START = 0; ZERO_FLAG = 0; RST = 0; #100;
37     START = 0; ZERO_FLAG = 0; RST = 0; #100;
38     START = 0; ZERO_FLAG = 1; RST = 0; #100;
39     START = 0; ZERO_FLAG = 0; RST = 1; #100;
40
41     START = 1; ZERO_FLAG = 0; RST = 0; #100;
42     START = 0; ZERO_FLAG = 0; RST = 0; #100;
43 end
44 endmodule
45
```

## ModelSim Simulation:



Comments: FIBO\_FSM is the combination of FSM and FSM\_DECO. It is written using top level design and the modelsim simulations verifies that the outputs are correct.

# FIBO\_CALCULATOR)

## Verilog code:

```
1 module FIBO_CALCULATOR(START, CLK, RST, COUNT, DONE, DATA);
2
3 parameter size = 4;
4
5 input [size-1:0] COUNT;
6 input START, CLK, RST;
7
8 output [size-1:0] DATA;
9 output DONE;
10
11 wire [size-2:0] alu_opcode;
12 wire [size-3:0] rd_addr1, rd_addr2, wrt_addr;
13 wire clk, wrt_en, load_data;
14 wire zero_flag;
15
16 FIBO_FSM F1(START, CLK, RST, zero_flag, wrt_addr, wrt_en, clk, load_data, rd_addr1, rd_addr2, alu_opcode, DONE);
17 FIBO_DATAPATH D1(wrt_addr, wrt_en, clk, load_data, rd_addr1, rd_addr2, alu_opcode, COUNT, zero_flag, DATA);
18
19 endmodule
```

## ModelSim Testbench:

```
1 module FIBO_CALUCLATOR_TB();
2     parameter size = 4;
3
4     reg [size-1:0] COUNT;
5     reg START, CLK, RST;
6
7     wire [size-1:0] DATA;
8     wire DONE;
9
10    FIBO_CALCULATOR DUT(START, CLK, RST, COUNT, DONE, DATA);
11
12    always begin
13        CLK = 0; #50;
14        CLK = 1; #50;
15    end
16
17    initial begin
18        START = 1; RST = 0; COUNT = 4'b0101; #3000;
19        START = 1; RST = 1; COUNT = 4'b0111; #200;
20        START = 1; RST = 0; COUNT = 4'b0111; #100;
21    end
22
23 endmodule
```

## ModelSim Simulation:



Comments: This is the top level design for the whole implementation of fibonacci calculator. This includes the FIBO\_FSM and the DATAPATH. The FIBO\_FSM controls the outputs and uses the datapath to find the fibonacci. The modelsim simulation is used to first find the fibonacci for 5 sequence then after a reset it calculates for 7 sequences. The simulation shows that the output is correct for the 5 sequences but for 7 sequences since the number gets larger then what 4 bit can store, the output is not as expected. Since we have used a parameterized approach we can easily increase the bit size and overcome this issue. Overall the simulation is successful in showing a correct fibonacci sequence.

# FMAX)

| Slow 1200mV 85C Model Fmax Summary |            |                 |                             |                                                               |
|------------------------------------|------------|-----------------|-----------------------------|---------------------------------------------------------------|
|                                    | Fmax       | Restricted Fmax | Clock Name                  | Note                                                          |
| 1                                  | 401.12 MHz | 250.0 MHz       | CLK                         | limit due to minimum period restriction (max I/O toggle rate) |
| 2                                  | 531.35 MHz | 257.2 MHz       | FIBO_FSM:F1 FSM:F1 state.S0 | limit due to hold check                                       |

Comments: Overall, the fibonacci fsm calculator is written in a scalable way to ensure that number of bits can be increased, furthermore every verilog code written is tested using the modelsim testbench to look for any anomaly. I can safely say that my modelsim simulations act accordingly and that the requirements of the lab have been met.