# MADVLSI MP3 Report 

Kenta Burpee

October 2023

## 1 Introduction

The goal of this project was to design a folded-cascode differential amplifier and its associated bias circuit using Xschem, Magic and Skywater Technology's sky130 PDK.


Figure 1: Basic schematic of a folded-cascode differential amplifier.

### 1.1 Design Files

The design files for this project can be found here: https://github.com/kburp/folded-cascode-diffamp-vlsi

## 2 Circuit Analysis

a) Which input voltage is the non-inverting input? Which is the inverting input?
$I_{\text {out }}=I_{6}-I_{10}$ by KCL
$I_{10}=I_{9}$ because of the low-voltage current mirror
$I_{\text {out }}=I_{6}-I_{9}$ by substitution
$I_{6}=I_{b}-I_{2}$ and $I_{9}=I_{b}-I_{1}$ by KCL
$I_{o u t}=I_{b}-I_{2}-\left(I_{b}-I_{1}\right)$ by substitution
$I_{\text {out }}=I_{1}-I_{2}$
$I_{1}$ and $I_{2}$ are dependent on $V_{1}$ and $V_{2}$ respectively
Therefore, $V_{1}$ is the non-inverting input and $V_{2}$ is the inverting input

## b) What is the allowable common-mode input voltage range of this circuit?

For a common-mode voltage input, we assume $V_{1}=V_{2}=V_{c m}$. Under this condition, since $M_{1}$ and $M_{2}$ share a common gate and source and $I_{1}+I_{2}=I_{b}$ by KCL, the differential pair comprised of $M_{1}, M_{2}$, and $M_{b}$ can be collapsed into an equivalent source follower $M_{s f}$ and $M_{b}$ where the two transistors have the same channel current $I_{b}$. $M_{s f}$ has gate voltage $V_{c m}, M_{b}$ has gate voltage $V_{b n}$, and the two transistors have a common source/drain voltage $V$. Since $M_{b}$ has to be saturated in order to maintain a constant channel current, $M_{s f}$ must also be saturated because it has the same current through it and the transistors are matching. Using the EKV model, the current through each transistor is:

$$
\begin{aligned}
& M_{s f} \Rightarrow I_{b}=S I_{s} \log ^{2}\left(1+e^{\kappa\left(\left(V_{c m}-V_{T 0}\right)-V\right) / 2 U_{T}}\right) \\
& M_{b} \Rightarrow I_{b}=S I_{s} \log ^{2}\left(1+e^{\kappa\left(V_{b n}-V_{T 0}\right) / 2 U_{T}}\right)
\end{aligned}
$$

Setting the two currents equal to each other and simplifying results in

$$
\begin{aligned}
& \kappa \cdot V_{c m}-V=\kappa \cdot V_{b n} \\
& V=\kappa\left(V_{c m}-V_{b n}\right)
\end{aligned}
$$

To keep $M_{b}$ in saturation, $V \geq V_{D S s a t}$, so

$$
\begin{aligned}
& \kappa\left(V_{c m}-V_{b n}\right) \geq V_{D S s a t} \\
& V_{c m} \geq V_{b n}+\frac{V_{D S s a t}}{\kappa}
\end{aligned}
$$

The upper bound of $V_{c m}$ is $V_{D D}$.
c) If the output voltage were fixed by a voltage source somewhere in the middle of the rails, what would be the output current in terms of I1 and I2 if the Early effect were negligible?

See answer to question A for derivation.
d) Do we need to make the bias current sourced by M3 and M4 equal to the diff pair bias current, $I_{b}$ ?
$I_{3}$ and $I_{4}$ should be equal to $I_{b}$. With a large differential mode input to the circuit, $I_{1} \gg I_{2}$ or $I_{1} \ll I_{2}$, and the larger of the currents will approximately equal $I_{b}$ by KCL. If $I_{3}$ and $I_{4}$ are smaller than $I_{b}, I_{b}$ becomes limited by $I_{3}$ or $I_{4}$ and $M_{b}$ can no longer be in saturation. If $I_{3}$ and $I_{4}$ are larger than $I_{b}$, this results in excess power dissipation. Since $I_{\text {out }}$ only depends on $I_{1}$ and $I_{2}$, the current $I_{3}$ and $I_{4}$ excess of $I_{b}$ will be sunk into ground, resulting in the circuit using more power than it requires.
e) Design a bias circuit for the folded-cascode amplifier that receives input from a single current source, $I_{b}$, and generates cascode bias voltages, $V_{c n}$ and $V_{c p}$, optimally for a given bias current $I_{b}$ so as to maximize the output voltage swing of the amplifier. Your circuit must also generate the other bias voltages, $V_{b n}$ and $V_{b p}$, so that $I_{3}=I_{4}=I_{b}$.

