

# **MachXO4 PLL Module**

IP Version: v3.0.1

# **User Guide**

FPGA-IPUG-02316-1.0

December 2025



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS, with all faults, and all associated risk is the responsibility entirely of the Buyer. The information provided herein is for informational purposes only and may contain technical inaccuracies or omissions, and may be otherwise rendered inaccurate for many reasons, and Lattice assumes no obligation to update or otherwise correct or revise this information. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. LATTICE PRODUCTS AND SERVICES ARE NOT DESIGNED, MANUFACTURED, OR TESTED FOR USE IN LIFE OR SAFETY CRITICAL SYSTEMS, HAZARDOUS ENVIRONMENTS, OR ANY OTHER ENVIRONMENTS REQUIRING FAIL-SAFE PERFORMANCE, INCLUDING ANY APPLICATION IN WHICH THE FAILURE OF THE PRODUCT OR SERVICE COULD LEAD TO DEATH, PERSONAL INJURY, SEVERE PROPERTY DAMAGE OR ENVIRONMENTAL HARM (COLLECTIVELY, "HIGH-RISK USES"). FURTHER, BUYER MUST TAKE PRUDENT STEPS TO PROTECT AGAINST PRODUCT AND SERVICE FAILURES, INCLUDING PROVIDING APPROPRIATE REDUNDANCIES, FAIL-SAFE FEATURES, AND/OR SHUT-DOWN MECHANISMS. LATTICE EXPRESSLY DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY OF FITNESS OF THE PRODUCTS OR SERVICES FOR HIGH-RISK USES. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.

#### **Inclusive Language**

This document was created consistent with Lattice Semiconductor's inclusive language policy. In some cases, the language in underlying tools and other items may not yet have been updated. Please refer to Lattice's inclusive language FAQ 6878 for a cross reference of terms. Note in some cases such as register names and state names it has been necessary to continue to utilize older terminology for compatibility.



## **Contents**

| Contents                                  | 3  |
|-------------------------------------------|----|
| Abbreviations in This Document            | 5  |
| 1. Introduction                           | 6  |
| 1.1. Quick Facts                          | 6  |
| 1.2. Features                             | 6  |
| 1.3. Licensing and Ordering Information   |    |
| 1.4. Naming Conventions                   |    |
| 1.4.1. Nomenclature                       | 7  |
| 1.4.2. Signal Names                       | 7  |
| 2. Functional Description                 | 8  |
| 2.1. Overview of the IP                   | 8  |
| 3. IP Parameter Description               |    |
| 3.1. General                              |    |
| 3.2. Optional Signal Control              | 11 |
| 4. Signal Description                     | 12 |
| 4.1. Clock Interface                      | 12 |
| 4.2. Enable and Reset Interface           | 12 |
| 4.3. Control Interface                    | 13 |
| 4.4. WishBone Interface                   | 13 |
| 5. Designing with the IP                  | 14 |
| 5.1. Generating and Instantiating the IP  | 14 |
| 5.1.1. Generated Files and File Structure | 16 |
| 5.2. Running Functional Simulation        | 16 |
| 5.2.1. Simulation Results                 | 18 |
| References                                | 19 |
| Technical Support Assistance              | 20 |
| Revision History                          | 21 |



# **Figures**

| Figure 2.1. PLL Module Top Level Block Diagram | 8  |
|------------------------------------------------|----|
| Figure 5.1. Module/IP Block Wizard             | 14 |
| Figure 5.2. IP Configuration                   | 15 |
| Figure 5.3. Check Generated Result             |    |
| Figure 5.4. Simulation Wizard                  | 16 |
| Figure 5.5. Add and Reorder Source             |    |
| Figure 5.6. Simulation Waveform                | 17 |
| Figure 5.7. Simulation Complete Message        | 18 |
| Tables                                         |    |
| Table 1.1. Summary of the PLL Module           | 6  |
| Table 3.1. General Attributes                  | 9  |
| Table 3.2. Optional Signal Control             | 11 |
| Table 4.1. Clock Ports                         | 12 |
| Table 4.2. Enable and Reset Ports              |    |
| Table 4.3. Control Ports                       | 13 |
| Table 4.4 WishBone Ports                       | 13 |



