\*\*\*\*\*\*\*\*DRAFT\*\*\*\*\*

# Adapting the ICOBOARD ZIPCPU to the CATBOARD 11/03/18

\*\*\*\*\*\*\*\*DRAFT\*\*\*\*\*

Cathoard & Icoboard

# CATBOARD vs ICOBOARD

- Catboard SDRAM 33554432
- Autofaga project
- 2 PMODS, 4 pin dipsw, 4 leds, 2 push button switches & 20 pin header
- 50 MHz clock with PLL
- Ver 0.01 catboard has issues with spiflash
- · Yosys tool chain
- Interface to Rpi
- HX8K FPGA

- ICOboard SRAM 131072
- Autofpga project
- 4 PMODS
- 50 MHz clock no PLL
- Spixpress works on gamma version
- · Yosys tool chain
- Interface to Rpi
- HX8K FPGA

Testing Remote Access & building on Ubuntu 16.04 modified the script to perform remote control access of the FPGA interfaced to the RPi3B+testing build on ubuntu 16.04

Linux ws010 4.4.0-137-generic #163-Ubuntu SMP Mon Sep 24 13:14:43 UTC 2018 x86\_64 x86\_64 x86\_64 GNU/Linux cd testbuilds/

git clone https://github.com/develone/catzip.git
The build proces on Ubuntu take a relative short time.
-rw-rw-r-- 1 vidal vidal 6373 Oct 30 10:55 Makefile
-rw-rw-r-- 1 vidal vidal 135100 Oct 30 11:03 rtl/catzip/catzip.bin
./rtl/pptest/linepp.bin

```
./rtl/pptest/speechpp.bin
./rtl/switch_leds/switch_leds.bin
./rtl/uart/speechfifo.bin
./rtl/uart/helloworld.bin
./rtl/catzip/catzip.bin
./rtl/leddigits/leddigits.bin
./rtl/basic/pmodtest.bin
./rtl/basic/dimmer.bin
./rtl/basic/blinky.bin
./rtl/basic/clktest.bin
pi@mypi3-1:~/testbuilds/ws010/catzip/sw/host $ diff rem_test_sim102218.sh test_sim102218.sh
2,18c2,18
<./pc-wbregs -n mypi3-1 version
<./pc-wbregs -n mypi3-1 0x2000004 0x55aaaa55
<./pc-wbregs -n mypi3-1 0x2000004
<./pc-wbregs -n mypi3-1 0x20ffff8 0x55aaaa55
<./pc-wbregs -n mypi3-1 0x20ffff8
<./pc-wbregs -n mypi3-1 0x2800004 0x55aaaa55
<./pc-wbregs -n mypi3-1 0x2800004</p>
<./pc-wbregs -n mypi3-1 0x28ffff8 0x55aaaa55</p>
<./pc-wbregs -n mypi3-1 0x28ffff8
<./pc-wbregs -n mypi3-1 0x2c00004 0x55aaaa55
<./pc-wbregs -n mypi3-1 0x2c00004
<./pc-wbregs -n mypi3-1 0x2cffff8 0x55aaaa55</p>
< ./pc-wbregs -n mypi3-1 0x2cffff8
<./pc-wbregs -n mypi3-1 0x2f00004 0x55aaaa55</p>
<./pc-wbregs -n mypi3-1 0x2f00004
<./pc-wbregs -n mypi3-1 0x2fffff8 0x55aaaa55</p>
<./pc-wbregs -n mypi3-1 0x2fffff8
> ./arm-wbregs version
> ./arm-wbregs 0x2000004 0x55aaaa55
> ./arm-wbregs 0x2000004
> ./arm-wbregs 0x20ffff8 0x55aaaa55
> ./arm-wbregs 0x20ffff8
> ./arm-wbregs 0x2800004 0x55aaaa55
> ./arm-wbregs 0x2800004
> ./arm-wbregs 0x28ffff8 0x55aaaa55
> ./arm-wbregs 0x28ffff8
> ./arm-wbregs 0x2c00004 0x55aaaa55
> ./arm-wbregs 0x2c00004
> ./arm-wbregs 0x2cffff8 0x55aaaa55
> ./arm-wbregs 0x2cffff8
> ./arm-wbregs 0x2f00004 0x55aaaa55
> ./arm-wbregs 0x2f00004
> ./arm-wbregs 0x2fffff8 0x55aaaa55
> ./arm-wbregs 0x2fffff8
pi@mypi3-1:~/testbuilds/ws010/catzip/sw/host $ diff sim_hw_test.sh rem_sim_hw_test.sh
5c5
< ./arm-wbregs version
```

