



### 1) Datapath

- signals -  
 1) PC (15-0)  
 2) Instruction (15-0)  
 3) t<sub>1</sub>  
 4) t<sub>2</sub>  
 5) C  
 6) Z  
 7) t<sub>3</sub>  
 8) t<sub>4</sub>  
 9) t<sub>5</sub>



### 2) FSM

S<sub>0</sub>: m1 = m1.read = 1  
 if LA1, LHI, SA, JAL: M2 = 00  
 D1 = 00

S<sub>2</sub>: other next\_val = S<sub>2</sub>  
 S<sub>1</sub> := D2 = 00  
 D3 = 00

M2 = 00  
 M3 = 00 ?

if ADD, LHI, LW, SW, BEQ, JAL: -  
 next\_val = S<sub>4</sub>

if ADD, ADC, AD, Z NAN

next\_state = S<sub>5</sub>



S<sub>5</sub>: if ADD,  
 ALU-control = 02

M<sub>Y</sub> = 00  
 M<sub>S</sub> = 00

D<sub>Y</sub> = 00  
 nothing = 0

ADC

nothing = !C

M<sub>Y</sub> = 00

M<sub>S</sub> = 00

D<sub>Y</sub> = 00

Similarly AD, Z

NAND

if ADD, LW, SW:

M<sub>Y</sub> = 01

M<sub>S</sub> = 01



if AD:

M<sub>Y</sub> = 00  
 M<sub>S</sub> = 01

JAL:

M<sub>Y</sub> = 00  
 M<sub>S</sub> = 01

S<sub>4</sub>: if LMI:  
 style = 1

else style = 0



'f' style = 1

else style = 0

if JAL or LHJ

M6 = 0;

if ~~SE~~, ADD, LW, SW, BEQ  
M6 = 1

S6: if ADD:  
    if M7 = 1  
        w = 1 }     M9 = 1

    if ADD:

        w = 1 C

        M7 = 1

    if ADD     next-state = S10

    if NAND

    next-state = S10

    if LHJ:  
        M9 = 0

    M7 = 0

    if (BEQ):

        if ( $t_1 = t_2$ ):  
            M3 = 01

        else     M5 = 10

    if LA:  
        M7 = M9 = 10  
        reg\_val = 2  
        next-state =

    if LW:  
        M7 = 10  
        M9 = 10  
        next-state = S12

S10:

    if (BEQ):

        if LA:  
            M1 = 01  
            D1 = 01  
            next-state = S6

    else     M5 = 01

else

    M5 = 10  
    next-state = S11



S11:

    if JLR:

        M8 = 1

    else     M8 = 0

    next-state = S0

S7:

    mem-read = 1

M9 = 10

    M1 = 01

    D1 = 01

    next-state = S06

S8 :

$$\text{mem\_write} = 1$$

$$P1 = 02$$

$$\text{next\_state} = S10$$

$$t_1 - \text{Address}$$



S12: Counter increment  $\rightarrow$   $(t_{\text{reg}})$

S13:

$$\text{next\_state} = S5$$

$$\underline{\text{next\_state} = S5}$$

