# Scalable PLL design

Dimitri Galayko, LIP6, Sorbonne Université dimitri.galayko@sorbonne-universite.fr

August 2022

## 1 PLL architecture

The PLL architecture is given on fig. 1. This is a PLL of type 3 containing three pure integrators in the open loop (capacitors  $C_1$  and  $C_2$  and the VCO).

The linear model of the PLL in the phase domain is given in fig. 2.

The VCO is a voltage-controlled oscillator. The frequency divider by N can be incorporated into the VCO if the frequencies are scaled by N, yielding the equivalent structure shown in the green frame in fig. 1. The useful output of the PLL is somewhere between the output of the real VCO (labeled  $f_{ref} \times N$  in the figure) and the output of the divider. For instance, is a divider is a cascade of dividers such as  $N = N1 \cdot N2 \cdot N3$ , the output of the PLL can be the output of any of the cascades yielding frequencies differently related to  $f_{ref}$ .



Figure 1: Structure of the designed PLL



Figure 2: Linear model of the designed PLL

The open loop transfer function in the phase domain between the input (reference signal) and the output of the divider is given by:

$$H(p) = K_{pfd} \frac{1}{\frac{1}{pC_1} + R} + pC_2 \frac{G_{vco}}{p}$$
(1)

Here

$$G_{vco} = 2\pi K_{vco}/N,\tag{2}$$

is the gain of VCO in  $rad \cdot Hz/V$ , where  $K_{VCO}$  is the gain of the physical VCO, in Hz/V.

The closed loop transfer function is

$$K(p) = \frac{H(p)}{1 + H(p)} = \frac{K_{pfd}G_{VCO}(1 + C_1pR)}{K_{pfd}G_{vco} + (C_1 + C_2)p^2 + C_1K_{pfd}G_{vco}pR + C_1C_2p^3R}$$
(3)

A PLL is a closed-loop regulation system. The input of a PLL is the phase of the reference clock signal, the output is the phase of the signal issued from the divider and generated by the VCO. Since the frequency of the source is constant, the input phase evolves linearly:

$$\phi_{ref} = \int 2\pi f_{ref} dt = 2\pi f_{ref} t + \phi_0 \tag{4}$$

The VCO, after a divider, must produce the same phase. The error is measured by the phase-frequency detector (PFD), and the output voltage of the PFD is proportional to the phase error. The loop filter (regulator) generates a command for the VCO so to adjust its phase. The input voltage



Figure 3: Influence of the capacitor  $C_2$  on the frequency characteristics of the PLL: a) Open loop, b) Closed loop.

of the VCO controls the frequency of the VCO, and hence, its phase, since the phase and the frequency are in a differential-integral relation.

A proportional-integral (PI) corrector is the most used solutions for the PLLs.

When  $C_2 = 0$ , the network  $R_1C_1$  implements a PI filter for the current generated by the charge pump. Indeed,

$$V_{out\ cp} = I_{out\ cp} \left( \frac{1}{C_1 p} + R \right) \tag{5}$$

Here  $I_{out\ cp}$  is the average output current of the charge pump. The current of the charge pump can take only three values  $(+I_0, -I_0 \text{ and } 0)$ . However, the information about the phase error is coded by the combination "Phase-Frequency Detector and Charge Pump" with PWM (Pulse Width Modulation).

In order to improve the reduction of the noise at high frequencies, a capacitor  $C_2$  is added. It should be much smaller than the capacitor  $C_1$ , otherwise its impedance will dominate the impedance of the network  $C_1R_1$  and the loop filter will be only an integrator, yielding an unstable (undamped) loop. Fig. 3 explains the modification of the open and closed loop characteristic brought by  $C_2$ .