./rtl/pptest/hellopp.bin

```
>./pc-wbregs -n mypi3-1 version
7c7
<./arm-wbregs 0x1000000 0x10000001</pre>
>./pc-wbregs -n mypi3-1 0x1000000 0x10000001
9c9
< ./arm-wbregs 0x1000004 0x10000002
> ./pc-wbregs -n mypi3-1 0x1000004 0x10000002
11c11
< ./arm-wbregs 0x1000008 0x10000003
> ./pc-wbregs -n mypi3-1 0x1000008 0x10000003
13c13
<./arm-wbregs 0x100000c 0x10000004</pre>
>./pc-wbregs -n mypi3-1 0x100000c 0x10000004
15c15
<./arm-wbregs 0x1000000 0x10000001
> ./pc-wbregs -n mypi3-1 0x1000000 0x10000001
<./arm-wbregs 0x1000004 0x10000002
>./pc-wbregs -n mypi3-1 0x1000004 0x10000002
19c19
< ./arm-wbregs 0x1000008 0x10000003
>./pc-wbregs -n mypi3-1 0x1000008 0x10000003
21c21
<./arm-wbregs 0x100000c 0x10000004
>./pc-wbregs -n mypi3-1 0x100000c 0x10000004
23c23
< ./arm-wbregs 0x1000000
> ./pc-wbregs -n mypi3-1 0x1000000
25c25
<./arm-wbregs 0x1000004</pre>
> ./pc-wbregs -n mypi3-1 0x1000004
27c27
<./arm-wbregs 0x1000008
> ./pc-wbregs -n mypi3-1 0x1000008
29c29
<./arm-wbregs 0x100000c
>./pc-wbregs -n mypi3-1 0x100000c
```

<./arm-wbregs 0x1000000

```
> ./pc-wbregs -n mypi3-1 0x1000000
33c33
<./arm-wbregs 0x1000004</pre>
> ./pc-wbregs -n mypi3-1 0x1000004
35c35
<./arm-wbregs 0x1000008</pre>
> ./pc-wbregs -n mypi3-1 0x1000008
< ./arm-wbregs 0x100000c
> ./pc-wbregs -n mypi3-1 0x100000c
40c40
<./arm-wbregs gpio 0x00010001</p>
> ./pc-wbregs -n mypi3-1 gpio 0x00010001
43c43
<./arm-wbregs apio 0x00020002
>./pc-wbregs -n mypi3-1 gpio 0x00020002
<./arm-wbregs apio 0x00040004</p>
> ./pc-wbregs -n mypi3-1 gpio 0x00040004
49c49
<./arm-wbregs apio 0x00070000
> ./pc-wbregs -n mypi3-1 gpio 0x00070000
Adding SDRAM to catzip
Starting with this version of catzip
catzip
commit 1e0dd38e890187ae3d6629fd35ddeeaad39a6701
Author: Edward Vidal Jr <develone@sbcglobal.net>
Date: Mon Aug 13 02:04:34 2018 +0000
  speechfifo not working
Using this version of learning_hdl to copy the files to add
the sdram support to catzip
commit 59da9a3ae53a03c20d516ee4c75da5597e448205
Author: Edward Vidal Jr <develone@sbcglobal.net>
Date: Wed Oct 24 16:51:00 2018 -0600
  using hardware
./config_catzip_simulation.sh
~/testbuilds/catzip_simulation/catzip
```

