Textual Configuration Format

Project Trellis supports a simple text-based configuration format so that place-and-route, design manipulation and design analysis tools do not have to deal with bitstream specifics, nor link directly to libtrellis.

Overview

The text-based configuration format uses standard ASCII text files. # denotes a comment that continues until the end of the line. . at the start of the line followed by the command type denotes a command. Command options follow on the line, some commands may then have data on subsequent lines until the next command

Non-Tile Configuration

.device <device name> specifies the device type, for example .device LFE5U-85F. This should always be the first command in a file.

.comment <comment> marks the rest of a line as a comment that is included in the header of the bitstream. The FPGA ignores these, but they may be required if you wish to use vendor programming or deployment tools with the bitstream.

Tile Configuration

.tile <tile name> denotes the start of a tile. Note that Project Trellis tile names are the Lattice tile name followed by the colon and the tile type, for example MIB_R22C5:MIB_DSP1. This is because the Lattice tile names on their own are not unique.

Inside a tile there can be four entries: arcs, words, enums and unknown bits.

arc: <sink> <source> enables an arc inside the tile, using the same Trellis relative netnames as used in the database, for example arc: S3_V06S0303 E1_H01W0100.

word: <name> <value> sets the value of a configuration word (i.e. a configuration value that can reasonable be split into bits, such as LUT initialisation). The value is always in binary, MSB first. For example word: SLICEC.K0.INIT 0101010101010101 configures LUT0 in SLICEC to be an inverter.

enum: <name> <value> sets the value of a configuration enum (i.e. a configuration value with multiple textual values). In all cases one of the values from the Trellis database must be used. For example enum: PIOA.BASE_TYPE INPUT_LVCMOS25 configures PIOA as a LVCMOS25 input.

unknown: F<frame>B<bit> sets an unknown bit, specified by tile-relative frame and bit. For example unknown: F95B0 sets unknown bit 0 in frame 95 in the tile.

Words and enums will not be included when converting a bitstream to textual configuration if they are at their default value (i.e. the value they would have in a bitstream generated from an empty design).

Beware that some configuration words and enums are split across multiple tiles in features such as IO, EBR and DSPs. To generate correct bitstreams, they must be included in every tile where they appear. Currently the value matcher, when converting bitstreams to config looks at each tile individually, so may pick a config that is correct in each tile but not overall. This will be fixed in the future.

Conversion

You can use libtrellis/examples/bit_to_config.py <bitstream> to convert a bitstream to a text config file, and libtrellis/examples/config_to_bit.py <config> <bitstream> to convert from config to a bitstream. C++ command line tools and an install script are currently being developed.