## **Abbreviations in This Document**

A list of abbreviations used in this document.

| Abbreviations | Definition                    |
|---------------|-------------------------------|
| CSR           | Control and Status Register   |
| EFB           | Embedded Function Block       |
| FPGA          | Field-Programmable Gate Array |
| IP            | Intellectual Property         |
| LSE           | Lattice Synthesis Engine      |
| PLL           | Phase-Locked Loop             |



### 1. Introduction

This user guide describes the Phase Locked Loop (PLL) Module. PLL is essential component in digital systems that enable precise clock management, frequency synthesis, and phase alignment.

The PLL Module lets you generate multiple output clocks with configurable frequencies, phases, and duty cycles from a single reference clock input. It support high-speed interfaces, reduce clock jitter, and manages multiple clock domains within a single FPGA.

### 1.1. Quick Facts

Table 1.1. Summary of the PLL Module

|                            | Supported Devices        | MachXO4™                                                                                        |  |  |
|----------------------------|--------------------------|-------------------------------------------------------------------------------------------------|--|--|
| IP Requirements            | IP Changes <sup>1</sup>  | For a list of changes to the IP, refer to the MachXO4 PLL Module Release Notes (FPGA-RN-02316). |  |  |
| Resource Utilization       | Supported User Interface | Native interface.                                                                               |  |  |
|                            | Lattice Implementation   | IP Core v3.0.1 – Lattice Radiant™ Software 2025.2.                                              |  |  |
|                            | Synthesis                | Synopsys® Synplify Pro for Lattice,                                                             |  |  |
| <b>Design Tool Support</b> |                          | Lattice Synthesis Engine (LSE)                                                                  |  |  |
|                            | Simulation               | For a list of supported simulators, see the Lattice Radiant                                     |  |  |
|                            | Simulation               | Software User Guide.                                                                            |  |  |

#### Note:

#### 1.2. Features

Key features of the PLL Module:

- Reference input clock:
  - Clock range: 10 MHz to 400 MHz
  - Clock divider range: 1 to 40
  - Dynamic clock source selection
- Feedback Path:
  - Feedback divider range: 1 to 128
  - Supports a Fractional-N divider with up to 16-bit resolution
  - Feedback input selection: internal, external, or user port
- Generated Output Clock
  - Supports up to four individual configurable output clocks
  - Frequency range: 0.0122 MHz to 400 MHz
  - Output divider range: 1 to 128
  - Supports internal clock output cascading
  - Supports bypassing of VCO and divider for output clocks
  - Supports trim and duty cycle adjustment
- Phase Shift Support:
  - Static phase shift: 8 steps (0° to 315°) per output clock
  - Dynamic VCO phase shift supported
- Reset Capability:
  - Full PLL reset
  - Individual output reset for CLKOS2 and CLKOS3
- Lock Detector
- WishBone Interface: Used with Embedded Function Block (EFB) Block for CSR access
- Dynamic Low-Power/Standby Mode Supported

<sup>1.</sup> In some instances, the IP may be updated without changes to the user guide. This user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.



## 1.3. Licensing and Ordering Information

The PLL Module is provided at no additional cost with the Lattice Radiant software.

## 1.4. Naming Conventions

#### 1.4.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL.

#### 1.4.2. Signal Names

- \_n are active low (asserted when value is logic 0)
- \_i are input signals
- \_o are output signals



## 2. Functional Description

#### 2.1. Overview of the IP

The top-level block diagram of the PLL Module is shown in Figure 2.1. The PLL Module supports WishBone interface, which must be used with the EFB block to configure the PLL CSR at runtime.



Figure 2.1. PLL Module Top Level Block Diagram



# 3. IP Parameter Description

The configurable attributes of the PLL Module are shown in the following tables. You can configure the IP by setting the attributes accordingly in the IP Catalog's Module/IP wizard of the Lattice Radiant software.