. myenv.sh make datestamp

#### make autodata

```
~/testbuilds/catzip_simulation/catzip/rtl/catzip
. ../../mvenv.sh
make clean
make cpudefs.h
make design.h
make verilated
make bin
sudo config_cat catzip.bin
~/testbuilds/catzip simulation/catzip/sim/verilated
. ../../myenv.sh
make clean
make
~/testbuilds/catzip_simulation/catzip/sw/host
. ../../myenv.sh
make clean
make
~/testbuilds/catzip_simulation/catzip/sw/host $ ./arm-netpport
pi@mypi3-1:~/testbuilds/catzip_simulation/catzip/sw/host $ ./test_sim102218.sh
00c00010 (VERSION): [...)] 20181029
               )-> 55aaaa55
02000004 (
02000004 (
               ) : [.U.U] aa55aa55
020ffff8 (
             )-> 55aaaa55
             ): [.U.U] aa55aa55
020ffff8 (
02800004 (
              )-> 55aaaa55
02800004 (
               ): [.U.U] aa55aa55
028ffff8 (
             )-> 55aaaa55
028ffff8 (
             ) : [.U.U] aa55aa55
              )-> 55aaaa55
02c00004 (
02c00004 (
               ): [.U.U] aa55aa55
02cffff8 (
             )-> 55aaaa55
02cffff8 (
             ): [.U.U] aa55aa55
02f00004 (
              )-> 55aaaa55
02f00004 (
              ) : [.U.U] aa55aa55
             )-> 55aaaa55
02fffff8 (
             ) : [.U.U] aa55aa55
02fffff8 (
pi@mypi3-1:~/testbuilds/catzip_simulation/catzip/rtl/catzip $ diff wbsdram.v
~/testbuilds/xulalx25soc/rtl/wbsdram.v
66c66
<
      parameter [0:0]
                           F_OPT_CLK2FFLOGIC = 1'b1;
      parameter [0:0]
                           F OPT CLK2FFLOGIC = 1'b0;
122,123c122
                    refresh_clk <= 10'd391; // Make suitable for 50 MHz clk
<
<
                    //refresh_clk <= 10'd625; // Make suitable for 80 MHz clk
                    refresh_clk <= 10'd625; // Make suitable for 80 MHz clk
>
183c182
```

```
//initial
                     fwd_addr = 1;
<
       initial fwd_addr = 1;
>
cd ../basic
~/testbuilds/catzip_simulation/catzip/rtl/basic
make clean
make
sudo config_cat blinky.bin
sudo config_cat dimmer.bin
sudo config_cat clktest.bin
pmodtest.bin not testing.
cd ../leddigits/
~/testbuilds/catzip_simulation/catzip/rtl/leddigits
make clean
make
sudo config_cat leddigits.bin
cd ../switch_leds/
~/testbuilds/catzip_simulation/catzip/rtl/switch_leds
make clean
make
sudo config_cat switch_leds.bin
cd ../pptest/
~/testbuilds/catzip_simulation/catzip/rtl/pptest
make clean
make
sudo config_cat hellopp.bin
. Hello, World!
sudo config_cat speechpp.bin
. | Four score and seven years ago our fathers brought forth on this |
. | continent, a new nation, conceived in Liberty, and dedicated to |
. | the proposition that all men are created equal.
. | Now we are engaged in a great civil war, testing whether that
. | nation, or any nation so conceived and so dedicated, can long
. | endure. We are met on a great battle-field of that war. We have
. | come to dedicate a portion of that field, as a final resting
. | place for those who here gave their lives that that nation might |
. | live. It is altogether fitting and proper that we should do this. |
. | But, in a larger sense, we can not dedicate-we can not consecrate-
. | we can not hallow-this ground. The brave men, living and dead,
. | who struggled here, have consecrated it, far above our poor power |
. | to add or detract. The world will little note, nor long remember |
. | what we say here, but it can never forget what they did here. It |
. | is for us the living, rather, to be dedicated here to the
. | unfinished work which they who fought here have thus far so nobly |
. | advanced. It is rather for us to be here dedicated to the great |
. | task remaining before us-that from these honored dead we take
. | increased devotion to that cause for which they gave the last
. | full measure of devotion-that we here highly resolve that these |
```

