4.3 KiB
[DRAFT] Specification for the Cardiograph Architecture
CPU
Registers
There are four 8-bit registers:
- A, the accumulator (and the only general-purpose register)
- IP, the instruction pointer (aka program counter)
- IOD, the ID of the current I/O device
- Status
Status register
The high byte holds the state of the four Sense Switches. (TODO: is this easy enough to do in hardware?)
The low byte holds four flags:
Overflow, Negative, Zero, and Carry.
These are all addressed by number:*
| S1 | S2 | S3 | S4 | O | N | Z | C | |
|---|---|---|---|---|---|---|---|---|
| 80 | 40 | 20 | 10 | 08 | 04 | 02 | 01 |
- (Because the core instruction set doesn't include bitwise operations)
Instruction set
-
Instructions are two bytes long: one byte for the opcode, one for the operand
-
Opcode format is
GGMM OOOO— Group, Mode, Operation
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | ||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | NOP | HLT | |||||||||||||||
| 5 | LDA # | STO # | ADD # | SUB # | JMP # | JEQ # | JFL # | FTG # | MUL # | DIV # | JLT # | JGT # | NOT # | AND # | OR # | XOR # | |
| 6 | LDA ind | STO ind | ADD ind | SUB ind | JMP ind | JEQ ind | JFL ind | FTG ind | MUL ind | DIV ind | JLT ind | JGT ind | NOT ind | AND ind | OR ind | XOR ind | |
| 9 | DEV # | INP # | OUT # | FED | |||||||||||||
| A | DEV ind | INP ind | OUT ind | FED | |||||||||||||
| F | RSL A | RSR A | ASL A | ASR A |
Operations in italics are extensions to the core set of operations.
High byte reference:
| g, m | bin | hex |
|---|---|---|
| 0, 0 | 0000 | 0 |
| 1, 1 | 0101 | 5 |
| 1, 2 | 0110 | 6 |
| 2, 1 | 1001 | 9 |
| 2, 2 | 1010 | A |
| 3, 3 | 1111 | F |
TODO: assess JMPs vs. HOPs
Brief legend for mnemonics:
- RSL/RSR: Ring Shift Left/Right
- JLT/JGT: Jump Less/Greater Than
- DEV: select IO device
- FED: "feed" - line feed / end of card
TODO: format/document better:
- core computational operations: low nibbles of 0x, 5x, 6x
- arithmetic extension (optional): MUL, DIV
- IO extension (optional): 9x, Ax
- bitwise arithmetic extension (optional): NOT, AND, OR, XOR and RSL, RSR, ASL, ASR
- control flow extension (optional): JLT, JGT
- The mainframe system implements at least 1, 2, and 3
- The microprocessor trainer implements 1
- (see note dated 2023-09-24)
Connections (pinout)
TBC
| name | in/out? | description |
|---|---|---|
| RST | in | reset |
| VCC | in | power |
| GND | in | ground |
| CLK | in | clock |
| A0 - A7 | out | address bus |
| D0 - D7 | out | data bus |
| ABE | out | address bus enable: low when the CPU is using the address bus |
| DBE | out | data bus enable: low when the CPU is using the data bus |
| WAIT | in | wait — when pulled low, the current operation is completed and then execution pauses |
| /RD | out | TODO |
| /WR | out | |
| M/IO | out |
Start-up
TODO: see if this makes sense for the mainframe
When starting up, the CPU executes a JMP $FF.
Put differently: it starts executing instructions at the address contained in $FF.
TODO: currently the simulator doesn't actually do this