# ECE 238L Digital Computers and Number Systems Lecture lab 9

November 20, 2006

– Typeset by  $\ensuremath{\mathsf{FoilT}}_E\!X$  –

# Lab 9 – FSM control for the LC-3

- Implement at least AND, ADD, NOT, JSR, BR, LD, ST and JMP/RET instructions
- ADD, AND, NOT should not require multiple states
- Don't forget the to have a decode state use a decoder and not if/then within a process.

# Problem – Programming VHDL can be tedious and error prone

- There other behavioral and structural circuits.
- VHDL has some structures that are very close to structural, but more convenient.
- I prefer using the when/else construct and will provide examples.
- Continue to use the provided flipflops, but these other structures will provide us some easier middle ground. (Don't go and write funky processes. I won't help you and you will loose points on your code.)

### **Example – Finite State Machines (FSMs)**

```
library ieee ;
use ieee.std_logic_1164.all;
```

```
entity seq_design is
port( a: in std_logic;
clock: in std_logic;
reset: in std_logic;
x: out std_logic
);
end seq_design;
```

\_\_\_\_\_\_

– Typeset by  $\ensuremath{\mathsf{FoilT}}_E\!X$  –

# Example – Finite State Machines (FSMs) - Interface

architecture FSM of seq\_design is

-- define the states of FSM model

type state\_type is (S0, S1, S2, S3); signal next\_state, current\_state: state\_type;

#### Example – FSMs - State FF

```
begin
   -- concurrent process 1: state registers
   state_reg: process(clock, reset)
   begin
if (reset='1') then
        current_state <= S0;
elsif (clock'event and clock='1') then
   current_state <= next_state;
end if;
   end process;</pre>
```

#### Example – FSMs - Next State/Output

#### Example – FSMs - Next State/Output

– Typeset by  $\ensuremath{\mathsf{FoilT}}_E\!X$  –

#### Example – FSMs - Next State/Output

```
when S2 =>
     x <= '0';
     if a='0' then
       next_state <= S2;</pre>
     elsif a='1' then
       next_state <= S3;</pre>
     end if;
when S3 =>
      x <= '1';
       if a='0' then
         next_state <= S3;</pre>
       elsif a='1' then
         next_state <= S0;</pre>
       end if;
```

#### **Example – FSMs - Closing**

```
when others =>
    x <= '0';
    next_state <= S0;
end case;
end process;</pre>
```