```
. | dead shall not have died in vain-that this nation, under God,
. | shall have a new birth of freedom-and that government of the
. | people, by the people, for the people, shall not perish from the |
. | earth.
cd ../uart/
~/testbuilds/catzip_simulation/catzip/rtl/uart
make clean
make
sudo config_cat helloworld.bin
pi@mypi3-1:~/testbuilds/catzip_simulation/catzip/sw/host $ ./sim_hw_test.sh
he date built
00c00010 (VERSION): [...)] 20181029
01000000 (
           RAM)-> 10000001
01000004 (
             )-> 10000002
01000008 (
             )-> 10000003
0100000c (
             )-> 10000004
01000000 (
           RAM)-> 10000001
01000004 (
             )-> 10000002
01000008 (
             )-> 10000003
0100000c (
             )-> 10000004
01000000 (
           RAM): [....] 10000001
01000004 (
             ): [....] 10000002
01000008 (
             ): [....] 10000003
0100000c (
             ): [....] 10000004
01000000 (
           RAM): [....] 10000001
01000004 (
             ): [....] 10000002
01000008 (
             ): [....] 10000003
0100000c (
             ): [....] 10000004
Turning on the 4th led
00c00008 ( GPIO)-> 00010001
Turning on the 1st led
00c00008 ( GPIO)-> 00020002
Turning on the 2nd led
00c00008 ( GPIO)-> 00040004
Turning off the leds
00c00008 ( GPIO)-> 00070000
Versions of support sopport software to
autofpga
commit 2f443503d1edcff1a401d30207790906cb01df32
Author: ZipCPU <dgisselq@ieee.org>
Date: Sun Aug 5 20:55:25 2018 -0400
  Fixed an uninitialized error in the subdirectory string
icestorm
commit 8cac6c584044034210fe0ba1e6b930ff1cc59465
```

Author: Clifford Wolf <clifford@clifford.at>
Date: Mon Jul 30 16:04:04 2018 +0200

### Also install text timing databases

Signed-off-by: Clifford Wolf <clifford@clifford.at>

arachne-pnr

commit 5d830dd94ad956d17d77168fe7718f22f8b55b33

Merge: 3a40328 9763e6e

Author: Clifford Wolf <clifford@clifford.at>
Date: Sun May 13 20:58:41 2018 +0200

Merge pull request #115 from awygle/lm

Add basic lm4k support (no hard IP)

vosys

commit e275692e84c935d0cdf42c2a4adf7ac949a88132

Author: Clifford Wolf <clifford@clifford.at>
Date: Sun Jul 22 18:44:05 2018 +0200

Verific: Produce errors for instantiating unknown module

Because if the unknown module is connected to any constants, Verific will actually break all constants in the same module, even if they have nothing to do structurally with that instance of an unknown module.

Signed-off-by: Clifford Wolf <clifford@clifford.at> commit ab82a886305ceec79b5516d7fc356f95a762c9fd

Author: ZipCPU <dgisselq@ieee.org> Date: Fri Apr 20 12:49:05 2018 -0400

Renamed the autoreload value of the ziptimer to be the interval count

verilator v3.926

commit c8e437c45cf0a9849e0a0465ecca882dbb66933a

Author: Wilson Snyder <wsnyder@wsnyder.org>

