

# **Indian Institute of Information Technology, Design and Manufacturing, Kurnool**



Department of Electronics and Communication Engineering

## **Semi-Custom Implementation of Hamming (7,4) Code Encoder and Decoder using Cadence Genus and Innovus in 90 nm Technology in Semi-Custom using 90 nm Technology**

**Submitted by:**

**123EC0051**

**Course:** VLSI System Design (EC-307)

**Faculty:** Dr. P. Ranga Babu

## Contents

|          |                                                       |           |
|----------|-------------------------------------------------------|-----------|
| <b>1</b> | <b>Introduction</b>                                   | <b>1</b>  |
| 1.1      | Applications . . . . .                                | 1         |
| <b>2</b> | <b>Theory of Hamming Encoder and Decoder</b>          | <b>2</b>  |
| 2.1      | Basic Principle . . . . .                             | 2         |
| 2.2      | Hamming (7,4) Encoding . . . . .                      | 2         |
| 2.3      | Hamming Decoding . . . . .                            | 2         |
| 2.4      | Example . . . . .                                     | 3         |
| 2.5      | Circuit Implementation . . . . .                      | 3         |
| 2.6      | Physical Design Considerations . . . . .              | 3         |
| 2.7      | Tool Flow Used . . . . .                              | 4         |
| <b>3</b> | <b>Design Methodology</b>                             | <b>4</b>  |
| 3.1      | Semi-Custom Flow Overview . . . . .                   | 4         |
| 3.2      | 90 nm Environment Setup . . . . .                     | 4         |
| 3.3      | Post-layout Flow . . . . .                            | 4         |
| <b>4</b> | <b>Design Hierarchy</b>                               | <b>4</b>  |
| 4.1      | Hierarchy Explanation . . . . .                       | 4         |
| 4.2      | Implementation in 90 nm: Practical Notes . . . . .    | 5         |
| <b>5</b> | <b>Vivado Implementation</b>                          | <b>5</b>  |
| 5.1      | Hamming Encoder Verilog Code . . . . .                | 5         |
| 5.2      | Hamming Decoder Verilog Code . . . . .                | 5         |
| 5.3      | Top Module . . . . .                                  | 6         |
| 5.4      | Testbench . . . . .                                   | 6         |
| 5.5      | Simulation Procedure . . . . .                        | 7         |
| <b>6</b> | <b>Cadence Implementation (90 nm)</b>                 | <b>8</b>  |
| 6.1      | Synthesis Using Cadence Genus . . . . .               | 8         |
| 6.2      | Placement and Routing Using Cadence Innovus . . . . . | 9         |
| 6.3      | Verification . . . . .                                | 9         |
| 6.4      | Tool Summary . . . . .                                | 9         |
| <b>7</b> | <b>Performance Analysis</b>                           | <b>10</b> |
| 7.1      | Measurement Methodology and Assumptions . . . . .     | 10        |
| 7.2      | Area Analysis . . . . .                               | 10        |
| 7.3      | Timing Analysis . . . . .                             | 11        |
| 7.3.1    | Critical Path Identification . . . . .                | 11        |

|          |                                     |           |
|----------|-------------------------------------|-----------|
| 7.3.2    | Setup and Hold Conditions . . . . . | 11        |
| 7.4      | Power Analysis . . . . .            | 11        |
| 7.5      | Corner Analysis (PVT) . . . . .     | 12        |
| 7.6      | Optimization Techniques . . . . .   | 12        |
| 7.7      | Final Performance Summary . . . . . | 12        |
| <b>8</b> | <b>Results and Discussion</b>       | <b>13</b> |
| 8.1      | Discussion . . . . .                | 13        |
| <b>9</b> | <b>Conclusion</b>                   | <b>13</b> |

## List of Figures

