

## CDP1802 COSMAC Microprocessor

Jennifer Bi (jb3495) Nelson Gomez (ng2573) Kundan Guha (kg2632) Justin Wong (jw3554)

#### **Overview**

- 1802 ISA, Memory, CPU
- Timing Diagrams
- Hardware-Software interface
- Testing & Debugging

#### ISA

- Memory reference
- Register operations
- Logic operations
- Arithmetic operations
- Control flow (branch, long branch, skip, long skip)
- (I/O byte transfer) -- not implemented



#### Memory

- Dual-port RAM (4KB)
  - o using Altera Megawizard
  - Single clock
  - single-cycle access
  - new data on same-port read-during-write
- 32 16-bit all-purpose registers
- D, N, I, P, T, X, DF, ALU
- We used more flip-flops...



# **CPU design**

- 4 clock cycles per machine cycle
- LOAD, RESET, RUN, PAUSE modes
  - In run mode: FETCH, EXECUTE, EXECUTE2 states

# Graphics

- (incomplete)
- VGA displays 64x32 resolution
- Framebuffer implemented with Megawizard dual-port RAM
- Requires 1x2048-bit RAM
  - use only 1 bit for on/off, rather than 8-bit luminance

# Timing diagrams



Original CDP1802 timing, Group 1 instructions

|               | CLK               |               |               |               |               |
|---------------|-------------------|---------------|---------------|---------------|---------------|
| MACHINE CYCLE |                   | Machine Cycle | Machine Cycle | Machine Cycle | Machine Cycle |
| Group 1       | INSTRUCTION       | Fetch         | Execute       | Fetch         | Execute       |
|               | ram_rd            |               |               |               |               |
|               | ram_wr            |               |               |               |               |
|               | MEMORY OUTPUT     | Data valid    |               | Data valid    |               |
|               | CPU OUTPUT TO MEM |               |               |               |               |
| Group 2       | INSTRUCTION       | Fetch         | Execute       | Fetch         | Execute       |
|               | ram_rd            |               |               |               |               |
|               | ram_wr            |               |               |               |               |
|               | MEMORY OUTPUT     | Data valid    |               | Data valid    |               |
|               | CPU OUTPUT TO MEM |               | Data valid    |               | Data valid    |

Instruction set timing: Group 1 Read/Non-memory, Group 2 Read/Read



#### Instruction set timing: Group 3 Read/Write



Instruction set timing: Group 4 Read/Read/Read, Group 2 Read/Non-memory/Non-memory

### Hardware-software interface

- Avalon Memory-Mapped Port reads from/writes to RAM
- Linux Device driver
  - dtb specification generated from sopc file
  - ioctls for 8-bit read/write and burst 32-bit read/write
- User-space programs using device driver

### **Debugging & Testing**





# test\_9N\_BN

E4 :: x = 4

24 :: R(4) = FF

84 :: D = R(4).0 = FF

B3 :: R(3) = FF00

23 :: R(3) = FEFF

93 :: D = R(3).1 = FE

# test\_5N

E0 : D = 0

1a:R(a) = 1

1a:R(a) = 2

8a : D = R(a) = 2

5a: M(2) = 2