Date: Wed Aug 22 18:09:06 2018 -0400

Version bump

The following information is from https://github.com/ZipCPU/zipcpu/blob/master/doc/spec.pdf

### Introduction

The goal of the ZipCPU was to be a very simple CPU. You might think of it as a poor manâ alternative to the OpenRISC architecture. You might also think of it as an Open Source microcontroller. For this reason, all instructions have been designed to be as simple as possible, and the base instructions are all designed to be executed in one instruction cycle per instruction, barring pipeline stalls.1 Indeed, even the bus has been simplified to a constant 32-bit width, with no option for more or less. This has resulted in the choice to drop push and pop instructions, pre-increment and post-decrement addressing modes, the integrated memory management unit (MMU), and more

For those who like buzz words, the ZipCPU is:

A 32-bit CPU: All registers are 32-bits, addresses are 32-bits, instructions are 32-bits wide, etc.

A RISC CPU. There is no microcode for executing instructions. All instructions are designed to be completed in one clock cycle.

A Load/Store architecture. (Only load and store instructions can access memory.) Wishbone compliant. All peripherals are accessed just like memory across this bus.

A Von-Neumann architecture. The instructions and data share a common bus.

A pipelined architecture, having stages for Prefetch, Decode, Read-Operand, a combined stage containing the ALU, Memory, Divide, and Floating Point units, and then the final Write-back stage. See Fig. 1.1 for a diagram of this structure.

Completely open source, licensed under the GPL.3

| OpCode  |        | A-Reg Instruction                                           | Sets CC |  |
|---------|--------|-------------------------------------------------------------|---------|--|
| 5'h00   | SUB    | Subtract                                                    |         |  |
| 5'h01   | AND    | Bitwise And                                                 | 1       |  |
| 5'h02   | ADD    | Add two numbers                                             |         |  |
| 5'h03   | OR     | Bitwise Or                                                  |         |  |
| 5'h04   | XOR    | Bitwise Exclusive Or                                        |         |  |
| 5'h05   | LSR    | Logical Shift Right                                         |         |  |
| 5'h06   | LSL    | Logical Shift Left                                          |         |  |
| 5'h07   | ASR    | Arithmetic Shift Right                                      |         |  |
| 5'h08   | BREV   | Bit Reverse B operand into result                           |         |  |
| 5'h09   | LDILO  | Load Immediate Low N                                        |         |  |
| 5'h0a   | MPYUHI | Upper 32 of 64 bits from an unsigned 32x32 multiply         |         |  |
| 5'h0b   | MPYSHI | Upper 32 of 64 bits from a signed 32x32 multiply            |         |  |
| 5'h0c   | MPY    | 32x32 bit multiply                                          | 1       |  |
| 5'h0d   | VOM    | Move OpB into Ra                                            | N       |  |
| 5'h0e   | DIVU   | R0-R13 Divide, unsigned                                     | Y       |  |
| 5'h0f   | DIVS   | R0-R13 Divide, signed                                       |         |  |
| 5'h10   | CMP    | Compare (Ra-OpB) to zero                                    | Y       |  |
| 5'h11   | TST    | Test (AND w/o setting result)                               | 1       |  |
| 5'h12   | LW     | Load a 32-bit word from memory (OpB) into Ra                |         |  |
| 5'h13   | SW     | Store a 32-bit word from Ra into memory at (OpB)            |         |  |
| 5'h14   | LH     | Load 16-bits from memory (opB) into Ra, clear upper 16 bits |         |  |
| 5'h15   | SH     | Store the lower 16-bits of Ra into memory at (OpB)          |         |  |
| 5'h16   | LB     | Load 8-bits from memory (OpB) into Ra, clear upper 24 bits  |         |  |
| 5'h17   | SB     | Store the lower 8-bits of Ra into memory at (OpB)           |         |  |
| 5'h18/9 | LDI    | Load 23-bit signed immediate                                | N       |  |
| 5'h1a   | FPADD  | R0-R13 Floating point add                                   |         |  |
| 5'h1b   | FPSUB  | R0-R13 Floating point subtract                              | 1       |  |
| 5'h1c   | FPMPY  | R0-R13 Floating point multiply                              | Y       |  |
| 5'h1d   | FPDIV  | R0-R13 Floating point divide                                | 1       |  |
| 5'h1e   | FPI2F  | R0-R13 Convert integer to floating point                    | 1       |  |
| 5'h1f   | FPF2I  | R0-R13 Convert floating point to integer                    | 1       |  |
| 5'h1c   | BREAK  | None(15)                                                    |         |  |
| 5'h1d   | LOCK   | None(15)                                                    | N       |  |
| 5'h1e   | SIM    | None(15)                                                    | 1       |  |
| 5'h1f   | NOOP   | None(15)                                                    | 1       |  |

