## Catboard-Pipelinec PMOD-Ethernet 03/07/25

The current image which does work in the form matrix multiply.





Tested 02/28/25 in PipelineC repo.

devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/examples/net \$ ./compile-work\_test.sh
In file included from work\_test.c:30:

work.h:26:10: **fatal error:** type\_bytes\_t.h/work\_inputs\_t\_bytes\_t.h/work\_inputs\_t\_bytes.h: No such file or directory

26 | #include "type\_bytes\_t.h/work\_inputs\_t\_bytes\_t.h/work\_inputs\_t\_bytes.h"

\( \lambda \) \(

devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/examples/catboard/ice\_makefile\_pipelinec \$ ./build.sh

- rm -f lextab.py
- rm -f yacctab.py
- rm -f pll\_clk\_mhz.h
- rm -f -r pipelinec\_output
- rm -f pipelinec.log
- rm -f pll.v
- rm -f \*.json \*.asc \*.bin \*.uf2
- rm -f yosys\_stderr.log

```
rm -f dfu util.log
echo "#define PLL CLK MHZ 25.0\n" > pll clk mhz.h
/home/devel/PipelineC/src/pipelinec ethernet_top.c --top pipelinec_top --out_dir pipelinec_output --
comb --no synth > pipelinec.log
/home/devel/oss-cad-suite//bin/icepll -q -i 100 -o 25.0 -m -f pll.v
/home/devel/oss-cad-suite//bin/yosys -l simple.log -q -m ghdl -p "ghdl --std=08 -frelaxed `cat
pipelinec_output/vhdl_files.txt`-e pipelinec_top; read_verilog -sv ethernet_top.sv pll.v;
synth_ice40 -top ethernet_top -json gateware.json" 2> yosys_stderr.log
/home/devel/oss-cad-suite//bin/nextpnr-ice40 -l nextpnr.log -q --randomize-seed --hx8k --package
ct256 --pcf ice40.pcf --json gateware.json --asc gateware.asc --pre-pack eth_clocks.py
/home/devel/oss-cad-suite//bin/icepack gateware.asc gateware.bin
devel@pi4-28:~/Catboard-Pipelinec/pmod-ethernet/examples/catboard/ice_makefile_pipelinec $
~/Catboard-Pipelinec/prg-cat1.sh
OK: GPIO 25 exported
OK: GPIO 17 exported
OK: GPIO 22 exported
OK: SPI driver loaded
Setting GPIO directions
out
out
in
Setting output to low
Reseting FPGA
0
1
Checking DONE pin
Continuing with configuration procedure
263+1 records in
263+1 records out
135100 bytes (135 kB, 132 KiB) copied, 0.0274133 s, 4.9 MB/s
Setting output to high
Checking DONE pin
devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/examples/net $ ./compile-work_test.sh
devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/examples/net $ sudo ./work_test
CPU threads: 1
n 'work()'s: 1
Total tx bytes: 8
Total rx bytes: 4
CPU took 0.000278 seconds to execute
CPU iteration time: 0.000278 seconds
CPU bytes per sec: 43166.078902 B/s
FPGA took 0.000180 seconds to execute
FPGA iteration time: 0.000180 seconds
```

FPGA bytes per sec: 66664.434437 B/s Speedup: 1.544371

## The work\_test.c is dependent on the successful build of gateware.bin see Appendix A.



This image was loopback tested on 02/17/25





pico-ice 12MHz Catboard 100MHz pmod-ether 25MHz

### **/**\*\*

\* PLL configuration

\*

- \* This Verilog header file was generated automatically
- \* using the icepll tool from the IceStorm project.
- \* It is intended for use with FPGA primitives SB\_PLL40\_CORE,
- \* SB PLL40 PAD, SB PLL40 2 PAD, SB PLL40 2F CORE or SB PLL40 2F PAD.
- \* Use at your own risk.

\*

\* Given input frequency: 100.000 MHz

\* Requested output frequency: 25.000 MHz

# pico-ice to catboard # PMOD0A

set\_io -nowarn ICE\_45 B15 #PM3-A4 345 set\_io -nowarn ICE\_47 B14 #PM3-A3 47 set\_io -nowarn ICE\_2 B12 #PM3-A2 2 set\_io -nowarn ICE\_4 A11 #PM3-A1 4

#### # PMOD0B

set\_io -nowarn ICE\_44 A15 #PM3-B4 44 set\_io -nowarn ICE\_46 B13 #PM3-B3 46 set\_io -nowarn ICE\_48 B11 #PM3-B2 48 set\_io -nowarn ICE\_3 B10 #PM3-B1 3

#### # PMOD1A

set\_io -nowarn ICE\_31 B6 #PM2-A4 31 set\_io -nowarn ICE\_34 A5 #PM2-A3 34 set\_io -nowarn ICE\_38 B3 #PM2-A2 38 set\_io -nowarn ICE\_43 A1 #PM2-A1 43

#### # PMOD1B

set\_io -nowarn ICE\_28 A6 #PM2-B4 28 set\_io -nowarn ICE\_32 A5 #PM2-B3 32 set\_io -nowarn ICE\_36 B4 #PM2-B2 36 set\_io -nowarn ICE\_42 A2 #PM2-B1 42





devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/ice\_makefile\_pipelinec \$ make clean

- rm -f lextab.py
- rm -f yacctab.py
- rm -f pll\_clk\_mhz.h
- rm -f -r pipelinec\_output
- rm -f pipelinec.log
- rm -f pll.v
- rm -f \*.json \*.asc \*.bin \*.uf2
- rm -f yosys\_stderr.log
- rm -f dfu\_util.log

devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/ice\_makefile\_pipelinec \$ make pipelinec

TOP\_NAME=ethernet\_top

echo "#define PLL\_CLK\_MHZ 25.0\n" > pll\_clk\_mhz.h

/home/devel/PipelineC/src/pipelinec ethernet\_top.c --top pipelinec\_top --out\_dir pipelinec\_output -comb --no synth > pipelinec.log

devel@pi5-70:~/Catboard-Pipelinec/pmod-ethernet/ice\_makefile\_pipelinec \$ make gateware.bin TOP NAME=ethernet top

/home/devel/oss-cad-suite//bin/icepll -q -i 100 -o 25.0 -p -m -f pll.v

/home/devel/oss-cad-suite//bin/yosys -l simple.log -q -m ghdl -p "ghdl --std=08 -frelaxed `cat pipelinec\_output/vhdl\_files.txt` -e pipelinec\_top; read\_verilog -sv ethernet\_top.sv pll.v; synth\_ice40 -top ethernet\_top -json gateware.json" 2> yosys\_stderr.log

/home/devel/oss-cad-suite//bin/nextpnr-ice40 -l nextpnr.log -q --randomize-seed --hx8k --package ct256 --pcf ice40.pcf --json gateware.json --asc gateware.asc --freq 25.0

ERROR: PLL 'pll\_inst.uut' PACKAGEPIN SB\_IO 'clk\_12p0\$sb\_io' is not connected to any PLL

ERROR: Packing design failed.

0 warnings, 2 errors

make: \*\*\* [Makefile:40: gateware.bin] Error 255

| 3.3 grd A4 A                     | A3 A2 A1                         | pico-ice | 3.3 grd A                       | 4 A3 A2 A1                      |  |
|----------------------------------|----------------------------------|----------|---------------------------------|---------------------------------|--|
|                                  |                                  |          |                                 |                                 |  |
| 3.3 grd B4 B3 A2 B1              |                                  |          | 3.3 grd B                       | 3.3 grd B4 B3 B2 B1             |  |
| A1-43<br>A2-38<br>A3-34<br>A4-31 | B1-42<br>B2-36<br>B3-32<br>B4-28 |          | A1-4<br>A2-2<br>A3-47<br>A4- 45 | B1-3<br>B2-48<br>B3-46<br>B4-44 |  |

**USB** 

| 3.3 grd A4 A3 A2 A1                            | 3.3grd A4 A3 A2 A1                      | HDR-1 J1     | HDR-1 k1 |
|------------------------------------------------|-----------------------------------------|--------------|----------|
|                                                |                                         |              |          |
| PM3                                            | PM2                                     |              |          |
| 3.3 grd B4 B3 B2 B1                            | 3.3 grd B4 B3 B2 B1                     |              |          |
| PM3-A4 B15 PM3-B4 A15                          | PM2-A4 B6 PM2-B4 A6                     |              |          |
| PM3-A3 B14 PM3-B3 B13<br>PM3-A2 B12 PM3-B2 B11 | PM2-A3 B5 PM2-B3 A5 PM2-A2 B3 PM2-B2 B4 |              |          |
| PM3-A1 A11 PM3-B1 B10                          | PM2-A1 A1 PM2-B1 A2                     |              |          |
|                                                |                                         | HDR-15 grd [ |          |
|                                                |                                         |              |          |
|                                                |                                         |              |          |
| Ver 0.1                                        |                                         |              |          |
| 03/01/25                                       |                                         |              |          |

#### Appendix A

```
#pragma once
#include "type_bytes_t.h/int8_t_bytes_t.h/int8_t_bytes.h"
#define work_inputs_t_SIZE 8
void work_inputs_t_to_bytes(work_inputs_t* x, uint8_t* bytes)
size_t pos = 0;
// matrix0
size_t matrix0_dim_0;
for(matrix0_dim_0=0;matrix0_dim_0<2;matrix0_dim_0=matrix0_dim_0+1){
size_t matrix0_dim_1;
for(matrix0_dim_1=0;matrix0_dim_1<2;matrix0_dim_1=matrix0_dim_1+1){
int8_t_to_bytes(&(x->matrix0[matrix0_dim_0][matrix0_dim_1]), &(bytes[pos]));
pos = pos + 1; // not sizeof()
}
}
// matrix1
size_t matrix1_dim_0;
for(matrix1_dim_0=0;matrix1_dim_0<2;matrix1_dim_0=matrix1_dim_0+1){
size_t matrix1_dim_1;
for(matrix1_dim_1=0;matrix1_dim_1<2;matrix1_dim_1=matrix1_dim_1+1){</pre>
int8_t_to_bytes(&(x->matrix1[matrix1_dim_0][matrix1_dim_1]), &(bytes[pos]));
pos = pos + 1; // not sizeof()
}
}
void bytes_to_work_inputs_t(uint8_t* bytes, work_inputs_t* x)
```

```
size_t pos = 0;
// matrix0
size t matrix0 dim 0;
for(matrix0_dim_0=0;matrix0_dim_0<2;matrix0_dim_0=matrix0_dim_0+1){
size_t matrix0_dim_1;
for(matrix0_dim_1=0;matrix0_dim_1<2;matrix0_dim_1=matrix0_dim_1+1){
bytes_to_int8_t(&(bytes[pos]), &(x->matrix0[matrix0_dim_0][matrix0_dim_1]));
pos = pos + 1; // not sizeof()
// matrix1
size_t matrix1_dim_0;
for(matrix1_dim_0=0;matrix1_dim_0<2;matrix1_dim_0=matrix1_dim_0+1){
size_t matrix1_dim_1;
for(matrix1_dim_1=0;matrix1_dim_1<2;matrix1_dim_1=matrix1_dim_1+1){</pre>
bytes_to_int8_t(&(bytes[pos]), &(x->matrix1[matrix1_dim_0][matrix1_dim_1]));
pos = pos + 1; // not sizeof()
}
}
```