### State Machines

University of Texas at Austin CS310 - Computer Organization Spring 2009 Don Fussell





### Synchronous state machines

If a system can both process and store information, then the values stored in the memory elements depend on both the inputs and the previous values in these elements. This is called a **sequential** system.

Such a system is also called a finite-state machine (FSM).

If all changes to memory values happen at the same time as determined by a global system clock, we have a **synchronous FSM**.





### FSM definition

#### An FSM has the following components:

- A set of states
- A set of inputs
- A set of outputs
- A state-transition function (of the states and inputs)
- An output function (of the states and maybe inputs)
  - Moore machine function of states only
  - Mealy machine function of states and inputs

#### This can be represented by a state diagram

- States are circles
- Arcs show the state transition function
- Arcs are labeled with input values
- Outputs are labels on states (Moore) or arcs (Mealy)



# Another example - 2-bit counter



Counter starts at 0 (green) and increments each time the clock cycles, until it gets to 3 and then overflows back to 0.

Only input is the clock, we don't show that.

| H <sub>old</sub> | L <sub>old</sub> | H <sub>new</sub> | L <sub>new</sub> |
|------------------|------------------|------------------|------------------|
| 0                | 0                | 0                | 1                |
| 0                | 1                | 1                | 0                |
| 1                | 0                | 1                | 1                |
| 1                | 1                | 0                | 0                |



2-bit counter





#### 2-bit counter with reset



| R | H <sub>old</sub> | L <sub>old</sub> | H <sub>new</sub> | L <sub>new</sub> |
|---|------------------|------------------|------------------|------------------|
| 0 | 0                | 0                | 0                | 1                |
| 0 | 0                | 1                | 1                | 0                |
| 0 | 1                | 0                | 1                | 1                |
| 0 | 1                | 1                | 0                | 0                |
| 1 | Х                | Х                | 0                | 0                |

$$L_{new} = R'H_{old}'L_{old}' + R'H_{old}L_{old}'$$
  
= R'L\_{old}' = (R + L\_{old})'

$$H_{new} = R'H_{old}'L_{old} + R'H_{old}L_{old}'$$
  
= R'(H\_{old}'L\_{old} + H\_{old}L\_{old}')

University of Texas at Austin CS310 - Computer Organization Spring 2009 Don Fussell



## 2-bit counter with reset





# Counter with 7-segment display

Each segment in the display can be lit independently to allow all 10 decimal digits to be displayed (also hex)

2-bit counter will need to display digits 0-3, so will output a 1 for each segment to be lit for a given state







Counter with output functions

| R                                                      | H <sub>o</sub> | L <sub>o</sub> | H <sub>n</sub> | L <sub>n</sub> | A                      | B                    | C | D | E | F | G |
|--------------------------------------------------------|----------------|----------------|----------------|----------------|------------------------|----------------------|---|---|---|---|---|
| 0                                                      | 0              | 0              | 0              | 1              | 1                      | 1                    | 1 | 1 | 1 | 1 | 0 |
| 0                                                      | 0              | 1              | 1              | 0              | 0                      | 1                    | 1 | 0 | 0 | 0 | 0 |
| 0                                                      | 1              | 0              | 1              | 1              | 1                      | 1                    | 0 | 1 | 1 | 0 | 1 |
| 0                                                      | 1              | 1              | 0              | 0              | 1                      | 1                    | 1 | 1 | 0 | 0 | 1 |
| 1                                                      | X              | X              | 0              | 0              | 0                      | 0                    | 0 | 0 | 0 | 0 | 0 |
| $A = D = R'H_o'L_o'+R'H_oL_o'+R'H_oL_o = R'(H_o'L_o)'$ |                |                |                |                |                        |                      |   |   |   |   |   |
| $B = R' \qquad C = R'(H_o L_o')'$                      |                |                |                |                | E = R'L <sub>o</sub> ' |                      |   |   |   |   |   |
| $F = R'H_o'L_o' = (R+H_o+L_o)'$                        |                |                |                |                | G =                    | G = R'H <sub>o</sub> |   |   |   |   |   |

University of Texas at Austin CS310 - Computer Organization Spring 2009 Don Fussell



# 7-segment output logic



11



### Example - 101 lock



12



# 101 combination lock

$$X = H_o L_o$$

$$H_{n} = B'H_{o}'L_{o} + BH_{o}L_{o}'$$

$$L_{n} = BH_{o}'L_{o} + BH_{o}L_{o}' + BH_{o}L_{o}$$

$$= BH_{o}'L_{o} + BH_{o}L_{o} + BH_{o}L_{o}' + BH_{o}L_{o}$$

$$= BI_{o} + BH_{o}H_{o}$$



# LC-3 datapath