My bias circuit is equivalent to twelve transistors shown in the schematic below. The circuit can be broken into two main parts. The left half uses $V_{b n}$, generated by a diode-connected nMOS transistor with $I_{b}$ fed into it (not shown in this schematic), and generates $V_{c p}$. The right half uses $V_{b n}$ to generate $V_{b p}$ and $V_{c n}$. $M_{1}$ through $M_{5}$ is the same circuit as $M_{6}$ through $M_{10}$, except the pMOS and nMOS transistors are switched.


Figure 2: Basic schematic of the bias circuit.
The goal of the bias circuit is to generate four bias voltages such that each one keeps the transistors in the main amplifier in saturation. Taking the right side of the circuit as an example, Since $M_{11}$ is diodeconnected, it is in saturation, so a current mirror composed of $M_{11}$ and another pMOS transistor produces a saturation current on the output. From this, we know that a pMOS transistor with its source at $V_{D D}$ and its gate at $V_{b p}$ will be saturated, so $V_{b p}$ is a sufficient bias voltage for $M_{3}$ and $M_{4}$ in the main part of the amplifier.

Continuing analysis on the right side of the bias circuit, we know that $M_{3}$ is saturated because it is diodeconnected, but $M_{5}$ could be operating in the ohmic region. If $M_{3}$ and $M_{5}$ have multiplicities $m_{3}$ and 1 respectively, their gate voltage is $V_{G}$, and their common source/drain voltage is $V$, their currents can are given by

$$
\begin{aligned}
& I_{3}=I_{1}=m_{3} I_{s} f\left(V_{G}, V\right) \\
& I_{5}=I_{1}+I_{2}=I_{s}\left(f\left(V_{G}, 0\right)-f\left(V_{G}, V\right)\right) \\
& I_{1}+I_{2}+\frac{I_{1}}{m_{3}}=I_{s} f\left(V_{G}, 0\right)
\end{aligned}
$$

Using this, the saturation index (ratio of forward and reverse current) of $M_{5}$ is given by

$$
\frac{I_{F}}{I_{R}}=\frac{f\left(V_{G}, 0\right)}{f\left(V_{G}, V\right)}=\frac{I_{1}+I_{2}+\left(I_{1} / m_{3}\right)}{I_{1} / m_{3}}=\frac{m_{3} I_{2}}{I_{1}}+m_{3}+1
$$

We want $M_{5}$ to be in saturation becuase this would guarantee that $V$, which is used to generate $V_{c n}$, would be greater than or equal to $V_{D S s a t}$, making a transistor with drain voltage $V$ and its source at ground saturated. Since $V_{c n}$ is a cascoded bias voltage, we want to generate a gate voltage that can put an nMOS transistor whose source is at $V_{D S s a t}$ in saturation. Putting a diode-connected transistor $M_{4}$ in the circuit with gate voltage $V_{c n}$ and source voltage $V$ accomplishes this. If the saturation index of $M_{5}$ is in the range of 20 to 30 , we can say that $M_{5}$ will be saturated. If we let the current ratio $\frac{I_{2}}{I_{1}}=n$, the saturation index becomes

$$
20 \leq m_{3} \cdot n+m_{3}+1 \leq 30
$$

To make the number of transistors in the layout match nicely, we can let $n=m_{3}+2$. Making $m_{3}$ an even number also optimizes the layout, so solving the equation, we find that $m_{3}=4$ and $n=6$ is a solution. $m_{3}$ can be implemented by making the multiplicity of $M_{3}$ equal to 4 and $M_{5}$ equal to 1 , and $n$ can be implemented by making the multiplicity of $M_{1}$ equal to $\frac{1}{6}$ and $M_{2}$ equal to 1 .

A similar analysis of the left side of the circuit yields the same multiplicities for the complementary circuit.

## 3 Schematic Capture and Simulation

After creating the basic schematics, the next step is to turn them into layout-driven schematics that can be referenced during the layout process. The layout-driven schematics of both the main part of the amplifier and the bias circuit create common centroids for matching transistors by splitting each transistor into multiple transistors that are less wide. The outside edges of the circuit also contain dummy devices to maintain the same surroundings for all of the active transistors.

### 3.1 Layout-Driven Schematics



Figure 3: Layout-driven schematic of the main part of the amplifier. The top two rows of transistors have a width of $6 \mu \mathrm{~m}$ and the bottom two rows of transistors have a width of $3 \mu \mathrm{~m}$.


Figure 4: Layout-driven schematic of the bias circuit. All of the transistors have a width of $6 \mu \mathrm{~m}$.

### 3.2 Voltage Transfer Characteristics



