www.latticesemi.com
15-1
tn1008_02.1
October 2005
Technical Note TN1008
Introduction
Coding style plays an important role in utilizing FPGA resources. Although many popular synthesis tools have sig-
nificantly improved optimization algorithms for FPGAs, it still is the responsibility of the user to generate meaningful
and efficient HDL code to guide their synthesis tools to achieve the best result for a specific architecture. This appli-
cation note is intended to help designers establish useful HDL coding styles for Lattice Semiconductor FPGA
devices. It includes VHDL and Verilog design guidelines for both novice and experienced users.
The application note is divided into two sections. The general coding styles for FPGAs section provides an over-
view for effective FPGA designs. The following topics are discussed in detail:
Hierarchical Coding
Design Partitioning
Encoding Methodologies for State Machines
Coding Styles for Finite State Machines (FSM)
Using Pipelines
Comparing IF Statements and CASE Statements
Avoiding Non-intentional Latches
The HDL Design with Lattice Semiconductor FPGA Devices section covers specific coding techniques and exam-
ples:
Using the Lattice Semiconductor FPGA Synthesis Library
Implementation of Multiplexers
Creating Clock Dividers
Register Control Signals (CE, LSR, GSR)
Using PIC Features
Implementation of Memories
Preventing Logic Replication and Fanout
Comparing Synthesis Results and Place and Route Results
General Coding Styles for FPGA
The following recommendations for common HDL coding styles will help users generate robust and reliable FPGA
designs.
Hierarchical Coding
HDL designs can either be synthesized as a flat module or as many small hierarchical modules. Each methodology
has its advantages and disadvantages. Since designs in smaller blocks are easier to keep track of, it is preferred to
apply hierarchical structure to large and complex FPGA designs. Hierarchical coding methodology allows a group
of engineers to work on one design at the same time. It speeds up design compilation, makes changing the imple-
mentation of key blocks easier, and reduces the design period by allowing the re-use of design modules for current
and future designs. In addition, it produces designs that are easier to understand. However, if the design mapping
into the FPGA is not optimal across hierarchical boundaries, it will lead to lower device utilization and design perfor-
mance. This disadvantage can be overcome with careful design considerations when choosing the design hierar-
chy. Here are some tips for building hierarchical structures:
The top level should only contain instantiation statements to call all major blocks
Any I/O instantiations should be at the top level
Any signals going into or out of the devices should be declared as input, output or bi-directional pins at the
top level
HDL Synthesis Coding Guidelines for
Lattice Semiconductor FPGAs