# Chiselizing SDR Blocks

Albert Magyar

March 18, 2015

# Overview

- ► Intro to RFNoC
- RFNoC Blocks
- ► Example: addsub
- Recurring patterns in Verilog and Chisel
- ▶ Goals

### Intro to RFNoC



- ▶ FPGA toolkit for GNU radio
- Allows chaining of hardware and software blocks

## Intro to RFNoC

- Accelerators implemented in Verilog
- NoC: packet headers on top of AXI4 Streaming crossbar
- Designers write parametrized blocks with ready/valid/last and settings registers

#### Intro to RFNoC

- Designers write parametrized blocks
- GNU Radio frontend elaborates instances
- RFNoC configurator assigns endpoint addresses and parametrizes RFNoC shim modules (noc\_shell)
- Parametrizes and generates Verilog for NoC

## RFNoC Blocks

- ► Simple, fixed-function DSP blocks
- Blocks have simple FIFO interfaces
- Export parameters to the GNU Radio space
- Identity as RFNoC endpoint transparent to designer

#### RFNoC Blocks

- Simple, fixed-function DSP blocks
- Blocks have simple FIFO interfaces
- Export parameters to the GNU Radio space
- Identity as RFNoC endpoint transparent to designer
- We want people to write these in Chisel