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

# Adapting the OLED designed for the ICOBOARD to the CATBOARD 05/27/18

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

The youtube video <a href="https://www.youtube.com/watch?v=UMDcnwZA2YE">https://www.youtube.com/watch?v=UMDcnwZA2YE</a> describes the interface between an OLED display and the ICOBOARD.

*Goal of this effor:* Is to perform the same functions using the CATBOARD instead of the ICOBOARD.

## otl-icoboard-pmodoldergb-demo



Design Block Diagram

## **Design Structure**



First forked the repository <a href="mailto:ttps://github.hcom/jhol/otl-icoboard-pmodoledrgb-demo">ttps://github.hcom/jhol/otl-icoboard-pmodoledrgb-demo</a>

git clone <a href="https://github.com/develone/otl-icoboard-pmodoledrgb-demo.git">https://github.com/develone/otl-icoboard-pmodoledrgb-demo.git</a>

"cd otl-icoboard-pmodoledrgb-demo/"

Need to create a new branch to track the changes required for the CATBOARD. *"git branch catboard"* 

Even though the FPGAs ice40 HX8K are same for the CATBOARD and the ICOBOARD.

1.) The first issue is the interface between the Raspberry Pi and FPGA hat.

ICOBOARD RPi



CATBOARD RPi

## **GPIO**

GPI01

| RPI_GPI0               |             |             |                 |             |
|------------------------|-------------|-------------|-----------------|-------------|
| × 1 0                  | 3.30        | 57          | 0.2             | (+5V-RP1)   |
| BCM2_SDA O             | BCM2_SDA    | 5V          | p <u>4</u>      | +5V-RP1     |
| BCM3_SCL) 5 o          | BCM3_SCL    | GND         | p <u>6</u>      | GND         |
| BCM4_GPCLK0 \O         | BCM4_GPCLK0 | BCM14_TXD   | 0 <u>B</u>      | BCM14_TXD   |
| GND) 9                 | GND         | BCM15_RXD   | 010             | BCM15_RXD   |
| BCM17) 110             | BCM17       | BCM18_PCM_C | 012             | BCM18_PCM_C |
| BCM27_PCM_0 > 13       | BCM27_PCM_D | GND         | 014             | GND         |
| BCM22) 15 <sub>0</sub> | BCM22       | BCM23       | 016             | ВСМ23       |
| x 17 0                 | 3.37        | BCM24       | 0 <sup>18</sup> | BCM24       |
| BCM10_MOSI) 19         | BCM10_M05I  | GND         | 0 <u>20</u>     | GND         |
| BCM9_MISO 210          | BCM9_MISO   | BCM25       | 022             | BCM25       |
| BCM11_SCLK) 230        | BCM11_SCLK  | BCMB_CE0    | o <del>24</del> | BCMB_CE0    |
| GND) 250               | GND         | BCM7_CE1    | 0 <del>26</del> | BCM7_CE1    |
| BCM0_ID_SD 270         | BCMO_ID_SD  | BCM1_ID_SC  | 0 <del>28</del> | BCM1_ID_SC  |
| BCM5) 29 <sub>0</sub>  | BCM5        | GND         | 0.30            | GND         |
| BCM6) 31 <sub>0</sub>  | ВСМ6        | BCM12       | 032             | BCM12       |
| BCM13) 330             | ВСМ13       | GND         | 034             | GND         |
| BCM19_MIS0 350         | BCM19_MISO  | BCM16       | o <u>36</u>     | BCM16       |
| BCM26) 37 <sub>0</sub> | ВСМ26       | BCM20_MOSI  | 0 <u>38</u>     | BCM20_M051  |
| GND 390                | GND         | BCM21_SCLK  | 0 <del>40</del> | BCM21_SCLK  |
|                        |             |             | J               |             |

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

set\_io clk\_100mhz C8 #R9

set\_io pmod1\_1 A11 set\_io pmod1\_2 B12 #D8 #B9

```
set_io pmod1_3 B14
                    #B10
set_io pmod1_4 B15
                    #B11
  654321
            catboard
                    # 654321 icoboard
#
    xxxxxx PMOD3 A
                         #
                              xxxxxx PMOD1 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

