EE 231L Fall 2005

## EE 231L Lab 4

## Prelab Part 2

The writeup for Lab 4 gives a code fragment for the state machine for the control system for a computer. It shows what should be on the output lines of the control system for two instructions: LDAA addr and LDAA #num. Make a table which shows what should which control lines should be active (READ, STORE, INST\_L, C\_L, ACCA\_L, PC\_I, and MAR\_L), and what should be on the ALU\_CTL and MEM\_SEL lines for the other instructions of the computer. Here is the start for the LDAA addr and LDAA #num instructions:

| Instruction | State C1                           | State C2                                   | State C3                                        |
|-------------|------------------------------------|--------------------------------------------|-------------------------------------------------|
| LDAA addr   | INST_L, READ, PC_I                 | MAR_L, READ, PC_I                          | READ, ACCA_L                                    |
|             | $\mathtt{PC} 	o \mathtt{MEM\_SEL}$ | $\mathtt{PC} 	o \mathtt{MEM\_SEL}$         | $\mathtt{MAR} 	o \mathtt{MEM\_SEL}$             |
|             |                                    |                                            | $oxedsymbol{ALU\_LOAD} 	o oxedsymbol{ALU\_CTL}$ |
|             | Next state: C2                     | Next State: C3                             | Next State: C1                                  |
| LDAA #num   | INST_L, READ, PC_I                 | ACCA_L, READ, PC_I                         |                                                 |
|             | $\mathtt{PC} 	o \mathtt{MEM\_SEL}$ | $\mathtt{PC} 	o \mathtt{MEM\_SEL}$         |                                                 |
|             |                                    | $\mathtt{ALU\_LOAD} \to \mathtt{ALU\_CTL}$ |                                                 |
|             | Next state: C2                     | Next State: C1                             |                                                 |
| ADDA addr   | INST_L, READ, PC_I                 | MAR_L, READ, PC_I                          | READ, ACCA_L                                    |
|             | $\mathtt{PC} 	o \mathtt{MEM\_SEL}$ | $\mathtt{PC} 	o \mathtt{MEM\_SEL}$         | $	exttt{MAR} 	o 	exttt{MEM\_SEL}$               |
|             |                                    |                                            | $\mathtt{ALU\_ADD} \to \mathtt{ALU\_CTL}$       |
|             | Next state: C2                     | Next State: C3                             | Next State: C1                                  |

Here are a few hints for finishing the table:

- The instructions SUBA addr, ANDA addr, ORAA addr, and CMPA addr are the same as LDAA addr, except for the ALU\_CTL lines in State C3.
- The instructions JMP addr is similar to LDAA addr, except that in State C3, you need to load the data out of the memory chip into the PC register rather than into the ACCA register.