Wherever applicable, default values are in bold.

#### 3.1. General

**Table 3.1. General Attributes** 

| Attribute                               | Selectable Values                                                                     | Description                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configuration Mode                      | <b>Frequency</b><br>Divider                                                           | Determines the input type you should provide.  In Frequency mode, enter the desired CLKI and CLKOP frequencies  In Divider mode, enter the desired CLKI frequency and divider settings                                                                                                                                                                       |
| VCO Frequency                           | _                                                                                     | <ul> <li>Displays the calculated VCO frequency based on selected value</li> <li>Acceptable range: 200 MHz to 800 MHz</li> </ul>                                                                                                                                                                                                                              |
| Estimate Bandwidth                      | _                                                                                     | Displays the calculated bandwidth based on your selected value                                                                                                                                                                                                                                                                                               |
| Reference Clock (CLKI)                  |                                                                                       |                                                                                                                                                                                                                                                                                                                                                              |
| Frequency (MHz)                         | 7 MHz to 400 MHz                                                                      | <ul> <li>Specifies the reference input clock frequency</li> <li>Default is 100 MHz</li> </ul>                                                                                                                                                                                                                                                                |
| Divider Value                           | 1 to 40                                                                               | <ul> <li>Contains the reference input clock divider value</li> <li>In Divider Mode, this allows you to enter the value</li> <li>In Frequency Mode, the calculated value is displayed</li> <li>Default: 1</li> <li>This value is used to divide upon reference clock frequency to generate the feedback source output frequency</li> </ul>                    |
| Feedback                                |                                                                                       |                                                                                                                                                                                                                                                                                                                                                              |
| Feedback Mode                           | CLKOP, CLKOS,<br>CLKOS2, CLKOS3,<br>INT_OP, INT_OS,<br>INT_OS2, INT_OS3,<br>UserClock | <ul> <li>Specifies which clock source used as the feedback path</li> <li>The selection adjusts based on the generated clock enablement</li> <li>INT_* option indicates use of primitive internal feedback loop path</li> <li>When you select <i>UserClock</i> option, additional <i>clkfb_i</i> signal is exposed for connection</li> </ul>                  |
| Feedback Divider Value                  | 1 to 128                                                                              | <ul> <li>Contains the value for the feedback loop divider value</li> <li>In Divider Mode, this allows you to enter the value</li> <li>In Frequency Mode, the calculated value is displayed</li> <li>Default: 1</li> <li>This value is used to perform multiplication upon reference clock frequency generate the feedback source output frequency</li> </ul> |
| Feedback Fractional-N<br>Divider Enable | Checked<br>Unchecked                                                                  | Determines Fractional-N feature usage.     When checked, feedback divider includes the Fractional-N divider feature                                                                                                                                                                                                                                          |
| Feedback Fractional-N<br>Divider Value  | 0 to 65535                                                                            | <ul> <li>Specifies the value used for the Fractional-N divider</li> <li>In Divider Mode, this allows you to enter the value</li> <li>In Frequency Mode, the calculated value is displayed</li> <li>Default: 0</li> </ul>                                                                                                                                     |
| Clock Output: [n] (n = CLK              | OP, CLKOS, CLKOS2, CLKOS                                                              | 53)                                                                                                                                                                                                                                                                                                                                                          |
| [n]: Enable                             | Checked<br><b>Unchecked</b>                                                           | <ul> <li>Determines whether specific generated clock output usage</li> <li>When checked, enables the generated clock output feature selection and the output signal ([n]_o)</li> <li>This feature does not apply to CLKOP, which CLKOP is always enabled</li> </ul>                                                                                          |

FPGA-IPUG-02316-1.0