As show these plots, without  $C_2$  ( $C_2 = 0$ ) the closed loop characteristics is a low pass filter. When  $C_2$  is added and when its value is low comparing to  $C_1$ , the passband is not affected, but in the rejection band at high frequencies the slope is -40 dB/decade instead of -20 dB/decade. If  $C_2$  is too large ( $C_2 = C_1$ ), the stability of the loop is strongly degraded.

## 2 Design of a PLL

In this document, a choice is made to fix the input specifications of the PLL in the following way:

- 1. The division coefficient N is fixed by the user
- 2. The nominal working frequency is fixed by the user. We advise to fix the nominal output frequency to be in the middle of the range of the used VCO. The nominal working frequency is defined by the input reference applied to the PFD. The corresponding output frequency depends on the division factor of the divider.
- 3. The PLL is designed to work for the nominal frequency. If the PLL needs to work for a range of the frequency, it is up to the user to check the operation of the designed PLL for all frequency range. The developed scripts perform this check for the full frequency range of the used VCO. A satisfactory operation of the same PLL in a range of frequencies requires a compromise (e.g., different dynamic behaviour at different frequencies). This compromise should be done by the user, especially if he has specific needs.
- 4. This generator is designed for a divider with a division factor 24, having intermediate outputs div2, div4, div8. That yieds a grid of output frequencies  $F_{ref} \times \{2, 4, 8, 24\}$
- 5. The user may adjust the trend between the the value of the filter capacitors and the current of the charge pump. Since the integrated capacitors may have only limited values (few pF, max. few tens of pF depending on the technology), it may be interesting to reduce the current of the charge pump  $I_0$ , that will yield a reduced value of  $C_1$  and  $C_2$ . However, it will lead to a greater value of R. As a consequence, a compromise is required here, and the last decision is up to the user. Recommended values of  $I_0$  is between 1 and 10  $\mu$ m.

After performing the design for one selected frequency, the user will have to verify that for other frequencies (corresponding to different VCO gains and hence to different dynamic parameters of the PLL) the dynamic behaviour of the PLL is satisfactory. The dynamic behaviour is mostly defined by the phase margin.

We present now the sequence of step leading to the PLL design.

Step 1. The design of a PLL starts with the design of a VCO, since the output frequency range is the main specification of a PLL. Also, VCO is the most difficult block to design. The choice of the VCO architecture is dictated by several factors related to the purpose of the PLL, to the specification regarding the frequency range and the noise and to the available technology. The solution based on ring CMOS oscillators is the most simple and is often used in the clocking applications. In this project we use the current-starved VCO. However, this PLL design procedure is compatible with any architecture of the VCO.

The VCO is characterised by the characteristic "output frequency versus control voltage". An example of such a characteristic is given in fig. 8a. The derivative of this characteristic provides the link between the VCO gain and the control voltage, yielding a parametric plot "VCO gain versus output frequency", see an example on fig. 8b.

Step 2. Choice of the PLL natural frequency.

The natural frequency of the PLL  $\omega_n$  defines the bandwidth of the PLL in the phase domain (see an example of fig. 3b). This frequency defines the time duration needed for the PLL to lock, which is of order of  $2\pi/\omega_n$ .

For the designed PLL, the natural frequency is given by

$$\omega_n = \sqrt{\frac{K_{pfd}G_{vco}}{C_1}},\tag{6}$$

where  $K_{pfd}$  is the gain of the phase-frequency detector and  $G_{VCO}$  is the effective gain of the VCO accounting for the frequency division and measured in  $rad \cdot Hz/V$ :

$$G_{VCO} = 2\pi K_{vco} \cdot \frac{1}{N} \tag{7}$$

The gain of VCO  $K_{vco}$ , in Hz/V, is obtained from the "gain-frequency" characteristic of the VCO designed in the step 1, see fig. 8b.

The phase frequency detector gain is given by:

$$K_{PFD} = \frac{I_0}{\pi} \tag{8}$$

where  $I_0$  is the current generated by the charge pump.

