

## Miniproject 2

This report presents the design, simulation, and verification of a rising-edge triggered Complementary Set-Reset Logic (CSRL) D flip-flop and its integration into a four-bit shift register. It includes transistor-level schematics, Xschem transient simulations across all process corners (TT, FF, SS, FS, SF), and Magic layouts verified through DRC and LVS. The attached GitHub repository contains all schematic files, circuit symbols, layout cells, simulation test benches, and extracted netlists used for the project. Key screenshots throughout the project are displayed in the report.

Github Repository Link:

<https://github.com/Ahan-Trivedi2/Mixed-Analog-Digital-VLSI/tree/main/Miniproject2>

---

### Schematic Capture and Simulation

#### D flip-flop transistor level schematic:





## Simulation test harness:



\*In this picture, the TT\_models from the MADVLSI library were used. I simply swapped out the transistor model type, but used the same test harness.

## Plots for transient simulations from TT, FF, SS, FS, and SF corner models:

TT



FF



SS



FS



SF



# Layout Design

## Dimensions of D flip-flop layout:

Width: 3.650 micron

Height: 15.250 micron

## D flip-flop layout:



**Dimensions of shift register layout:**

Width: 16.550 micron

Height: 15.250 micron

**Shift register layout:**



## Layout Versus Schematic

### Terminal Output from LVS:

```
madvlsi@madvlsi-ubuntu-usb:~/Documents/Miniproject2/magic$ lvs FBSR.spice
FBSR_xschem.spice FBSR
Netgen 1.5.299 compiled on Sat Sep 6 02:50:48 PM EDT 2025
Warning: netgen command 'format' use fully-qualified name '::netgen::format'
Warning: netgen command 'global' use fully-qualified name '::netgen::global'
Reading netlist file FBSR.spice
Call to undefined subcircuit sky130_fd_pr_pfet_01v8
Creating placeholder cell definition.
Call to undefined subcircuit sky130_fd_pr_nfet_01v8
Creating placeholder cell definition.
Reading netlist file FBSR_xschem.spice
Call to undefined subcircuit CSRL_D_FF
Creating placeholder cell definition.
Call to undefined subcircuit inverter
Creating placeholder cell definition.
Call to undefined subcircuit sky130_fd_pr_pfet_01v8
Creating placeholder cell definition.
Call to undefined subcircuit sky130_fd_pr_nfet_01v8
Creating placeholder cell definition.
```

Reading setup file /usr/local/share/pdk/sky130A/libs.tech/netgen/sky130A\_setup.tcl

```
Model sky130_fd_pr_nfet_01v8 pin 1 == 3
No property mult found for device sky130_fd_pr_nfet_01v8
No property sa found for device sky130_fd_pr_nfet_01v8
No property sb found for device sky130_fd_pr_nfet_01v8
No property sd found for device sky130_fd_pr_nfet_01v8
No property nf found for device sky130_fd_pr_nfet_01v8
No property nrd found for device sky130_fd_pr_nfet_01v8
No property nrs found for device sky130_fd_pr_nfet_01v8
No property area found for device sky130_fd_pr_nfet_01v8
No property perim found for device sky130_fd_pr_nfet_01v8
No property topography found for device sky130_fd_pr_nfet_01v8
Model sky130_fd_pr_nfet_01v8 pin 1 == 3
No property area found for device sky130_fd_pr_nfet_01v8
No property perim found for device sky130_fd_pr_nfet_01v8
No property topography found for device sky130_fd_pr_nfet_01v8
Model sky130_fd_pr_pfet_01v8 pin 1 == 3
No property mult found for device sky130_fd_pr_pfet_01v8
No property sa found for device sky130_fd_pr_pfet_01v8
```

```
No property sb found for device sky130_fd_pr_pfet_01v8
No property sd found for device sky130_fd_pr_pfet_01v8
No property nf found for device sky130_fd_pr_pfet_01v8
No property nrd found for device sky130_fd_pr_pfet_01v8
No property nrs found for device sky130_fd_pr_pfet_01v8
No property area found for device sky130_fd_pr_pfet_01v8
No property perim found for device sky130_fd_pr_pfet_01v8
No property topography found for device sky130_fd_pr_pfet_01v8
Model sky130_fd_pr_pfet_01v8 pin 1 == 3
No property area found for device sky130_fd_pr_pfet_01v8
No property perim found for device sky130_fd_pr_pfet_01v8
No property topography found for device sky130_fd_pr_pfet_01v8
Comparison output logged to file comp.out
Logging to file "comp.out" enabled
Circuit sky130_fd_pr_pfet_01v8 contains no devices.
Circuit sky130_fd_pr_nfet_01v8 contains no devices.
```

```
Contents of circuit 1: Circuit: 'FBSR'
Circuit FBSR contains 66 device instances.
  Class: sky130_fd_pr_nfet_01v8 instances: 33
  Class: sky130_fd_pr_pfet_01v8 instances: 33
Circuit contains 37 nets.
Contents of circuit 2: Circuit: 'FBSR'
Circuit FBSR contains 66 device instances.
  Class: sky130_fd_pr_nfet_01v8 instances: 33
  Class: sky130_fd_pr_pfet_01v8 instances: 33
Circuit contains 37 nets.

Circuit 1 contains 66 devices, Circuit 2 contains 66 devices.
Circuit 1 contains 37 nets, Circuit 2 contains 37 nets.
```

```
Final result:
Circuits match uniquely.

.
Logging to file "comp.out" disabled
LVS Done.
madvlsi@madvlsi-ubuntu-usb:~/Documents/Miniproject2/magic$
```