| Checked Unchecked                               | Determines input source for the generated output clock                                                                                            |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Unchecked                                       |                                                                                                                                                   |
| Unchecked                                       | When checked, uses the reference input clock                                                                                                      |
|                                                 | When unchecked, uses VCO output                                                                                                                   |
| Checked                                         | Determine whether to apply output division to generate the output clock                                                                           |
| Unchecked                                       | When checked, the output clock is divided based on the reference input clock                                                                      |
|                                                 | When unchecked, the output clock matches the reference input clock                                                                                |
| 1.5625 MHz to 400<br>MHz                        | Available in Frequency Mode. Allow you to enter the desired generated output clock frequency                                                      |
|                                                 | <ul> <li>Supports minimum frequency of 0.0122 MHz by utilizing<br/>internal cascade feature</li> </ul>                                            |
|                                                 | Not applicable when Bypass feature is used                                                                                                        |
|                                                 | Default: 100 MHz                                                                                                                                  |
| <b>0.0</b> , 0.1, 0.2, 0.5, 1.0, 2.0, 5.0, 10.0 | Used in Frequency Configuration Mode to specify the acceptance delta between desired frequency and actual frequency.                              |
| 1 to 128                                        | Contains the divider value for the generated output clock                                                                                         |
|                                                 | In Divider Mode, this allow you enters the desired value                                                                                          |
|                                                 | In Frequency Mode, the calculated value is displayed (If Bypass)                                                                                  |
|                                                 | and Clock Divider are enabled, you must enter value)                                                                                              |
|                                                 | Default: 5                                                                                                                                        |
|                                                 | This value is used to divide upon VCO frequency to generate the output frequency                                                                  |
| _                                               | Displays the generated output clock is used as the internal cascade source                                                                        |
|                                                 | Cascade mode is supported only in Frequency mode to achieve lower desired output frequency                                                        |
| _                                               | Displays the actual generated output frequency based on your settings or per best achievable configuration                                        |
| <b>0</b> , 45, 90, 135, 180,                    | Controls the phase shift of the generated output clock signal                                                                                     |
| 225, 270, 31                                    | This feature does not apply to generated output clock that is used as feedback source set in <i>Feedback Mode</i> option                          |
| Checked                                         | Determines whether to enable duty trim feature                                                                                                    |
| Unchecked                                       | When checked, expose the trim feature and selection options                                                                                       |
|                                                 | This option does not apply to CLKOS2 and CLKOS3                                                                                                   |
| Rising, Falling                                 | When the <i>trimming feature</i> is enabled, controls which edge of the generated clock signal is trimmed                                         |
|                                                 | Rising – Trim happens at the rising edge                                                                                                          |
|                                                 | Falling – Trim happens at the falling edge                                                                                                        |
|                                                 | This option does not apply to CLKOS2 and CLKOS3                                                                                                   |
| <b>0</b> , 1, 2, 4                              | When trimming feature is enabled, it controls the amount of time that is trimmed                                                                  |
|                                                 | 0 – No Trim performed                                                                                                                             |
|                                                 | • 1 – 70 ps trim on the selected edge                                                                                                             |
|                                                 | • 2 – 140 ps trim on the selected edge                                                                                                            |
|                                                 | • 4 – 280 ps trim on the selected edge                                                                                                            |
|                                                 | This option does not apply to CLKOS2 and CLKOS3                                                                                                   |
|                                                 | 1.5625 MHz to 400 MHz  0.0, 0.1, 0.2, 0.5, 1.0, 2.0, 5.0, 10.0  1 to 128  -  0, 45, 90, 135, 180, 225, 270, 31  Checked Unchecked Rising, Falling |



## 3.2. Optional Signal Control

Table 3.2 contains the selection which exposes one or group of signals. For the details on each signal usage and detail, refer to Signal Description section.

**Table 3.2. Optional Signal Control** 

