

# GP8B

Datasheet

-

Version 5.x

This document has been made with LibreOffice.

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 1/17   | Licensed under CERN-OHL-W v2 or later |

Copyright (C) 2020 Guillaume Guillet  
Licensed under CERN-OHL-W v2 or later

This source describes Open Hardware and is licensed under the CERN-OHL-W v2 or later.

You may redistribute and modify this documentation and make products using it under the terms of the CERN-OHL-W v2 (<https://cern.ch/cern-ohl>). This documentation is distributed WITHOUT ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING OF MERCHANTABILITY, SATISFACTORY QUALITY AND FITNESS FOR A PARTICULAR PURPOSE.

Please see the CERN-OHL-W v2 for applicable conditions.

## Table of contents

|                            |    |
|----------------------------|----|
| Description.....           | 3  |
| Features.....              | 3  |
| CodeG.....                 | 4  |
| Details.....               | 6  |
| Bus.....                   | 6  |
| Instruction execution..... | 9  |
| Sequencer.....             | 9  |
| Simple instructions.....   | 11 |
| Complex instructions.....  | 12 |
| Arguments.....             | 13 |
| ALU.....                   | 14 |
| RAM.....                   | 15 |
| Fabrication.....           | 16 |
| Getting the PCB.....       | 16 |
| Getting the materials..... | 16 |
| Soldering.....             | 16 |
| Changes.....               | 17 |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 2/17   | Licensed under CERN-OHL-W v2 or later |

# Description

The GP8B or G\_Processor8Bits is a custom, from scratch, with no micro-controller, only made with logic circuits, 8bits processor.

This project is one part of a larger project which is the complete development of a home-made 8bits computer.

One of the goals is to create a new community around 8bits computers with a set of electrical/mechanical standards and projects in order to be able to create a simple and practical environment for all interested persons, whether they are hobbyists or not.

## Features

- 64 kByte of pluggable RAM maximum.
- Using a CPLD to build the 8bits ALU (arithmetic-logic unit) with **ALUminium**<sup>\*1</sup>.
- A simple SPI implementation.
- 16 writeable bits for parallel peripheral communication.
- 16 readable bits for parallel peripheral communication.
- Following the custom standard **SPS1**<sup>\*2</sup>.
- Following the **CodeG binary rev1**<sup>\*2</sup> standard.
- Accessible debug pins and Jtag for the CPLD.
- 50Mhz theoretical maximum frequency.
- 24bits available address bus to execute binary code from a source.

<sup>\*1</sup> ALUminium is an VHDL 8bits ALU code that you can find here:

<https://github.com/JonathSpirit/ALUminium>

<sup>\*2</sup> You can find the standard here:

[https://github.com/JonathSpirit/GComputer\\_standard](https://github.com/JonathSpirit/GComputer_standard)

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 3/17   | Licensed under CERN-OHL-W v2 or later |

# CodeG

GP8B execute the revision 1 of the home-made binary language called CodeG:

| CodeG binary revision 1 |             |                |                                                  |
|-------------------------|-------------|----------------|--------------------------------------------------|
| Instruction selection   |             |                |                                                  |
| Opcode                  | Hex         | Name           | Description                                      |
| <b>xxx0'0000</b>        | <b>0x00</b> | BWRITE1_CLK    | Apply value to bus “write 1”.                    |
| <b>xxx0'0001</b>        | <b>0x01</b> | BWRITE2_CLK    | Apply value to bus “write 2”.                    |
| <b>xxx0'0010</b>        | <b>0x02</b> | BPCS_CLK       | Apply value to bus “peripheral CS”.              |
| <b>xxx0'0011</b>        | <b>0x03</b> | OPLEFT_CLK     | Apply value to the left operation.               |
| <b>xxx0'0100</b>        | <b>0x04</b> | OPRIGHT_CLK    | Apply value to the right operation.              |
| <b>xxx0'0101</b>        | <b>0x05</b> | OPCHOOSE_CLK   | Apply value for choosing the operation.          |
| <b>xxx0'0110</b>        | <b>0x06</b> | PERIPHERAL_CLK | Send a clock pulse to the peripheral.            |
| <b>xxx0'0111</b>        | <b>0x07</b> | BJMPSRC1_CLK   | Apply value to bus “jump source 1”.              |
| <b>xxx0'1000</b>        | <b>0x08</b> | BJMPSRC2_CLK   | Apply value to bus “jump source 2”.              |
| <b>xxx0'1001</b>        | <b>0x09</b> | BJMPSRC3_CLK   | Apply value to bus “jump source 3”.              |
| <b>xxx0'1010</b>        | <b>0x0A</b> | JMPSRC_CLK     | Jump to the address of “jump source”.            |
| <b>xxx0'1011</b>        | <b>0x0B</b> | BRAMADD1_CLK   | Apply value to bus “RAM address 1”.              |
| <b>xxx0'1100</b>        | <b>0x0C</b> | BRAMADD2_CLK   | Apply value to bus “RAM address 2”.              |
| <b>xxx0'1101</b>        | <b>0x0D</b> | SPI_CLK        | Send a clock pulse for the SPI.                  |
| <b>xxx0'1110</b>        | <b>0x0E</b> | BCFG_SPI_CLK   | Apply value to the config bus SPI.               |
| <b>xxx0'1111</b>        | <b>0x0F</b> | STICK          | Simple tick, do nothing (delay).                 |
| <b>xxx1'0000</b>        | <b>0x10</b> | IF             | Conditional instruction.                         |
| <b>xxx1'0001</b>        | <b>0x11</b> | IFNOT          | Conditional instruction inverted.                |
| <b>xxx1'0010</b>        | <b>0x12</b> | RAMW           | Write value to the actual address of the memory. |
| <b>xxx1'0011</b>        | <b>0x13</b> | UOP            | Undefined operation.                             |
| <b>xxx1'0100</b>        | <b>0x14</b> | UOP            | Undefined operation.                             |
| <b>xxx1'0101</b>        | <b>0x15</b> | UOP            | Undefined operation.                             |
| <b>xxx1'0110</b>        | <b>0x16</b> | UOP            | Undefined operation.                             |
| <b>xxx1'0111</b>        | <b>0x17</b> | LTICK          | Long tick, do nothing (delay).                   |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 4/17   | Licensed under CERN-OHL-W v2 or later |

| CodeG binary revision 1 |             |          |                                          |
|-------------------------|-------------|----------|------------------------------------------|
| Argument selection      |             |          |                                          |
| Opcode                  | Hex         | Name     | Description                              |
| <b>000x'xxxx</b>        | <b>0x00</b> | SRCVALUE | The value stored to the source.          |
| <b>001x'xxxx</b>        | <b>0x20</b> | BREAD1   | The value of the read bus 1.             |
| <b>010x'xxxx</b>        | <b>0x40</b> | BREAD2   | The value of the read bus 2.             |
| <b>011x'xxxx</b>        | <b>0x60</b> | OPRESULT | The value of the operation result (ALU). |
| <b>100x'xxxx</b>        | <b>0x80</b> | RAMVALUE | The value of the processor memory.       |
| <b>101x'xxxx</b>        | <b>0xA0</b> | SPI      | The value of the SPI.                    |
| <b>110x'xxxx</b>        | <b>0xC0</b> | EXT_1    | External value 1.                        |
| <b>111x'xxxx</b>        | <b>0xE0</b> | EXT_2    | External value 2.                        |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 5/17   | Licensed under CERN-OHL-W v2 or later |

# Details

## Bus

Details of essential/functional bus are listed here:

| Bus name       | Size (bits) | Direction  | Description                                                                                                                                                                                                     |
|----------------|-------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>BWRITE1</b> | <b>8</b>    | <b>out</b> | Bus for parallel peripheral communication.                                                                                                                                                                      |
|                |             |            | <p><b>A D-latch chip control the write bus 1.</b><br/> <b>You can apply a value with the instruction “BWRITE1_CLK”.</b></p>    |
| <b>BWRITE2</b> | <b>8</b>    | <b>out</b> | Bus for parallel peripheral communication.                                                                                                                                                                      |
|                |             |            | <p><b>A D-latch chip control the write bus 2.</b><br/> <b>You can apply a value with the instruction “BWRITE2_CLK”.</b></p>  |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 6/17   | Licensed under CERN-OHL-W v2 or later |

| Bus name      | Size (bits) | Direction | Description                                                                                                                        |
|---------------|-------------|-----------|------------------------------------------------------------------------------------------------------------------------------------|
| <b>BREAD1</b> | 8           | in        | Bus for parallel peripheral communication.                                                                                         |
|               |             |           | <b>The readable bus 1 can be directly applied as an argument into the “NUMBER” bus.</b>                                            |
|               |             |           |                                                                                                                                    |
| <b>BREAD2</b> | 8           | in        | Bus for parallel peripheral communication.                                                                                         |
|               |             |           | <b>The readable bus 2 can be directly applied as an argument into the “NUMBER” bus.</b>                                            |
|               |             |           |                                                                                                                                    |
| <b>NUMBER</b> | 8           | in/out    | Main argument bus.                                                                                                                 |
|               |             |           | <b>The “NUMBER” bus is applied almost everywhere. With it, you can control most of the register like the writeable bus 1 or 2.</b> |
|               |             |           |                                                                                                                                    |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 7/17   | Licensed under CERN-OHL-W v2 or later |



# Instruction execution

## Sequencer

The first main component is a 4bits counter that will receive the “GLOBAL\_CLK” of the motherboard.

The goal of this chip is to provide, with the help of a demux, all the pulse required for executing instruction sequentially.



The 4bits count from 0 to 4, the fifth clock reset the counter to 0:



|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 9/17   | Licensed under CERN-OHL-W v2 or later |

Every pulse from the sequencer represent a stat/action:

| <b>Sequence value</b> | <b>Action/Stat</b> | <b>Counter reset?</b> | <b>Next address?</b> | <b>Instruction latched?</b> |
|-----------------------|--------------------|-----------------------|----------------------|-----------------------------|
| <b>0</b>              | <b>Sync bit</b>    | <b>No</b>             | <b>No</b>            | <b>No</b>                   |

At this stat, no instruction are executed and the SYNC\_BIT is pulled high, this serve only for syncing with an interface like a debugger and prepare the execution of the next instruction.

|          |                        |           |            |            |
|----------|------------------------|-----------|------------|------------|
| <b>1</b> | <b>Instruction set</b> | <b>No</b> | <b>Yes</b> | <b>Yes</b> |
|----------|------------------------|-----------|------------|------------|

A pulse have been made to ‘U7’ (8bit D-Latch) to save the instruction to execute and the next address is requested (the argument).

|          |                  |               |               |           |
|----------|------------------|---------------|---------------|-----------|
| <b>2</b> | <b>Execution</b> | <b>Yes/No</b> | <b>Yes/No</b> | <b>No</b> |
|----------|------------------|---------------|---------------|-----------|

**“Simple instruction”:** One pulse is made to execute the instruction and a reset/next address is requested.

**“Complex instruction”**: The first part of the instruction is executed with no reset:

**IF/IFNOT:** If the argument is valid ( $>0$  or  $=0$ ), then the next instruction is skipped (usually a JMP\$SRC\_CLK instruction) by requesting the next address.

**RAMW:** The “output enable” pin is pulled high for write preparation.

Noting is executed for UOP/LTICK instructions.

**3**      **Waiting**      **No**      **No**      **No**

At this stat, the processor do nothing (this stat is only useful for write preparation to the memory).

|          |                             |            |            |           |
|----------|-----------------------------|------------|------------|-----------|
| <b>4</b> | <b>RAM Write or<br/>END</b> | <b>Yes</b> | <b>Yes</b> | <b>No</b> |
|----------|-----------------------------|------------|------------|-----------|

Depending on the instruction:

**RAMW:** The RAM write the requested data by pulling low the “write enable” pin.

At the end, a reset and the next address is requested.

## Simple instructions



Simple instruction consist of just one pulse and an argument.

Every simple instruction is executed in 3 rising-edges from GLOBAL\_CLK.

| Opcode    | Hex  | Name           | Description                             |
|-----------|------|----------------|-----------------------------------------|
| xxx0'0000 | 0x00 | BWRITE1_CLK    | Apply value to bus “write 1”.           |
| xxx0'0001 | 0x01 | BWRITE2_CLK    | Apply value to bus “write 2”.           |
| xxx0'0010 | 0x02 | BPCS_CLK       | Apply value to bus “peripheral CS”.     |
| xxx0'0011 | 0x03 | OPLLEFT_CLK    | Apply value to the left operation.      |
| xxx0'0100 | 0x04 | OPRIGHT_CLK    | Apply value to the right operation.     |
| xxx0'0101 | 0x05 | OPCHOOSE_CLK   | Apply value for choosing the operation. |
| xxx0'0110 | 0x06 | PERIPHERAL_CLK | Send a clock pulse to the peripheral.   |
| xxx0'0111 | 0x07 | BJMPSRC1_CLK   | Apply value to bus “jump source 1”.     |
| xxx0'1000 | 0x08 | BJMPSRC2_CLK   | Apply value to bus “jump source 2”.     |
| xxx0'1001 | 0x09 | BJMPSRC3_CLK   | Apply value to bus “jump source 3”.     |
| xxx0'1010 | 0x0A | JMPSRC_CLK     | Jump to the address of “jump source”.   |
| xxx0'1011 | 0x0B | BRAMADD1_CLK   | Apply value to bus “RAM address 1”.     |
| xxx0'1100 | 0x0C | BRAMADD2_CLK   | Apply value to bus “RAM address 2”.     |
| xxx0'1101 | 0x0D | SPI_CLK        | Send a clock pulse for the SPI.         |
| xxx0'1110 | 0x0E | BCFG_SPI_CLK   | Apply value to the config bus SPI.      |
| xxx0'1111 | 0x0F | STICK          | Simple tick, do nothing (delay).        |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 11/17  | Licensed under CERN-OHL-W v2 or later |

## Complex instructions



Complex instructions are instructions that takes 5 rising-edges from GLOBAL\_CLK to execute.

| Opcode           | Hex         | Name  | Description                                      |
|------------------|-------------|-------|--------------------------------------------------|
| <b>xxx1'0000</b> | <b>0x10</b> | IF    | Conditional instruction.                         |
| <b>xxx1'0001</b> | <b>0x11</b> | IFNOT | Conditional instruction inverted.                |
| <b>xxx1'0010</b> | <b>0x12</b> | RAMW  | Write value to the actual address of the memory. |
| <b>xxx1'0111</b> | <b>0x17</b> | LTICK | Long tick, do nothing (delay).                   |

The RAMW instruction consist by pulling OE low when counter is at 2, and send a WE pulse when counter is at 4.

The conditional instruction consist of checking the argument when counter is at 2, if the argument is valid, the next instruction (usually a jump) is skipped else the next instruction is executed.

# Arguments

The argument for an operation is selected by changing the last 3bits of the opcode :



The 3bits, once latched, are connected to the demux "U17".



Every "SELECTING" line control an 8bits buffer with tri-state output and every buffer is connected to the argument bus "NUMBER".

| Opcode    | Hex  | Name     | Description                              |
|-----------|------|----------|------------------------------------------|
| 000x'xxxx | 0x00 | SRCVALUE | The value stored to the source.          |
| 001x'xxxx | 0x20 | BREAD1   | The value of the read bus 1.             |
| 010x'xxxx | 0x40 | BREAD2   | The value of the read bus 2.             |
| 011x'xxxx | 0x60 | OPRESULT | The value of the operation result (ALU). |
| 100x'xxxx | 0x80 | RAMVALUE | The value of the processor memory.       |
| 101x'xxxx | 0xA0 | SPI      | The value of the SPI.                    |
| 110x'xxxx | 0xC0 | EXT_1    | External value 1.                        |
| 111x'xxxx | 0xE0 | EXT_2    | External value 2.                        |

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 13/17  | Licensed under CERN-OHL-W v2 or later |

# ALU

A CPLD is used as an ALU (arithmetic-logic unit) in order to be able to implement various operations more easily.

Small parenthesis on the CPLD:

I do not consider the CPLD to be any form of "cheating" in my processor made entirely with logic circuits.

Implementing a multitude of operations by hand can be extremely long, expensive and often complicated. Here the CPLD is only used to perform asynchronous operations.

The only buses entering the CPLD are:

- The number on the left
- The number on the right
- And the desired operation.

The only outgoing bus is the result.

You can access Jtag pins and unused/used pins with the connectors: J4, J5 and J1.



|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 14/17  | Licensed under CERN-OHL-W v2 or later |

# RAM

The RAM module follow the MM1 standard which you can find here:

[https://github.com/JonathSpirit/GComputer\\_standard](https://github.com/JonathSpirit/GComputer_standard)

You can set the address register by using the “BRAMADD1\_CLK”/“BRAMADD2\_CLK” instruction.



To write a certain value to the current memory address, use the “RAMW” instruction.



|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 15/17  | Licensed under CERN-OHL-W v2 or later |

# Fabrication

## Getting the PCB

Fabrication files can be found in the folder: “documents/GP8B\_gerbert”.

For JLCPCB or other manufacturers, you can zip the fabrication folder and send it to them directly.

## Getting the materials

A bill of materials can be found here: “documents/GP8B\_materials”. Note that if you want to change the supplier, you have to make sure that the component is fully compatible mostly for the package.

## Soldering

If you solder the board manually, a microscope can be useful for small component like the CPLD.

Follow the bill of materials and the PCB placement file to solder the board.

I suggest you start with the CPLD and finish with the connectors.

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 16/17  | Licensed under CERN-OHL-W v2 or later |

# Changes

Revision 0:

initial release

|                              |              |                                       |
|------------------------------|--------------|---------------------------------------|
| Author: Guillaume Guillet    | Revision: R0 | <b>G_Processor8bits</b>               |
| Date of creation: 18.05.2020 | Page: 17/17  | Licensed under CERN-OHL-W v2 or later |