

# **VLSI Testing and Verification**

## Scan Chain Insertion and ATPG Implementation Report

**Prepared by: Nandakishor PB**  
**Date: February -2 -2026**

# 1. Introduction

This report documents the complete process of implementing Design for Testability (DFT) techniques on a digital counter design. The workflow includes setting up the development environment, performing scan chain insertion, generating test patterns using Automatic Test Pattern Generation (ATPG), and analyzing fault coverage.

## 1.1 Objectives

- Implement scan chain insertion in a counter design to enable efficient testing of sequential circuits
- Generate optimized test patterns using ATPG for comprehensive fault detection
- Achieve high fault coverage while minimizing the number of test vectors
- Understand the internal structure and content of generated output files

## 1.2 Tools Used

- **OSS CAD Suite:** Open-source Electronic Design Automation (EDA) toolchain
- **Fault Tool:** Advanced DFT tool for scan chain insertion and ATPG
- **Yosys:** Synthesis framework for resynthesizing modified designs

## 2. Environment Setup

### 2.1 Activating OSS CAD Suite Environment

The first step is to activate the OSS CAD Suite environment, which sets up all necessary paths and environment variables for the VLSI tools.

#### Command Executed:

```
source environment
```

#### What Happens:

- The command sources the environment script that configures shell variables
- Updates PATH to include directories containing tools like yosys, fault, iverilog, etc.
- The prompt changes to (OSS CAD Suite) indicating the environment is active
- All subsequent commands will use tools from the OSS CAD Suite installation

### 2.2 Navigating to Work Directory

After activating the environment, we navigate to the fault\_environment directory containing our design files and standard cell libraries.

#### Commands:

```
cd .. cd fault_environment/ ls
```

#### Directory Contents:

- **counter\_trial.v**: Original counter design (RTL)
- **counter.v**: Alternative counter implementation
- **oscu35\_stdcells.lib**: Liberty format standard cell library (timing/power data)
- **osu035\_stdcells.v**: Verilog behavioral models of standard cells
- **synth.ys**: Yosys synthesis script

```
synth.ys->
read_verilog counter.v read_liberty -lib osu035_stdcells.lib synth -top counter dfflibmap -
liberty osu035_stdcells.lib proc; opt; flatten; opt techmap opt stat write_verilog
counter_trial.v
```

#### synthesized report:

```
(OSS CAD Suite) nandkishor@nandkishor-HP-Laptop-15s-eq2xxc:~/vlsi_testing_verification/fault_environment$ yosys synth.ys
-----
| yosys - Yosys Open SYNthesis Suite
| Copyright (C) 2012 - 2025 Claire Xenia Wolf <claire@yosyshq.com>
| Distributed under an ISC-like license, type "license" to see terms
| -----
Yosys 0.60+70 (git sha1 8101c87fa, clang++ 18.1.8 -fPI/C -O3)

-- Executing script file 'synth.ys' --
1. Executing Verilog-2005 frontend: counter.v
Parsing Verilog input from 'counter.v' to AST representation.
verilog frontend filename counter.v
Generating RTUIL representation for module 'counter'.
Successfully finished Verilog frontend.

2. Executing Liberty frontend: osu035_stdcells.lib
Imported 39 cell types from liberty file.

3. Executing SYNTH pass.

3.1. Executing HIERARCHY pass (managing design hierarchy).
3.1.1. Analyzing design hierarchy..
Top module: lcounter
3.1.2. Analyzing design hierarchy..
Top module: lcounter
```

Removed 0 unused modules.

3.2. Executing PROC pass (convert processes to netlists).

3.2.1. Executing PROC\_CLEAN pass (remove empty switches from decision trees).  
Cleaned up 0 empty switches.

3.2.2. Executing PROC\_RMDEAD pass (remove dead branches from decision trees).  
Marked 1 switch rules as full, case in process \$proc\$counter.v:7\$1 in module counter.  
Removed a total of 0 dead cases.

3.2.3. Executing PROC\_PRUNE pass (remove redundant assignments in processes).  
Removed 1 redundant assignment.  
Promoted 0 assignments to connections.

3.2.4. Executing PROC\_INIT pass (extract init attributes).

3.2.5. Executing PROC\_ARST pass (detect async resets in processes).

3.2.6. Executing PROC\_ROM pass (convert switches to ROMs).  
Converted 0 switches.  
<suppressed -1 debug messages>

3.2.7. Executing PROC\_MUX pass (convert decision trees to multiplexers).  
Creating decoders for process `counter.\$proc\$counter.v:7\$1'.  
1/1: \$0/Q[3:0]

3.2.8. Executing PROC\_DLATCH pass (convert process syncs to latches).

3.2.9. Executing PROC\_DFF pass (convert process syncs to FFs).  
Creating register for signal `counter.IQ' using process `counter.\$proc\$counter.v:7\$1'.  
created Sdfl cell '\$procdffs6' with positive edge clock.

3.2.10. Executing PROC\_MEMWR pass (convert process memory writes to cells).

3.2.11. Executing PROC\_CLEAN pass (remove empty switches from decision trees).  
Found and cleaned up 1 empty switch in `counter.\$proc\$counter.v:7\$1'.  
Removing empty process `counter.\$proc\$counter.v:7\$1'.  
Cleaned up 1 empty switch.

3.2.12. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.3. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.4. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module `counter'.  
Removed 0 unused cells and 2 unused wires.  
<suppressed -1 debug messages>

3.5. Executing CHECK pass (checking for obvious problems).  
Checking module counter...  
Found and reported 0 problems.

3.6. Executing OPT pass (performing simple optimizations).

3.6.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.6.2. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module `counter'.  
Removed a total of 0 cells.

3.6.3. Executing OPT\_MUXTREE pass (detect dead branches in mux trees).  
Running muxtree optimizer on module `counter'.  
Creating internal representation of mux trees.  
Evaluating internal representation of mux trees.  
Analyzing evaluation results.  
Removed 0 multiplexer ports.  
<suppressed -2 debug messages>

3.6.4. Executing OPT\_REDUCE pass (consolidate \$mux and \$reduce\_\* inputs).  
Optimizing cells in module `counter'.  
Performed a total of 0 changes.

3.6.5. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module `counter'.  
Removed a total of 0 cells.

3.6.6. Executing OPT\_DFF pass (perform DFF optimizations).

3.6.7. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module `counter'.  
<suppressed -1 debug messages>

3.6.8. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.6.9. Finished fast OPT passes. (There is nothing left to do.)

3.7. Executing FSM pass (extract and optimize FSM).

3.7.1. Executing FSM\_DETECT pass (finding FSMs in design).

3.7.2. Executing FSM\_EXTRACT pass (extracting FSM from design).

3.7.3. Executing FSM\_OPT pass (simple optimizations of FSMs).

3.7.4. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module `counter'.  
<suppressed -1 debug messages>

3.7.5. Executing FSM\_OPT pass (simple optimizations of FSMs).

3.7.6. Executing FSM\_RECODE pass (re-assigning FSM state encoding).

3.7.7. Executing FSM\_INFO pass (dumping all available information on FSM cells).

3.7.8. Executing FSM\_MAP pass (mapping FSMs to basic logic).

3.8. Executing OPT pass (performing simple optimizations).

3.8.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.8.2. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module `counter'.  
Removed a total of 0 cells.

3.8.3. Executing OPT\_MUXTREE pass (detect dead branches in mux trees).  
Running muxtree optimizer on module `counter'.  
Creating internal representation of mux trees.  
Evaluating internal representation of mux trees.  
Analyzing evaluation results.  
Removed 0 multiplexer ports.  
<suppressed -2 debug messages>

3.8.4. Executing OPT\_REDUCE pass (consolidate \$mux and \$reduce\_\* inputs).  
Optimizing cells in module `counter'.  
Performed a total of 0 changes.

3.8.5. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module `counter'.  
Removed a total of 0 cells.

3.8.6. Executing OPT\_DFF pass (perform DFF optimizations).  
Adding SRST signal on \$procdffs6 (Sdfl) from module counter (D = \$add\$counter.v:11\$2\_Y[3:0], Q = IQ, rval = 4'0000).

3.8.7. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module `counter'.  
<suppressed -1 debug messages>

Removed 1 unused cells and 1 unused wires.  
<suppressed -2 debug messages>

3.8.8. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.8.9. Restarting OPT passes. (Maybe there is more to do.)

3.8.10. Executing OPT\_MUXTREE pass (detect dead branches in mux trees).  
Running muxtree optimizer on module 'counter'.  
Creating internal representation of mux trees.  
No muxes found in this module.  
Removed 0 multiplexer ports.

3.8.11. Executing OPT\_REDUCE pass (consolidate \$\*mux and \$reduce\_\* inputs).  
Optimizing cells in module 'counter'.  
Performed a total of 0 changes.