Figure 5: Schematic of VTC test harness.

Folded Cascode Differential Amplifier VTC


Figure 6: The amplifier's VTC for five different values of the inverting input. The slope of the curves is the DC gain of the amplifier.

The DC gain of the circuit, found from the slope of the VTC, is around 1020.

### 3.3 Voltage-to-Current Transfer Characteristics



Figure 7: Schematic of IV characteristic test harness.

Folded Cascode Differential Amplifier IV Characteristic


Figure 8: IV characteristic of the folded-cascode differential amplifier when the inverting input is held at 1 V and the output is held at 0.9 V . The slope of the curve is the incremental transconductance gain of the circuit.

From the slope of the voltage-to-current transfer characteristic, the incremental transconductance gain of the circuit is $1.03 \mathrm{e}-5$ mhos. The limiting values of the output current are $1.06 \mu \mathrm{~A}$ at $V_{D D}$ and $-0.950 \mu \mathrm{~A}$ at ground.

### 3.4 Loopgain



Figure 9: Schematic of loopgain test harness.

Folded Cascode Differential Amplifier Loopgain


Figure 10: Magnitude and phase of the loopgain of the amplifier. The loopgain was found using Ochoa's Z method, which involves performing AC simulations with two voltage sources and calculating the ratio between the current in each voltage source due to the other voltage source and the current through each voltage source due to itself.

The low-frequency gain is 63.581 dB , which is equal to 1510 . This is greater than the DC gain calculated from the VTC. The unity-gain crossover frequency is 1.78 MHz . Using the load capacitance of 2 pF and incremental transconductance gain of $1.03 \mathrm{e}-5$, the expected unity-gain crossover frequency is $\frac{G m}{2 \pi C}=819 \mathrm{kHz}$.

### 3.5 Unity-Gain Follower Frequency Response



Figure 11: Schematic of frequency response test harness.


Figure 12: Unity-gain frequency response of the amplifier found by performing an AC sweep.

The corner frequency of the circuit is 447 kHz . This is lower than the measured unity-gain crossover frequency of the loopgain by about a factor of 4 .

## 4 Layout Design



Figure 13: Layout of the main part of the amplifier designed in Magic. The output voltage is available at the top right of the circuit in the local interconnect layer, and the differential pair inputs are also available on the right side in the polysilicon layer.


Figure 14: Layout of the bias circuit designed in Magic. The four bias voltages are available as outputs on the polysilicon layer on the rights side of the circuit.


Figure 15: Full layout of the folded-cascode differential amplifier and its bias circuit.

## 5 Layout Versus Schematic

A layout versus schematic comparison using Netgen shows that the layout and schematic SPICE netlists match.

```
Circuit 1 cell sky130_fd_pr__pfet_01v8 and Circuit 2 cell sky130_fd_pr__pfet_01v8 are black boxes.
Equate elements: no current cell.
Device classes sky130_fd_pr__pfet_01v8 and sky130_fd_pr__pfet_01v8 are equivalent.
Circuit 1 cell sky130_fd_pr__nfet_01v8 and Circuit 2 cell sky130_fd_pr__nfet_01v8 are black boxes.
Equate elements: no current cell.
Device classes sky130_fd_pr__nfet_01v8 and sky130_fd_pr__nfet_01v8 are equivalent.
Flattening unmatched subcell biasgen_lds in circuit fc_diffamp_full_xschem.spice (0)(1 instance)
Flattening unmatched subcell fc_diffamp_lds in circuit fc_diffamp_full_xschem.spice (0)(1 instance)
Flattening unmatched subcell biasgen in circuit full_fc_diffamp.spice (1)(1 instance)
Flattening unmatched subcell fc_diffamp in circuit full_fc_diffamp.spice (1)(1 instance)
Class fc_diffamp_full_xschem.spice (0): Merged 46 parallel devices.
Class full_fc_diffamp.spice (1): Merged 46 parallel devices.
Subcircuit summary:
Circuit 1: fc_diffamp_full_xschem.spice |Circuit 2: full_fc_diffamp.spice
-----------------------------------------|-------------------------------------------------
sky130_fd_pr__pfet_01v8 (42->24) |sky130_fd_pr__pfet_01v8 (42->24)
sky130_fd_pr__nfet_01v8 (62->34) |sky130_fd_pr__nfet_01v8 (62->34)
Number of devices: 58 |Number of devices: 58
Number of nets: 41 |Number of nets: 41
```

Resolving symmetries by property value.
Resolving symmetries by pin name.
Netlists match with 28 symmetries.
Cells have no pins; pin matching not needed.
Device classes fc_diffamp_full_xschem.spice and full_fc_diffamp.spice are equivalent.

Final result: Circuits match uniquely.