In order to filter out the PWM noise of the phase-frequency detector, the natural frequency should be at least 10 times less than the reference frequency (the frequency received by the PFD in the lock-in state). Hence, we have

$$\omega_{n max} = 2\pi f_{ref}/10 \tag{9}$$

In order to fix  $\omega_n$ , two free independent design parameters are present in (6):  $I_0$  (through  $K_{PFD}$ ) and  $C_1$ .

We recommend to set  $I_0$ , since it defines the power consumption of the PLL. So,  $I_0$  is an independent input design parameter. Hence,  $C_{1 min}$  is automatically obtained with

$$C_{1 min} = \frac{I_0 G_{vco}}{\pi \omega_{n max}^2} \tag{10}$$

We recommend to set  $C_1$  to  $C_{1 min}$ , but a larger value may be chosen by the user.

#### Step 3. Choice of the filter parameters.

We first design the dynamic response of the filter in the passband of the PLL. For that we set  $C_2 = 0$  and we choose the remaining parameter, the value of the resistance R. The open loop characteristic is now given by

$$H(p) = K_{pfd} \left( \frac{1}{pC_1} + R \right) \frac{G_{vco}}{p} = \frac{\omega_n^2}{p} \left( \frac{1}{p} + \frac{2\gamma}{\omega_n} \right)$$
 (11)

where  $\gamma$  is the damping factor of the second-order system.

The input design parameter in this step is the desired phase margin of the PLL open loop response.  $PM_{target} = 60$  value is a usual target, since it ensures the fastest transient response. However, at this stage we need to set the phase margin a little bit above the wanted value, since the capacitor  $C_2$  will degrade the stability. Hence, we suggest to add 10° to the target phase margin, setting it to 70°. That corresponds to the damping factor  $\gamma = 0.9$ , according to the formula valid for the system with the open loop function give by (11).

$$phase \ margin = \tan^{-1} \frac{2\gamma}{\sqrt{-2\gamma^2 + \sqrt{4\gamma^4 + 1}}}$$
 (12)

After  $\gamma$  is set, the resistance value is derived:

$$R = \frac{2\gamma}{\omega_n} \tag{13}$$

After fixing R, we can choose the value of  $C_2$ . We will find a maximum value of  $C_2$  degrading the phase margin to the wanted value  $PM_{target}$ .

Since the open loop function is now a third order function, we suggest to find  $C_2$  numerically, for instance, by trying for  $C_2$  100 values from 0 to  $C_1$ , or by using any other numeric method of algebraic equation solving.

**Step 4.** CMOS implementation of the filter. That is explained in the next section.

#### **Setp 5.** Validation of the PLL.

The dynamics of the PLL depends on the differential gain of the VCO and on the capacitances of the loop filter. Both of these parameters are function of the voltage  $V_c$  at the input of the VCO, whose nominal (average steady-state in locked PLL) defines the output frequency. Since there is a bijective relation between  $V_c$  and the output frequency of the VCO  $f_{vco}$ , we can speak about the dependence of the VCO gain and of the filter capacitors at the output frequency.

In order to identify the frequency range in which the PLL has an acceptable dynamics (the phase margin and the natural frequency), we recommend to calculate these characteristics for the range of  $V_c$  voltages going from 0 to VDD.

# 3 CMOS implementation of the loop filter

If the used technology offers capacitors, the implementation is straightforward. If not, the capacitors may be implemented with gates of MOS transistors. This section describes implementation of CMOS capacitors of large values.

The greatest capacitance of the MOS transistor is that between the gate and the channel. The drawback of the MOS capacitance is its nonlinearity. Namely, it is much greater in the strong invertion mode than in the subthreshold mode. Consider a nMOS transistor connected as shown in fig. 4a. Here the equivalent capacitor is between the gate and the ground. In the PLL application, we are mainly interested by the small-signal (differential) capacitance, which is given by the simulator after a DC operating point analysis. This parameter is named  $C_{qq}$ .