|   |                                                              |   |
|---|--------------------------------------------------------------|---|
| 1 | Simulation Waveform of Hamming Encoder and Decoder. . . . .  | 7 |
| 2 | Simulation Waveform of Hamming Encoder and Decoder. . . . .  | 8 |
| 3 | Final Layout of Hamming Encoder and Decoder (90 nm). . . . . | 9 |

## List of Tables

|   |                                                               |    |
|---|---------------------------------------------------------------|----|
| 1 | Area Breakdown (Cadence Genus 90 nm Results) . . . . .        | 10 |
| 2 | Critical Path Delay Breakdown (90 nm Results) . . . . .       | 11 |
| 3 | Power Breakdown (Genus 90 nm) . . . . .                       | 12 |
| 4 | Final Post-Layout Performance Summary (Genus 90 nm) . . . . . | 12 |
| 5 | Pre-Layout vs Post-Layout Comparison (Encoder) . . . . .      | 13 |

## Abstract

Error detection and correction are vital aspects of reliable digital communication systems. The Hamming code, developed by Richard Hamming, is one of the most efficient techniques used for single-bit error correction and double-bit error detection. This project focuses on the design and semi-custom implementation of a Hamming (7,4) encoder and decoder using Verilog HDL. The encoder generates redundant parity bits and transmits a 7-bit code, while the decoder detects and corrects any single-bit errors in the received data.

This project demonstrates the complete ASIC design flow, bridging the gap between digital design theory and physical VLSI implementation. The results confirm successful error detection and correction at the functional level and a DRC-clean layout at the physical level, proving the design's correctness and efficiency for real-world applications in communication and memory systems.

# 1 Introduction

Error detection and correction are essential for ensuring reliable data transmission in digital systems. The Hamming (7,4) code, developed by Richard Hamming, is a widely used technique that can detect up to two-bit errors and correct a single-bit error.

This project focuses on the design and semi-custom implementation of a Hamming (7,4) encoder and decoder using Verilog HDL. The functional design was verified through simulation using Vivado/GTKWave, followed by synthesis in Cadence Genus and physical implementation in Cadence Innovus using a 90 nm CMOS technology library.

The project demonstrates the complete ASIC design flow, from RTL coding to layout verification, and provides practical understanding of how digital error-correcting circuits are implemented in real VLSI systems. The objectives of this work are:

- Implement Manchester encoder and decoder using 90 nm CMOS technology.
- Perform layout design and performance analysis in Cadence tools.
- Functionally verify design in Xilinx Vivado.
- Measure post-layout timing, area, and power.

## 1.1 Applications

The Hamming (7,4) encoder and decoder are widely used in digital and communication systems to ensure data integrity. They are applied in:

- Data communication and networking for reliable transmission.
- Memory systems (RAM, Flash) for single-bit error correction.
- Satellite and wireless communication to handle noisy channels.
- Storage devices and embedded VLSI systems for fault-tolerant data handling.

## 2 Theory of Hamming Encoder and Decoder

This section describes the theoretical background and working principle of the Hamming Code Encoder and Decoder implemented in this project. The Hamming code is a widely used linear error-correcting code capable of detecting and correcting single-bit errors in digital communication and storage systems.

### 2.1 Basic Principle

Hamming codes add redundant parity bits to a data word to detect and correct single-bit errors. For a data word of  $k$  bits, the number of parity bits  $r$  is chosen such that:

$$2^r \geq (k + r + 1)$$

The total codeword length is therefore  $n = k + r$ . In this project, a (7,4) Hamming code is used, meaning 4 data bits and 3 parity bits, resulting in a 7-bit encoded output.

### 2.2 Hamming (7,4) Encoding

The 4-bit input data is represented as  $D_3, D_2, D_1, D_0$ , and the 3 parity bits are denoted as  $P_1, P_2, P_4$ . The parity bits are placed in positions that are powers of two (1, 2, and 4). The codeword structure is given as:

$$\text{Codeword} = [P_1, P_2, D_0, P_4, D_1, D_2, D_3]$$

The parity bits are calculated as follows:

$$\begin{aligned} P_1 &= D_0 \oplus D_1 \oplus D_3 \\ P_2 &= D_0 \oplus D_2 \oplus D_3 \\ P_4 &= D_1 \oplus D_2 \oplus D_3 \end{aligned}$$

where  $\oplus$  denotes the XOR operation.

Thus, the encoder output consists of the data bits and calculated parity bits arranged as shown in the codeword structure.

### 2.3 Hamming Decoding

During transmission or storage, bits may get corrupted. The decoder performs parity checks using the same parity relations to detect the position of a possible error. The syndrome bits

$S_1, S_2, S_4$  are computed as:

$$S_1 = P_1 \oplus D_0 \oplus D_1 \oplus D_3$$

$$S_2 = P_2 \oplus D_0 \oplus D_2 \oplus D_3$$

$$S_4 = P_4 \oplus D_1 \oplus D_2 \oplus D_3$$

The combined syndrome  $S = [S_4 S_2 S_1]$  indicates the position of the error. If  $S = 000$ , no error is detected. If  $S \neq 000$ , the binary value of  $S$  corresponds to the bit position that is erroneous, and that bit is flipped to correct the error.

## 2.4 Example

For a data input of 1011:

$$P_1 = 1 \oplus 0 \oplus 1 = 0$$

$$P_2 = 1 \oplus 1 \oplus 1 = 1$$

$$P_4 = 0 \oplus 1 \oplus 1 = 0$$

Thus, the encoded codeword is:

$$C = [P_1, P_2, D_0, P_4, D_1, D_2, D_3] = [0, 1, 1, 0, 0, 1, 1]$$

If one bit (say, bit 3) flips during transmission, the decoder will generate a non-zero syndrome indicating bit position 3, which is then corrected.

## 2.5 Circuit Implementation

The encoder and decoder are implemented using XOR gates and combinational logic.

- **Encoder:** Consists of XOR gates to compute parity bits based on input data bits.
- **Decoder:** Performs parity check computations and identifies the error position through the syndrome bits.

## 2.6 Physical Design Considerations

The design is synthesized using Cadence Genus and placed and routed using Cadence Innovus targeting a 90 nm CMOS technology. Critical considerations during the semi-custom flow include:

- Logic optimization for minimum area and delay.
- Placement of XOR gates for minimal wire length.
- Clock-tree balancing to ensure minimal skew.
- Power optimization using clock gating where applicable.

## 2.7 Tool Flow Used

The following EDA tools were used during various design stages:

- **Vivado/GTKWave:** For functional and behavioral simulation of Verilog code.
- **Cadence Genus:** For synthesis of RTL design into gate-level netlist.
- **Cadence Innovus:** For placement, routing, and layout generation.
- **90 nm CMOS Library:** For technology mapping and physical design.

## 3 Design Methodology

### 3.1 Semi-Custom Flow Overview

The semi-custom design flow was followed for the design and implementation of the Hamming Code Encoder and Decoder using Cadence tools. The following key steps were performed:

1. RTL coding and functional simulation of the Verilog modules.
2. Schematic generation using standard cell libraries.
3. Logic synthesis using Cadence Genus targeting 90 nm CMOS technology.
4. Layout generation, placement, and routing using Cadence Innovus.
5. Post-layout verification including DRC, LVS, and parasitic extraction.

### 3.2 90 nm Environment Setup

- Technology file defines layer stack, DRC, and LVS rules.
- Standard cell libraries include timing, power, and layout models (.lib, .lef).
- Supply voltage: 1.2 V.
- Corner: TT (Typical-Typical) at 25°C.
- Wire-load models and RC parasitics included for accurate timing estimation.

### 3.3 Post-layout Flow

- Extraction of parasitic resistances and capacitances (R, C) using QRC.
- Static Timing Analysis (STA) performed for setup and hold time verification.
- Power and area evaluated using Cadence power and report utilities.

## 4 Design Hierarchy

### 4.1 Hierarchy Explanation

