## \*\*\*\*\*\*\*\*DRAFT\*\*\*\*\*

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

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



RPI\_SPI\_CLK H11 Pin 23 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? daveshah

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

```
set_io clk_100mhz C8
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 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
```

#R9



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



```
/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 "
  exit 1
fi
if [$EUID -ne 0]; then
  echo "This script must be run as root" 1>&2
  exit 1
fi
if [!-d/sys/class/qpio/qpio25]; then
  echo "GPIO 25 not exported, trying to export..."
  echo 25 > /sys/class/qpio/export
  if [!-d/sys/class/qpio/qpio25]; then
       echo "ERROR: directory /sys/class/qpio/qpio25 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/qpio/qpio17]; then
       echo "ERROR: directory /sys/class/qpio/qpio17 does not exist"
       exit 1
```

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

```
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/qpio/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
echo ""
echo "Setting GPIO directions"
echo out > /sys/class/gpio/gpio25/direction
cat /sys/class/gpio/gpio25/direction
echo out > /sys/class/gpio/gpio22/direction
cat /sys/class/gpio/gpio22/direction
echo in > /sys/class/gpio/gpio17/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 "x0x0x0x0x0x0x0x0" > /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"