The maximum value of this capacitance can be estimated as

$$C_{gg\ max} = \epsilon_0 W L / t_{ox},\tag{14}$$

where  $t_{ox}$  is the effective thickness of the gate dielectric, W and L are width and length of the transistor, respectively. A typical relation between the



Figure 4: Schematic of MOS capacitors referenced to ground: a) nMOS transistor, b) pMOS transistor, c) complementary MOS capacitor



Figure 5: Capacitors of the gate of MOS transistors

gate capacitance and the voltage of a nMOS transistor is shown in fig. 5. The maximum value is only reached when  $V_{gs}$  is well above  $V_{th}$ . Such a behaviour is generally not satisfactory, since the control voltage needed for the input of the VCO may be below or around Vth.

Note that a pMOS transistor may be equally used, as shown in 4b. The corresponding characteristics is given in fig. 5. One can see that for Vc > Vdd - Vth, the capacitance strongly reduced.

For this reason, it is more interesting to use a complementary MOS capacitor composed of NMOS and PMOS transistors of equal size, see fig. 4c. In this case, the ratio between maximum and minimum capacitance value is strongly reduced, passing from 3 to 3/2, see fig. 5.

When a capacitance of large value  $C_t$  needs to be implemented, the procedure may be the following. One can characterize the capacitance of some unity area transistors, for instance  $S_0 = 1\mu m^2$ , with L=W=1 $\mu$ m. That yields a characteristics  $C_0(V)$ . Since the capacitance is proportional to the area, the required area can be calculated setting  $S_0C_t/C_0(V)$ . However, since  $C_0(V)$  is not a constant, the designer needs to decide which value from the characteristics  $C_0(V)$  will be chosen. That depends on the context. For instance, if the working voltage V is known, the corresponding capacitance value can be chosen as the reference. Otherwise, it can be the minimum or the maximum value of  $C_0(V)$ , depending on what is less critical for the circuit' characteristics: increase or decrease of the capacitance.

For the PLL,  $\omega_n^2$  is inversely proportional to the capacitance  $C_1$ . Since we want  $\omega_n$  to be less than  $\omega_{n \ max}$ , we should take  $min[C_0(V)]$  as the reference. However, the damping factor  $\gamma$  is proportional to  $R\omega_n$ , and when  $\omega_n$  decreases, the damping factor decreases as well. That may be bad for the dynamic behaviour of the PLL.

For this reason, it may be reasonably to select basically a *lower* natural frequency  $\omega$ , design the system for the nominal damping factor at this frequency and select the *maximum value* of  $C_0(V)$ . In this way, when  $C_0(V)$  decreases, the corresponding decrease of  $\omega_n$  is not critical, and increase of  $\gamma$  yields the dynamic of the system more slow, without causing overshoot.

Alternative strategies may exist. For instance, one can use the average value of  $C_0(V)$ . Or, another solution can consist in using the voltage range for which the characteristics  $C_0(V)$  is constant and maximum, which is in the middle of the V range and hence in the middle of the output VCO frequency range. That corresponds to the maximum of  $C_0(V)$ . This is possible if the frequency generated by the VCO for this range of the control voltage covers the required output frequencies.

In the designed PLL generator, we select the maximum value of  $C_0(Vc)$ 



Figure 6: Schematic of the Phase Frequency Detector.

as the reference value of complementary MOS capacitor.

## 4 Design of digital blocks

The digital blocks of the PLL are done with standard digital cells. The digital blocks are composed of two parts: the phase-frequency detector and the frequency divider.

## 4.1 Phase Frequency detector

The phase-frequency detector has a standard architecture described in many sources, e.g., in "CMOS Circuit Design, Layout, and Simulation by R. Jacob Baker". The full and detailed schematic is given in fig. 6. It uses the Flexlib standard cell library, but can be implemented with any standard logic cells.