Table 2.2: ZipCPU OpCodes

"export PATH=/home/pi/zipcpu/sw/install/cross-tools/bin:/home/pi/autofpga/sw/:\$PATH"

"cd catzip"

"make clean"

"make" This creates the 2 executeables arm-netpport & arm-wbregs used to communicate with the FPGA.in files for download to FPGA

In additon compiles the

The rtl has several folders basic, uart,catzip, leddigits, pptest, switch\_leds, and sdram where \*.bin files are created.

The sw/host has 2 executeables arm-netpport & arm-wbregs used to communicate with the FPGA.









```
- sdram.v
   switch leds
       Makefile
      - switch_leds.pcf
      - switch_leds.v
   - uart
     – helloworld.bin
     - helloworld.pcf
     - helloworld.v
     - Makefile
     - notwkg_speechfifo.png
     - README.md
     - speechfifo.bin
     - speechfifo.pcf
     - speechfifo.v
     speechfifo.v.notwkg
     - speechfifo.v.wkg
     - speech.hex
     - wkg_speechfifo.png
- sim
   - verilated
     - automaster_tb.cpp
     - byteswap.cpp
     – byteswap.h
     - dblpipecmdr.cpp
     - dblpipecmdr.h
     - hellopp.cpp
     - linepp.cpp
     - main_tb.cpp
     - Makefile
     - memsim.cpp
     - memsim.h
     - obj-arm
        - depends.txt
        - verilated.o
        verilated_vcd_c.o
        - xdepends.txt
     port.h -> ../../sw/host/port.h
     pportsim.cpp
     pportsim.h
      qspiflashsim.cpp
      qspiflashsim.h
      regdefs.h
      speechpp.cpp
      tags
     tbclock.h
      testb.h
     twoc.cpp
     - twoc.h
     uartsim.cpp
     uartsim.h
      zipelf.cpp
```

# 

Initial testing 06/05/18

cd catzip/rtl/catzip

sudo config\_cat catzip.bin This programs the FPGA

cd catzip/sw/host

./arm-netpport Listening on port 8363 Listening on port 8364

cd catzip/sw/host

./arm-wbregs version 00001010 ( VERSION) : [....] 20180605

1st Led on /arm-wbregs gpio 0x00010001 00001008 ( GPIO)-> 00010001



1st Led off ./arm-wbregs gpio 0x00010000 00001008 ( GPIO)-> 00010000

2n led on ./arm-wbregs gpio 0x00020002 00001008 ( GPIO)-> 00020002



2nd led off ./arm-wbregs gpio 0x00020000 00001008 ( GPIO)-> 00020000

3<sup>rd</sup> led on ./arm-wbregs gpio 0x00040004 00001008 ( GPIO)-> 00040004



 $3^{rd}$  led off ./arm-wbregs gpio 0x00040000 00001008 ( GPIO)-> 00040000

