

# Lab\_DFT\_1

You have to synthesize and insert DFT logic using **DFT Compiler shell** and generate Technology Dependent gate level netlists in Verilog format using standard cell libraries (typical, worst, best) inside **std\_cells** folder:-

- scmetro\_tsmc\_cl013g\_rvt\_tt\_1p2v\_25c.db
- scmetro\_tsmc\_cl013g\_rvt\_ff\_1p32v\_m40c
- scmetro\_tsmc\_cl013g\_rvt\_ss\_1p08v\_125c

## Steps: -

1. Copy **Lab\_DFT\_1** folder from your computer into the virtual machine inside **Labs** directory
2. Perform RTL preparation
  - Add scan ports (SI, SE, SO, test\_mode, scan\_clk, scan\_RST)
  - Instantiate mux2X1 module for clocks
  - Instantiate mux2X1 module for resets
  - Connect muxed clk and muxed rst to the Instantiated modules
3. Open **dft\_script.tcl** and Read the verilog module “mux2X1”.
4. Run **dft\_script.tcl** using (**dc\_shell -f dft\_script.tcl | tee dft.log**) to check that the instantiated file is consistent with the RTL files (**No Errors, No Warnings**)
5. Open **dft\_script.tcl** and Add the following commands: -
  - Configuring scan chain style using **set\_scan\_configuration** command
  - Test-Ready Compile using **compile -scan** command
  - Defining the DFT Signals (SI, SE, SO, test\_mode, scan\_clk, scan\_RST ) using **set\_dft\_signal** command
  - Create Test Protocol using **create\_test\_protocol** command
  - Preform Pre-DFT Design Rule Checking using **dft\_drc -verbose** command
  - Preview DFT using **preview\_dft -show scan\_summary** command
  - Insert DFT logic using **insert\_dft** command
  - Optimize Post DFT Insertion using **compile -scan -incremental** command
  - Preform Post-DFT Design Rule Checking using **dft\_drc -verbose - coverage\_estimate** command

6. Run dft\_script.tcl inside **Lab\_DFT\_1** & check the log (dft.log) to be sure that: -

- No Errors
- No Warnings
- No Latches
- No Comb Loops

7. Check DFT Test Coverage.

8. Open Design Compiler GUI, View the DFT Scan chain.