| Attribute                                                          | Selectable Values    | Description                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dynamic Phase Ports                                                | Checked<br>Unchecked | When checked, exposes the ports <i>phasedir_i</i> , <i>phasesel_i[1:0]</i> , <i>phasestep_i</i> , and dphsrc_o.                                                                                                                                                      |
| Clock Enable Ports                                                 | Checked<br>Unchecked | When checked, exposes the ports <code>enclkop_i</code> , <code>enclkos_i</code> , <code>enclkos2_i</code> , and <code>enclkos3_i</code> based on the enable status for each output port.                                                                             |
| Standby Ports                                                      | Checked<br>Unchecked | When checked, exposes the port stdby_i.                                                                                                                                                                                                                              |
| Enable Clock Select                                                | Checked<br>Unchecked | When checked, exposes the ports <i>clki2_i</i> and <i>sel_i</i> .                                                                                                                                                                                                    |
| PLL Reset Options                                                  |                      |                                                                                                                                                                                                                                                                      |
| Provide PLL Reset                                                  | Checked<br>Unchecked | When checked, exposes the port rst_i.                                                                                                                                                                                                                                |
| Provide PLL M Reset                                                | Checked<br>Unchecked | When checked, exposes the port resetm_i.                                                                                                                                                                                                                             |
| PLL CLKOS2 Reset                                                   | Checked<br>Unchecked | When checked, exposes the port resetc_i.                                                                                                                                                                                                                             |
| PLL CLKOS3 Reset                                                   | Checked<br>Unchecked | When checked, exposes the port resetd_i.                                                                                                                                                                                                                             |
| Lock Settings                                                      |                      |                                                                                                                                                                                                                                                                      |
| Provide PLL Lock Signal                                            | Checked<br>Unchecked | When checked, exposes the signal <i>lock_o</i> .                                                                                                                                                                                                                     |
| PLL lock is Sticky                                                 | Checked<br>Unchecked | <ul> <li>Available only when PLL lock signal is exposed</li> <li>When checked, the lock signal remains asserted after achieving lock condition until PLL is reset</li> <li>When unchecked, lock signal de-asserts when the lock condition lost is applied</li> </ul> |
| WishBone Bus                                                       |                      |                                                                                                                                                                                                                                                                      |
| Provide Wishbone Ports<br>(Requires Instantiation of EFB<br>Block) | Checked<br>Unchecked | When checked, exposes the ports <code>plladdr_i[4:0]</code> , <code>pllclk_i</code> , <code>plldati_i[7:0]</code> , <code>pllrst_i</code> , <code>pllstb_i</code> , <code>pllwe_i</code> , and <code>plldato_o[7:0]</code> .                                         |



# 4. Signal Description

This section describes the PLL Module ports, in which certain port exposure is controlled by the parameter mentioned in IP Parameter Description section.

### 4.1. Clock Interface

**Table 4.1. Clock Ports** 

| Port     | Туре   | Description                                                                                                         |
|----------|--------|---------------------------------------------------------------------------------------------------------------------|
| clki_i   | Input  | These signals are the reference input clock                                                                         |
| clki2_i  |        | The signal frequency input must match the value set in the Reference Clock Frequency option in the General section. |
| sel_i    | Input  | This signal is used to select the current reference input clock.                                                    |
|          |        | • 0 = use <i>clki_i</i>                                                                                             |
|          |        | • 1 = use <i>clki2_i</i>                                                                                            |
| clkfb_i  | Input  | This signal is used for the user-provided feedback loop                                                             |
| clkop_o  | Output | This signal is the generated CLKOP output clock signal                                                              |
|          |        | The output frequency follows the Frequency Actual Value option in General section                                   |
| clkos_o  | Output | This signal is the generated CLKOS output clock signal                                                              |
|          |        | The output frequency follows the Frequency Actual Value option in General section                                   |
| clkos2_o | Output | This signal is the generated CLKOS2 output clock signal                                                             |
|          |        | The output frequency follows the Frequency Actual Value option in General section                                   |
| clkos3_o | Output | This signal is the generated CLKOS3 output clock signal                                                             |
|          |        | The output frequency follows the Frequency Actual Value option in General section                                   |

## 4.2. Enable and Reset Interface

**Table 4.2. Enable and Reset Ports** 