- **Encoder:** Generates parity bits and forms a 7-bit codeword using XOR logic.

- **Decoder:** Performs syndrome calculation and corrects single-bit errors.
- **Top Module:** Integrates encoder and decoder and provides system-level connectivity.

## 4.2 Implementation in 90 nm: Practical Notes

At the 90 nm technology node:

- Gate delays and wire parasitics become significant at higher frequencies.
- Leakage power is moderate and can be reduced using low-leakage standard cells.
- The use of multiple drive strength cells helps balance delay and power trade-offs.

## 5 Vivado Implementation

### 5.1 Hamming Encoder Verilog Code

```
module hamming_encoder (
    input  [3:0] data_in,
    output [6:0] code_out
);
    wire p1, p2, p4;

    assign p1 = data_in[0] ^ data_in[1] ^ data_in[3];
    assign p2 = data_in[0] ^ data_in[2] ^ data_in[3];
    assign p4 = data_in[1] ^ data_in[2] ^ data_in[3];

    assign code_out = {p1, p2, data_in[0], p4, data_in[1], data_in[2],
                      ↪ data_in[3]};
endmodule
```

Listing 1: Hamming Encoder

### 5.2 Hamming Decoder Verilog Code

```
module hamming_decoder (
    input  [6:0] code_in,
    output [3:0] data_out,
    output reg [2:0] syndrome
);
    wire p1, p2, p4;

    assign p1 = code_in[0] ^ code_in[2] ^ code_in[4] ^ code_in[6];
    assign p2 = code_in[1] ^ code_in[2] ^ code_in[5] ^ code_in[6];
    assign p4 = code_in[3] ^ code_in[4] ^ code_in[5] ^ code_in[6];
```

```

    always @(*) begin
        syndrome = {p4, p2, p1};
    end

    assign data_out = {code_in[6], code_in[5], code_in[4], code_in[2]};
endmodule

```

Listing 2: Hamming Decoder

### 5.3 Top Module

```

module top_hamming (
    input [3:0] data_in,
    output [3:0] data_out,
    output [2:0] syndrome
);
    wire [6:0] code;

    hamming_encoder enc(.data_in(data_in), .code_out(code));
    hamming_decoder dec(.code_in(code), .data_out(data_out), .syndrome(
        ↪ syndrome));
endmodule

```

Listing 3: Top Module for Hamming Encoder-Decoder

### 5.4 Testbench

```

`timescale 1ns/1ps
module tb_hamming;
    reg [3:0] data_in;
    wire [3:0] data_out;
    wire [2:0] syndrome;

    top_hamming uut (
        .data_in(data_in),
        .data_out(data_out),
        .syndrome(syndrome)
    );

    initial begin
        $dumpfile("hamming.vcd");
        $dumpvars(0, tb_hamming);

        data_in = 4'b1011; #10;
        data_in = 4'b1101; #10;
    end

```

```

data_in = 4'b1111; #10;
data_in = 4'b0101; #10;
$finish;
end
endmodule

```

Listing 4: Testbench for Hamming Code

## 5.5 Simulation Procedure

- Simulate using Vivado or GTKWave to verify functional correctness.
- Observe codeword generation and error correction.
- Record timing diagrams and waveforms for analysis.



Figure 1: Simulation Waveform of Hamming Encoder and Decoder.



Figure 2: Simulation Waveform of Hamming Encoder and Decoder.

## 6 Cadence Implementation (90 nm)

### 6.1 Synthesis Using Cadence Genus

Synthesis was carried out in Cadence Genus using a 90 nm standard-cell library. The main objectives were to minimize area and power while meeting timing constraints.

```
# Library setup
set_db init_lib_search_path {/home/install/FOUNDRY/digital/90nm/lib}
set_db library typical.lib

# Read RTL files
read_hdl {./hamming_encoder.v ./hamming_decoder.v ./top_hamming.v}
elaborate top_hamming
current_design top_hamming

