# symbiflow-arch-defs Documentation

Release 0.1

**Various** 

### Contents

| 1 | Contents             |                       |   |  |  |
|---|----------------------|-----------------------|---|--|--|
|   | 1.1                  | Getting Started       | 3 |  |  |
|   | 1.2                  | Development Practices | 3 |  |  |
| 2 | 2 Indices and tables |                       |   |  |  |

#### \*Warning: This project is a work in progress and many items may be broken.\*

This project contains documentation of various FPGA architectures, it is currently concentrating on;

- Lattice iCE40
- Artix 7

The aim is to include useful documentation (both human and machine readable) on the primitives and routing infrastructure for these architectures. We hope this enables growth in the open source FPGA tools space.

The project includes;

- Black box part definitions
- · Verilog simulations
- Verilog To Routing architecture definitions
- Documentation for humans

Contents 1

2 Contents

### CHAPTER 1

Contents

### 1.1 Getting Started

Checkout the project from:

https://github.com/SymbiFlow/symbiflow-arch-defs

Make sure git submodules are cloned:

```
git submodule init
git submodule update
```

#### Run the full suite:

make

### 1.2 Development Practices

These documents outline the development practices for the project.

#### 1.2.1 Structure

#### **Directories**

- XXX/device/ Full architecture definitions of a given device for [Verilog To Routing](https://verilogtorouting.org/)
  - XXX/device/YYYY-virt Verilog to Routing architecture definitions generally are not able to able to generate the **exact** model of many FPGA routing interconnects, but this is a pretty close.
- XXX/primitives/ The primitives that make up the architecture. These are generally used inside the tiles.

- XXX/tiles/ The tiles found in the architecture.
- XXX/tests/ Tests for making sure the architecture specific features works with VPR.
- [vpr](vpr) Common defines used by multiple architectures.

#### **Files**

- *pb\_type.xml* The Verilog to Routing [Complex reference/#complex-blocks) definition.

  Block](https://docs.verilogtorouting.org/en/latest/arch/
  - Inside primitives directory they should be intermediate or primitive <pb\_type> and thus allow setting the num\_pb attribute.
  - Inside *tiles* directory they should be top level *<pb\_type>* and thus have,
    - \* capacity (if a pin type),
    - \* width & height (and maybe area)
- *model.xml* The Verilog to Routing [Recognized BLIF Models](https://docs.verilogtorouting.org/en/latest/arch/reference/#recognized-blif-models-models) definitinition.
- sim.v A Verilog definition of the object. It should;
  - [] Match the definition in model.xml (should be one module in sim.v for every model in model.xml)
  - [] Include a *ifndef BLACKBOX* section which actually defines how the Verilog works.
- *macro.v* A Verilog definition of the object which a user might instantiate in their own code when specifying a primitive. This should match the definition provided by a manufacturer. Examples would be the definitions in;
  - [Lattice iCE Technology Library](http://www.latticesemi.com/~/media/LatticeSemi/Documents/ TechnicalBriefs/SBTICETechnologyLibrary201504.pdf)
  - [UG953: Vivado Design Suite 7 Series FPGA and Zynq-7000 All Programmable SoC Libraries Guide](https://www.xilinx.com/support/documentation/sw\_manuals/xilinx2017\_3/ug953-vivado-7series-libraries.pdf)

#### **Names**

- BLK\_MB-block\_1\_name-block\_2\_name BLOCK which is a "\*\*m\*\*ega \*\*b\*\*lock". A "mega block" is a top level block which is made up of other blocks.
- BLK\_XX-name BLOCK which is the hierarchy. Maps to BLK\_SI -> SITE and BLK\_TI -> TILE in Xilinx terminology.
- BLK\_IG-name BLOCK which is ignored. They don't appear in the output hierarchy and are normally used when something is needed in the description which doesn't match actual architecture.
- BEL\_RX-mux\_name BEL which is a **r\*\*outing mu\*\*x**. Routing muxes are statically configured at PnR time.
- BEL\_MX-mux\_name BEL which is a m\*\*u\*\*x.
- BEL LT-lut name BEL which is a \*\*l\*\*ook up \*\*t\*\*able.
- BEL MM-mem name BEL which is a \*\*m\*\*e\*\*m\*\*ory.
- BEL FF-ff name BEL which is a \*\*f\*\*lip \*\*f\*\*lop (FF).
- BEL\_LL-latch\_name BEL which is a \*\*l\*\*atch (LL).
- BEL\_BB-name BEL which is a \*\*b\*\*lack \*\*b\*\*ox (BB).

- PAD\_IN-name A signal input location.
- PAD\_OT-name A signal output location.

#### **Notes**

- Unless there is a good reason otherwise, all muxes should be generated via [mux\_gen.py](utils/mux\_gen.py)
- DRY (Don't repeat yourself) Uses [XML XIncludes](https://en.wikipedia.org/wiki/XInclude) to reuse stuff!

#### 1.2.2 Verilog To Routing Notes

We have to do some kind of weird things to make VPR work for real architectures, here are some tips;

- VPR doesn't have channels right or above tiles on the right most / left most edge. To get these channels, pad the left most / right most edges with EMPTY tiles.
- Generally we use the [vpr/pad](vpr/pad) object for the **actual** .input and .output BLIF definitions. These are then connected to the tile which has internal IO logic.

## CHAPTER 2

### Indices and tables

- genindex
- modindex
- search