## Chapter 12: Synthesis

#### Prof. Soo-Ik Chae

#### Objectives

After completing this chapter, you will be able to:

- Describe ASIC/VLSI design flow
- Understand the RTL and physical synthesis flow
- Understand the principle of logic synthesis tools
- Understand issues of language translation
- Describe the considerations of clock signals
- Describe the considerations of reset signals
- Describe the partition issues for synthesis

#### An ASIC/VLSI Design Flow



#### An RTL Synthesis Flow



#### A Physical Synthesis Flow



#### Logic Synthesis Environment

- The following must be provided to synthesis tools:
  - design environment
  - design constraints
  - RTL code
  - technology library



## Design Environment

Specify those directly influence design synthesis and optimization results

- The external operating conditions (PVT) include
  - manufacturing process
    - worst case: setup-time violations
    - best case: hold-time violations
  - operating conditions: voltage and temperature
- ✤ I/O port attributes contain
  - drive strength of input port
  - capacitive loading of output port
  - design rule constraints: fanin, fanout

Statistical wire-load model provides a wire-load model for processing the pre-layout static timing analysis.

#### Design Environment



## **Design Constraints**

- Clock signal specification
  - period, duty cycle
  - transition time, skew
- Delay specifications
  - input delay, output delay
  - maximum, minimum delay for combinational circuits
- Timing exception
  - false path : instruct the synthesis to ignore a particular path for timing optimization
  - multicycle path: inform the synthesis tool regarding the number of clock cycles that a particular path requires to reach its endpoint
- Path grouping: bundle together critical paths in calculating a cost function

#### Input Delay and Output Delay



#### The Architecture of Logic Synthesis Tools



#### Logic Synthesis Tools: Front end

#### Parsing phase

- checks the syntax of the source code
- creates internal components
- Elaboration phase (to construct a complete description of the input circuit)
  - connects the internal components
  - unrolls loops
  - expands generate-loops
  - sets up parameters passing for tasks and functions
  - and so on

#### Logic Synthesis Tools: Back end

- analysis/translation prepares for technology-independent logic synthesis.
  - managing the design hierarchy
  - extracting finite-state machine (FSM)
  - exploring resource sharing
  - and so on.
- logic synthesis (logic optimization) creates a new gate network which computes the functions specified by a set of Boolean functions, one per primary output.
- netlist generation generates a gate-level netlsit.

#### Logic Synthesis (Logic Optimization)

Major concerns when synthesizing a logic gate network:

- functional metric: such as fanin, fanout, and others.
- non-functional metric: such as area, power, and delay.
- Two phases of logic synthesis:
  - technology-independent logic optimization
  - technology-dependent logic optimization
- The process of translating from technology-independent to the technology-dependent gate network is called library binding.

#### Technology-Independent Logic Optimization

- Technology-independent logic synthesis
  - Simplification rewrites a single function in the network to the literals of that network.
  - Restructuring network creates new function nodes that can be used as common factors and collapses sections of the network into a single node.
  - Restructuring delay changes the factorization of a subnetwork to reduce the number of function nodes through which delay-critical signal must pass.

## **Technology Mapping**

- ✤ A two-step approach
  - The network is decomposed into nodes with no nodes more than k inputs, where k is determined by the fan-in of each LUT.
  - The number of nodes is reduced by combining some of them taking into account the special features of LUTs.



## **Technology Mapping**

- FlowMap method
  - Using a k-feasible cut algorithm breaks the network into LUT-sized blocks.
  - Using heuristics to maximize the amount of logic fit into each cut to reduce the number of logic elements or LUTs required.



#### Synthesis-Tool Tasks

Synthesis tools at least perform the following critical tasks:

- Detect and eliminate redundant logic
- Detect combinational feedback loops
- Exploit don't-care conditions
- Detect unused states
- Detect and collapse equivalent states
- Make state assignments
- Synthesize optimal, multilevel logic subject to constraints.

The Key Point for Successful Logic Synthesis

# Think hardware.

#### Language Structure Translations

- Language structure translation
  - Synthesizable operators
  - Synthesizable constructs
    - assignment statement
    - if .. else statement
    - case statement
    - loop structures
    - always statement
  - Memory synthesis approaches

#### Synthesizable Operators

| Arithmetic                  | Bitwise          | Reduction        | Relational                     |
|-----------------------------|------------------|------------------|--------------------------------|
| +: add                      | ~ :NOT           | & : A N D        | >: greater than                |
| - : subtract                | & : A N D        | I:OR             | <: less than                   |
| * : multiply                | :OR              | ~&:NAND          | >= : greater than or equal     |
| /:divide                    | ^ : X O R        | ~ :NOR           | <=: less than or equal         |
| % : modulus                 | ~^, ^~ : X N O R | <b>^</b> : X O R | Equality                       |
| **: exponent                |                  | ~^, ^~ : X N O R |                                |
| Shift                       | 1.               | Logical          | ==: equality<br>!=: inequality |
| << : left shift             | case equality    | &&: AND          | Miscellaneous                  |
| >> : right shift            | ===: equality    | ∥:OR             | { }: concatenation             |
| <                           | !==: inequality  | ! : NOT          | {const expr{ }}: replication   |
| >>>: arithmetic right shift |                  |                  | ?: : conditional               |

#### Synthesizing if-else Statements

- Features of if-else statement:
  - The if-else statement infers a priority-encoded, cascaded combination of multiplexers.
  - For combinational logic, we need to specify a complete if...else structure, otherwise, a latch will be inferred.
  - For sequential logic, we need not specify a complete if ...else structure, otherwise, we will get as a notice removing redundant expression from synthesis tools.

always @(enable or data) if (enable) y = data; //infer a latch always @(posedge clk)
 if (enable) y <= data;
 else y <= y; // a redundant expression</pre>

