### Design of Digital Circuits and Systems ASM with Datapath I

#### Instructor: Justin Hsia

#### **Teaching Assistants:**

Colton Harris Gayathri Vadhyan Lancelot Wathieu

Deepti Anoop Jared Yoder Matthew Hung

#### **Relevant Course Information**

- Homework 2 late deadline tonight (4/11)
- Homework 3 due next Friday (4/19)
  - FIFO buffers & ASM charts
- Lab 2 reports due Friday (4/12), demos 4/15-19
  - Same lab demo slots for whole quarter
- Lab 3 due 4/26
  - Lab 3 + 4 are really ~1.5 weeks long, so don't wait!
- Quiz 2 next Thursday (4/18)
  - Memory (ROM, RAM, reg files)

#### **Review: ASM Chart**



#### **Review Question: 3-way Switch**

- Create an ASM chart for a 3-way switch system using *Mealy*-type output
  - LTog and RTog pulse 1 when switch is flipped/toggled, output called light







#### **ASMD Charts**

- An Algorithmic State Machine with a Datapath chart is created by adding RTL operations to an ASM chart
   Timing of operations can be confusing – NOT a flowchart
- School of Thought #1:
  - RTL operations are triggered by control signals, so they can appear anywhere an output signal can:



#### **ASMD Charts**

- An Algorithmic State Machine with a Datapath chart is created by adding RTL operations to an ASM chart
  - Timing of operations can be confusing NOT a flowchart
- School of Thought #2:
  - It's clearer to separate control signals (Control) from RTL operations (Datapath)
- There isn't a set standard
  - You may see both or variants
  - We use School of Thought #2



#### **ASMD Hardware**

- State transitions and <u>RTL operations</u> are both controlled by the clock
  - It's often helpful to remember the underlying hardware registers!



#### **ASMD Hardware**

- State transitions and RTL operations are both controlled by the clock
  - It's often helpful to remember the underlying hardware registers!
- The behavior of both state and data registers depend on the current control state
  - Can conceptually think of as a MUX to the registers' inputs that uses the current state as its selector bits



#### Hardware Example #1

- State transitions and RTL operations are both controlled by the clock
  - It's often helpful to remember the underlying hardware registers!





#### Hardware Example #1

- State transitions and RTL operations are both controlled by the clock
  - It's often helpful to remember the underlying hardware registers!



#### Hardware Example #2

- State transitions and RTL operations are both controlled by the clock
  - It's often helpful to remember the underlying hardware registers!





#### **ASMD** Timing

- Everything (registers!) within an ASM block occurs simultaneously at the <u>next</u> clock trigger
  - Differs from a flowchart changes occur at state <u>exit</u> rather



#### **ASMD** Timing

- Everything (registers!) within an ASM block occurs simultaneously at the <u>next</u> clock trigger
  - Differs from a flowchart changes occur at state <u>exit</u> rather than <u>entrance</u>





#### **ASMD Timing Question**

\* What value will be stored in r when we transition from state s1 to the next state? (-1) 0, 1



#### **ASMD** Timing

- When a registered output (*e.g.*, *r*) is used in a decision box, its effect may appear to be delayed by one clock
  - Can define a next-state value (e.g., r\_next) to use instead



## Short Tech

## Break

#### **ASMD Design Procedure**

- From problem description or algorithm pseudocode:
  - **1)** Identify necessary datapath components and operations
  - 2) Identify states and signals that cause state transitions (external inputs and status signals), based on the necessary sequencing of operations
  - **3) Name the control signals** that are generated by the controller that cause the indicated operations in the datapath unit
  - 4) Form an ASM chart for your controller, using states, decision boxes, and signals determined above
  - 5) Add the datapath RTL operations associated with each control signal

Input signals (external)

Control unit

(FSM)

Status

Datapath

unit

Output

data

C clr\_A-F

Control

Status signals

#### **Design Example #1**

- System specification:
- $data path = Flip-flops \underline{E} \text{ and } \underline{F}$
- determined 4-bit binary up-counter  $\underline{A} = 0bA_3A_2A_1A_0$
- inputs to contro
- Active-low reset signal <u>reset\_b</u> puts us in state <u>S\_idle</u>, where we remain while signal <u>Start</u> = 0
  - Start = 1 initiates the system's operation by clearing A and
- control signals

status

signals

signals

- F. At each subsequent clock pulse, the counter is incremented by 1 until the operations stop.
- Bits  $\underline{A_2}$  and  $\underline{A_3}$  determine the sequence of operations:
  - If  $A_2 = 0$ , set *E* to 0 and the count continues
  - If  $A_2 = 1$ , set E to 1; additionally, if  $A_3 = 0$ , the count continues, otherwise, wait one clock pulse to set F to 1 and stop counting (*i.e.*, back to  $S_idle$ )



#### **Design Example #1**

The system can be represented by the following block diagram:



#### Design Example #1 (ASM $\rightarrow$ ASMD Chart)

Synchronous or <u>asynchronous</u> reset?



for sychronous reset, add decision box on reset-b out of every state box:



#### **Design Example #1 (Timing)**

#### Sequence of operations:



#### **Design Example #1 (Logic)**

- Controller:
  - State Table:
  - S\_idle = P, Po
  - Scount = P, Po
  - $S_F = P_1 P_0$