| Port       | Туре  | Description                                                                            |
|------------|-------|----------------------------------------------------------------------------------------|
| enclkop_i  | Input | Active high, asynchronous signal that performs clock gated for <i>clkop_o</i> output.  |
| enclkos_i  | Input | Active high, asynchronous signal that performs clock gated for clkos_o output.         |
| enclkos2_i | Input | Active high, asynchronous signal that performs clock gated for clkos2_o output.        |
| enclkos3_i | Input | Active high, asynchronous signal that performs clock gated for <i>clkos3_o</i> output. |
| resetc_i   | Input | Active high, asynchronous signal that resets clkos2_o output when asserted             |
| resetd_i   | Input | Active high, asynchronous signal that resets clkos3_o output when asserted             |
| resetm_i   | Input | Active high, asynchronous signal that resets PLL including the M-divider when asserted |
| rst_i      | Input | Active high, asynchronous signal that reset PLL except the M-divider when asserted     |



## 4.3. Control Interface

#### **Table 4.3. Control Ports**

| Port        | Туре   | Description                                                                              |
|-------------|--------|------------------------------------------------------------------------------------------|
| lock_o      | Output | This signal indicates PLL lock status.                                                   |
|             |        | 0 = Not yet archive lock state or at lose lock state                                     |
|             |        | • 1 = Archive lock state                                                                 |
| phasesel_i  | Input  | This signal selects on which generated output signal the dynamic phase shift applies to: |
| [1:0]       |        | • 00 = Apply to <i>clkop_o</i>                                                           |
|             |        | • 01 = Apply to clkos_o                                                                  |
|             |        | • 10 = Apply to <i>clkos2_o</i>                                                          |
|             |        | • 11 = Apply to <i>clkos3_o</i>                                                          |
| phasedir_i  | Input  | This signal determines the dynamic phase shift direction:                                |
|             |        | 0 = Delay (Lagging)                                                                      |
|             |        | • 1 = Advance (Leading)                                                                  |
| phasestep_i | Input  | This signal determines when the Dynamic Phase Shift step takes effect.                   |
| dphsrc_o    | Output | This signal indicates:                                                                   |
|             |        | 0 = honoring wishbone interface operation                                                |
|             |        | • 1 = honoring Dynamic Phase Shift port (phase*_i) operation                             |
| stdby_i     | Input  | This signal puts the PLL into a low power standby mode:                                  |
|             |        | 0 = Normal operating mode                                                                |
|             |        | 1 = Low power standby mode                                                               |

**Note**: phase\*\_i refers to phasel\_i , phasedir\_i, and phasestep\_i.

### 4.4. WishBone Interface

**Table 4.4. WishBone Ports** 

| Port            | Туре   | Description                                                                                                    |
|-----------------|--------|----------------------------------------------------------------------------------------------------------------|
| plladdr_i [4:0] | Input  | This signal is the PLL WishBone interface address signal.                                                      |
| pllclk_i        | Input  | This signal is the PLL WishBone interface clock signal.                                                        |
| plldati_i [7:0] | Input  | This signal is the PLL WishBone interface data input signal.                                                   |
| pllrst_i        | Input  | This active-high signal resets the WishBone interface. It does not reset the PLL CSR.                          |
| pllstb_i        | Input  | This active-high strobe signal indicates which WishBone interface signal is a valid signal.                    |
| pllwe_i         | Input  | This active-high signal is a write enable that indicates the read or write direction.                          |
| pllack_o        | Output | This signal is the acknowledge signal of the PLL WishBone interface. High indicates the input is acknowledged. |
| plldato_o [7:0] | Output | This signal is the data output signal of the PLL WishBone interface.                                           |



## 5. Designing with the IP

This section provides information on how to generate the IP Core using the Lattice Radiant software and how to run simulation and synthesis. For more details on the Lattice Radiant software, refer to the Lattice Radiant Software User Guide.

**Note:** The screenshots provided are for reference only. Details may vary depending on the version of the IP or software being used. If there have been no significant changes to the GUI, a screenshot may reflect an earlier version of the IP.

### 5.1. Generating and Instantiating the IP