This implementation has two particularities. First, the feedback of the phase-frequency detector (the NOR gate generating the reset of the registers) is reinforced by a x8 buffer. That is done in order not to loose the very short reset signal. Second, the up and dn signals are used to generate the control signals for transistors of charge pump. The truth table is given in table 1. The point here is to generate no current by the charge pump (and hence to block the both nMOS and pMOS transistors) when up and dn signals are both at "1" (the reset generation).

In order to avoid glitches in the generation of dn\_mos and up\_mos, a buffer delay (a pair of always on nMOS and pMOS transistors) is used to balance the delay of the invertor.

| up | dn | upmos | dnmos |
|----|----|-------|-------|
| 0  | 0  | 1     | 0     |
| 0  | 1  | 1     | 1     |
| 1  | 0  | 0     | 0     |
| 1  | 1  | 1     | 0     |

Table 1: Truth table for generation of the signals for the charge pump



Figure 7: Schematic of dividers by 2 (a) and by 3 (a).

## 4.2 Divider

The PLL designed in this generator uses a divider with a fixed division factor of 24, with intermediate outputs with division factor 2, 4, 8 and 24. This divider is cascade of three dividers by 2 and one divider by 3.

The schematics of dividers by 2 and by 3 are given in fig. 7.

# 5 Symmary of the PLL desgin procedure with python generators

1. Design of VCO.

Run the notebook "CMOS\_VCO".

Input: maximum desired output frequency.

Output: Size of all transistors of the VCO, the file "VCO\_characteristic.py" containing the characteristics  $f_{vco}(Vc)$  and  $gain_{vco}(Vc)$ .

2. Design of the charge pump. Run the notebook "chargepump".

Input parameter:  $I_{ref}$  and K, yielding the current  $I_0$  of the charge pump,  $I_0 = KI_{ref}$ .

Output: the size of all transistors of the chargepump.

3. Design of the loop filter of the PLL. Run the notebook "PLL\_design". Input parameter: the reference (input) frequency of the PLL,  $f_{ref}$  and the division factor N.

Output: the nominal values of the filter components  $(C_1, C_2 \text{ and } R)$ , the sizes of the MOS transistors implementing  $C_1$  and  $C_2$ .

Each script generates files parametrising the schematic of the PLL compnents and containing size of transistors. Three files are generated:

- "parameters\_chargepump.scs",
- "parameters\_CMOS\_VCO.scs",
- "parameters\_PLL\_filter\_PI.scs".

The files "chargepmup\_cell.scs", "CMOS\_VCO\_cell.scs", "PLL\_filter\_PI.scs" and "PLL.scs" are written "by hand" and provided. In addition, testbench files "PLL\_testbenchN.scs" are written as well, here N is the number of the testbench.

After these files are generated, the PLL is designed and is ready to be simulated by running the command

spectre PLL\_testbench1.scs -outdir <output\_directory>

# 6 Appendix: Design cases

### 6.1 Case 1

**Parameters: VCO:** Maximum VCO frequency is fmax=1000 MHz, the working frequency is 480 MHz (middle of the range). This frequency corresponds to a reference frequency Fref=20 MHz and the division factor N=24.

For the designed VCO, the gain Kvco at  $F_{ref}$  is 1.6·10<sup>9</sup> Hz/V.

After running the notebook "CMOS<sub>-</sub>VCO", the characteristics of the VCO are given in fig. 8.

**PLL:** Division factor : N=24  $f_{ref}$ =20 MHz Targeted phase margin: 60° Charge pump: Iref=1  $\mu$ A, K=10  $\rightarrow$  I0=10  $\mu$ A

Filter parameters: From these parameters, minimum C1 is 8.2 pF. Calculated values of C2: 5.8e-13 F. Calculated value of R: 17.5 kOhms Test scenario of the PLL:

We observation of the input voltage of the VCO during a sequenence of event on the VDD line:



Figure 8: Case 1: characteristics of the designed VCO

