



# DW\_dpll\_sd

### Digital Phase Locked Loop

Version, STAR, and myDesignWare Subscriptions: IP Directory

#### **Features and Benefits**

- Parameterizable divisor (ratio of reference clock to baud rate)
- Multichannel data recovery (recovery of channels that accompany the locked channel)
- Stall input for power saving mode and/or prescaler (allowing one DW\_dpll\_sd to recover data at multiple rates)
- Squelch input for ignoring phase information when channel data is unknown or unconnected
- Sampling window control to aid data recovery under harsh conditions
- Parameterizable gain to meet a variety of application needs
- Parameterizable filter (controls phase correction reactiveness from minor phase errors)



**Revision History** 

### **Applications**

- Networking
- Digital communication

### **Description**

DW\_dpll\_sd is a digital phase-locked loop (DPLL) designed for data recovery.

#### Table 1-1 **Pin Description**

| Pin Name | Width | Direction | Function                                                                                                       |
|----------|-------|-----------|----------------------------------------------------------------------------------------------------------------|
| clk      | 1 bit | Input     | Reference clock                                                                                                |
| rst_n    | 1 bit | Input     | Asynchronous reset, active low                                                                                 |
| stall    | 1 bit | Input     | Stalls everything except synchronizer, active high                                                             |
| squelch  | 1 bit | Input     | Turns off phase detection. When high no phase correction is carried out leaving DPLL free running, active high |

Table 1-1 Pin Description (Continued)

| Pin Name  | Width                | Direction | Function                              |
|-----------|----------------------|-----------|---------------------------------------|
| window    | ceil( log2(windows)) | Input     | Sampling window selector <sup>a</sup> |
| data_in   | width bits           | Input     | Serial input data stream              |
| clk_out   | 1 bit                | Output    | Recovered clock                       |
| bit_ready | 1 bit                | Output    | Output data ready flag                |
| data_out  | width bits           | Output    | Recovered output data stream          |

a. The minimum value must be 1.

**Table 1-2** Parameter Description

| Parameter | Values                           | Description                                                                                                                                                                                                                            |  |
|-----------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| width     | 1 to 16<br>Default: 1            | Number of input serial channels                                                                                                                                                                                                        |  |
| divisor   | 4 to 256<br>Default: 4           | Determines the number of samples per input clock cycle                                                                                                                                                                                 |  |
| gain      | 1 to 2<br>Default: 1             | Phase correction factor for the absolute value of clock phase error greater than   1   1:50% phase correction   2:100% phase correction                                                                                                |  |
| filter    | 0 to 8<br>Default: 2             | Phase correction control for +/- 1 clock phase error region.  O: No correction  1: Always correct  For integer N > 1, correct after N samples at a current phase (such as, N consecutive samples at +1 or N consecutive samples at -1) |  |
| windows   | 1 to (divisor+1)/2<br>Default: 1 | Number of sampling windows for the input serial data stream                                                                                                                                                                            |  |

Table 1-3 Synthesis Implementations

| Implementation Name | Function        | License Feature Required |
|---------------------|-----------------|--------------------------|
| str                 | Synthesis model | DesignWare               |