You can use the Lattice Radiant software to generate IP modules and integrate them into the device architecture. The steps below describe how to generate the PLL Module in the Lattice Radiant software.

To generate the PLL Module:

- 1. Create a new Lattice Radiant software project or open an existing project.
- 2. Click the IP Catalog button to view the IP Catalog pane.
- 3. On the IP on Local tab, double-click PLL under IP, Architecture\_Module category. The Module/IP Block Wizard opens as shown in Figure 5.1. Enter values in the Component name and the Create in fields and click Next.



Figure 5.1. Module/IP Block Wizard

4. In the next **Module/IP Block Wizard** window, customize the selected PLL Module using drop-down lists and check boxes. Figure 5.2 shows an example configuration of the PLL Module. For details on the configuration options, refer to the IP Parameter Description section.





Figure 5.2. IP Configuration

5. Click **Generate**. The **Check Generated Result** dialog box opens, showing design block messages and results as shown in Figure 5.3.



Figure 5.3. Check Generated Result

6. Click **Finish**. All the generated files are placed under the directory paths in the **Create in** and the **Component name** fields shown in Figure 5.1.



#### 5.1.1. Generated Files and File Structure

The generated PLL Module package includes the closed-box (<Component name>\_bb.v) and instance templates (<Component name>\_tmpl.v/vhd) that can be used to instantiate the core in a top-level design. An example RTL top-level reference source file (<Component name>.v) that can be used as an instantiation template for the module is also provided. You may also use this top-level reference as the starting template for the top-level for their complete design. The generated files are listed in Table 5.1.

**Table 5.1. Generated File List** 

| Attribute                                                                                       | Description                                                              |
|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| <component name="">.ipx</component>                                                             | Contains the information on the files associated to the generated IP.    |
| <component name="">.cfg</component>                                                             | Contains the parameter values used in IP configuration.                  |
| component.xml                                                                                   | Contains the ipxact: component information of the IP.                    |
| design.xml                                                                                      | Documents the configuration parameters of the IP in IP-XACT 2014 format. |
| rtl/ <component name="">.sv</component>                                                         | Provides an example RTL top file that instantiates the module.           |
| rtl/ <component name="">_bb.v</component>                                                       | Provides the synthesis closed-box.                                       |
| misc/ <component name="">_tmpl.v<br/>misc /<component name="">_tmpl.vhd</component></component> | Provide instance templates for the module.                               |

### 5.2. Running Functional Simulation

You can run functional simulation after the IP is generated.

To run functional simulation:

1. Click the button located on the **Toolbar** to initiate the **Simulation Wizard** shown in Figure 5.4.



Figure 5.4. Simulation Wizard

2. Click **Next** to open the **Add and Reorder Source** window as shown in Figure 5.5.





Figure 5.5. Add and Reorder Source

- 3. Click **Next**. The **Summary** window is shown.
- 4. Click **Finish** to run the simulation.

The waveform in Figure 5.6 shows an example simulation result.



Figure 5.6. Simulation Waveform



#### 5.2.1. Simulation Results

When the simulation is completed successfully, *Simulation Passed* string can be observed in the simulation transcript as shown in Figure 5.7

Figure 5.7. Simulation Complete Message



## **References**

- MachXO4 PLL Module Release Notes (FPGA-RN-02316)
- Lattice Radiant Timing Constraints Methodology (FPGA-AN-02059)
- MachXO4 web page
- Lattice Radiant Software web page
- Lattice Solutions IP Cores web page
- Lattice Solutions Reference Designs web page
- Lattice Insights for Lattice Semiconductor training courses and learning plans



# **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport.
For frequently asked questions, please refer to the Lattice Answer Database at

www.latticesemi.com/Support/Answer Database.



# **Revision History**

**Note:** In some instances, the IP may be updated without changes to the user guide. The user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.

#### Revision 1.0, IP v3.0.1, December 2025

| Section | Change Summary   |
|---------|------------------|
| All     | Initial release. |



www.latticesemi.com