



# Electronics Systems (938II)

Lecture 2.4

Building Blocks of Electronic Systems – Finite State Machine

# Finite State Machine (FSM)

- A **Finite State Machine (FSM)** is a **sequential circuit** that:
  - Has a finite (limited) **number of states**
  - Is in **exactly one of the finite states at any given time**
- The **evolution** between the states **depends** on
  - **Inputs**
  - **Current state**
  - In fact, it is a sequential circuit

# Finite State Machine (FSM)

- Memory resources are required to store the current state
  - We have already seen an example
    - Latches
    - Flip-flops/Registers
  - If the FSM employs latches, it is asynchronous
  - If it employs a register, it is synchronous
    - By default, we will assume synchronous FSM in the next slides
    - This means that the state change occurs on the rising edge of the clock signal

Sep. networks: our ws  
assigned only on  
the edge of the clock  
if we have synchronous  
machines.

# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



It depends on

# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM



This is the circuit that defines the outputs → Output logic

# Finite State Machine (FSM)

- Outline of an FSM



*It depends on*

# Finite State Machine (FSM)

- Outline of an FSM



It depends on → **Current state** (ONLY!!!)

# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- Outline of an FSM

- Next-state =  $F(\text{input}, \text{current state})$



- Output:  $O = G(\text{current state})$ 
  - Moore FSM
  - A Moore FSM is an FSM in which the output depends ONLY on the current state

# Finite State Machine (FSM)

- An FSM can be represented by
  - State diagram
  - State transition table
  - Output transition table
- State and output transition tables can be merged in a unique table

# Finite State Machine (FSM)

- **State diagram (Moore)**



# Finite State Machine (FSM)

- State diagram (Moore)

- State



# Finite State Machine (FSM)

- State diagram (Moore)

- State
- Output value  
(per state)



# Finite State Machine (FSM)

- **State diagram (Moore)**

- State
- Output value (per state)
- Input value (trigger for state transition)



# Finite State Machine (FSM)

- State diagram (Moore)



- An FSM with  $N$  states requires a (status) register of  $K = \lceil \log_2(N) \rceil$  bits at least

# Finite State Machine (FSM)

- At least  $K = \lceil \log_2(N) \rceil$ , because other coding style can be used
  - Example: One-hot encoding
    - The binary representation of each state has only one 1; all other bits are 0
    - $N$  states  $\rightarrow K = N$  bits
    - Higher resource consumption (more bits)
    - But higher robustness against disturbance

More bits change so disturbance can be bad (ex: 000  $\rightarrow$  111)

---

One-hot encoding for a 4-state FSM

---

| State | SR <sub>0</sub> | SR <sub>1</sub> | SR <sub>2</sub> | SR <sub>3</sub> |
|-------|-----------------|-----------------|-----------------|-----------------|
| S0    | 1               | 0               | 0               | 0               |
| S1    | 0               | 1               | 0               | 0               |
| S2    | 0               | 0               | 1               | 0               |
| S3    | 0               | 0               | 0               | 1               |

$SR_i = i^{\text{th}}$  bit of SR (Status Register)

# Finite State Machine (FSM)

- **State transition table (Moore)**

- Input: I (2-bit)

- S = State (current)

- Number of states = 4

- $S^*$  = Next state

| S  | I  |    |    |    |
|----|----|----|----|----|
|    | 00 | 01 | 10 | 11 |
| S0 | S0 | S0 | S1 | S1 |
| S1 | S2 | S1 | S2 | S2 |
| S2 | S0 | S3 | S0 | S3 |
| S3 | S1 | S3 | S0 | S1 |

$S^*$

# Finite State Machine (FSM)

- **Output transition table (Moore)**

- Output: O (3-bit)

- S = State (current)

- Number of states = 4

| S  |     |
|----|-----|
| S0 | 011 |
| S1 | 100 |
| S2 | 110 |
| S3 | 010 |
|    | O   |

# Finite State Machine (FSM)

- How to set the initial state of FSM?
  - At the power-on of the device/system, the logic value of elements is unpredictable
  - Unless it is addressed with specific techniques
  - Most diffused approach: Power-on Reset (PoR)
    - The main goal of reset is to bring a digital system into a known state!!!
    - Reset signal (and logic) must be added to the FSM circuit

# Finite State Machine (FSM)

- Outline of an FSM



# Finite State Machine (FSM)

- State diagram (Moore)

$S_0 = \text{Initial State}$

$R = \text{reset}$



