
This project is an 8-bit computer I originally designed in Logisim Evolution, which I am now porting to TinyTapeout for manufacturing. Below is the computer’s general architecture as shown in Logisim Evolution; however, certain modifications were made to ensure compatibility with VHDL and TinyTapeout.

The primary change includes the addition of a B register, alongside adjustments to enable ROM and RAM communication via SPI. Detailed information on these modifications is provided below.
The computer supports the following operations:
The computer features four main registers: a, b, c, and d. It supports:
mov) data between all registers.cmp) values between registers, or between a register and a constant (0, 1, -1, or 255).jmp) to labels and performing conditional jumps (=, !=, <, <=, >, >=) and relative jumps.The ALU (Arithmetic Logic Unit) offers the following operations:
~) and negation (-).+1) and decrement (-1).+) and subtraction (-).*) and division (/).&) and OR (|).in) port.out) port.The computer doesn't have any start signal and will begin read from the SPI ROM as soon as the clock signal (clk) starts ticking.
For examples of programs and a basic assembler, please see this repository (https://github.com/AeroX2/tt06-jrb8-computer/). 
Clone the repository and use the assembler with the following command:
python3 ./example_programs/assembler.py
A file dialog will open, allowing you to select a *.j file.
Below is a simple 8-bit Fibonacci program in the custom J format (fibonacci.j):
:start
load rom a 1
load rom b 0
:repeat
// Store the previous in c register
mov a c
// a = a + b
opp a+b
// This also corresponds to the carry flag being set
// So jump to start if a+b has overflowed  
jmp < start
// Output the value to the output pins
out a
// Restore the previous value in b register
mov c b 
jmp repeat
This program, when assembled, translates to the following hexadecimal format:
d0 01 d1 00 02 6c 33 00 00 f4 08 36 00 04
For a comprehensive guide on assembler instructions and their corresponding hex codes, refer to this document (https://docs.google.com/document/d/1ZVZw_Kt-KQHER0Wr5ty7JpUEeox_284Mih4rwE16FVM/edit?usp=sharing). 
You can also look at roms/cu_flags.csv in the tt06-jrb8-computer repository
The input register or the i register is mapped to ui_in
The output register or the o register is mapped to uo_out
To load data into the ROM, place it at offset 0. The address space is divided as follows:
RAM addressing is handled through two registers:
mpage Register: Controls 0x1**00mar Register: Controls 0x100**External SPI storage is required for this computer, with mappings compatible with spi-ram-emu (https://github.com/MichaelBell/spi-ram-emu/). The following uio mappings are used:
uio[0]: "cs rom"
uio[1]: "mosi"
uio[2]: "miso"
uio[3]: "sck"
| # | Input | Output | Bidirectional | 
|---|---|---|---|
| 0 | input bit 0 | output bit 0 | cs rom | 
| 1 | input bit 1 | output bit 1 | mosi | 
| 2 | input bit 2 | output bit 2 | miso | 
| 3 | input bit 3 | output bit 3 | sck | 
| 4 | input bit 4 | output bit 4 | cs ram | 
| 5 | input bit 5 | output bit 5 | |
| 6 | input bit 6 | output bit 6 | |
| 7 | input bit 7 | output bit 7 | 24 addressing bit mode |