./arm-wbregs 0x2000 0x01
00002000 ( RAM)-> 00000001
pi@pi3-5:~/catzip/sw/host \$ ./arm-wbregs ram
00002000 ( RAM): [....] 00000001
pi@pi3-5:~/catzip/sw/host \$ ./arm-wbregs 0x2000 0x02
00002000 ( RAM)-> 00000002
pi@pi3-5:~/catzip/sw/host \$ ./arm-wbregs ram
00002000 ( RAM): [....] 00000002

./arm-wbregs pic 00001004 ( PIC) : [....] 00000003

./arm-wbregs ufifo 00000804 ( UFIFO) : [@?@.] 403f4000 ICOBOARD RPi



RPI\_SPI\_CLK H11 Pin 23 Pi icoboard



rpi\_cs D4 IOT\_224 Pin 26 Pi icoboard

| IOT_221 | C4  | IO222 |
|---------|-----|-------|
| IOT_222 | B3  | IO223 |
| IOT_223 | D4  | IO224 |
| IOT 225 | ∠E5 | IO225 |

CATBOARD RPi



CATBOARD connection to FPGA pins PMOD 2 & PMOD 3 push button switches, dip switch, and leds.



# CATBOARD sw1 & sw2



# **CATBOARD** leds



# BCM11\_SCLK Pin 23 CATBOARD



BCM7\_CE1 Pin 26 CATBOARD



# **CATBOARD**



- 2.) The 2<sup>nd</sup> issue is the PMOD connections to FPGA are different.
- 3.) Third, I do not have a Diglient PMOD 4 push button switch module.
- 4.) The 4<sup>th</sup> issue is the PHASE LOCK LOOP difference.

# Post on #yosys

Pin C8 is my USER\_CLK comes from a 100MHz osc. It is connected to IOT\_197\_GBIN1 on HX8K. When I try using it for as an input to PLL I get the fatal error: bad constraint on `i\_clk': no PLL at pin C8.

Can only certain pins be used as inputs to PLL? dayeshah

develonepi3: use the SB\_PLL40\_CORE instead of SB\_PLL40\_PAD variant (and REFERENCECLK in instead of PACKAGEPIN)

```
set io clk 100mhz C8 #R9
```

```
set_io pmod1_1 A11
                    #D8
set_io pmod1_2 B12
                    #B9
set_io pmod1_3 B14
                    #B10
set_io pmod1_4 B15
                    #B11
# 654321
           catboard # 654321 icoboard
                              xxxxxx PMOD1 A
#
    xxxxxx PMOD3 A
                         #
#
    xxxxxx PMOD3 B
                              xxxxxx PMOD1 B
                        # 654321
# 654321
#
set_io pmod1_7 B10
                    #B8
set_io pmod1_8 B11
                    #A9
set_io pmod1_9 B13
                    #A10
set_io pmod1_10 A15
                    #A11
```



CATBOARD connection to FPGA pins PMOD 2 & PMOD 3 push button switches, dip switch, and leds.



```
In top.v
module top(clk_100mhz, pmod1_1, pmod1_2, pmod1_3, pmod1_4, pmod1_7, pmod1_8,
 pmod1_9, pmod1_10, pmod2_7, pmod2_8, pmod2_9, pmod2_10, rpi_sck, rpi_cs,
 rpi_mosi);
input rpi_sck, rpi_cs, rpi_mosi;
rpi_sck
rpi_cs
rpi_mosi
spi_ram_slave spi_ram_slave(clk, rpi_sck, rpi_cs, rpi_mosi,
 ram_addr, ram_data, ram_wr);
module spi_ram_slave(clk, sck, cs, mosi, ram_addr, ram_data, ram_wr);
PMOD pin out on icoboard
```

# Pinout Pmod P1 and P2



## Pinout PMOD P3 and P4



"lrwxrwxrwx 1 root staff 34 May 18 20:10 /usr/local/bin/config\_cat -> /home/pi/catboard\_yosys/config\_cat"

# #!/bin/bash

```
#
   A script to configure Lattice iCE40 FPGA by SPI from Raspberry Pi