We should add a loop in  $S_0$  for  $R$  because  $R$  is a synchronous input  
 In this case  $I = \text{power on}$ .  $I$  not specified because state doesn't depend on it

# Finite State Machine (FSM)

- State diagram (Moore)

$S_0 = \text{Initial State}$

$R = \text{reset}$



# Finite State Machine (FSM)

- State diagram (Moore)

$S_0 = \text{Initial State}$

$R = \text{reset}$



- Also reset signal is an input

# Finite State Machine (FSM)

- **State transition table with reset (Moore)**

- Inputs:
  - I (2-bit)
  - R = Reset (1-bit)

- S = State (current)
  - Number of states = 4
- S0 = Initial state (upon reset)
- S\* = Next state

| S  | R,I |     |     |     |     |
|----|-----|-----|-----|-----|-----|
|    | 000 | 001 | 010 | 011 | 1xx |
| S0 | S0  | S0  | S1  | S1  | S0  |
| S1 | S2  | S1  | S2  | S2  | S0  |
| S2 | S0  | S3  | S0  | S3  | S0  |
| S3 | S1  | S3  | S0  | S1  | S0  |

S\*

# Finite State Machine (FSM)

- The Moore architecture is not the only possible architecture for FSM
- Two other architectures exist...
  - ... or better, another main architecture
  - and its modified version to overcome a problem that this second architecture may present

# Finite State Machine (FSM)

- Recall: **Moore FSM**



# Finite State Machine (FSM)

- Mealy FSM



# Finite State Machine (FSM)

- Mealy FSM

- Next-state =  $F(\text{input}, \text{current state})$ 
  - Such as Moore FSM
- Output:  $O = G(\text{input}, \text{current state})$ 
  - A Mealy FSM is an FSM in which the output depends on the current state AND the input



# Finite State Machine (FSM)

Moore FSM

- Next-state =  $F(\text{input}, \text{current state})$

- Output:  $O = G(\text{current state})$



Mealy FSM

- Next-state =  $F(\text{input}, \text{current state})$

- Output:  $O = G(\text{input, current state})$



# Finite State Machine (FSM)

- **State diagram (Mealy)**

- **Output is no more associated to the state, but is on the branch (with input)**
  - I/O



# Finite State Machine (FSM)

- State transition table is like the one in Moore's FSM
- Instead, output transition table changes with respect to the one in Moore's FSM, because output depends also on input(s)

# Finite State Machine (FSM)

- **Output transition table (Mealy)**

- Input: I (2-bit)

- S = State (current)

- Number of states = 4

- Output: O (3-bit)

| S  | I   |     |     |     | O |
|----|-----|-----|-----|-----|---|
|    | 00  | 01  | 10  | 11  |   |
| S0 | 001 | 010 | 010 | 111 |   |
| S1 | 100 | 000 | 011 | 101 |   |
| S2 | 111 | 110 | 101 | 100 |   |
| S3 | 000 | 010 | 110 | 101 |   |

# Finite State Machine (FSM)

- **State/output transition table (Mealy)**

- Input: I (2-bit)

- S = State (current)

- Number of states = 4

- $S^*$  = Next state

- Output: O (3-bit)

| S  | I       |         |         |         | $S^*, O$ |
|----|---------|---------|---------|---------|----------|
|    | 00      | 01      | 10      | 11      |          |
| S0 | S0, 001 | S0, 010 | S1, 010 | S1, 111 |          |
| S1 | S2, 100 | S1, 000 | S2, 011 | S2, 101 |          |
| S2 | S0, 111 | S3, 110 | S0, 101 | S3, 100 |          |
| S3 | S1, 000 | S3, 010 | S0, 110 | S1, 101 |          |

# Finite State Machine (FSM)

- Mealy FSM

- Since the output depends on both the current state (i.e. the State Register) and the input(s), the output is asynchronous
  - It does not change (only) on the clock edge as it happens in a Moore FSM
    - In a Moore FSM output is synchronous (with the clock)
  - The output may present spurious transitions, creating problems in some cases

↳ You choose if you need more robustness. If so, you use the registers

# Finite State Machine (FSM)

- Mealy FSM

- Since the output depends on both the current state (i.e. the State Register) and the input(s), the output is asynchronous
  - It does not change (only) on the clock edge as it happens in a Moore FSM
    - In a Moore FSM output is synchronous (with the clock)
  - The output may present spurious transitions, creating problems in some cases
- If so, this problem can be solved by ‘registering’ the output ?
  - I.e., placing a register after the Output logic (G) block
  - In this way the output is again synchronous (with the clock)

# Finite State Machine (FSM)

