/tt-cpu8

8 bit cpu

Primary LanguageVerilogApache License 2.0Apache-2.0

tiny 8-bit CPU

From Paul Campbell - Moonbase Otago - visit VROOM! for something slightly bigger

This is a 8-bit CPU in verilog designed for tiny-tapeout.

It has a 8-bit accumulator, a 12-bit PC, 2 13-bit index registers and a carry bit.

The main limitations are the 6/8-bit bus - it's designed to run with an external SRAM and a 12-bit address latch, code is loaded externally. Accesses are 4 beats:

  • strobe loads the address latch low nibble
  • strobe loads the address latch high nibble
  • next clock loads/stores the high nibble
  • next clock loads/stores the low nibble

There are 33 instructions. each 1, 2 or 3 bytes:

0v:		add a, v(x/y)	- sets C
1v: 	sub a, v(x/y)	- sets C
2v:		or a, v(x/y)
3v:		and a, v(x/y)
4v:		xor a, v(x/y)
5v:		mov a, v(x/y)
6v:		movd a, v(x/y)
70:		add a, c
71:		inc a
72:		swap x, y
73:		ret
74:		add y, a
75:		add x, a
76:		add y, #1
77:		add x, #1
78:		mov a, y
79:		mov a, x
7a:		mov b, a
7b:		swap b, a
7c:		mov y, a
7d:		mov x, a
7e:		clr a
7f:		mov a, pc
8v:		nop
9v:		nop
av:		movd v(x/y), a
bv:		mov  v(x/y), a
cv:		nop
dv:		nop
ev:		nop
f0 HL:	mov a, #HL
f1 HL:	add a, #HL
f2 HL:	mov y, #EEHL
f3 HL:	mov x, #EEHL
f4 HL:	jne a/c, EEHL	if ee[4] the test c otherwise test a
f5 HL:	jeq a/c, EEHL	if ee[4] the test c otherwise test a
f6 HL:	jmp/call EEHL
f7 HL:	nop

Memory is 4096 bytes, references are a 3 bit (8 byte) offset from the X or Y index registers - the general idea is that the Y register points to a scratch pad block (a bit like an 8051) but can also be repurposed for copies when required. There is an on-chip SRAM block for data access only (addressed with the MSB of the data address) - mostly just to soak up any additional gates.

There is a 3-deep hardware call stack.

An assembler for this CPU is here

What is Tiny Tapeout?

TinyTapeout is an educational project that aims to make it easier and cheaper than ever to get your digital designs manufactured on a real chip!

Go to https://tinytapeout.com for instructions!

How to change the Wokwi project

Edit the info.yaml and change the wokwi_id to match your project.

How to enable the GitHub actions to build the ASIC files

Please see the instructions for:

How does it work?

When you edit the info.yaml to choose a different ID, the GitHub Action will fetch the digital netlist of your design from Wokwi.

After that, the action uses the open source ASIC tool called OpenLane to build the files needed to fabricate an ASIC.

Resources

What next?