

#### **C88**

The 8 address, 8 bit computer. Control FSM Specification.

#### 

# Outputs: ram\_addr\_sel (RAM address source select) instr\_reg\_wen (Instruction register write enable) pc\_inc (Increment program counter) pc\_load (Load program counter) is exec (Is execute state)



\* The step input from user is connected to a one shot pulse generator. If the step button is held, the machine should step once. If the button is released then pressed again then the machine will step again.

|         | ram_addr_sel | instr_reg_wen | pc_inc    | pc_load           | is_exec |
|---------|--------------|---------------|-----------|-------------------|---------|
| READ    | 0            | 1             | 0         | 0                 | 0       |
| EXECUTE | 1            | 0             | skip      | 0                 | 1       |
| STEP    | X            | 0             | ! is_jump | is_jump AND! skip | 0       |
| PAUSE   | X            | 0             | 0         | 0                 | 0       |

#### **C88**

## The 8 address, 8 bit computer. Instruction set Specification.

All instructions are 8 bits wide (7 down to 0). In every instruction that requires an address, the address is in bits 2 down to 0. Bits 7 down to 3 determine the unique operation (opcode). If the operation doesn't require an address then bits 2 down to 0 are ignored and can take any value with the exception of the SHL, SHR, ROL and ROR instructions.

| Mnemonic | Description                                               | Opcode | Mnemonic | Description                                         | Opcode | Mnemonic | Description                                          | Opcode | Mnemonic | Description                  | Opcode |
|----------|-----------------------------------------------------------|--------|----------|-----------------------------------------------------|--------|----------|------------------------------------------------------|--------|----------|------------------------------|--------|
| LOAD     | Load memory<br>location to<br>register                    | 00000  | JMP      | Jump to memory<br>location                          | 01000  | ADD      | Add memory location to register                      | 10000  | ADDU     | Like ADD but<br>unsigned     | 11000  |
| SWAP     | Swap a memory location with the register                  | 00001  | JMA      | Jump to location<br>specified in memory<br>location | 01001  | SUB      | Subtract memory location from register               | 10001  | SUBU     | Like SUB but<br>unsigned     | 11001  |
| STORE    | Store the<br>register in a<br>memory locaion              | 00010  | NEG      | Negate the main register                            | 01010  | MUL      | Multiply memory location by register                 | 10010  | MULU     | Like MUL but<br>unsigned     | 11010  |
| STOP     | Halt all execution                                        | 00011  | INV      | Invert the main register                            | 01011  | DIV      | Divide register by memory location                   | 10011  | DIVU     | Like DIV but unsigned        | 11011  |
| TSG      | Test memory location, skip if greater than register       | 00100  | IOW      | Write register to the GP ouput register             | 01100  | SHL      | Shift register left using address as constant        | 10100  | INC      | Increment register by one    | 11100  |
| TSL      | Test memory<br>location, skip if<br>less than<br>register | 00101  | IOR      | Copy from the GP input to the register              | 01101  | SHR      | Shift register right using address as constant       | 10101  | DEC      | Decrement register by one    | 11101  |
| TSE      | Test memory location, skip if equal to register           | 00110  | IOS      | Shorthand for an IOW followed by an IOR             | 01110  | ROL      | Rotate register left<br>using address as<br>constant | 10110  | DOUBLE   | Double the value of register | 11110  |
| TSI      | Test memory location, skip if not equal to register       | 00111  | IOC      | Clear the GP output register                        | 01111  | ROR      | Rotate register right using address as constant      | 10111  | HALF     | Half the value of register   | 11111  |

### **C88**

The 8 address, 8 bit computer. Decoder Specification.

```
addr = instruction(2:0)
ALU op = instruction(6:3)
COMP ap = instruction(4:3)
reg wen = 1 when (opcode \geq 16)
    or (opcode(4:1) = "0000")
    or (opcode = "01110")
    or (opcode = "01101")
ram wen = 1 when (opcode = "00001")
    or (opcode = "00010")
stop = 1 when (opcode = "00011")
is jump = 1 when (opcode(4:1) = "0100")
jump type = opcode(0)
reg input select = 1 when (opcode(4:1) = "0000")
is_{test} = 1 \text{ when opcode}(4:2) = "001"
is_iow = 1 when (opcode = "01110")
    or (opcode = "01110")
    or (opcode = "01101")
is io in = 1 when (opcode = "01110")
    Or (opcode = "01101")
io_reg_in_sel = opcode(0)
```

```
Inputs:
· instruction
                    (8 bit instruction from RAM)
                    (implicit, first 5 bits of instruction, 7:3)
 (opcode)
Outputs:
 addr
                    (Address specified in instruction, 3 bits)
· ALU op
                    (ALU operation, 4 bits)
 COMP op
                    (Comparator operation, 2 bits)
                    (Register write enable)
 reg wen
                    (RAM write enable)
· ram wen
                    (Halt processor)
 stop
                    (Is jump instruction)
 is jump
                    (Jump type, 0=direct, 1=indirect)
· jump type
 reg input select (Register input select, 0=ALU result, 1=RAM)
 is test
                    (Instruction is a test and skip)
                    (Instruction requires IO write)
 is iow
                    (Instruction requires IO read)
 is io in
                    (IO register input select, 0=Register, 1=Constant 0)
 io reg in sel
```