3.8.12. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

3.8.13. Executing OPT\_DFF pass (perform DFF optimizations).

3.8.14. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

3.8.15. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.8.16. Finished fast OPT passes. (There is nothing left to do.)

3.9. Executing WREDUCE pass (reducing word size of cells).  
Removed top 31 bits (of 32) from port B of cell counter.\$addCounter.v.11S2 (\$add).  
Removed top 28 bits (of 32) from port Y of cell counter.\$addCounter.v.11S2 (\$add).  
Removed top 28 bits (of 32) from wire counter.\$addCounter.v.11S2\_Y.

3.10. Executing PEEPOPT pass (run peephole optimizers).

3.11. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.  
Removed 0 unused cells and 1 unused wires.  
<suppressed -1 debug messages>

3.12. Executing ALUMACC pass (create \$alu and \$macc cells).  
Extracting \$alu and \$macc cells in module counter.  
creating \$macc model for \$addCounter.v.11S2 (\$add).  
creating \$alu model for \$macc \$addCounter.v.11S2.  
creating \$alu cell for \$addCounter.v.11S2: \$auto\$alumacc.cc:512:replace.\_alu\$9  
created 1 \$alu and 0 \$macc cells.

3.13. Executing SHARE pass (SAT-based resource sharing).

3.14. Executing OPT pass (performing simple optimizations).

3.14.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.14.2. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

3.14.3. Executing OPT\_MUXTREE pass (detect dead branches in mux trees).  
Running muxtree optimizer on module 'counter'.  
Creating internal representation of mux trees.  
No muxes found in this module.  
Removed 0 multiplexer ports.

3.14.4. Executing OPT\_REDUCE pass (consolidate \$\*mux and \$reduce\_\* inputs).  
Optimizing cells in module 'counter'.  
Performed a total of 0 changes.

3.14.5. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

3.14.6. Executing OPT\_DFF pass (perform DFF optimizations).

3.14.7. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

3.14.8. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.14.9. Finished fast OPT passes. (There is nothing left to do.)

3.15. Executing MEMORY pass.

3.15.1. Executing OPT\_MEM pass (optimize memories).  
Performed a total of 0 transformations.

3.15.2. Executing OPT\_MEM\_PRIORITY pass (removing unnecessary memory write priority relations).  
Performed a total of 0 transformations.

3.15.3. Executing OPT\_MEM\_FEEDBACK pass (finding memory read-to-write feedback paths).

3.15.4. Executing MEMORY\_BMUXROM pass (converting muxes to ROMs).

3.15.5. Executing MEMORY\_DFF pass (merging \$dff cells to \$memrd).

3.15.6. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

3.15.7. Executing MEMORY\_SHARE pass (consolidating \$memrd/\$memwr cells).

3.15.8. Executing OPT\_MEM\_WIDEN pass (optimize memories where all ports are wide).  
Performed a total of 0 transformations.

3.15.9. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

3.15.10. Executing MEMORY\_COLLECT pass (generating \$mem cells).

3.16. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

3.17. Executing OPT pass (performing simple optimizations).

3.17.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

3.17.2. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

3.17.3. Executing OPT\_DFF pass (perform DFF optimizations).

3.17.4. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

3.17.5. Finished fast OPT passes.

3.18. Executing MEMORY\_MAP pass (converting memories to logic and flip-flops).

3.19. Executing OPT pass (performing simple optimizations).

3.19.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.



```

Finding unused cells or wires in module `counter..
Removed 0 unused cells and 0 unused wires.
<suppressed -1 debug messages>

3.23.5. Finished fast OPT passes.

3.24. Executing HIERARCHY pass (managing design hierarchy).
Attribute `top` found on module `counter`. Setting top module to counter.

3.24.1. Analyzing design hierarchy..
Top module: `lcounter
Removed 0 unused modules.

3.25. Printing statistics.

==== counter ====
+-----Local Count, excluding submodules.
| 
7 wires
3 public wires
6 public wire bits
3 ports
6 port bits
10 cells
  1 $_ANDNOT_
  1 $_NAND_
  1 $_NOT_
  4 $_SDFF_PP0_
  1 $_XNOR_
  2 $_XOR_

3.26. Executing CHECK pass (checking for obvious problems).
Checking module counter...
Found and reported 0 problems.

4. Executing DFUFBMAP pass (mapping DFF cells to sequential cells from liberty file).
cell DFFNEGEX1 (noninv, pins=3, area=380.00) is a direct match for cell type $_DFF_N_
cell DFFPOSX1 (noninv, pins=3, area=384.00) is a direct match for cell type $_DFF_P_
cell DFFSR (noninv, pins=5, area=704.00) is a direct match for cell type $_DFFSR_PNN_
final dff cell mappings:
IDFFNEGEX1 $_DFF_N_(.CLK(C).D(D).Q(Q));
IDFFPOSX1 $_DFF_P_(.CLK(C).D(D).Q(Q));
unmapped dff cell: $_DFF_NND_
unmapped dff cell: $_DFF_NN1_
unmapped dff cell: $_DFF_NP0_
unmapped dff cell: $_DFF_NP1_
unmapped dff cell: $_DFF_PN0_
unmapped dff cell: $_DFF_PN1_
unmapped dff cell: $_DFF_PP0_
unmapped dff cell: $_DFF_PP1_
unmapped dff cell: $_DFFE_NN_
unmapped dff cell: $_DFFE_NP_
unmapped dff cell: $_DFFE_PP0_
unmapped dff cell: $_DFFE_PP1_
unmapped dff cell: $_DFFSR_NNN_
unmapped dff cell: $_DFFSR_NNP_
unmapped dff cell: $_DFFSR_NPN_
unmapped dff cell: $_DFFSR_NPP_
IDFFSR_DFSR_PNN_ (.CLK(C).D(D).Q(Q).R(R).S(S));
unmapped dff cell: $_DFFSR_PNP_
unmapped dff cell: $_DFFSR_PPN_
unmapped dff cell: $_DFFSR_PPP_

4.1. Executing DFLEGALIZE pass (convert FFs to types supported by the target).
Mapping DFF cells in module `counter`.
mapped 4 $_DFF_P_ cells to IDFFPOSX1 cells.

5. Executing PROC pass (convert processes to netlists).

5.1. Executing PROC_CLEAN pass (remove empty switches from decision trees).
Cleaned up 0 empty switches.

5.2. Executing PROC_RMDEAD pass (remove dead branches from decision trees).
Removed a total of 0 dead cases.

5.3. Executing PROC_PRUNE pass (remove redundant assignments).
Removed 0 redundant assignments.
Promoted 0 assignments to connections.

5.4. Executing PROC_INIT pass (extract init attributes).

5.5. Executing PROC_ARST pass (detect async resets in processes).

5.6. Executing PROC_ROM pass (convert switches to ROMs).
Converted 0 switches.

5.7. Executing PROC_MUX pass (convert decision trees to multiplexers).

5.8. Executing PROC_DLATCH pass (convert process syncs to latches).

5.9. Executing PROC_DFF pass (convert process syncs to FFs).

5.10. Executing PROC_MEMWR pass (convert process memory writes to cells).

5.11. Executing PROC_CLEAN pass (remove empty switches from decision trees).
Cleaned up 0 empty switches.

5.12. Executing OPT_EXPR pass (perform const folding).
Optimizing module counter.

6. Executing OPT pass (performing simple optimizations).

6.1. Executing OPT_EXPR pass (perform const folding).
Optimizing module counter.

6.2. Executing OPT_MERGE pass (detect identical cells).
Finding identical cells in module `lcounter'.
Removed a total of 0 cells.

6.3. Executing OPT_MUXTREE pass (detect dead branches in mux trees).
Running muxtree optimizer on module `lcounter'.
Creating internal representation of mux trees.
No muxes found in this module.
Removed 0 multiplexer ports.

6.4. Executing OPT_REDUCE pass (consolidate $mux and $reduce_* inputs).
Optimizing cells in module `lcounter'.
Performed a total of 0 changes.

6.5. Executing OPT_MERGE pass (detect identical cells).
Finding identical cells in module `lcounter'.
Removed a total of 0 cells.

6.6. Executing OPT_DFF pass (perform DFF optimizations).

6.7. Executing OPT_CLEAN pass (remove unused cells and wires).
Finding unused cells or wires in module `lcounter.

6.8. Executing OPT_EXPR pass (perform const folding).
Optimizing module counter.

6.9. Finished fast OPT passes. (There is nothing left to do.)

7. Executing FLATTEN pass (flatten design).