|                         | state logic <<br>inputs |                |        |                       |                       |               | -> state logic<br>outputs |         |       |       |         |        |  |
|-------------------------|-------------------------|----------------|--------|-----------------------|-----------------------|---------------|---------------------------|---------|-------|-------|---------|--------|--|
|                         | Present<br>State        |                | Inputs |                       |                       | Next<br>State |                           | Outputs |       |       |         |        |  |
| Present-State<br>Symbol | <b>P</b> <sub>1</sub>   | P <sub>0</sub> | Start  | <b>A</b> <sub>2</sub> | <b>A</b> <sub>3</sub> | <b>N</b> 1    | N <sub>o</sub>            | set_E   | clr_E | set_F | clr_A_F | incr_A |  |
| S_idle                  | 0                       | 0              | 0      | Х                     | Х                     | 0             | 0                         | 0       | 0     | 0     | 0       | 0      |  |
| S_idle                  | 0                       | 0              | 1      | Х                     | Х                     | 0             | 1                         | 0       | 0     | 0     | 1       | 0      |  |
| S_count                 | 0                       | 1              | X      | 0                     | Х                     | 0             | 1                         | 0       | 1     | 0     | 0       | 1      |  |
| S_count                 | 0                       | 1              | X      | 1                     | 0                     | 0             | 1                         | 1       | 0     | 0     | 0       | 1      |  |
| S_count                 | 0                       | 1              | ¦Χ     | 1                     | 1                     | 1             | 1                         | 1       | 0     | 0     | 0       | 1      |  |
| S_F                     | 1                       | 1              | X      | Х                     | Х                     | 0             | 0                         | 0       | 0     | 1     | 0       | 0      |  |

• Logic: 
$$N_1 = S_{\text{count}} \cdot A_2 A_3$$
 set  $F = S_F$   
 $N_0 = S_{\text{count}} + S_{\text{idk}} \cdot Start clr_A F = S_{\text{idle}} \cdot Start$   
 $set_E = S_{\text{count}} \cdot A_2$  incr\_A = S\_{\text{count}}  
 $clr_E = S_{\text{count}} \cdot A_2$ 

# Short Tech

## Break

#### Design Example #1 (SV, Controller) status signals (in) external inputs (in)

#### Design Example #1 (SV, Controller) status signals (in) external inputs (in)

```
// port definitions
input logic Start, clk, reset_b, A2, A3;
output logic set_E, clr_E, set_F, clr_A_F, incr_A;
// define state names and variables
enum logic [1:0] {S_idle, S_count, S_F = 2'b11} ps, ns;
```

```
// controller logic w/synchronous reset
always_ff @(posedge clk)
    if (~reset_b)
        ps <= S_idle;
    else
        ps <= ns;</pre>
```

#### Design Example #1 (SV, Controller)



#### Design Example #1 (SV, Controller)

```
// next state logic
always_comb
   case (ps)
     S idle: ns = Start ? S_count : S_idle;
     S_count: ns = (A2 & A3) ? S_F : S_count;
     S F: ns = S idle;
   endcase
// output assignments
assign set_E = (ps == S_count) & A2;
assign clr_E = (ps == S_count) & ~A2;
assign set_F = (ps == S_F);
assign clr_A_F = (ps == S_idle) & Start;
assign incr_A = (ps == S_count);
```

endmodule // controller

control signals (in)

status signals (aut)

external inputs (in) external outputs (out)

#### Design Example #1 (SV, Datapath)

```
module datapath (A, E, E, clk, set_E, clr E, set_F, clr_A_F,
                 incr A);
   // port definitions
   output logic [3:0] A;
   output logic E, F;
   input logic clk, set_E, clr_E, set_F, clr_A_F, incr_A;
   // datapath logic
   always-ff@ (povedge clk) begin
    if (set_E) E <= 1; } watch for potential conflicts!
else if (clr_E) E <= 0; }
if (set_F) F <= 1;
    clse if (clr_A-F) begin
           A <= 4'h0;
            F<= 0;
        end
    else F(mor-A) A <= A+4 h1;
  end
endmodule // datapath
```

control signals (in)

status signals (aut)

external inputs (in) external outputs (out)

#### Design Example #1 (SV, Datapath)

```
module datapath (A, E, E, clk, set_E, clr_E, set_F, clr_A_F,
                incr A);
  // port definitions
   output logic [3:0] A;
   output logic E, F;
   input logic clk, set_E, clr_E, set_F, clr_A_F, incr_A;
   // datapath logic
   always_ff @(posedge clk) begin
      if (clr E) E <= 1'b0;
      else if (set E) E <= 1'b1;</pre>
      if (clr A F)
         begin
            A <= 4'b0;
            F <= 1'b0;
         end
      else if (set F) F <= 1'b1;</pre>
      else if (incr_A) A <= A + 4'h1;</pre>
   end // always ff
endmodule // datapath
```

#### Design Example #1 (SV, Top-Level Design)

```
module top level (A, E, F, clk, Start, reset b);
   // port definitions
   output logic [3:0] A;
   output logic E, F;
   input logic clk, Start, reset b;
   // internal signals (control signals and status signals that aren't autputs)
   logic set E, clr E, set F, clr A F, incr A;
   // instantiate controller and datapath
   controller c unit (.set E, .clr E, .set F,
                       .clr_A_F, .incr_A, .A2(A[2]),
                       .A3(A[3]), .Start, .clk,
                       .reset b);
   datapath d_unit (.*);
endmodule // top_level
```