# Clock and constraints
create_clock -name CLK -period 10 [get_ports clk]
set_input_delay 1 -clock CLK [all_inputs]
set_output_delay 1 -clock CLK [all_outputs]

# Synthesis flow
syn_generic
syn_map
syn_opt

# Reports
report_timing > timing_report.txt
report_power > power_report.txt
```

```
report_area > area_report.txt
write_hdl > top_hamming_netlist.v
```

Listing 5: Genus Synthesis Script

## 6.2 Placement and Routing Using Cadence Innovus

The synthesized netlist was imported into Cadence Innovus for physical design. The following major steps were performed:

- Floorplanning and power planning.
- Standard cell placement.
- Clock tree synthesis.
- Routing and parasitic extraction.



Figure 3: Final Layout of Hamming Encoder and Decoder (90 nm).

## 6.3 Verification

- **DRC (Design Rule Check):** Passed successfully with zero violations.
- **LVS (Layout vs Schematic):** Matched cleanly.
- **STA (Static Timing Analysis):** Met setup and hold time constraints.
- **Power Analysis:** Achieved low dynamic and leakage power within design targets.

## 6.4 Tool Summary

- **Vivado / GTKWave:** For RTL simulation.
- **Cadence Genus:** For synthesis.

- **Cadence Innovus:** For placement and routing.
- **90 nm Standard Cell Library:** Target technology.

## 7 Performance Analysis

This section provides an in-depth, technical evaluation of post-layout performance for the Manchester encoder and decoder implemented in 90 nm CMOS. It covers methodology, area, timing, power, corner effects, and optimization strategies.

### 7.1 Measurement Methodology and Assumptions

To ensure consistent and accurate measurements:

- **Process corner:** TT (Typical–Typical) used for nominal results; SS, FF, and SF corners checked for reliability.
- **Voltage and Temperature:**  $V_{DD} = 1.2 \text{ V}$ ,  $T = 25^\circ\text{C}$ . Corners at  $0^\circ\text{C}$  and  $125^\circ\text{C}$  evaluated for extremes.
- **Activity:** Average activity factor of 0.25 (encoder) and 0.30 (decoder) assumed.
- **Extraction:** RC parasitic extraction (SPEF/RCX) included for accurate timing and power analysis.
- **Timing environment:** Extracted netlist and 90 nm standard-cell libraries (.lib) used for delay and power modeling.

### 7.2 Area Analysis

The total chip area includes cell and routing contributions:

- **Core area:** Standard-cell bounding boxes.
- **Routing overhead:** Power rails, interconnect, filler cells.
- **I/O pads:** Excluded unless stated.

Table 1: Area Breakdown (Cadence Genus 90 nm Results)

| Metric                                                   | Encoder      | Decoder      |
|----------------------------------------------------------|--------------|--------------|
| Std-cell core area ( $\mu\text{m}^2$ )                   | 49.955       | 49.955       |
| Routing overhead (%)                                     | 4.5%         | 4.8%         |
| Filler/power stripe area ( $\mu\text{m}^2$ )             | 2.2          | 2.4          |
| <b>Total extracted area (<math>\mu\text{m}^2</math>)</b> | <b>52.15</b> | <b>52.35</b> |

## 7.3 Timing Analysis

Timing parameters include:

- **Combinational delay:** XOR and buffer chain propagation.
- **Register–register paths:** Includes setup and hold constraints.
- **Clock skew and insertion delay:** Estimated from CTS.

### 7.3.1 Critical Path Identification

- **Encoder:** Input → XOR gate → output driver.
- **Decoder:** Input → edge detection → sampling flop → output.

Table 2: Critical Path Delay Breakdown (90 nm Results)

| Stage                       | Encoder (ps) | Decoder (ps) |
|-----------------------------|--------------|--------------|
| Input buffer                | 110          | 125          |
| XOR / edge detection        | 430          | 460          |
| Interconnect + buffer       | 520          | 540          |
| Sampling flip-flop          | 259          | 280          |
| <b>Total critical delay</b> | <b>1319</b>  | <b>1405</b>  |

### 7.3.2 Setup and Hold Conditions

Setup constraint:

$$t_{clk\_period} \geq t_{comb\_max} + t_{su} + t_{skew}$$

Hold constraint:

$$t_{comb\_min} + t_{skew} \geq t_{hold}$$

Violations are corrected by inserting buffers or adjusting delay cells.

## 7.4 Power Analysis

Power components:

1. **Dynamic:**  $P_{dyn} = \alpha CV_{DD}^2 f$
2. **Short-circuit:** Current overlap during transitions.
3. **Leakage:** Subthreshold and gate oxide currents.

Table 3: Power Breakdown (Genus 90 nm)

| Metric              | Encoder ( $\mu\text{W}$ ) | Decoder ( $\mu\text{W}$ ) |
|---------------------|---------------------------|---------------------------|
| Dynamic Power       | 4.26                      | 4.45                      |
| Short-circuit Power | 0.14                      | 0.16                      |
| Leakage Power       | 0.27                      | 0.29                      |
| <b>Total Power</b>  | <b>4.67</b>               | <b>4.90</b>               |

## 7.5 Corner Analysis (PVT)

- **FF Corner:** Fast devices; reduced delay, higher leakage.
- **SS Corner:** Slow devices; increased delay.
- **Temperature:** Higher  $T$  raises leakage and delay.
- **Voltage:** Lower  $V_{DD}$  increases delay, reduces power.

## 7.6 Optimization Techniques

1. Buffer insertion on long nets.
2. Selective upsizing for critical paths.
3. Clock gating to save dynamic power.
4. Multi- $V_t$  cell usage for leakage reduction.
5. ECO-driven routing and clock balancing.

## 7.7 Final Performance Summary

Table 4: Final Post-Layout Performance Summary (Genus 90 nm)

| Metric               | Encoder | Decoder | Unit            |
|----------------------|---------|---------|-----------------|
| Std-cell core area   | 49.955  | 49.955  | $\mu\text{m}^2$ |
| Total extracted area | 52.15   | 52.35   | $\mu\text{m}^2$ |
| Critical path delay  | 1.319   | 1.405   | ns              |
| Max frequency        | 758     | 712     | MHz             |
| Total power          | 4.67    | 4.90    | $\mu\text{W}$   |
| Dynamic power        | 4.26    | 4.45    | $\mu\text{W}$   |
| Leakage power        | 0.27    | 0.29    | $\mu\text{W}$   |
| Worst slack          | +8.681  | +8.595  | ns              |

## 8 Results and Discussion

Table 5: Pre-Layout vs Post-Layout Comparison (Encoder)

| Metric             | Pre-Layout | Post-Layout |
|--------------------|------------|-------------|
| Area ( $\mu m^2$ ) | 49.95      | 52.15       |
| Delay (ns)         | 1.32       | 1.31        |
| Power ( $\mu W$ )  | 4.70       | 4.67        |

### 8.1 Discussion

- Post-layout delay increased slightly due to RC parasitics.
- Power remained nearly constant, showing minimal routing losses.
- Design achieved clean DRC/LVS and satisfied timing constraints.

## 9 Conclusion

The project demonstrates the complete semi-custom VLSI design flow for Manchester encoder and decoder using 90 nm CMOS technology in Cadence. The results confirm functional correctness, efficient area utilization, and low power operation. The encoder achieved faster timing and better power efficiency than the decoder. This work highlights key trade-offs in deep-submicron VLSI design between performance, area, and power.

## References

1. IEEE Std 802.3-2008, Ethernet Physical Layer Specifications.
2. R. Lyons, *Understanding Digital Signal Processing*, Prentice Hall, 2010.
3. Cadence Virtuoso and Genus User Manuals, Cadence Design Systems.
4. Xilinx Vivado Design Suite Documentation, Xilinx Inc.