The DPLL functionality is achieved through the use of a state machine design that runs on a reference clock that is at least four times the bit rate of the data channel. After synchronization of the data\_in input signal to the reference clock (using a three stage synchronizer) the oversampled signal is monitored for transitions. When transitions are detected, the state machine evaluates (based on what state it's currently in) whether or

not an adjustment is needed to align the state machine's natural cycle to the incoming data stream. The amount of the adjustment depends on how far out of alignment the state machine is and the related parameter values used.

Recovered data is output on the data\_out bus and the bit\_ready output indicates the arrival of each data bit at the data\_out bus. The clk\_out port can provide a derived clock which is phase-aligned to cleanly clock recovered data from the data out bus on its rising edge.

A stall input port is provided for power savings and for easily implementing multiple data rates through prescaling. A squelch input is provided to command the DPLL to ignore phase information during times when the link is not receiving valid data.

A windowing control bus is provided to allow control of where to sample data within a bit time. This may be useful in recovering noisy data especially if the data rate is significantly different from the DPLLs nominal rate.

The DW\_dpll\_sd can recover multiple channels of data as long as the channels are well phase-aligned with each other. See the *width* parameter functional description for more detail.

Figure 1-1 Functional Block



### **Functional Description**

#### width -

The *width* parameter sets the number of serial input channels processed by the DW\_dpll\_sd component. Although as many as 16 channels can be recovered, phase locking operates only on the data\_in[0] channel. Thus, all other channels received must be well phase-aligned with data\_in[0] in order to cleanly recover data from them. Accompanying channels may be used to bring link status or other non-data information through the DPLL so as to keep this information aligned to the data stream.

#### divisor -

The static *divisor* parameter determines the number of divisions or phase states per bit time. This controls the sample rate, therefore, the granularity or coarseness of the phase corrections.

A *divisor* of 4, not only gives the coarsest granularity, but is the minimum number of samples per bit time to ensure an accurate sampling of the input signal. A large (*divisor*) value increases the number of correction (phase) states or divisions that a bit time is sub-divided into resulting in finer phase corrections.

Since each phase state is one reference clock period long, the number of phase states per bit time also determines the free running or center frequency of the DPLL. Increasing the *divisor* value increases the effective output clock period. For example, using a *divisor* value of 10 for a reference clock of 50 Mhz will divide the bit time into 10 states and set the center frequency to 5 Mhz.

The free running or nominal frequency should be chosen as close as possible to the input frequency or baud rate to ensure the best phase correction conditions.

#### stall -

The stall input port enhances the dynamics of the divisor to center frequency relationship. When using only the *divisor* parameter, compared with the addition of using the stall pin, each frequency is associated with only one *divisor* value to any one reference clock input. This means there is a set (inflexible) one-to-one correspondence between the *divisor* and center frequency.

Therefore, a large *divisor* value for a comparatively high reference clock to expected input frequency may be inconvenient especially if there is no desire to increase the granularity.

By using the stall pin to prescale the reference clock input, clk, a more flexible choice of sample rate can be chosen for a frequency.

Naturally, this allows for maintaining the same granularity over different frequencies or a coarser phase correction at a desired frequency balanced by a lower power system.

The resulting baud time will be the product of the *divisor* value and prescale factor. So, a *divisor* value of 5 for a reference clock of 50 Mhz, with the stall pin driven by a divide-by-two circuit translates to a center frequency of 5 Mhz.

Care should be taken in the use of pre-scaling to affect frequency and sampling rate combinations. Stalling the DPLL freezes all outputs at their current states. This could lead to output data mis-sampling if not considered. For example, stalling the DPLL right at the time the bit\_ready output signal goes high will freeze it at that state (see Figure 1-6 on page 11). So, for such a situation not gating the bit\_ready signal with the stall signal, for instance, to generate a secondary data arrival flag will lead to incorrectly validating the data\_out bus values if just reading the bit\_ready output flag while in the stall state.

Input data passing through the synchronizer stage of the DPLL is unaffected by the stall pin.

#### filter -

The *filter* parameter controls the degree of adjustment in the plus or minus one phase error region, which represents the edge detection of input data transition one division off in either direction of the center or zero error reference for correction. This helps alleviate possible jitter propagation due to any dithering that occurs in this region.

#### gain -

The *gain* parameter determines the amount of phase correction for each detected phase error. A *gain* value of 1 results in a 50% phase correction of any detected error and a *gain* value of 2 in a 100% correction. A 50% phase correction (gain = 1) means a phase error of 6 will be corrected by 3 states compared with a 6 state correction for the case of a 100% phase correction (gain = 2).

#### windows -

The *windows* parameter feature allows for a number of sample points along the input stream to be used. A zero reference point at the approximate center of the bit time is chosen as the default sample point for output data. The reference point is the center of the bit time for even integer values of *divisor* and slightly off center for odd values. Additional sample points, if defined, are accessed through the window pin by use of indexes.

The index pattern for the window follows an alternating left and right sequence with the default zeroth index as the center pivot point, window [0].

This windowing sequence is analogous to a spiral search pattern but in one dimension, where the goal is to maximize the probability of finding a good sample point assuming the center as the optimal sample point. For more information, see Figure 1-3 on page 8.

This windowing option, provides the ability to compensate for noisy conditions such as asymmetric noise along the input stream and/or frequency difference or static error between the transmit and receive clock domains.

### **Application Notes**

Note that with each phase correction that is carried out, the <code>clk\_out</code> signal will either be shortened or lengthened by an amount equal to the phase correction.

Therefore it is generally desired to use the bit\_ready output signal as a flag to indicate when data\_out is ready to be read during normal operations.

Note that the squelch input disables the phase detection mechanism leaving the DPLL free running

### **Examples of Application Configurations**

Three following common configurations can be used to cover most applications:

- For the non-coherent phase DPLL case and where there is more jitter with respect to the reference clock, *gain* = 1, *filter* = 2.
- For the coherent phase DPLL case, where the transmission and reception clock phase relation do not change with respect to each other, *gain* = 2, *filter* = 0.
- For the non-coherent phase DPLL condition and where there is less jitter and smoother corrections are desired, *gain* = 1, *filter* > 2.

### **Suppressing Warning Messages During Verilog Simulation**

The Verilog simulation model includes macros that allow you to suppress warning messages during simulation.

To suppress all warning messages for all DWBB components, define the DW\_SUPPRESS\_WARN macro in either of the following ways:

Specify the Verilog preprocessing macro in Verilog code:

```
`define DW_SUPPRESS_WARN
```

• Or, include a command line option to the simulator, such as:

```
+define+DW SUPPRESS WARN (which is used for the Synopsys VCS simulator)
```

The warning messages for this model include the following:

■ If values other than 1 or 0 are present on a clock port, the following message is displayed:

```
WARNING: <instance_path>.<clock_name>_monitor:
    at time = <timestamp>, Detected unknown value, x, on <clock name> input.
```

To suppress only this warning message for all DWBB components, use the following macro:

- □ Define the DW\_DISABLE\_CLK\_MONITOR macro. You can define this macro in the following ways:
  - Specify the Verilog preprocessing macro in Verilog code:

```
`define DW DISABLE CLK MONITOR
```

Or, include a command line option to the simulator, such as:

```
+define+DW DISABLE CLK MONITOR (which is used for the Synopsys VCS simulator)
```

This message is also suppressed using the DW\_SUPPRESS\_WARN macro explained earlier.

### **Timing Diagrams**

The following figures show various timing conditions for the DW\_dpll\_sd.

Figure 1-2 Functional Operation: Initialize Reset Followed by Phase Correction



Figure 1-3 Window Shifting Sequence Concept



Figure 1-4 Functional Operation: Window shifting



Figure 1-5 Functional Operation: Squelch Active



Figure 1-6 Functional Operation: Stall Active



## **Related Topics**

- Logic Sequential Overview
- DesignWare Building Block IP User Guide

### **HDL Usage Through Component Instantiation - VHDL**

```
library IEEE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.DWpackages.all;
use DWARE.DW foundation comp.all;
entity DW dpll sd inst is
  generic (inst width : INTEGER := 1;
           inst divisor : INTEGER := 5;
           inst gain : INTEGER := 1;
           inst filter : INTEGER := 2;
           inst windows : INTEGER := 1);
  port (inst clk : in std logic;
        inst rst n : in std logic;
        inst_stall : in std logic;
        inst squelch : in std logic;
        inst window: in std logic vector(bit width(inst windows)-1 downto 0);
        inst data in : in std logic vector(inst width-1 downto 0);
        clk out inst : out std logic;
        bit ready inst : out std logic;
        data out inst : out std logic vector(inst width-1 downto 0) );
end DW dpll sd inst;
architecture inst of DW dpll sd inst is
begin
  -- Instance of DW dpll sd
 U1 : DW dpll sd
    generic map ( width => inst width, divisor => inst divisor,
                  gain => inst gain, filter => inst filter,
                  windows => inst windows )
 port map ( clk => inst clk, rst n => inst rst n, stall => inst stall,
             squelch => inst squelch, window => inst window,
             data in => inst data in, clk out => clk out inst,
             bit ready => bit ready inst, data out => data out inst );
end inst;
-- pragma translate off
configuration DW_dpll_sd_inst_cfg_inst of DW_dpll_sd_inst is
  for inst
  end for; -- inst
end DW dpll sd inst cfg inst;
-- pragma translate on
```

SolvNetPlus

DesignWare.com

13

### **HDL Usage Through Component Instantiation - Verilog**

```
module DW dpll sd inst(inst clk, inst rst n, inst stall,
                        inst squelch, inst window, inst data in,
                        clk out inst, bit ready inst, data out inst );
 parameter inst width = 1;
 parameter inst divisor = 5;
 parameter inst gain = 1;
 parameter inst filter = 2;
 parameter inst windows = 3;
  `define bit width windows 2 // ceil(log2(inst windows)
  input inst clk;
  input inst rst n;
  input inst stall;
  input inst squelch;
  input ['bit width windows-1 : 0] inst window;
  input [inst_width-1 : 0] inst_data_in;
  output clk out inst;
  output bit ready inst;
  output [inst width-1 : 0] data out inst;
  // Instance of DW dpll sd
 DW dpll sd #(inst width, inst divisor, inst gain,
               inst filter, inst windows)
   U1 ( .clk(inst_clk), .rst_n(inst_rst_n), .stall(inst_stall),
         .squelch(inst squelch), .window(inst window),
         .data_in(inst_data_in), .clk_out(clk_out_inst),
         .bit ready(bit ready inst), .data out(data out inst));
endmodule
```

### **Revision History**

For notes about this release, see the *DesignWare Building Block IP Release Notes*.

For lists of both known and fixed issues for this component, refer to the STAR report.

For a version of this datasheet with visible change bars, click here.

| Date         | Release       | Updates                                                                                                                                                           |  |
|--------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| July 2020    | DWBB_201912.5 | <ul> <li>Adjusted content and title of "Suppressing Warning Messages During<br/>Verilog Simulation" on page 6 and added the DW_SUPPRESS_WARN<br/>macro</li> </ul> |  |
| October 2019 | DWBB_201903.5 | ■ Added the "Disabling Clock Monitor Messages" section                                                                                                            |  |
| March 2019   | DWBB_201903.0 | ■ Removed minPower designation from this datasheet                                                                                                                |  |
| January 2019 | DWBB_201806.5 | <ul> <li>Updated example in "HDL Usage Through Component Instantiation -<br/>VHDL" on page 12</li> </ul>                                                          |  |
|              |               | <ul> <li>Added this Revision History table and the document links on this page</li> </ul>                                                                         |  |

#### **Copyright Notice and Proprietary Information**

© 2022 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, modification, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### **Disclaimer**

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at https://www.synopsys.com/company/legal/trademarks-brands.html.

All other product or company names may be trademarks of their respective owners.

#### Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

#### **Third-Party Links**

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

Synopsys, Inc. www.synopsys.com