## OPEN SOURCE FPGA TOOLCHAIN WHY IF VIVADO AND QUARTUS ARE "FREE" ANYWAY

## WHOAMI

• Open Source Evangelist

Team: Clifford Daniel Edmund



## WHAT DO WE HAVE: FPGA TOOLCHAIN



|                     | Yosys<br>Arachne-pnr | Synplify Pro<br>SBT Backend | Lattice LSE<br>SBT Backend |
|---------------------|----------------------|-----------------------------|----------------------------|
| Packed LCs          | 2996                 | 2647                        | 2533                       |
| LUT4                | 2417                 | 2147                        | 2342                       |
| DFF                 | 1005                 | 1072                        | 945                        |
| CARRY               | 497                  | 372                         | 372                        |
| RAM4K               | 8                    | 7                           | 8                          |
| Synthesis Time      | 30 seconds           | 30 seconds                  | 21 seconds                 |
| Implementation Time | 81 seconds           | 405 seconds                 | 415 seconds                |

| Design                                  | Timing Tool | Yosys<br>Arachne-pnr<br>(unconstrained) | Lattice LSE<br>SBT Backend<br>(constr. 100 MHz) |
|-----------------------------------------|-------------|-----------------------------------------|-------------------------------------------------|
| PicoRV32_AXI<br>(w/ reduced pin count)  | sbtime      | N/A                                     | 41.74 MHz                                       |
|                                         | icetime -i  | 54.33 MHz                               | 41.75 MHz                                       |
|                                         | icetime -im | 53.02 MHz                               | 41.40 MHz                                       |
| Navre AVR Clone<br>(from Milkymist SoC) | sbtime      | N/A                                     | 45.82 MHz                                       |
|                                         | icetime -i  | 29.89 MHz                               | 45.59 MHz                                       |
|                                         | icetime -im | 27.61 MHz                               | 44.90 MHz                                       |
| Whishbone SPI Core<br>(from OpenCores)  | sbtime      | N/A                                     | 62.13 MHz                                       |
|                                         | icetime -i  | 42.62 MHz                               | 62.23 MHz                                       |
|                                         | icetime -im | 38.89 MHz                               | 61.14 MHz                                       |

## WHAT DO WE HAVE: BOARDS

- Lattice ICEstick 1k (21 USD)
- Lattice evaluation board 8k LUT (42 USD)
- IcoBoard 8k LUT, 1 Mb SRAM, Flash (90 Euro)
- Olimex, BQ

## WHAT DO WE HAVE: Verilog IP BLOCKS

#### • CPUs

- SRAM, SPI, UART, I2C, ...
- Minimal Risc-V SoC

## **Demo SoC – Simplified Block Diagram**



## **OPEN SOURCE TOOLCHAIN: WHY CARE?**

- learning
- innovation
- Integration
- wastefull IP

## The Industry



ρ

C



## GOAL:

## make money by moving many chips



#### Learners dont buy many chips

==> manufacturer do not
listen/invest in their requirements

tools are too powerfull tools are too complicated Chipmakers do not make money on innovative high added value designs.

Innovators only move small number of chips

==> no good toolsupport for innovation

## LITTLE TOOL INNOVATION

- No new programming tools (Verilog was started 1984, Perl was started 1987)
- No new usecases (which usually start out small)



- makes cross vendor integration hard and expensive
- Is In the interest of Altera and Xilinx
- They love "lock in", not sharing, reuse and innovation

# Green walled gardens of

## Xilinx and Altera.

Think "Unix wars"

### For an innovation very often you have to touch the whole stack

- If a part of stack is propriety, this component determines the speed of innovation.
- With open compenents, innovation can go forward faster.
- There would be no Facebook without Linux.



λ





#### FPGA is hard! Use it only if you need to!

- Application has requiremement for low latency
   Application has a huge bandwith-requirement and
   a streamable solution
- Application has requirement for precise timing

## **USECASES** for Lattice ICE40

- digital design education
- research

- control-systems
- dynamic trigger in logic analyser
- signal predistortion, fast sensordata processing

embedded bitstream generation

We are looking ...

- to grow the eco system
- to write open/free Verilog blocks
- to have great demo usecases
- to support larger/faster FPGAs
- for learners and innovators
- to develop an integrated IDE to ease integration

More technical presentation:

### Clifford Wolf: Author of Yosys

AW1.121 EDA developer room today 14:00

## Q & A ...

## http://icoboard.org