- Delayed (or pipelined) Mealy FSM



# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim
  - Input(s)
    - en (1-bit)
    - rst\_n (asynchronous active-low reset)
  - Output(s)
    - out\_code (2-bit)
  - States
    - 4 states: S0, S1, S2, S3
    - 2-bit state register

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim

- Moore FSM

- S = current state
- S\* = next state

State transition table

| S  | rst_n, en |    |    |
|----|-----------|----|----|
|    | 0x        | 10 | 11 |
| S0 | S0        | S0 | S1 |
| S1 | S0        | S1 | S2 |
| S2 | S0        | S2 | S3 |
| S3 | S0        | S3 | S0 |
| S* |           |    |    |

Output transition table

| S  | out_code |
|----|----------|
| S0 | 00       |
| S1 | 01       |
| S2 | 10       |
| S3 | 11       |

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim
  - Moore FSM

State diagram



# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment

```
/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
if (!rst_n)
    current_state <= S0;
else
    current_state <= next_state;
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment

```
/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
① always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment

```
/* Logic signals */  
② reg [1:0] current_state;  
  
/* State Register (SR) */  
① always_ff @ (posedge clk or negedge rst_n)  
    if(!rst_n)  
        current_state <= S0;  
    else  
        current_state <= next_state;
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment

```

/* Logic signals */
② reg [1:0] current_state;