#### Synthesizing case Statements

- Features of case statement:
  - A case statement infers a multiplexer.
  - The consideration of using a complete or incomplete specified statement is the same as that of if...else statement.

#### Latch Inference --- Incomplete if-else Statements



#### Coding style:

- Avoid using any latches in your design.
- Assign outputs for all input conditions to avoid inferred latches.

#### For example:

always @(enable or data)
 y = 1'b0; // initialize y to its initial value.
 if (enable) y = data;

#### Latch Inference --- Incomplete case Statements



#### Igncored Delay Values --- An Incorrect Version

```
// a four phase clock example --- Generated incorrect hardware
module four_phase_clock_wrong(clk, phase_out);
input clk;
output reg [3:0] phase_out; // phase output
// the body of the four phase clock
always @(posedge clk) begin
  phase_out <= 4'b0000;
  phase_out <= #5 4'b0001;
                                                      1000
                                                         phase out[3:0
  phase_out <= #10 4'b0010;
  phase_out <= #15 4'b0100;
  phase_out <= #20 4'b1000;
end
endmodule
```

#### Ignored Delay Values --- A Correct Version



#### Mixed Use of posedge/level Signals

```
// an example to illustrating the mixed usage of posedge/negedge signal.
// The result cannot be synthesized. Try it in your system !!
module DFF_bad (clk, reset, d, q);
input clk, reset, d;
output reg q;
// the body of DFF
always @(posedge clk or reset)
begin
    if (reset) q <= 1'b0;
    else q <= d;
end
endmodule</pre>
```

#### Error: Can't mix posedge/negedge use with plain signal references.

#### Mixed Use of posedge/negedge Signals

```
// an example to illustrate the mixed usage of posedge/negedge signal.
// try it in your system !!
module DFF_good (clk, reset_n, d, q);
input clk, reset_n, d;
output reg q;
// the body of DFF
always @(posedge clk or negedge reset_n)
begin
   if (!reset_n) q <= 1'b0;
                                                                 R
           q \ll d;
   else
end
                                          eset n
                                                                 q
endmodule
```

#### Loop Structures

```
// an N-bit adder using for loop.
module nbit_adder_for( x, y, c_in, sum, c_out);
parameter N = 4; // define default size
input [N-1:0] x, y;
input c_in;
output reg [N-1:0] sum;
output reg c_out;
reg
       co;
integer i;
// specify the function of an n-bit adder using for loop.
always @(x or y or c_in) begin
  co = c_{in};
  for (i = 0; i < N; i = i + 1)
                                                                                          <sup>1</sup> c out
     \{co, sum[i]\} = x[i] + y[i] + co;
                                                                             un61_sum[1:0]
  c out = co; end
                                                                   un40_sum[1:0]
                                                         un19_sum[1:0]
endmodule
                                                sum_1[1:0]
```

#### Loop Structures --- An Incorrectly Synthesizable Example



#### Memory Synthesis Approaches

- Random logic using flip-flops or latches
  - is independent of any software and type of ASIC.
  - is independent of easy to use but inefficient in terms of area.
- Register files in datapaths
  - use a synthesis directive or hand instantiation.
- RAM standard components
  - are supplied by an ASIC vendor.
  - depend on the technology.
- RAM compilers

A flip-flop may take up 10 to 20 times the area of a 6-transistor static RAM cell.

are the most area-efficient approach.

## Coding Guidelines for Synthesis

- Goals of coding guidelines:
  - Testability
  - Performance
  - Simplification of static timing analysis
  - Gate-level behavior that matches that of the original RTL codes.

#### **Guidelines for Clocks**

- Using single global clock
- Avoiding using gated clocks
- Avoiding mixed use of both positive and negative edgetriggered flip-flops
- Avoiding using internally generated clock signals



#### **Guidelines for Resets**

- The basic design issues of resets are:
  - Asynchronous or synchronous?
  - An internal or external power-on reset?
  - More than one reset, hard vs. soft reset?
- The basic writing styles for both asynchronous and synchronous reset are as follows:

```
always @(posedge clk or posedge reset)always @(posedge clk)if (reset) .....if (reset) .....else .....else .....
```

Asynchronous reset

Synchronous reset

The only logic function for the reset signal should be a direct clear of all flip-flops.

#### **Guidelines for Resets**

- Asynchronous reset
  - is harder to implement.
    - since reset is a special signal like clock, it requires a tree of buffers to be inserted at place and route.
  - does not require a free-running clock.
  - does not affect flip flop data timing.
  - makes static timing analysis (or cycle-based simulation) more difficult.
  - makes the automatic insertion of test structure more difficult.
- Synchronous reset
  - is easy to implement.
    - It is just another synchronous signal to the input.
  - requires a free-running clock
    - in particular, at power-up, for reset to occur.

#### **Guidelines for Resets**

Avoid internally generated conditional resets.

always @(posedge gate or negedge reset\_n or posedge timer\_load\_clear)
if (!reset\_n || timer\_load\_clear) timer\_load <= 1'b0;
else timer\_load <= 1'b1;</pre>

When a conditional reset is required:

- to create a separate signal for the reset signal.
- to isolate the conditional reset logic in a separate logic block.

assign timer\_load\_reset = !reset\_n || timer\_load\_clear; always @(posedge gate or posedge timer\_load\_reset) if (timer\_load\_reset) timer\_load <= 1'b0; else timer\_load <= 1'b1;</pre>

Partitioning for Synthesis

\* Keep related logic within the same module.



Partitioning for Synthesis

#### Register all outputs.



Separating structural logic from random logic.

#### Partitioning for Synthesis

Synthesis tools tend to maintain the original hierarchy.



(b) Resources in the same module can be shared.