```

8. Executing OPT pass (performing simple optimizations).

8.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

8.2. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

8.3. Executing OPT\_MUXTREE pass (detect dead branches in mux trees).  
Running muxtree optimizer on module counter..  
Creating internal representation of mux trees.  
No muxes found in this module.  
Removed 0 multiplexer ports.

8.4. Executing OPT\_REDUCE pass (consolidate \$\*mux and \$reduce\_\* inputs).  
Optimizing cells in module 'counter'.  
Performed a total of 0 changes.

8.5. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

8.6. Executing OPT\_DFF pass (perform DFF optimizations).

8.7. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

8.8. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

8.9. Finished fast OPT passes. (There is nothing left to do.)

9. Executing TECHMAP pass (map to technology primitives).

9.1. Executing Verilog-2005 frontend: /home/nandakishor/vlsi\_testing\_verification/oss-cad-suite/lib/.share/yosys/techmap.v  
Parsing Verilog input from /home/nandakishor/vlsi\_testing\_verification/oss-cad-suite/lib/.share/yosys/techmap.v to AST representation.  
verilog frontend filename /home/nandakishor/vlsi\_testing\_verification/oss-cad-suite/lib/.share/yosys/techmap.v  
Generating RTUIL representation for module '\\_90\_simplemap\_bool\_ops'.  
Generating RTUIL representation for module '\\_90\_simplemap\_reduce\_ops'.  
Generating RTUIL representation for module '\\_90\_simplemap\_log\_ops'.  
Generating RTUIL representation for module '\\_90\_simplemap\_arith\_ops'.  
Generating RTUIL representation for module '\\_90\_simplemap\_various'.  
Generating RTUIL representation for module '\\_90\_shift\_ops\_shr\_shl\_sshl\_sshr'.  
Generating RTUIL representation for module '\\_90\_shift\_ops\_shl\_shrl'.  
Generating RTUIL representation for module '\\_90\_fa'.  
Generating RTUIL representation for module '\\_90\_icu\_brent\_kung'.  
Generating RTUIL representation for module '\\_90\_max'.  
Generating RTUIL representation for module '\\_90\_alumacc'.  
Generating RTUIL representation for module '\\$div\_mod\_u'.  
Generating RTUIL representation for module '\\$div\_mod\_trunc'.  
Generating RTUIL representation for module '\\_90\_div'.  
Generating RTUIL representation for module '\\_90\_mod'.  
Generating RTUIL representation for module '\\_90\_div\_floor'.  
Generating RTUIL representation for module '\\_90\_divceil'.  
Generating RTUIL representation for module '\\_90\_powl'.  
Generating RTUIL representation for module '\\_90\_mux'.  
Generating RTUIL representation for module '\\_90\_demux'.  
Generating RTUIL representation for module '\\_90\_lut'.  
Generating RTUIL representation for module '\\$connect'.  
Generating RTUIL representation for module '\\$input\_port'.  
Successfully finished Verilog frontend.

9.2. Continuing TECHMAP pass.  
No more expansions possible.  
<suppressed ~77 debug messages>

10. Executing OPT pass (performing simple optimizations).

10.1. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

10.2. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

10.3. Executing OPT\_MUXTREE pass (detect dead branches in mux trees).  
Running muxtree optimizer on module counter..  
Creating internal representation of mux trees.  
No muxes found in this module.  
Removed 0 multiplexer ports.

10.4. Executing OPT\_REDUCE pass (consolidate \$\*mux and \$reduce\_\* inputs).  
Optimizing cells in module 'counter'.  
Performed a total of 0 changes.

10.5. Executing OPT\_MERGE pass (detect identical cells).  
Finding identical cells in module 'counter'.  
Removed a total of 0 cells.

10.6. Executing OPT\_DFF pass (perform DFF optimizations).

10.7. Executing OPT\_CLEAN pass (remove unused cells and wires).  
Finding unused cells or wires in module 'counter'.

10.8. Executing OPT\_EXPR pass (perform const folding).  
Optimizing module counter.

10.9. Finished fast OPT passes. (There is nothing left to do.)

11. Printing statistics.

```
==== counter ====
+-----Local Count, excluding submodules.
| 
11 wires
20 wire bits
3 public wires
6 public wire bits
3 ports
6 port bits
14 cells
1 \$_ANDNOT_
4 \$_MUX_
1 \$_NAND_
1 \$_NOT_
1 \$_XNOR_
2 \$_XOR_
4 DFPPOSX1
```

12. Executing Verilog backend.

12.1. Executing BMUXMAP pass.

12.2. Executing DEMUXMAP pass.  
Dumping module 'counter'.

### 3. Scan Chain Insertion Process

#### 3.1 Successful Scan Chain Insertion

```
fault chain counter_trial.v \ --clock clk \ --reset rst \ --
liberty osu035_stdcells.lib \ --sout sout \ -o counter_scan1.v
```

##### Command Breakdown:

- **fault chain**: Invokes the scan chain insertion subcommand
- **counter\_trial.v**: Input Verilog file containing the original design
- **--clock clk**: Specifies the clock signal name for scan chain operation
- **--reset rst**: Specifies the reset signal for initializing scan cells
- **--liberty**: Points to the Liberty (.lib) file containing cell timing and area data
- **--sout sout**: Defines the scan chain output port name
- **-o counter\_scan1.v**: Output file name for the scan-inserted design

```
(OSS CAD Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:~/vlsi_testing_verification/fault_environment$ fault chain counter_trial.v \
--clock clk \
--reset rst \
--liberty osu035_stdcells.lib \
--sout sout \
-o counter_scan1.v
Processing file counter_trial.v...
Generating LALR tables
WARNING: 183 shift/reduce conflicts
Processing module counter...
Chaining internal flip-flops...
Internal scan chain successfully constructed. Length: 4
Boundary scan cells successfully chained. Length: 4
Generating LALR tables
WARNING: 183 shift/reduce conflicts
Total scan-chain length: 8
Resynthesizing with yosys...
Done.
```

## What Happened During Processing:

1. **Parsing Phase:** The tool parses the input Verilog file and builds an Abstract Syntax Tree (AST). LALR parser warnings are normal for complex Verilog syntax.
2. **Module Analysis:** Identifies the counter module and extracts flip-flops, combinational logic, and port definitions.
3. **Internal Scan Chain:** Converts 4 internal D flip-flops to scan flip-flops and chains them together. Each scan cell can operate in normal mode or shift mode.
4. **Boundary Scan:** Adds 4 boundary scan cells at the module I/O ports for better controllability and observability.
5. **Total Chain Length:** Combined length is 8 cells (4 internal + 4 boundary), allowing 8-bit test patterns to be shifted through.
6. **Resynthesis:** Yosys re-optimizes the modified design to ensure correct functionality and timing.

## Generated Files:

- **counter\_scan1.v:** Main output file with scan chain inserted. Contains modified module with scan flip-flops, scan input/output ports (scan\_in, scan\_out, scan\_enable), and all original functionality preserved.
- **counter\_scan1.v+attrs:** Attribute file containing metadata about scan chain configuration, cell types used, and chain topology.
- **counter\_scan1.v.chain-intermediate.v:** Intermediate file created during the chaining process, useful for debugging chain construction.

```
(OSS CAD Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:~/vlsi_testing_verification/fault_environment$ ls
counter_scan1.v                      counter.v          parsetab.py
counter_scan1.v+attrs                  osu035_stdcells.lib  synth.ys
counter_scan1.v.chain-intermediate.v  osu035_stdcells.v
counter_trial.v                       parser.out
```

## 4. Scan Chain Cut Operation

### 4.1 Purpose of Cutting the Scan Chain

The 'cut' operation prepares the scan-inserted design for ATPG by converting it into a form where sequential elements are treated as pseudo-primary inputs and outputs. This allows the ATPG tool to generate test patterns for combinational logic between scan elements more effectively.

### 4.2 Cut Command Execution

#### Command:

```
fault cut counter_scan1.v \ --clock clk \ -o counter_scan_cut.v
```

#### Command Parameters:

- **fault cut:** Subcommand that cuts the scan chain
- **counter\_scan1.v:** Input file with scan chain inserted
- **--clock clk:** Clock signal used for timing analysis
- **-o counter\_scan\_cut.v:** Output file with cut scan chain

#### What the Cut Operation Does:

7. **Flattens Sequential Logic:** Converts flip-flops into separate input/output ports, effectively breaking the sequential feedback loops.
8. **Creates Pseudo-Ports:** Each flip-flop D input becomes a pseudo-primary output, and each Q output becomes a pseudo-primary input.
9. **Enables Combinational ATPG:** The resulting netlist is purely combinational from the ATPG perspective, simplifying test pattern generation.
10. **Preserves Topology:** The combinational logic structure remains unchanged, only the sequential element boundaries are modified.

#### Generated File:

- **counter\_scan\_cut.v:** Contains the design with scan chain 'cut'. All flip-flops are converted to input/output port pairs. Ready for ATPG processing.

```
(OSS CAD Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:~/vlsi_testing_verification/fault_environment$ fault cut counter_scan1.v \
--clock clk \
-o counter_scan_cut.v
Generating LALR tables
WARNING: 183 shift/reduce conflicts
```

```
(OSS CAD Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:~/vlsi_testing_verification/fault_environment$ ls
counter_scan1.v  counter_scan1.v+attrs  counter_scan1.v.chain-intermediate.v  counter_scan_cut.v  counter_trial.v  counter.v  osu035_stdcells.lib  osu035_stdcells.v  parser.out  parsetab.py  synth.sys
```

## 5. Automatic Test Pattern Generation (ATPG)

### 5.1 Understanding ATPG

ATPG is the process of automatically generating test vectors that detect manufacturing defects in digital circuits. It uses fault models (typically stuck-at-0 and stuck-at-1) to systematically create patterns that activate faults and propagate their effects to observable outputs.

### 5.2 Successful ATPG Execution

#### Final Working Command:

```
fault atpg counter_scan_cut.v \ --cell-model osu035_stdcells.v \
--clock clk \ -o patterns.tv.json \ --output-coverage-metadata
coverage.yml
```

#### Command Parameters Explained:

- **fault atpg**: Invokes the Automatic Test Pattern Generation engine
- **counter\_scan\_cut.v**: Input netlist with cut scan chain (from previous step)
- **--cell-model osu035\_stdcells.v**: Verilog file containing behavioral models of standard cells. Required for fault simulation to understand gate-level behavior.
- **--clock clk**: Clock signal for synchronous simulation
- **-o patterns.tv.json**: Output file for generated test vectors in JSON format
- **--output-coverage-metadata coverage.yml**: YAML file containing detailed fault coverage statistics

## Detailed Analysis of ATPG Process:

### Step 1: Fault Site Identification

- **125 fault sites detected**
- These represent all possible stuck-at-0 and stuck-at-1 faults in the design
- Found across 32 gates (AND, OR, NOT, NAND, NOR, XOR, etc.)
- And 24 input/output ports
- Each gate input/output can have both SA0 and SA1 faults

### Step 2: Simulation and Coverage

- **Initial coverage: 0.0%** - Before any patterns are applied
- **Final coverage: 86.0%** - After pattern generation
- This means 86% of all possible faults can be detected by the generated patterns
- The remaining 14% are likely untestable faults due to circuit topology
- Processing completed in 1.59 seconds

### Step 3: Essential Test Vector Analysis

- **0 essential test vectors found**
- Essential vectors are those that detect faults no other vector can detect
- Zero essential vectors means high redundancy - good for compaction

### Step 4: Test Vector Compaction

- **Initial count: 100 test vectors**
- **Compacted count: 7 test vectors**
- **Compaction ratio: 93.00%** - Reduced by 93 vectors!
- The compactor merged overlapping fault coverage
- Only 7 vectors are needed to maintain the same 86% coverage
- Significantly reduces test time and cost

## Generated Files from ATPG:

- **patterns.tv.json**: Contains the final 5 compacted test vectors in JSON format. Each vector specifies input values for all primary inputs and scan chain cells.
- **patterns.raw\_tv.json**: Contains the original 100 uncompacted test vectors. Useful for debugging or alternative compaction strategies.
- **coverage.yml**: YAML file with comprehensive fault coverage metadata including per-fault status (detected/undetected), coverage percentage by fault type, gate-level coverage breakdown, and test vector efficiency metrics.

```
(OSS CAD Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:~/vlsi_testing_verification/fault_environment$ fault atpg counter_scan_cut.v --cell-model osu035_stdcells.v --clock clk -o patterns.tv.json --output-coverage-metadata coverage.yml
Generating LALR tables
WARNING: 183 shift/reduce conflicts
Processing module counter...
Found 125 fault sites in 32 gates and 24 ports.
Performing simulations...
Initial coverage: 0.0%
Time elapsed: 1.59s.
Simulations concluded: Coverage 86.0%
Writing raw generated test vectors in Fault JSON format to patterns.tv.json...
Finding essential test vectors...
Found 0 essential test vectors.
Performing compaction...
Initial TV Count: 100. Compacted TV Count: 7.
Successfully compacted test vectors by a ratio of 93.00%.
Writing compacted generated test vectors in Fault JSON format to patterns.tv.json...
Writing YAML file of final coverage metadata to coverage.yml...
```

```
(OSS CAD Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:~/vlsi_testing_vg_g_vggggg
g_verification/fault_environment$ ls
counter_scan1.v                                counter.v          parsetab.py
counter_scan1.v+attrs                          coverage.yml      patterns.raw_tv.json
counter_scan1.v.chain-intermediate.v        osu035_stdcells.lib  patterns.tv.json
counter_scan_cut.v                            osu035_stdcells.v   synth.ys
counter_trial.v                             parser.out
```

## 6. Generated File Structure and Content Analysis

### 6.1 Scan-Inserted Verilog File (counter\_scan1.v)

#### File Structure:

- **Module Declaration:** Extended with scan chain control signals (scan\_in, scan\_out, scan\_enable)
- **Scan Flip-Flops:** Original DFFs replaced with scan DFFs (SDFF cells)
- **Scan Chain Wiring:** Internal signals connecting scan\_out of one cell to scan\_in of next
- **Multiplexers:** 2:1 MUX in each scan cell selects between functional data and scan data
- **Preserved Logic:** All original combinational logic remains functionally identical

#### Key Contents:

```
QSS CAP Suite) nandakishor@nandakishor-HP-Laptop-15s-eq2xxx:/vlsi_testing_verification/fault_environment$ cat counter_scan1.v
/*
  Automatically generated by Fault
  Do not modify.
  Generated on: 2026-02-02 23:12:03
*/
/* FAULT_METADATA: {"sout":"sout","shift":"shift","boundaryCount":4,"internalCount":4,"order":[{"ordinal":0,"kind":"dff","name":"_14_","width":1}, {"ordinal":0,"kind":"dff","name":"_15_","width":1}, {"ordinal":0,"kind":"dff","name":"_16_","width":1}, {"ordinal":0,"kind":"dff","name":"_17_","width":1}], "order":4, "kind": "output", "name": "Q", "width": 4}, "sin": "sin", "END_FAULT_METADATA "}
/* Generated by Yosys 0.60+70 (git sha1 810c87a, clang++ 18.1.8 -fPIC -O3) */

module counter(clk, rst, Q, sin, shift, sout, tck, test);
    input clk;
    wire clk;
    input rst;
    wire rst;
    output [3:0] Q;
    wire [3:0] Q;
    input sin;
    wire sin;
    input shift;
    wire shift;
    output sout;
    wire sout;
    input tck;
    wire tck;
    input test;
    wire test;
    wire _00_;
    wire _01_;
    wire _02_;
    wire _03_;
    wire _04_;
    wire _05_;
    wire _06_;
    wire _07_;
    wire _08_;
    wire _09_;
    wire _10_;
    wire _11_;
    wire _12_;
    wire _13_;
    wire _14_;
    wire _15_;
    wire _16_;
    wire _17_;
    wire _18_;
    wire _19_;
    wire _20_;
    wire _21_;
    wire _22_;
    wire _23_;
    wire _24_;
    wire _25_;
    wire _26_;
    wire _27_;
    wire _28_;
    wire _29_;
    wire _30_;
    wire _31_;
    wire _32_;
    wire _33_;
    wire _34_;
    wire _35_;
    wire _36_;
    wire _37_;

    wire [3:0] din[0];
    wire Q0.din[1];
    wire Q0.din[2];
    wire Q0.din[3];
    wire \BoundaryScanRegister_output__0__.sout;
    wire \BoundaryScanRegister_output__1__.sout;
    wire \BoundaryScanRegister_output__2__.sout;
    wire \ufb0f__.clk_source;
    INVX1_30_( .A(rst), .Y(_00_) );
    INVX1_31_( .A(sin), .Y(_01_) );
    INVX1_32_( .A(Q0.din[3]), .Y(_12_) );
    INVX1_33_( .A(Q0.din[3]), .Y(_13_) );
    INVX1_34_( .A(Q0.din[2]), .Y(_14_) );
    INVX1_35_( .A(Q0.din[0]), .Y(_15_) );
    INVX1_36_( .A(shift), .Y(_16_) );
    INVX1_37_( .A(clk), .Y(_17_) );
    INVX1_38_( .A(tck), .Y(_18_) );
    INVX1_39_( .A(test), .Y(_19_) );
    INVX1_40_( .A(sout), .Y(_20_) );
    INVX1_41_( .A(_00_), .Y(_21_) );
    INVX1_42_( .A(_01_), .Y(_22_) );
    INVX1_43_( .A(_02_), .Y(_23_) );
    INVX1_44_( .A(_03_), .Y(_24_) );
    INVX1_45_( .A(_04_), .Y(_25_) );
    INVX1_46_( .A(_05_), .Y(_26_) );
    INVX1_47_( .A(_06_), .Y(_27_) );
    INVX1_48_( .A(_07_), .Y(_28_) );
    INVX1_49_( .A(_08_), .Y(_29_) );
    INVX1_50_( .A(_09_), .Y(_30_) );
    INVX1_51_( .A(_10_), .Y(_31_) );
    INVX1_52_( .A(_11_), .Y(_32_) );
    INVX1_53_( .A(_12_), .Y(_33_) );
    INVX1_54_( .A(_13_), .Y(_34_) );
    INVX1_55_( .A(_14_), .Y(_35_) );
    INVX1_56_( .A(_15_), .Y(_36_) );
    INVX1_57_( .A(_16_), .Y(_37_) );
    INVX1_58_( .A(_17_), .Y(_38_) );
    INVX1_59_( .A(_18_), .Y(_39_) );
    INVX1_60_( .A(_19_), .Y(_40_) );
    INVX1_61_( .A(_20_), .Y(_41_) );
    INVX1_62_( .A(_21_), .Y(_42_) );
    INVX1_63_( .A(_22_), .Y(_43_) );
    INVX1_64_( .A(_23_), .Y(_44_) );
    INVX1_65_( .A(_24_), .Y(_45_) );
    INVX1_66_( .A(_25_), .Y(_46_) );
    INVX1_67_( .A(_26_), .Y(_47_) );
    INVX1_68_( .A(_27_), .Y(_48_) );
    INVX1_69_( .A(_28_), .Y(_49_) );
    INVX1_70_( .A(_29_), .Y(_50_) );
    INVX1_71_( .A(_30_), .Y(_51_) );
    INVX1_72_( .A(_31_), .Y(_52_) );
    INVX1_73_( .A(_32_), .Y(_53_) );
    INVX1_74_( .A(_33_), .Y(_54_) );
    INVX1_75_( .A(_34_), .Y(_55_) );
    INVX1_76_( .A(_35_), .Y(_56_) );
    INVX1_77_( .A(_36_), .Y(_57_) );
    INVX1_78_( .A(_37_), .Y(_58_) );
    INVX1_79_( .A(_38_), .Y(_59_) );
    INVX1_80_( .A(_39_), .Y(_60_) );
    INVX1_81_( .A(_40_), .Y(_61_) );
    INVX1_82_( .A(_41_), .Y(_62_) );
    INVX1_83_( .A(_42_), .Y(_63_) );
    INVX1_84_( .A(_43_), .Y(_64_) );
    INVX1_85_( .A(_44_), .Y(_65_) );
    INVX1_86_( .A(_45_), .Y(_66_) );
    INVX1_87_( .A(_46_), .Y(_67_) );
    INVX1_88_( .A(_47_), .Y(_68_) );
    INVX1_89_( .A(_48_), .Y(_69_) );
    INVX1_90_( .A(_49_), .Y(_70_) );
    INVX1_91_( .A(_50_), .Y(_71_) );
    INVX1_92_( .A(_51_), .Y(_72_) );
    INVX1_93_( .A(_52_), .Y(_73_) );
    INVX1_94_( .A(_53_), .Y(_74_) );
    INVX1_95_( .A(_54_), .Y(_75_) );
    INVX1_96_( .A(_55_), .Y(_76_) );
    INVX1_97_( .A(_56_), .Y(_77_) );
    INVX1_98_( .A(_57_), .Y(_78_) );
    INVX1_99_( .A(_58_), .Y(_79_) );
    INVX1_100_( .A(_59_), .Y(_80_) );
    INVX1_101_( .A(_60_), .Y(_81_) );
    INVX1_102_( .A(_61_), .Y(_82_) );
    INVX1_103_( .A(_62_), .Y(_83_) );
    INVX1_104_( .A(_63_), .Y(_84_) );
    INVX1_105_( .A(_64_), .Y(_85_) );
    INVX1_106_( .A(_65_), .Y(_86_) );
    INVX1_107_( .A(_66_), .Y(_87_) );
    INVX1_108_( .A(_67_), .Y(_88_) );
    INVX1_109_( .A(_68_), .Y(_89_) );
    INVX1_110_( .A(_69_), .Y(_90_) );
    INVX1_111_( .A(_70_), .Y(_91_) );
    INVX1_112_( .A(_71_), .Y(_92_) );
    INVX1_113_( .A(_72_), .Y(_93_) );
    INVX1_114_( .A(_73_), .Y(_94_) );
    INVX1_115_( .A(_74_), .Y(_95_) );
    INVX1_116_( .A(_75_), .Y(_96_) );
    INVX1_117_( .A(_76_), .Y(_97_) );
    INVX1_118_( .A(_77_), .Y(_98_) );
    INVX1_119_( .A(_78_), .Y(_99_) );
    INVX1_120_( .A(_79_), .Y(_100_) );
    INVX1_121_( .A(_80_), .Y(_101_) );
    INVX1_122_( .A(_81_), .Y(_102_) );
    INVX1_123_( .A(_82_), .Y(_103_) );
    INVX1_124_( .A(_83_), .Y(_104_) );
    INVX1_125_( .A(_84_), .Y(_105_) );
    INVX1_126_( .A(_85_), .Y(_106_) );
    INVX1_127_( .A(_86_), .Y(_107_) );
    INVX1_128_( .A(_87_), .Y(_108_) );
    INVX1_129_( .A(_88_), .Y(_109_) );
    INVX1_130_( .A(_89_), .Y(_110_) );
    INVX1_131_( .A(_90_), .Y(_111_) );
    INVX1_132_( .A(_91_), .Y(_112_) );
    INVX1_133_( .A(_92_), .Y(_113_) );
    INVX1_134_( .A(_93_), .Y(_114_) );
    INVX1_135_( .A(_94_), .Y(_115_) );
    INVX1_136_( .A(_95_), .Y(_116_) );
    INVX1_137_( .A(_96_), .Y(_117_) );
    INVX1_138_( .A(_97_), .Y(_118_) );
    INVX1_139_( .A(_98_), .Y(_119_) );
    INVX1_140_( .A(_99_), .Y(_120_) );
    INVX1_141_( .A(_100_), .Y(_121_) );
    INVX1_142_( .A(_101_), .Y(_122_) );
    INVX1_143_( .A(_102_), .Y(_123_) );
    INVX1_144_( .A(_103_), .Y(_124_) );
    INVX1_145_( .A(_104_), .Y(_125_) );
    INVX1_146_( .A(_105_), .Y(_126_) );
    INVX1_147_( .A(_106_), .Y(_127_) );
    INVX1_148_( .A(_107_), .Y(_128_) );
    INVX1_149_( .A(_108_), .Y(_129_) );
    INVX1_150_( .A(_109_), .Y(_130_) );
    INVX1_151_( .A(_110_), .Y(_131_) );
    INVX1_152_( .A(_111_), .Y(_132_) );
    INVX1_153_( .A(_112_), .Y(_133_) );
    INVX1_154_( .A(_113_), .Y(_134_) );
    INVX1_155_( .A(_114_), .Y(_135_) );
    INVX1_156_( .A(_115_), .Y(_136_) );
    INVX1_157_( .A(_116_), .Y(_137_) );
    INVX1_158_( .A(_117_), .Y(_138_) );
    INVX1_159_( .A(_118_), .Y(_139_) );
    INVX1_160_( .A(_119_), .Y(_140_) );
    INVX1_161_( .A(_120_), .Y(_141_) );
    INVX1_162_( .A(_121_), .Y(_142_) );
    INVX1_163_( .A(_122_), .Y(_143_) );
    INVX1_164_( .A(_123_), .Y(_144_) );
    INVX1_165_( .A(_124_), .Y(_145_) );
    INVX1_166_( .A(_125_), .Y(_146_) );
    INVX1_167_( .A(_126_), .Y(_147_) );
    INVX1_168_( .A(_127_), .Y(_148_) );
    INVX1_169_( .A(_128_), .Y(_149_) );
    INVX1_170_( .A(_129_), .Y(_150_) );
    INVX1_171_( .A(_130_), .Y(_151_) );
    INVX1_172_( .A(_131_), .Y(_152_) );
    INVX1_173_( .A(_132_), .Y(_153_) );
    INVX1_174_( .A(_133_), .Y(_154_) );
    INVX1_175_( .A(_134_), .Y(_155_) );
    INVX1_176_( .A(_135_), .Y(_156_) );
    INVX1_177_( .A(_136_), .Y(_157_) );
    INVX1_178_( .A(_137_), .Y(_158_) );
    INVX1_179_( .A(_138_), .Y(_159_) );
    INVX1_180_( .A(_139_), .Y(_160_) );
    INVX1_181_( .A(_140_), .Y(_161_) );
    INVX1_182_( .A(_141_), .Y(_162_) );
    INVX1_183_( .A(_142_), .Y(_163_) );
    INVX1_184_( .A(_143_), .Y(_164_) );
    INVX1_185_( .A(_144_), .Y(_165_) );
    INVX1_186_( .A(_145_), .Y(_166_) );
    INVX1_187_( .A(_146_), .Y(_167_) );
    INVX1_188_( .A(_147_), .Y(_168_) );
    INVX1_189_( .A(_148_), .Y(_169_) );
    INVX1_190_( .A(_149_), .Y(_170_) );
    INVX1_191_( .A(_150_), .Y(_171_) );
    INVX1_192_( .A(_151_), .Y(_172_) );
    INVX1_193_( .A(_152_), .Y(_173_) );
    INVX1_194_( .A(_153_), .Y(_174_) );
    INVX1_195_( .A(_154_), .Y(_175_) );
    INVX1_196_( .A(_155_), .Y(_176_) );
    INVX1_197_( .A(_156_), .Y(_177_) );
    INVX1_198_( .A(_157_), .Y(_178_) );
    INVX1_199_( .A(_158_), .Y(_179_) );
    INVX1_200_( .A(_159_), .Y(_180_) );
    INVX1_201_( .A(_160_), .Y(_181_) );
    INVX1_202_( .A(_161_), .Y(_182_) );
    INVX1_203_( .A(_162_), .Y(_183_) );
    INVX1_204_( .A(_163_), .Y(_184_) );
    INVX1_205_( .A(_164_), .Y(_185_) );
    INVX1_206_( .A(_165_), .Y(_186_) );
    INVX1_207_( .A(_166_), .Y(_187_) );
    INVX1_208_( .A(_167_), .Y(_188_) );
    INVX1_209_( .A(_168_), .Y(_189_) );
    INVX1_210_( .A(_169_), .Y(_190_) );
    INVX1_211_( .A(_170_), .Y(_191_) );
    INVX1_212_( .A(_171_), .Y(_192_) );
    INVX1_213_( .A(_172_), .Y(_193_) );
    INVX1_214_( .A(_173_), .Y(_194_) );
    INVX1_215_( .A(_174_), .Y(_195_) );
    INVX1_216_( .A(_175_), .Y(_196_) );
    INVX1_217_( .A(_176_), .Y(_197_) );
    INVX1_218_( .A(_177_), .Y(_198_) );
    INVX1_219_( .A(_178_), .Y(_199_) );
    INVX1_220_( .A(_179_), .Y(_200_) );
    INVX1_221_( .A(_180_), .Y(_201_) );
    INVX1_222_( .A(_181_), .Y(_202_) );
    INVX1_223_( .A(_182_), .Y(_203_) );
    INVX1_224_( .A(_183_), .Y(_204_) );
    INVX1_225_( .A(_184_), .Y(_205_) );
    INVX1_226_( .A(_185_), .Y(_206_) );
    INVX1_227_( .A(_186_), .Y(_207_) );
    INVX1_228_( .A(_187_), .Y(_208_) );
    INVX1_229_( .A(_188_), .Y(_209_) );
    INVX1_230_( .A(_189_), .Y(_210_) );
    INVX1_231_( .A(_190_), .Y(_211_) );
    INVX1_232_( .A(_191_), .Y(_212_) );
    INVX1_233_( .A(_192_), .Y(_213_) );
    INVX1_234_( .A(_193_), .Y(_214_) );
    INVX1_235_( .A(_194_), .Y(_215_) );
    INVX1_236_( .A(_195_), .Y(_216_) );
    INVX1_237_( .A(_196_), .Y(_217_) );
    INVX1_238_( .A(_197_), .Y(_218_) );
    INVX1_239_( .A(_198_), .Y(_219_) );
    INVX1_240_( .A(_199_), .Y(_220_) );
    INVX1_241_( .A(_200_), .Y(_221_) );
    INVX1_242_( .A(_201_), .Y(_222_) );
    INVX1_243_( .A(_202_), .Y(_223_) );
    INVX1_244_( .A(_203_), .Y(_224_) );
    INVX1_245_( .A(_204_), .Y(_225_) );
    INVX1_246_( .A(_205_), .Y(_226_) );
    INVX1_247_( .A(_206_), .Y(_227_) );
    INVX1_248_( .A(_207_), .Y(_228_) );
    INVX1_249_( .A(_208_), .Y(_229_) );
    INVX1_250_( .A(_209_), .Y(_230_) );
    INVX1_251_( .A(_210_), .Y(_231_) );
    INVX1_252_( .A(_211_), .Y(_232_) );
    INVX1_253_( .A(_212_), .Y(_233_) );
    INVX1_254_( .A(_213_), .Y(_234_) );
    INVX1_255_( .A(_214_), .Y(_235_) );
    INVX1_256_( .A(_215_), .Y(_236_) );
    INVX1_257_( .A(_216_), .Y(_237_) );
    INVX1_258_( .A(_217_), .Y(_238_) );
    INVX1_259_( .A(_218_), .Y(_239_) );
    INVX1_260_( .A(_219_), .Y(_240_) );
    INVX1_261_( .A(_220_), .Y(_241_) );
    INVX1_262_( .A(_221_), .Y(_242_) );
    INVX1_263_( .A(_222_), .Y(_243_) );
    INVX1_264_( .A(_223_), .Y(_244_) );
    INVX1_265_( .A(_224_), .Y(_245_) );
    INVX1_266_( .A(_225_), .Y(_246_) );
    INVX1_267_( .A(_226_), .Y(_247_) );
    INVX1_268_( .A(_227_), .Y(_248_) );
    INVX1_269_( .A(_228_), .Y(_249_) );
    INVX1_270_( .A(_229_), .Y(_250_) );
    INVX1_271_( .A(_230_), .Y(_251_) );
    INVX1_272_( .A(_231_), .Y(_252_) );
    INVX1_273_( .A(_232_), .Y(_253_) );
    INVX1_274_( .A(_233_), .Y(_254_) );
    INVX1_275_( .A(_234_), .Y(_255_) );
    INVX1_276_( .A(_235_), .Y(_256_) );
    INVX1_277_( .A(_236_), .Y(_257_) );
    INVX1_278_( .A(_237_), .Y(_258_) );
    INVX1_279_( .A(_238_), .Y(_259_) );
    INVX1_280_( .A(_239_), .Y(_260_) );
    INVX1_281_( .A(_240_), .Y(_261_) );
    INVX1_282_( .A(_241_), .Y(_262_) );
    INVX1_283_( .A(_242_), .Y(_263_) );
    INVX1_284_( .A(_243_), .Y(_264_) );
    INVX1_285_( .A(_244_), .Y(_265_) );
    INVX1_286_( .A(_245_), .Y(_266_) );
    INVX1_287_( .A(_246_), .Y(_267_) );
    INVX1_288_( .A(_247_), .Y(_268_) );
    INVX1_289_( .A(_248_), .Y(_269_) );
    INVX1_290_( .A(_249_), .Y(_270_) );
    INVX1_291_( .A(_250_), .Y(_271_) );
    INVX1_292_( .A(_251_), .Y(_272_) );
    INVX1_293_( .A(_252_), .Y(_273_) );
    INVX1_294_( .A(_253_), .Y(_274_) );
    INVX1_295_( .A(_254_), .Y(_275_) );
    INVX1_296_( .A(_255_), .Y(_276_) );
    INVX1_297_( .A(_256_), .Y(_277_) );
    INVX1_298_( .A(_257_), .Y(_278_) );
    INVX1_299_( .A(_258_), .Y(_279_) );
    INVX1_300_( .A(_259_), .Y(_280_) );
    INVX1_301_( .A(_260_), .Y(_281_) );
    INVX1_302_( .A(_261_), .Y(_282_) );
    INVX1_303_( .A(_262_), .Y(_283_) );
    INVX1_304_( .A(_263_), .Y(_284_) );
    INVX1_305_( .A(_264_), .Y(_285_) );
    INVX1_306_( .A(_265_), .Y(_286_) );
    INVX1_307_( .A(_266_), .Y(_287_) );
    INVX1_308_( .A(_267_), .Y(_288_) );
    INVX1_309_( .A(_268_), .Y(_289_) );
    INVX1_310_( .A(_269_), .Y(_290_) );
    INVX1_311_( .A(_270_), .Y(_291_) );
    INVX1_312_( .A(_271_), .Y(_292_) );
    INVX1_313_( .A(_272_), .Y(_293_) );
    INVX1_314_( .A(_273_), .Y(_294_) );
    INVX1_315_( .A(_274_), .Y(_295_) );
    INVX1_316_( .A(_275_), .Y(_296_) );
    INVX1_317_( .A(_276_), .Y(_297_) );
    INVX1_318_( .A(_277_), .Y(_298_) );
    INVX1_319_( .A(_278_), .Y(_299_) );
    INVX1_320_( .A(_279_), .Y(_300_) );
    INVX1_321_( .A(_280_), .Y(_301_) );
    INVX1_322_( .A(_281_), .Y(_302_) );
    INVX1_323_( .A(_282_), .Y(_303_) );
    INVX1_324_( .A(_283_), .Y(_304_) );
    INVX1_325_( .A(_284_), .Y(_305_) );
    INVX1_326_( .A(_285_), .Y(_306_) );
    INVX1_327_( .A(_286_), .Y(_307_) );
    INVX1_328_( .A(_287_), .Y(_308_) );
    INVX1_329_( .A(_288_), .Y(_309_) );
    INVX1_330_( .A(_289_), .Y(_310_) );
    INVX1_331_( .A(_290_), .Y(_311_) );
    INVX1_332_( .A(_291_), .Y(_312_) );
    INVX1_333_( .A(_292_), .Y(_313_) );
    INVX1_334_( .A(_293_), .Y(_314_) );
    INVX1_335_( .A(_294_), .Y(_315_) );
    INVX1_336_( .A(_295_), .Y(_316_) );
    INVX1_337_( .A(_296_), .Y(_317_) );
    INVX1_338_( .A(_297_), .Y(_318_) );
    INVX1_339_( .A(_298_), .Y(_319_) );
    INVX1_340_( .A(_299_), .Y(_320_) );
    INVX1_341_( .A(_300_), .Y(_321_) );
    INVX1_342_( .A(_301_), .Y(_322_) );
    INVX1_343_( .A(_302_), .Y(_323_) );
    INVX1_344_( .A(_303_), .Y(_324_) );
    INVX1_345_( .A(_304_), .Y(_325_) );
    INVX1_346_( .A(_305_), .Y(_326_) );
    INVX1_347_( .A(_306_), .Y(_327_) );
    INVX1_348_( .A(_307_), .Y(_328_) );
    INVX1_349_( .A(_308_), .Y(_329_) );
    INVX1_350_( .A(_309_), .Y(_330_) );
    INVX1_351_( .A(_310_), .Y(_331_) );
    INVX1_352_( .A(_311_), .Y(_332_) );
    INVX1_353_( .A(_312_), .Y(_333_) );
    INVX1_354_( .A(_313_), .Y(_334_) );
    INVX1_355_( .A(_314_), .Y(_335_) );
    INVX1_356_( .A(_315_), .Y(_336_) );
    INVX1_357_( .A(_316_), .Y(_337_) );
    INVX1_358_( .A(_317_), .Y(_338_) );
    INVX1_359_( .A(_318_), .Y(_339_) );
    INVX1_360_( .A(_319_), .Y(_340_) );
    INVX1_361_( .A(_320_), .Y(_341_) );
    INVX1_362_( .A(_321_), .Y(_342_) );
    INVX1_363_( .A(_322_), .Y(_343_) );
    INVX1_364_( .A(_323_), .Y(_344_) );
    INVX1_365_( .A(_324_), .Y(_345_) );
    INVX1_366_( .A(_325_), .Y(_346_) );
    INVX1_367_( .A(_326_), .Y(_347_) );
    INVX1_368_( .A(_327_), .Y(_348_) );
    INVX1_369_( .A(_328_), .Y(_349_) );
    INVX1_370_( .A(_329_), .Y(_350_) );
    INVX1_371_( .A(_330_), .Y(_351_) );
    INVX1_372_( .A(_331_), .Y(_352_) );
    INVX1_373_( .A(_332_), .Y(_353_) );
    INVX1_374_( .A(_333_), .Y(_354_) );
    INVX1_375_( .A(_334_), .Y(_355_) );
    INVX1_376_( .A(_335_), .Y(_356_) );
    INVX1_377_( .A(_336_), .Y(_357_) );
    INVX1_378_( .A(_337_), .Y(_358_) );
    INVX1_379_( .A(_338_), .Y(_359_) );
    INVX1_380_( .A(_339_), .Y(_360_) );
    INVX1_381_( .A(_340_), .Y(_361_) );
    INVX1_382_( .A(_341_), .Y(_362_) );
    INVX1_383_( .A(_342_), .Y(_363_) );
    INVX1_384_( .A(_343_), .Y(_364_) );
    INVX1_385_( .A(_344_), .Y(_365_) );
    INVX1_386_( .A(_345_), .Y(_366_) );
    INVX1_387_( .A(_346_), .Y(_367_) );
    INVX1_388_( .A(_347_), .Y(_368_) );
    INVX1_389_( .A(_348_), .Y(_369_) );
    INVX1_390_( .A(_349_), .Y(_370_) );
    INVX1_391_( .A(_350_), .Y(_371_) );
    INVX1_392_( .A(_351_), .Y(_372_) );
    INVX1_393_( .A(_352_), .Y(_373_) );
    INVX1_394_( .A(_353_), .Y(_374_) );
    INVX1_395_( .A(_354_), .Y(_375_) );
    INVX1_396_( .A(_355_), .Y(_376_) );
    INVX1_397_( .A(_356_), .Y(_377_) );
    INVX1_398_( .A(_357_), .Y(_378_) );
    INVX1_399_( .A(_358_), .Y(_379_) );
    INVX1_400_( .A(_359_), .Y(_380_) );
    INVX1_401_( .A(_360_), .Y(_381_) );
    INVX1_402_( .A(_361_), .Y(_382_) );
    INVX1_403_( .A(_362_), .Y(_383_) );
    INVX1_404_( .A(_363_), .Y(_384_) );
    INVX1_405_( .A(_364_), .Y(_385_) );
    INVX1_406_( .A(_365_), .Y(_386_) );
    INVX1_407_( .A(_366_), .Y(_387_) );
    INVX1_408_( .A(_367_), .Y(_388_) );
    INVX1_409_( .A(_368_), .Y(_389_) );
    INVX1_410_( .A(_369_), .Y(_390_) );
    INVX1_411_( .A(_370_), .Y(_391_) );
    INVX1_412_( .A(_371_), .Y(_392_) );
    INVX1_413_( .A(_372_), .Y(_393_) );
    INVX1_414_( .A(_373_), .Y(_394_) );
    INVX1_415_( .A(_374_), .Y(_395_) );
    INVX1_416_( .A(_375_), .Y(_396_) );
    INVX1_417_( .A(_376_), .Y(_397_) );
    INVX1_418_( .A(_377_), .Y(_398_) );
    INVX1_419_( .A(_378_), .Y(_399_) );
    INVX1_420_( .A(_379_), .Y(_400_) );
    INVX1_421_( .A(_380_), .Y(_401_) );
    INVX1_422_( .A(_381_), .Y(_402_) );
    INVX1_423_( .A(_382_), .Y(_403_) );
    INVX1_424_( .A(_383_), .Y(_404_) );
    INVX1_425_( .A(_384_), .Y(_405_) );
    INVX1_426_( .A(_385_), .Y(_406_) );
    INVX1_427_( .A(_386_), .Y(_407_) );
    INVX1_428_( .A(_387_), .Y(_408_) );
    INVX1_429_( .A(_388_), .Y(_409_) );
    INVX1_430_( .A(_389_), .Y(_410_) );
    INVX1_431_( .A(_390_), .Y(_411_) );
    INVX1_432_( .A(_391_), .Y(_412_) );
    INVX1_433_( .A(_392_), .Y(_413_) );
    INVX1_434_( .A(_393_), .Y(_414_) );
    INVX1_435_( .A(_394_), .Y(_415_) );
    INVX1_436_( .A(_395_), .Y(_416_) );
    INVX1_437_( .A(_396_), .Y(_417_) );
    INVX1_438_( .A(_397_), .Y(_418_) );
    INVX1_439_( .A(_398_), .Y(_419_) );
    INVX1_440_( .A(_399_), .Y(_420_) );
    INVX1_441_( .A(_400_), .Y(_421_) );
    INVX1_442_( .A(_401_), .Y(_422_) );
    INVX1_443_( .A(_402_), .Y(_423_) );
    INVX1_444_( .A(_403_), .Y(_424_) );
    INVX1_445_( .A(_404_), .Y(_425_) );
    INVX1_446_( .A(_405_), .Y(_426_) );
    INVX1_447_( .A(_406_), .Y(_427_) );
    INVX1_448_( .A(_407_), .Y(_428_) );
    INVX1_449_( .A(_408_), .Y(_429_) );
    INVX1_450_( .A(_409_), .Y(_430_) );
    INVX1_451_( .A(_410_), .Y(_431_) );
    INVX1_452_( .A(_411_), .Y(_432_) );
    INVX1_453_( .A(_412_), .Y(_433_) );
    INVX1_454_( .A(_413_), .Y(_434_) );
    INVX1_455_( .A(_414_), .Y(_435_) );
    INVX1_456_( .A(_415_), .Y(_436_) );
    INVX1_457_( .A(_416_), .Y(_437_) );
    INVX1_458_( .A(_417_), .Y(_438_) );
    INVX1_459_( .A(_418_), .Y(_439_) );
    INVX1_460_( .A(_419_), .Y(_440_) );
    INVX1_461_( .A(_420_), .Y(_441_) );
    INVX1_462_( .A(_421_), .Y(_442_) );
    INVX1_463_( .A(_422_), .Y(_443_) );
    INVX1_464_( .A(_423_), .Y(_444_) );
    INVX1_465_( .A(_424_), .Y(_445_) );
    INVX1_466_( .A(_425_), .Y(_446_) );
    INVX1_467_( .A(_426_), .Y(_447_) );
    INVX1_468_( .A(_427_), .Y(_448_) );
    INVX1_469_( .A(_428_), .Y(_449_) );
    INVX1_470_( .A(_429_), .Y(_450_) );
    INVX1_471_( .A(_430_), .Y(_4
```

```

    .Y(_.17_)

);
NAND2X1_38_ (
    .A(Q_din[3] ),
    .B(shift),
    .Y(.18_)

);
OA121X1_39_ (
    .A(.15_),
    .B(shift),
    .C(.18_),
    .Y(.04_)

);
NAND2X1_40_ (
    .A(shift),
    .B(\BoundaryScanRegister_output__0__.sout ),
    .Y(.19_)

);
OA121X1_41_ (
    .A(.14_),
    .B(shift),
    .C(.19_),
    .Y(.05_)

);
NAND2X1_42_ (
    .A(shift),
    .B(\BoundaryScanRegister_output__1__.sout ),
    .Y(.20_)

);
OA121X1_43_ (
    .A(.13_),
    .B(shift),
    .C(.20_),
    .Y(.06_)

);
NAND2X1_44_ (
    .A(shift),
    .B(\BoundaryScanRegister_output__2__.sout ),
    .Y(.21_)

);
OA121X1_45_ (
    .A(.12_),
    .B(shift),
    .C(.21_),
    .Y(.07_)

);
NAND2X1_46_ (
    .A(tck),
    .B(test),
    .Y(.22_)

);
OA121X1_47_ (
    .A(.17_),
    .B(test),
    .C(.22_),
    .Y(\u00f4f__.clk_source__)

);
NAND2X1_48_ (
    .A(Q_din[1] ),
    .B(Q_din[8] ),
    .Y(.23_)

);
NAND2X1_49_ (
    .A(Q_din[2] ),
    .B(Q_din[1] ),
    .C(Q_din[8] ),
    .Y(.24_)

);
NAND2X1_50_ (
    .A(.00_),
    .B(.16_),
    .Y(.25_)

);
XNOR2X1_51_ (
    .A(.12_),
    .B(.24_),
    .Y(.26_)

);
OA122X1_52_ (
    .A(.13_),
    .B(.16_),
    .C(.25_),
    .D(.26_),
    .Y(.11_)

);
XNOR2X1_53_ (
    .A(.13_),
    .B(.23_),
    .Y(.27_)

);
OA122X1_54_ (
    .A(.14_),
    .B(.16_),
    .C(.25_),
    .D(.11_),
    .Y(.10_)

);
OA121X1_55_ (
    .A(Q_din[1] ),
    .B(.16_),
    .C(Q_din[8] ),
    .Y(.28_)

);
OA121X1_56_ (
    .A(.14_),
    .B(.15_),
    .C(.00_),
    .Y(.29_)

);
OA121X1_57_ (
    .A(.16_),
    .B(.29_),
    .C(.28_),
    .Y(.09_)

);
NAND2X1_58_ (
    .A(shift),
    .B(sin),
    .Y(.30_)

);
OA121X1_59_ (
    .A(Q_din[8] ),
    .B(.25_),
    .C(.36_),
    .Y(.08_)

);
INVX1_60_ (
    .A(rst),
    .Y(.01_)

);
INVX1_61_ (
    .A(rst),
    .Y(.02_)

);
INVX1_62_ (
    .A(rst),
    .Y(.03_)

);
DFFSR_63_ (
    .CLK(tck),
    .D(.07_),
    .Q(sout),

```

```

.R(.00_),
.S(1'b1)
);
DFFSR_64_( 
    .CLK(tck),
    .D(.06_),
    .Q(\BoundaryScanRegister_output_2_.sout ),
    .R(.01_),
    .S(1'b1)
);
DFFSR_65_( 
    .CLK(tck),
    .D(.05_),
    .Q(\BoundaryScanRegister_output_1_.sout ),
    .R(.02_),
    .S(1'b1)
);
DFFSR_66_( 
    .CLK(tck),
    .D(.04_),
    .Q(\BoundaryScanRegister_output_0_.sout ),
    .R(.03_),
    .S(1'b1)
);
DFPPOSX1 \uuf_14_ (
    .CLK(\uuf_.clk_source_),
    .D(.08_),
    .Q(\Q.din[0] )
);
DFPPOSX1 \uuf_15_ (
    .CLK(\uuf_.clk_source_),
    .D(.09_),
    .Q(\Q.din[1] )
);
DFPPOSX1 \uuf_16_ (
    .CLK(\uuf_.clk_source_),
    .D(.10_),
    .Q(\Q.din[2] )
);
DFPPOSX1 \uuf_17_ (
    .CLK(\uuf_.clk_source_),
    .D(.11_),
    .Q(\Q.din[3] )
);
assign Q = { \Q.din[3] , \Q.din[2] , \Q.din[1] , \Q.din[0] };
endmodule

```

## 6.2 Cut Scan Chain File (counter\_scan\_cut.v)

### File Structure:

- Flattened Sequential Elements:** Each flip-flop becomes separate input and output ports
- Purely Combinational:** No sequential feedback paths remain in the netlist
- Port Naming:** Systematic naming like ff\_0\_D, ff\_0\_Q, ff\_1\_D, ff\_1\_Q, etc.
- Logic Preservation:** Combinational cone between ports unchanged

### Purpose:

Allows ATPG to treat the design as combinational logic, where flip-flop inputs and outputs are directly controllable and observable. Simplifies test generation by removing state dependencies.

## 6.3 Test Pattern File (patterns.tv.json)

### Key Fields:

- vectors:** Array of test patterns, each with input stimulus and expected output response
- inputs:** Values to apply to all primary inputs and scan chain
- outputs:** Expected values at outputs (X means don't care)
- metadata:** Summary statistics about the test set

## 6.4 Coverage Metadata File (`coverage.yml`)

### Key Information:

- **Overall Coverage:** Total, detected, and undetected fault counts with percentage
- **Per-Fault Status:** Lists every fault site with detection status and detecting vector ID
- **Undetected Reason:** Explains why faults couldn't be detected (redundant, inaccessible, etc.)
- **Gate-Level Breakdown:** Coverage percentage for each gate type
- **Vector Efficiency:** Number of faults detected by each test vector

## 6.5 Supporting Files

- **counter\_scan1.v+attrs:** Attribute metadata about scan chain configuration
- **counter\_scan1.v.chain-intermediate.v:** Intermediate representation during chaining
- **patterns.raw\_tv.json:** Uncompacted test vectors (100 vectors before optimization)
- **parser.out:** Parser debug information from Verilog processing
- **parsetab.py:** Python parsing table cache for faster subsequent runs

## 7. Results Summary and Analysis

### 7.1 Achieved Results

#### Design for Test Implementation:

- Successfully inserted scan chain of length **8** (4 internal + 4 boundary cells)
- Design remains functionally equivalent to original in normal mode
- 100% controllability and observability of all sequential elements

#### Test Pattern Generation:

- **86% fault coverage achieved**
- **Only 7 test vectors required** after 93% compaction from 100 original vectors
- **125 fault sites analyzed** across 32 gates
- **107 faults detected**, 18 remain undetected

### 7.2 Performance Metrics

| Metric                 | Value                             |
|------------------------|-----------------------------------|
| Total Fault Sites      | 125                               |
| Detected Faults        | 107                               |
| Fault Coverage         | 86.0%                             |
| Scan Chain Length      | 8 cells (4 internal + 4 boundary) |
| Original Test Vectors  | 100                               |
| Compacted Test Vectors | 7                                 |
| Compaction Ratio       | 93.0%                             |
| ATPG Runtime           | 1.59 seconds                      |

*The workflow presented in this report represents the standard methodology used in semiconductor manufacturing for ensuring chip quality and reducing production costs. The ability to detect 86% of faults with only 5 test vectors demonstrates the power of modern DFT techniques and ATPG algorithms.*