#
   Copyright (C) 2015 Jan Marjanovic < jan@marjanovic.pro>
#
#
   This program is free software: you can redistribute it and/or modify
#
   it under the terms of the GNU General Public License as published by
#
#
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.
#
#
#
```

This program is distributed in the hope that it will be useful,

```
but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <a href="http://www.gnu.org/licenses/">http://www.gnu.org/licenses/</a>.
echo ""
if [ $# -ne 1 ]; then
  echo "Usage: $0 FPGA-bin-file "
fi
if [$EUID -ne 0]; then
  echo "This script must be run as root" 1>&2
  exit 1
fi
if [!-d/sys/class/gpio/gpio25]; then
  echo "GPIO 25 not exported, trying to export..."
  echo 25 > /sys/class/qpio/export
  if [!-d/sys/class/gpio/gpio25]; then
       echo "ERROR: directory /sys/class/gpio/gpio25 does not exist"
       exit 1
  fi
else
  echo "OK: GPIO 25 exported"
fi
if [!-d/sys/class/qpio/qpio17]; then
  echo "GPIO 17 not exported, trying to export..."
  echo 17 > /sys/class/gpio/export
  if [!-d/sys/class/gpio/gpio17]; then
       echo "ERROR: directory /sys/class/gpio/gpio17 does not exist"
       exit 1
  fi
else
  echo "OK: GPIO 17 exported"
if [!-d/sys/class/gpio/gpio22]; then
  echo "GPIO 22 not exported, trying to export..."
  echo 22 > /sys/class/gpio/export
  if [!-d/sys/class/qpio/qpio22]; then
       echo "ERROR: directory /sys/class/gpio/gpio22 does not exist"
       exit 1
  fi
else
  echo "OK: GPIO 22 exported"
```

```
echo ""
if [ -e /dev/spidev0.0 ]; then
  echo "OK: SPI driver loaded"
else
  echo "spidev does not exist"
  lsmod | grep spi_bcm2708 >& /dev/null
  if [ $? -ne 0 ]; then
       echo "SPI driver not loaded, try to load it..."
       modprobe spi_bcm2708
       if [$? -eq 0]; then
         echo "OK: SPI driver loaded"
       else
         echo "Could not load SPI driver"
         exit 1
       fi
  fi
fi
echo ""
echo "Setting GPIO directions"
echo out > /sys/class/gpio/gpio25/direction
cat /sys/class/gpio/gpio25/direction
echo out > /sys/class/qpio/qpio22/direction
cat /sys/class/gpio/gpio22/direction
echo in >/sys/class/qpio/qpio17/direction
cat /sys/class/gpio/gpio17/direction
echo "Setting output to low"
echo 0 > /sys/class/gpio/gpio25/value
cat /sys/class/gpio/gpio25/value
#echo ""
#echo "Please reset the iCE40 FPGA board"
#echo "Press any key..."
#read
echo "Reseting FPGA"
echo 0 > /sys/class/gpio/gpio22/value
cat /sys/class/gpio/gpio22/value
echo 1 > /sys/class/gpio/gpio22/value
cat /sys/class/gpio/gpio22/value
echo "Checking DONE pin"
cat /sys/class/gpio/gpio17/value
echo "Continuing with configuration procedure"
dd if=$1 of=/dev/spidev0.0
```

echo - e " |x0|x0|x0|x0|x0|x0|x0" > /dev/spidev0.0

echo "Setting output to high" echo 1 > /sys/class/gpio/gpio25/value cat /sys/class/gpio/gpio25/value

echo "Checking DONE pin" cat /sys/class/gpio/gpio17/value

"cd otl-icoboard-pmodoledrgb-demo/stream-tool/"

"ffmpeg -f v4l2 -i /dev/video0 -s 96x64 -f rawvideo -pix\_fmt rgb565 - | ./stream-tool"