/* State Register (SR) */
① always_ff @ (posedge clk or negedge rst_n)
  if (!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
③
  
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment
- Signal internal to the module
  - Must be declared before its usage (in the module body)

```
/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment
- Signal internal to the module
  - Must be declared before its usage (in the module body)

```

module fsm (
  /* ports list */
);

/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;

endmodule
  
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment
- Signal internal to the module
  - Must be declared before its usage (in the module body)

```
module fsm (
    /* ports list */
);

/* Logic signals */
reg [1:0] current_state; // ←

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
if (!rst_n)
    current_state <= S0;
else
    current_state <= next_state;

endmodule
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment
- Signal internal to the module
  - Must be declared before its usage  
(in the module body)

```

module fsm (
    /* ports list */
);

    /* Logic signals */
    reg [1:0] current_state; ←

    /* State Register (SR) */
    always_ff @ (posedge clk or negedge rst_n)
        if (!rst_n)
            →current_state <= S0;
        else
            →current_state <= next_state;

endmodule
  
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- State register = sequential logic
  - always\_ff block + trigger(s) edge
  - reg signal
  - non-blocking assignment
- Signal internal to the module
  - Must be declared before its usage**  
(in the module body)

```

module fsm (
  /* ports list */
);

  /* Logic signals */
  reg [1:0] current_state; ←

  /* State Register (SR) */
  always_ff @ (posedge clk or negedge rst_n)
    if (!rst_n)
      → current_state <= S0;
    else
      → current_state <= next_state;

endmodule

```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- States can be coded using **labels**

```
/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- States can be coded using labels
  - Local parameters
    - Syntax: **localparam <name> = <constant value>;**
  - Again: declare before usage!!!



```
/* State labels */
localparam S0 = 2'b00;
localparam S1 = 2'b01;
localparam S2 = 2'b10;
localparam S3 = 2'b11;

/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- The always\_ff block includes the dependence on the asynchronous active-low reset for the next state
  - Such signal can be omitted in the description of F

```

/* State labels */
localparam S0 = 2'b00;
localparam S1 = 2'b01;
localparam S2 = 2'b10;
localparam S3 = 2'b11;

/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
  
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- The `always_ff` block includes the dependence on the asynchronous active-low reset for the next state
  - Such signal can be omitted in the description of F
- F (next-state logic) is combinational
  - Case statement can be very useful, so ...
    - `always_comb`
    - blocking assignment on `reg` signal

*always comb = blocking assignment*

That works  
on reg though

```

/* State labels */
localparam S0 = 2'b00;
localparam S1 = 2'b01;
localparam S2 = 2'b10;
localparam S3 = 2'b11;

/* Logic signals */
reg [1:0] current_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if (!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
  
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- The `always_ff` block includes the dependence on the asynchronous active-low reset for the next state
  - Such signal can be omitted in the description of F
- F (next-state logic) is combinational
  - Case statement can be very useful, so ...
    - `always_comb`
    - blocking assignment on `reg` signal

```

/* State labels */
localparam S0 = 2'b00;
localparam S1 = 2'b01;
localparam S2 = 2'b10;
localparam S3 = 2'b11;

/* Logic signals */
reg [1:0] current_state;
→ reg [1:0] next_state;

/* State Register (SR) */
always_ff @ (posedge clk or negedge rst_n)
  if(!rst_n)
    current_state <= S0;
  else
    current_state <= next_state;
  
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



```
/* Next-state logic (F) */
always_comb
```

```
case (current_state)
  S0: next_state = en ? S1 : S0;
  S1: next_state = en ? S2 : S1;
  S2: next_state = en ? S3 : S2;
  S3: next_state = en ? S0 : S3;
endcase
```

- The always\_ff block includes the dependence on the asynchronous active-low reset for the next state
  - Such signal can be omitted in the description of F
- F (next-state logic) is combinational
  - Case** statement can be very useful, so ...
    - always\_comb**
    - blocking assignment** on reg signal

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- The always\_ff block includes the dependence on the asynchronous active-low reset for the next state
  - Such signal can be omitted in the description of F
- F (next-state logic) is combinational
  - Case statement can be very useful, so ...
    - always\_comb
    - blocking assignment on reg signal

dependence on the current state

```
/* Next-state logic (F) */  
always_comb  
  
case (current_state)  
S0: next_state = en ? S1 : S0;  
S1: next_state = en ? S2 : S1;  
S2: next_state = en ? S3 : S2;  
S3: next_state = en ? S0 : S3;  
endcase
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- The always\_ff block includes the dependence on the asynchronous active-low reset for the next state
  - Such signal can be omitted in the description of F
- F (next-state logic) is combinational
  - Case statement can be very useful, so ...
    - always\_comb
    - blocking assignment on reg signal

dependence on the current state

```

/* Next-state logic (F) */
always_comb
  case (current_state)
    S0: next_state = en ? S1 : S0;
    S1: next_state = en ? S2 : S1;
    S2: next_state = en ? S3 : S2;
    S3: next_state = en ? S0 : S3;
  endcase

```

dependence on inputs

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- G (output logic) can be implemented in the same way as F

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



```
/* Output logic (G) */
always_comb
```

```
case (current_state)
S0: out_code = 2'd0;
S1: out_code = 2'd1;
S2: out_code = 2'd2;
S3: out_code = 2'd3;
endcase
```

- G (output logic) can be implemented in the same way as F

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- G (output logic) can be implemented in the same way as F
  - It depends only on the current state

dependence on the current state

```
/* Output logic (G) */  
always_comb
```

```
case (current_state)  
S0: out_code = 2'd0;  
S1: out_code = 2'd1;  
S2: out_code = 2'd2;  
S3: out_code = 2'd3;  
endcase
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- G (output logic) can be implemented in the same way as F
  - It depends only on the current state
  - Output (out\_code) must be a **reg**

```
module fsm (
    input clk,
    input rst_n,
    input en,
    output reg [1:0] out_code
);
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- List of ports (and module declaration)

```
module fsm (
    input clk,
    input rst_n,
    input en,
    ,output reg [1:0] out_code
);
```

Every assignment is always REG in blocking assignment

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim



- F and G can also be merged together

```
/* Next-state/Output logic (F/G) */
always_comb

  case(current_state)

    S0: begin
      out_code   = 2'd0;
      next_state = en ? S1 : S0;
    end

    S1: begin
      out_code   = 2'd1;
      next_state = en ? S2 : S1;
    end

    S2: begin
      out_code   = 2'd2;
      next_state = en ? S3 : S2;
    end

    S3: begin
      out_code   = 2'd3;
      next_state = en ? S0 : S3;
    end

  endcase
```

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim
  - You can find all the files about this exercise in the dedicated folder on the Team of the course
    - File > Electronics Systems module > Crocetti > Exercises > 2.4
  - Try to simulate on your own



# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim
  - You can find all the files about this exercise in the dedicated folder on the Team of the course
    - File > Electronics Systems module > Crocetti > Exercises > 2.4
  - Try to simulate on your own
  - However, I also included two .do files to automate the waveform and the simulation
    - wave.do and sim.do
    - Refer to README.txt file

# Exercise with SystemVerilog

- Implementation of an FSM and simulation with Modelsim
  - You can find all the files about this exercise in the dedicated folder on the Team of the course
    - File > Electronics Systems module > Crocetti > Exercises > 2.4
  - Try to simulate on your own
  - However, I also included two .do files to automate the waveform and the simulation
    - wave.do and sim.do
    - Refer to README.txt file
    - Look at the wave.do file, if you are curious about how to display labels for the current state





Thank you for your attention

Luca Crocetti  
(luca.crocetti@unipi.it)