- 1. Power on, Vdd=1.8 V
- 2. Step of +0.1 V on Vdd
- 3. Step of -0.2 V on Vdd

Fig. 9 presents the behaviour of the input voltage of the VCO for 5 simulation cases:  $f_{ref} = 10, 15, 20, 25, 30$  MHz. One can see that the lockin is achieved for all scenario and after each event. The duration of the transient is of order of 1  $\mu$ s.

#### 6.2 Case 2

**Parameters: VCO:** Maximum VCO frequency is fmax=300 MHz, the working frequency is 150 MHz (middle of the range). This frequency corresponds to a reference frequency Fref=6.25 MHz and the division factor N=24.

After running the notebook "CMOS\_VCO", the characteristics of the VCO are given in fig. 10.

**PLL:** Division factor : N=24  $f_{ref}$ =6.25 MHz Targeted phase margin: 60°

Charge pump: Iref=1  $\mu$ A, K=10  $\rightarrow$  I0=10  $\mu$ A

**Filter parameters :** From these parameters, minimum C1 is 24.3 pF. The chosen value is 24.3 pF.

Calculated values of C2: 1.72 pF. Calculated value of R: 18.9 kOhms

Test scenario of the PLL:

We observation of the input voltage of the VCO during a sequenence of event on the VDD line:



Figure 9: Input voltage of the VCO, test case 1.

- 1. Power on, Vdd=1.8 V
- 2. Step of +0.1 V on Vdd
- 3. Step of -0.2 V on Vdd

Fig. 13 presents the behaviour of the input voltage of the VCO for 5 simulation cases:  $f_{ref}=3.125, 4.68, 6.25, 7.8, 9.37$  MHz. One can see that the lock-in is achieved for all scenario and after each event. The duration of the transient is of order of 2  $\mu$ s for the most cases.

## 6.3 Case 3

Parameters: VCO: Maximum VCO frequency is fmax=100 MHz, the



Figure 10: Case 2: characteristics of the designed VCO



Figure 11: Input voltage of the VCO, test case 2.



Figure 12: Case 3: characteristics of the designed VCO

working frequency is 50 MHz (middle of the range). This frequency corresponds to a reference frequency Fref=2.08 MHz and the division factor N=24

After running the notebook "CMOS<sub>-</sub>VCO", the characteristics of the VCO are given in fig. 12.

**PLL:** Division factor : N=24  $f_{ref}$ =2.08 MHz Targeted phase margin: 60°

Charge pump: Iref=1  $\mu$ A, K=1  $\rightarrow$  I0=1  $\mu$ A Note that we reduced the current  $I_0$  by a factor of 1O comparing with the cases 1 and 2. This is in order to reduce the value of the capacitors.

**Filter parameters:** From these parameters, minimum C1 is 8.05 pF. The chosen value is 8.05 pF.

Calculated values of C2: 0.57 pF. Calculated value of R: 171 kOhms Test scenario of the PLL:

We observation of the input voltage of the VCO during a sequenence of event on the VDD line:

- 1. Power on, Vdd=1.8 V
- 2. Step of +0.1 V on Vdd
- 3. Step of -0.2 V on Vdd

Fig. 13 presents the behaviour of the input voltage of the VCO for 5 simulation cases:  $f_{ref} = 1.041, 1.5672, 2.08, 2.604, 3.125$  MHz. One can see that the lock-in is achieved for all scenario and after each event. The duration of the transient is of order of 10  $\mu$ s for the most cases.



Figure 13: Input voltage of the VCO, test case 3.

This paper was made possible with a donation from NGI Zero PET. NGI Zero PET is part of the European Commission's Next Generation Internet programme, established under the aegis of Directorate-General Communications Networks, Content and Technology (DG CNECT)





For more information, see: https://nlnet.nl/PET or https://ngi.eu

Horizon 2020 research and innovation grant agreement No 825310.