



# 2D Scaler IP

IP Version: 1.4.1

## User Guide

FPGA-IPUG-02133-1.4

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  |
| Acronyms in This Document .....                      | 5  |
| 1. Introduction .....                                | 6  |
| 1.1. Quick Facts .....                               | 6  |
| 1.2. Features .....                                  | 6  |
| 1.3. Conventions .....                               | 7  |
| 1.3.1. Nomenclature .....                            | 7  |
| 1.3.2. Signal Names .....                            | 7  |
| 1.4. Attributes .....                                | 7  |
| 2. Functional Description .....                      | 8  |
| 2.1. Overview .....                                  | 8  |
| 2.2. Algorithm and Supported Filter Kernels .....    | 9  |
| 2.3. Interface Descriptions .....                    | 10 |
| 2.3.1. Video Input/Output .....                      | 10 |
| 2.3.2. Parameter Register Read/Write Interface ..... | 10 |
| 2.3.3. Control Signals and Timing .....              | 10 |
| 2.4. Signal Description .....                        | 14 |
| 2.5. Attribute Summary .....                         | 15 |
| 2.6. Register Description .....                      | 18 |
| 3. IP Generation and Evaluation .....                | 20 |
| 3.1. Licensing the IP .....                          | 20 |
| 3.2. Generation and Synthesis .....                  | 20 |
| 3.3. Running Functional Simulation .....             | 22 |
| 3.4. Hardware Evaluation .....                       | 23 |
| 4. Design Considerations .....                       | 24 |
| 4.1. Limitations .....                               | 24 |
| Appendix A. Resource Utilization .....               | 25 |
| References .....                                     | 26 |
| Technical Support Assistance .....                   | 27 |
| Revision History .....                               | 28 |

## Figures

|                                                                                            |    |
|--------------------------------------------------------------------------------------------|----|
| Figure 2.1. 2D Scaler IP Core Functional Diagram.....                                      | 8  |
| Figure 2.2. 2D Scaler IP Core Block Diagram.....                                           | 9  |
| Figure 2.3. Scaling Process with 4-Tap Bicubic Filter .....                                | 9  |
| Figure 2.4. Timing Diagram for Line Flushing Cycles.....                                   | 10 |
| Figure 2.5. Timing Diagram for Frame Flushing Cycles .....                                 | 11 |
| Figure 2.6. RGB Serial Scaling.....                                                        | 11 |
| Figure 2.7. RGB Parallel Scaling (8-bit Pixel) .....                                       | 11 |
| Figure 2.8. YCbCr 4:2:2 Serial Scaling.....                                                | 12 |
| Figure 2.9. YCbCr 4:2:2 Parallel Scaling (8-bit Pixel) .....                               | 12 |
| Figure 2.10. dout_enable Control Timing .....                                              | 12 |
| Figure 2.11. Timing Diagram for Dynamic Parameter Updating (Parameter Bus Width = 32)..... | 13 |
| Figure 3.1. Module/IP Block Wizard .....                                                   | 20 |
| Figure 3.2. Configure User Interface of 2D Scaler IP Core .....                            | 21 |
| Figure 3.3. Check Generating Result.....                                                   | 21 |
| Figure 3.4. Simulation Wizard.....                                                         | 22 |
| Figure 3.5. Adding and Reordering Source .....                                             | 23 |
| Figure 3.6. Simulation Waveform .....                                                      | 23 |

## Tables

|                                                                  |    |
|------------------------------------------------------------------|----|
| Table 1.1. Quick Facts .....                                     | 6  |
| Table 2.1. 2D Scaler IP Core Signal Description .....            | 14 |
| Table 2.2. Attributes Table .....                                | 15 |
| Table 2.3. Attributes Description .....                          | 16 |
| Table 2.4. Dynamic Parameter Updating Register Description ..... | 18 |
| Table 3.1. Generated File List .....                             | 22 |
| Table A.1. Resource Utilization using LIFCL-40-9BG400I .....     | 25 |
| Table A.2. Resource Utilization using LFD2NX-40-9BG256I.....     | 25 |

## Acronyms in This Document

A list of acronyms used in this document.

| Acronym | Definition                    |
|---------|-------------------------------|
| RTL     | Register Transfer Level       |
| FPGA    | Field Programmable Gate Array |
| FIFO    | First In First Out            |
| RAM     | Random Access Memory          |
| EBR     | Embedded Block RAM            |
| CPU     | Central Processing Unit       |

# 1. Introduction

The 2D Scaler IP Core converts input video frames of one size to output video frames of a different size. Its flexible architecture supports a wide variety of scaling algorithms. The highly configurable design takes advantage of the embedded DSP blocks available in Lattice FPGAs. A simple I/O handshake makes the core suitable for either streaming video or burst input video data. In-system input and output frame sizes updating is possible on a frame basis.

## 1.1. Quick Facts

Table 1.1 presents a summary of the 2D Scaler IP Core.

Table 1.1. Quick Facts

|                             |                                     |                                                                                                                                                                                                                     |
|-----------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>IP Requirements</b>      | Supported Devices                   | CrossLink™-NX, Certus™-NX, CertusPro™-NX, MachXO5™-NX                                                                                                                                                               |
|                             | IP Changes <sup>1</sup>             | For a list of changes to the IP, refer to the <a href="#">2D Scaler IP Release Notes (FPGA-RN-02050)</a> .                                                                                                          |
| <b>Resource Utilization</b> | Supported User Interface            | Native interface, see <a href="#">Signal Description</a> section.                                                                                                                                                   |
|                             | Resources                           | See <a href="#">Table A.1</a> and <a href="#">Table A.2</a> .                                                                                                                                                       |
| <b>Design Tool Support</b>  | Lattice Implementation <sup>2</sup> | IP Core v1.1.3 – Lattice Radiant™ software 2.1 or later<br>IP Core v1.3.0 – Lattice Radiant software 2024.2<br>IP Core v1.4.0 – Lattice Radiant software 2025.1<br>IP Core v1.4.1 – Lattice Radiant software 2025.2 |
|                             | Synthesis                           | Lattice Synthesis Engine<br>Synopsys® Synplify Pro® for Lattice                                                                                                                                                     |
|                             | Simulation                          | For a list of supported simulators, see the Lattice Radiant software user guide.                                                                                                                                    |

Notes:

1. 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.
2. Lattice Implementation indicates the IP version release coinciding with the software version release. Check the software for IP version compatibility with earlier or later software versions.

## 1.2. Features

The key features of 2D Scaler IP Core include:

- Single-color, YCbCr 4:2:2, YCbCr 4:4:4 and RGB video formats
- Serial and parallel processing
- Dynamic parameter updating
- Multi-scaling algorithms
- Configurable number of filter taps for Lanczos coefficient set
- Configurable number of phases for Bicubic and Lanczos coefficient sets
- Configurable pixel data width
- Configurable coefficient width
- Configurable parameter bus width and separate parameter bus clock
- Selectable memory type for line buffer and coefficient memories
- Option for sharing vertical and horizontal filter coefficient memories

## 1.3. Conventions

### 1.3.1. Nomenclature

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

### 1.3.2. Signal Names

Signal names that end with:

- `_n` are active low
- `_i` are input signals
- `_o` are output signals
- `_io` are bi-directional input/output signals

## 1.4. Attributes

The names of attributes in this document are formatted in title case and italicized (*Attribute Name*).

## 2. Functional Description

### 2.1. Overview

Video scaling is the process of calculating values for the pixels in an output frame of dimensions  $X_{out}$ -by- $Y_{out}$  from the values of pixels in an input frame of dimensions  $X_{in}$ -by- $Y_{in}$ . Scaling up by an integer multiple involves inserting new pixels between the original pixels in the input frame and calculating each new pixel value as a weighted sum of nearby original pixel values. The number of original pixel values and their weights depends on the scaling algorithm employed. In general, including more original pixels in the calculation results in a higher quality result (but requires more FPGA resources). Conversely, down-scaling by an integer multiple involves dropping unneeded input pixels. Typically, the drop operation is preceded by a two-dimensional low-pass filter to avoid a jagged appearance in the output frame. The low-pass filtering operation is itself a weighted sum of nearby input pixels. The set of weights is referred to as the filter kernel or coefficient set.

Figure 2.1 shows the functional diagram of the 2D Scaler IP Core.



Figure 2.1. 2D Scaler IP Core Functional Diagram

2D Scaler IP Core allows different scaling factors for the horizontal and vertical dimensions. It uses a separable filter architecture which, as depicted by the block diagram, performs the vertical and horizontal scaling in two steps. The input pixel data is first stored in the line buffer. The size of the line buffer is dictated by the number of the vertical filter taps and the maximum input frame width. Pixel data are read out of the line buffer and passed to the vertical filter column by column. Likewise, the vertical filter coefficients are read out of the coefficient memories and passed to the vertical filter for processing along with the pixel data. The row outputs from the vertical filter are then passed to the horizontal filter to generate the output pixels. Output precision control is then performed on the final output pixel value.

It supports in-system re-programming of the input and output frame sizes via a parameter bus. If the IP Core is configured for dynamic parameter updating, then the maximum input and output frame resolutions need to be specified so that line buffer and various counters can be configured appropriately. Also the parameter bus can be configured to run on a separate clock. By default, the parameter bus runs on the input pixel sample clock.

When processing YCbCr 4:2:2 video format, the core averages neighboring pixels' Cb and Cr vectors to construct YCbCr 4:4:4 format for scaling.

Figure 2.2 shows the top-level diagram of 2D Scaler IP Core.



Figure 2.2. 2D Scaler IP Core Block Diagram

## 2.2. Algorithm and Supported Filter Kernels

Video scaling is a process of generating pixels that do not exist in the original image. In order to compute an output pixel from a set of fixed input pixels, it is necessary to map the output pixel to the input pixel grid and estimate the location of the output pixel relative to the input pixels. The algorithm approximates the output pixel value by using a filter with coefficients weighted accordingly.

A 4-tap Bicubic filter uses four adjacent input pixels to interpolate an output pixel, for example. The spaces between the adjacent pixels are divided into a configurable number of positions called phases so that the output pixel is mapped into one of these positions. The weights of the coefficients are determined by the positions or phases and how close they are to the output pixel. The higher the number of phases, the more accurate is the interpolated output pixel.



$$Dst = Pn-1 * \text{coeff}(1+v) + Pn * \text{coeff}(v) + Pn+1 * \text{coeff}(1-v) + Pn+2 * \text{coeff}(2-v)$$

● = Source Pixel

\* = Destination Pixel

Figure 2.3. Scaling Process with 4-Tap Bicubic Filter

The 2D Scaler IP Core supports five adaptive scaling kernels: 1-tap nearest neighbor, 2-tap bilinear, 4-tap bicubic, and configurable multi-tap Lanczos filters. The range for the sizes of the Lanczos filters is from 4 taps to 12 taps. Filter coefficients are generated at compile time when the kernel is configured.

## 2.3. Interface Descriptions

### 2.3.1. Video Input/Output

The 2D Scaler IP Core uses a simple handshake to pass pixel data into the core. The core asserts its ready output when it is ready to receive data. When the driving module has data to give the core, it drives the core's dvalid\_in\_i port to a 1 synchronously with the rising edge of the clk\_i signal, providing the input pixel data on port din\_i. The frmsync\_in\_i input should be driven to a 1 during the clock cycle when the first pixel of the first row in the incoming video frame is active.

Correspondingly, dvalid\_out\_o is active when valid output pixel data is available on dout\_o, and frmsync\_out\_o marks the first pixel, first row of the output video frame. When the input signal dout\_enable\_i is asserted, the core outputs video pixels. When dout\_enable\_i is de-asserted, the core stops generating output pixels after some pipeline delay. The maximum pipeline delay is not greater than 26 clock cycles.

### 2.3.2. Parameter Register Read/Write Interface

The 2D Scaler IP Core uses a simple register read/write interface to update the input and output frame size control registers for dynamic scaling. The parameter bus interface can be configured to run on a separate clock. It operates at the input pixel clock by default.

When pwrite\_i is high, pwdat\_i and paddr\_i should contain valid data. The contents of all parameter registers are transferred to the core's internal storage when UPDATE is asserted. If a parameter has not been written to before the assertion of UPDATE, its old value is transferred into the internal storage. The prdat\_o contains the register read data corresponding to the address value on the paddr\_i in the previous clock cycle.

When *Parameter bus width* equals 32, paddr\_i[1:0] should be fixed to 0. When *Parameter bus width* equals to 16, paddr\_i [0] should be fixed to 0. The *Parameter bus width* is determined by the system CPU data width.

### 2.3.3. Control Signals and Timing

#### 2.3.3.1. Line and Frame Flushing

The 2D Scaler IP Core can accept pixels line by line and output the pixels line by line. There are several clock cycles required at the end of every line for the core to flush the current output line. [Figure 2.4](#) shows the line flushing cycles. The core cannot accept new input pixels during this time and pulls its ready\_o output signal low.



**Figure 2.4. Timing Diagram for Line Flushing Cycles**

Similarly, there is a frame flushing period at the end of each input frame for the core to complete the current output frame. The number of clock cycles required equals  $((\text{number of vertical filter taps}) / 2) \times (\text{input frame width} + \text{line flushing cycle})$ . [Figure 2.5](#) shows the frame flushing cycle.



Figure 2.5. Timing Diagram for Frame Flushing Cycles

### 2.3.3.2. Video Input/Output Timing

The 2D Scaler IP Core supports single color, YCbCr 4:2:2, YCbCr 4:4:4 and RGB video formats. For YCbCr 4:4:4 or RGB video formats, the three planes are interleaved for serial scaling and combined on the din\_i and dout\_o ports for parallel scaling. [Figure 2.6](#) and [Figure 2.7](#) show the timing of RGB serial scaling and parallel scaling.



Figure 2.6. RGB Serial Scaling



Figure 2.7. RGB Parallel Scaling (8-bit Pixel)

For YCbCr 4:2:2 video serial scaling, the input and output sequence should be Cb, Y, Cr, Y, .... For parallel scaling, the Y plane occupies the upper bits of the din\_i and dout\_o ports, and the Cb and Cr planes occupy the lower bits. Cb and Cr planes are interleaved in the lower half, and Cb comes before Cr. [Figure 2.8](#) and [Figure 2.9](#) show the timing of YCbCr 4:2:2 serial scaling and parallel scaling.



**Figure 2.8. YCbCr 4:2:2 Serial Scaling**



**Figure 2.9. YCbCr 4:2:2 Parallel Scaling (8-bit Pixel)**

[Figure 2.10](#) shows the dout\_enable\_i control timing. When the dout\_enable\_i is de-asserted, the core stops outputting data after the pipeline delay. Similarly, when the dout\_enable\_i is asserted, the core begins outputting data after a certain pipeline delay. The asserting and de-asserting of dout\_enable\_i can be used to generate horizontal blank and vertical blank depending on the output video format.



**Figure 2.10. dout\_enable Control Timing**

### 2.3.3.3. Dynamic Parameter Updating



**Figure 2.11. Timing Diagram for Dynamic Parameter Updating (Parameter Bus Width = 32)**

As shown in [Figure 2.11](#), IW is the input frame width, IH is the input frame height, OW is the output frame width, and OH is the output frame height. VF is the vertical scaling factor and HF the horizontal scaling factor. The parameter registers are writable only when UPDATE register is 0. When the UPDATE register bit is set to 1, the driving block should start the parameter updating at the next active frmsync\_in\_i and reset the UPDATE register to 0.

## 2.4. Signal Description

Table 2.1 lists top-level input and output signals and their description.

**Table 2.1. 2D Scaler IP Core Signal Description**

| Port Name                       | Direction | Bits                                                                                                                                                                                                                                                                                                             | Description                                                                     |
|---------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| <b>Global Signals</b>           |           |                                                                                                                                                                                                                                                                                                                  |                                                                                 |
| clk_i                           | Input     | 1                                                                                                                                                                                                                                                                                                                | System clock                                                                    |
| rstn_i                          | Input     | 1                                                                                                                                                                                                                                                                                                                | System asynchronous active-low reset signal                                     |
| ce_i <sup>1</sup>               | Input     | 1                                                                                                                                                                                                                                                                                                                | Active high clock enable.                                                       |
| sr_i <sup>2</sup>               | Input     | 1                                                                                                                                                                                                                                                                                                                | Active high synchronous reset.                                                  |
| <b>Video Input</b>              |           |                                                                                                                                                                                                                                                                                                                  |                                                                                 |
| dvalid_in_i                     | Input     | 1                                                                                                                                                                                                                                                                                                                | Input valid                                                                     |
| frmsync_in_i                    | Input     | 1                                                                                                                                                                                                                                                                                                                | Input frame sync signal, indicating current input pixel is at row 0, column 0   |
| din_i                           | Input     | $2^* \text{ Input pixel width when Video format == YCbCr4:2:2 and Parallel processing == Checked}$<br>$3^* \text{ Input pixel width when Video format == YCbCr4:4:4 or RGB and Parallel processing == Checked}$<br>$\text{Input pixel width when Parallel processing == Unchecked or Video format == Single}$    |                                                                                 |
| ready_o                         | Output    | 1                                                                                                                                                                                                                                                                                                                | Signals that core is ready to accept input video frame                          |
| <b>Video Output</b>             |           |                                                                                                                                                                                                                                                                                                                  |                                                                                 |
| dout_enable_i                   | Input     | 1                                                                                                                                                                                                                                                                                                                | Active high input from down-stream module to enable output data.                |
| dvalid_out_o                    | Output    | 1                                                                                                                                                                                                                                                                                                                | Signals that the output valid                                                   |
| frmsync_out_o                   | Output    | 1                                                                                                                                                                                                                                                                                                                | Output frame sync signal, indicating current output pixel is at row 0, column 0 |
| dout_o                          | Output    | $2^* \text{ Output pixel width when Video format == YCbCr4:2:2 and Parallel processing == Checked}$<br>$3^* \text{ Output pixel width when Video format == YCbCr4:4:4 or RGB and Parallel processing == Checked}$<br>$\text{Output pixel width when Parallel processing == Unchecked or Video format == Single}$ |                                                                                 |
| frm_resync_o <sup>3</sup>       | Output    | 1                                                                                                                                                                                                                                                                                                                | Input frame re-sync flag signal                                                 |
| fwidth_out_o <sup>4</sup>       | Output    | <i>Output frame width</i>                                                                                                                                                                                                                                                                                        | Current output frame width                                                      |
| fheight_out_o <sup>4</sup>      | Output    | <i>Output frame height</i>                                                                                                                                                                                                                                                                                       | Current output frame height                                                     |
| <b>Parameter Bus (optional)</b> |           |                                                                                                                                                                                                                                                                                                                  |                                                                                 |
| pclk_i <sup>5</sup>             | Input     | 1                                                                                                                                                                                                                                                                                                                | Configurable parameter bus clock                                                |
| pwrite_i <sup>6</sup>           | Input     | 1                                                                                                                                                                                                                                                                                                                | Active-high parameter bus write enable                                          |
| paddr_i <sup>6</sup>            | Input     | 5                                                                                                                                                                                                                                                                                                                | Parameter bus address                                                           |
| pwdat_i <sup>6</sup>            | Input     | <i>Parameter bus width</i>                                                                                                                                                                                                                                                                                       | Parameter bus write data                                                        |
| prdat_o <sup>6</sup>            | Output    | <i>Parameter bus width</i>                                                                                                                                                                                                                                                                                       | Parameter bus read data                                                         |

**Notes:**

1. Available only when *Clock enable* is Checked.
2. Available when *Synchronous reset* is Checked.
3. Available when *Input frame re-sync flag* is Checked.
4. Available when *Output frame size ports* is Checked
5. Available when *Separate parameter bus clock* is Checked
6. Available only when *Dynamic parameter updating* is Checked.

## 2.5. Attribute Summary

Table 2.2 provides the list of user selectable and compile time configurable parameters for 2D Scaler IP Core. The parameter settings are specified using the 2D Scaler IP Core user interface in Lattice Radiant software.

**Table 2.2. Attributes Table**

| Attribute                              | Selectable Values                             | Default    | Dependency on Other Attributes                                                                                                                                                                               |
|----------------------------------------|-----------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Architecture</b>                    |                                               |            |                                                                                                                                                                                                              |
| <b>Frame Dimensions</b>                |                                               |            |                                                                                                                                                                                                              |
| Video format                           | Single color, YCbCr4:2:2, YcbCr4:4:4, and RGB | YCbCr4:2:2 | —                                                                                                                                                                                                            |
| Parallel processing                    | Checked, Unchecked                            | Checked    | Editable when <i>Video format</i> is not equal to Single color                                                                                                                                               |
| Dynamic parameter updating             | Checked, Unchecked                            | Checked    | —                                                                                                                                                                                                            |
| (Max.) Input frame width               | 32-4096                                       | 720        | —                                                                                                                                                                                                            |
| (Max.) Input frame height              | 32-4096                                       | 576        | —                                                                                                                                                                                                            |
| (Max.) Output frame width              | 32-4096                                       | 1280       | —                                                                                                                                                                                                            |
| (Max.) Output frame height             | 32-4096                                       | 720        | —                                                                                                                                                                                                            |
| <b>Filter Physical Characteristics</b> |                                               |            |                                                                                                                                                                                                              |
| Scaler kernel                          | Nearest, Bilinear, Bicubic, Lanczos           | Lanczos    | —                                                                                                                                                                                                            |
| Number of vertical filter taps         | 4-12                                          | 4          | Editable only when <i>Scaler kernel</i> == Lanczos<br>Fixed to 4 when <i>Scaler kernel</i> == Bicubic<br>Fixed to 2 when <i>Scaler kernel</i> == Bilinear<br>Fixed to 1 when <i>Scaler kernel</i> == Nearest |
| Number of horizontal filter taps       | 4-12                                          | 4          | Editable only when <i>Scaler kernel</i> == Lanczos<br>Fixed to 4 when <i>Scaler kernel</i> == Bicubic<br>Fixed to 2 when <i>Scaler kernel</i> == Bilinear<br>Fixed to 1 when <i>Scaler kernel</i> == Nearest |
| Number of vertical filter phases       | 16, 32, 64, 128, 256, 512                     | 16         | Editable only when <i>Scaler kernel</i> == Lanczos<br><i>Scaler kernel</i> == Bicubic<br>Fixed to 16 when <i>Scaler kernel</i> == Bilinear or <i>Scaler kernel</i> == Nearest                                |
| Number of horizontal filter phases     | 16, 32, 64, 128, 256, 512                     | 16         | Editable only when <i>Scaler kernel</i> == Lanczos<br><i>Scaler kernel</i> == Bicubic<br>Fixed to 16 when <i>Scaler kernel</i> == Bilinear or <i>Scaler kernel</i> == Nearest                                |
| <b>I/O Specification</b>               |                                               |            |                                                                                                                                                                                                              |
| <b>Data Width</b>                      |                                               |            |                                                                                                                                                                                                              |
| Input pixel width                      | 8-16                                          | 8          | —                                                                                                                                                                                                            |
| Coefficient width                      | 6-18                                          | 9          | —                                                                                                                                                                                                            |
| Coefficient type                       | Signed, Unsigned                              | Signed     | Editable when <i>Scaler Kernel</i> != Nearest                                                                                                                                                                |
| Output pixel width                     | 8-16                                          | 8          | Editable when <i>Scaler Kernel</i> != Nearest                                                                                                                                                                |

| <b>Parameter bus</b>                                |                                |             |                                                                                                                   |
|-----------------------------------------------------|--------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Parameter bus width                                 | 8, 16, 32                      | 32          | Editable when <i>Dynamic parameter updating</i> == Checked                                                        |
| Separate parameter bus clock                        | Checked, Unchecked             | Unchecked   | Editable when <i>Dynamic parameter updating</i> is Checked                                                        |
| <b>Optional Ports</b>                               |                                |             |                                                                                                                   |
| Synchronous reset(sr_i)                             | Checked, Unchecked             | Unchecked   | —                                                                                                                 |
| Clock enable(ce_i)                                  | Checked, Unchecked             | Unchecked   | —                                                                                                                 |
| Input frame re-sync flag(frm_resync_o)              | Checked, Unchecked             | Unchecked   | —                                                                                                                 |
| Output frame size ports(fheight_out_o,fwidth_out_o) | Checked, Unchecked             | Unchecked   | Editable when <i>Dynamic parameter updating</i> == Checked                                                        |
| <b>Precision Control</b>                            |                                |             |                                                                                                                   |
| Rounding mode                                       | Truncation, Normal, Convergent | Normal      | —                                                                                                                 |
| <b>Implementation</b>                               |                                |             |                                                                                                                   |
| <b>Memory Type</b>                                  |                                |             |                                                                                                                   |
| Line buffer type                                    | EBR, Distributed               | EBR         | —                                                                                                                 |
| Vertical coefficient memory type                    | EBR, Distributed               | Distributed | Editable only when <i>Scaler kernel</i> == Lanczos<br><i>Scaler kernel</i> == Bicubic                             |
| Horizontal coefficient memory type                  | EBR, Distributed               | Distributed | Editable only when <i>Scaler kernel</i> == Lanczos<br><i>Scaler kernel</i> == Bicubic                             |
| Share vertical and horizontal coefficient memories  | Checked, Unchecked             | Unchecked   | Editable when <i>Vertical coefficient memory type</i> and <i>Horizontal coefficient memory type</i> is set to EBR |
| <b>Multiplier type</b>                              |                                |             |                                                                                                                   |
| Multiplier type                                     | DSP, LUT                       | DSP         | —                                                                                                                 |

**Table 2.3. Attributes Description**

| Attribute                              | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Frame Dimensions</b>                |                                                                                                                                                                                                                                                                                                                                                                                                     |
| Video format                           | Format of video stream.                                                                                                                                                                                                                                                                                                                                                                             |
| Parallel processing                    | Determines whether the core processes video color planes in parallel or not.                                                                                                                                                                                                                                                                                                                        |
| Dynamic parameter updating             | Determines whether the core supports parameters updating at runtime. When enabled, maximum <i>Input Frame Width</i> , maximum <i>Input Frame Height</i> , maximum <i>Output Frame Width</i> and maximum <i>Output Frame Height</i> specify the largest input and output frame sizes the core needs to support.<br>Refer to the <a href="#">Interface Descriptions</a> section for more information. |
| (Max.) Input frame width               | Width of input video frame                                                                                                                                                                                                                                                                                                                                                                          |
| (Max.) Input frame height              | Height of input video frame                                                                                                                                                                                                                                                                                                                                                                         |
| (Max.) Output frame width              | Width of output video frame                                                                                                                                                                                                                                                                                                                                                                         |
| (Max.) Output frame height             | Height of output video frame                                                                                                                                                                                                                                                                                                                                                                        |
| <b>Filter Physical Characteristics</b> |                                                                                                                                                                                                                                                                                                                                                                                                     |
| Scaler kernel                          | Selects the scaling algorithm of the core.                                                                                                                                                                                                                                                                                                                                                          |
| Number of vertical filter taps         | Represents the number of multipliers that may be used by the core for the vertical filter                                                                                                                                                                                                                                                                                                           |
| Number of horizontal filter taps       | Represents the number of multipliers that may be used by the core for the horizontal filter                                                                                                                                                                                                                                                                                                         |
| Number of vertical filter phases       | Sets the number of phases of the vertical filter                                                                                                                                                                                                                                                                                                                                                    |

| Attribute                                          | Description                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of horizontal filter phases                 | Sets the number of phases of the vertical filter                                                                                                                                                                                                                                                             |
| <b>I/O Specification</b>                           |                                                                                                                                                                                                                                                                                                              |
| <b>Data width</b>                                  |                                                                                                                                                                                                                                                                                                              |
| Input pixel width                                  | Sets the bit width of the incoming pixel values                                                                                                                                                                                                                                                              |
| Coefficient width                                  | Sets the bit width of the coefficient                                                                                                                                                                                                                                                                        |
| Coefficient type                                   | Determine whether coefficient is signed or unsigned                                                                                                                                                                                                                                                          |
| Output pixel width                                 | Sets the output pixel bit width                                                                                                                                                                                                                                                                              |
| <b>Parameter bus</b>                               |                                                                                                                                                                                                                                                                                                              |
| Parameter bus width                                | Sets the bus width of the parameter register's read/write interface                                                                                                                                                                                                                                          |
| Separate parameter bus clock                       | Determines whether the core uses a separate clock to run the parameter update interface.                                                                                                                                                                                                                     |
| <b>Optional ports</b>                              |                                                                                                                                                                                                                                                                                                              |
| Synchronous reset (sr_i)                           | Determines whether the core has a synchronous reset port.                                                                                                                                                                                                                                                    |
| Clock enable (ce_i)                                | Determines whether the core has a clock enable port.                                                                                                                                                                                                                                                         |
| Input frame re-sync flag                           | Determines whether the core has a re-sync port.                                                                                                                                                                                                                                                              |
| Output frame size ports                            | Determines whether the core provides output frame size ports                                                                                                                                                                                                                                                 |
| <b>Precision Control</b>                           |                                                                                                                                                                                                                                                                                                              |
| Rounding mode                                      | Selects rounding mode for the output pixel value.<br>Normal: Rounds away from zero if the fractional part is exactly one-half.<br>Truncation: Discards all bits to the right of the output's least significant bit.<br>Convergent: Rounds to the nearest integer if the fractional part is exactly one-half. |
| <b>Implementation</b>                              |                                                                                                                                                                                                                                                                                                              |
| <b>Memory type</b>                                 |                                                                                                                                                                                                                                                                                                              |
| Line buffer type                                   | Selects memory type for the line buffer implementation                                                                                                                                                                                                                                                       |
| Vertical coefficient memory type                   | Selects memory type for the vertical coefficient memory                                                                                                                                                                                                                                                      |
| Horizontal coefficient memory type                 | Selects memory type for the horizontal coefficient memory                                                                                                                                                                                                                                                    |
| Share vertical and horizontal coefficient memories | Determines whether the core uses one memory for both the vertical and horizontal coefficients                                                                                                                                                                                                                |
| <b>Multiplier type</b>                             |                                                                                                                                                                                                                                                                                                              |
| Multiplier type                                    | Selects the multiplier type to be used on scaling                                                                                                                                                                                                                                                            |

## 2.6. Register Description

The 2D Scaler IP Core supports in-system input and output frame sizes updating via a register read/write interface called parameter ports. The parameter registers are listed below on [Table 2.4](#).

**Table 2.4. Dynamic Parameter Updating Register Description**

| Address | Register Name | Size | Access Type | Description                                                                                                                                                                                                                                                                                                                                                  |
|---------|---------------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0000  | FRMWIDTH      | 32   | R/W         | Input frame width register –<br>The FRMWIDTH value must be the input frame width minus 1. The minimum value is 31, and the maximum value is the maximum input frame width specified on the IP user interface minus 1. The default value is the maximum value. Input frame width must be an even number for YCbCr4:2:2 format (that is FRMWIDTH must be odd). |
| 0x0004  | FRMHEIGHT     | 32   | R/W         | Input frame height register –<br>The FRMHEIGHT must be the input frame height minus 1. The minimum value is 31, and the maximum value is the maximum input frame height specified on the IP user interface minus 1. The default value is the maximum value.                                                                                                  |
| 0x0008  | OUTWIDTH      | 32   | R/W         | Output frame width register –<br>The OUTWIDTH must be the output frame width minus 1. The minimum value is 31, and the maximum value is the maximum output frame width specified on the IP user interface minus 1. The default value is the maximum value. Output frame width must be an even number for YCbCr4:2:2 format (that is OUTWIDTH must be odd).   |
| 0x000C  | OUTHEIGHT     | 32   | R/W         | Output frame height register –<br>The OUTHEIGHT must be the output frame height minus 1. The minimum value is 31, and the maximum value is the maximum output frame height specified on the IP user interface minus 1. The default value is the maximum value.                                                                                               |
| 0x0010  | VSFATOR       | 32   | R/W         | Vertical scaling factor register –<br>$VSFACTOR = ((FRMHEIGHT+1) \times (1 << VFCBPWIDTH)) / (OUTHEIGHT+1)$ Where VFCBPWIDTH is the maximum value of $\log_2$ (maximum output frame height) and $\log_2$ (number of vertical filter phases).                                                                                                                 |
| 0x0014  | HSFACTOR      | 32   | R/W         | Horizontal scaling factor register –<br>$HSFACTOR = ((FRMWIDTH+1) \times (1 << HFCBPWIDTH)) / (OUTWIDTH+1)$ Where HFCBPWIDTH is the maximum value of $\log_2$ (maximum output frame width) and $\log_2$ (number of the horizontal filter phases).                                                                                                            |
| 0x0018  | UPDATE        | 32   | R/W         | Update parameter enable register –<br>When the writing of the parameter registers is complete, you should set this register to 1 to enable the parameter's status. The default value is 0. When the core updates the new parameters, it resets this register to 0.                                                                                           |

The parameter registers can be written to only when the UPDATE register bit is 0. When the UPDATE bit is set to 1, the six parameters inside the core are updated with the new values when the frmsync\_in signal is active, indicating a new input frame is arriving. After updating its internal parameters, the core resets the UPDATE bit to 0 to indicate that the parameter registers are now empty and can take on new values.

When dynamic parameter updating is enabled, you need to configure the largest input and output frame sizes the system expects to handle. This is so that the line buffer and various counters within the core can be configured properly. The core uses the default values for the input and output frame sizes to start until the driving block updates the parameters in the subsequent frames. The default values are the maximum input frame size and the maximum output frame size.

For most cases, VFCBPWIDTH equals to log2 (output frame height) for fixed scaler and log2(maximum output frame height) for dynamic scaler. HFCBPWIDTH equals to log2 (output frame width) for fixed scaler and log2 (maximum output frame width) for dynamic scaler. When the number of vertical phases is greater than the maximum output frame height, the VFCBPWIDTH equals to log2 (number of the vertical filter phases). When the number of horizontal phases is greater than the maximum output frame width, the HFCBPWIDTH equals to log2 (number of horizontal filter phases).

For the nearest neighbor and bilinear kernels, when the VFCBPWIDTH is smaller than the vertical coefficient bit width, its value should be replaced by the vertical coefficient bit width. Similarly, when the HFCBPWIDTH is smaller than the horizontal coefficient bit width, its value should be replaced by the horizontal coefficient bit width.

The values of VFCBPWIDTH and HFCBPWIDTH can be found in the generated parameter value file:  
`\<project_dir>\scaler_eval\<username>\rtl\params\params.v.`

## 3. IP Generation and Evaluation

This section provides information on how to generate the 2D Scaler 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.

### 3.1. Licensing the IP

The 2D Scaler IP is provided at no additional cost with the Lattice Radiant software.

### 3.2. Generation and Synthesis

The Lattice Radiant Software allows you to customize and generate modules and IPs and integrate them into the device's architecture. The procedure for generating the 2D Scaler IP Core in Lattice Radiant software is described below.

To generate the 2D Scaler IP Core:

1. Create a new Lattice Radiant software project or open an existing project.
2. In the **IP Catalog** tab, double-click **Scaler** under the **IP, DSP** category. The **Module/IP Block Wizard** opens as shown in [Figure 3.1](#). Enter values in the **Component name** and the **Create in** fields and click **Next**.



**Figure 3.1. Module/IP Block Wizard**

3. In the module's dialog box of the **Module/IP Block Wizard** window, customize the selected 2D Scaler IP Core using drop-down menus and check boxes. As a sample configuration, see [Figure 3.2](#). For configuration options, see the [Attribute Summary](#) section.



Figure 3.2. Configure User Interface of 2D Scaler IP Core

4. Click **Generate**. The **Check Generating Result** dialog box opens, showing design block messages and results as shown in Figure 3.3.



Figure 3.3. Check Generating Result

5. Click the **Finish** button. All the generated files are placed under the directory paths in the **Create in** and the **Component name** fields shown in [Figure 3.1](#).

The generated 2D Scaler IP Core 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 IP core 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 3.1](#).

**Table 3.1. Generated File List**

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

### 3.3. Running Functional Simulation

After the IP is generated, running functional simulation can be performed using different available simulators. The default simulator already has pre-compiled libraries ready for simulation. Choosing a non-default simulator, however, may require additional steps.

To run functional simulation using default simulator:

1. Click the  button located on the **Toolbar** to initiate the **Simulation Wizard** shown in [Figure 3.4](#).



**Figure 3.4. Simulation Wizard**

2. Click **Next** to open the **Add and Reorder Source** window as shown in [Figure 3.5](#).



**Figure 3.5. Adding and Reordering Source**

3. Click **Next**. The **Summary** window is shown.

4. Click **Finish** to run the simulation.

**Note:** It is necessary to follow the procedure above until it is fully automated in the Lattice Radiant software suite.

The results of the simulation in our example are provided in [Figure 3.6](#).



**Figure 3.6. Simulation Waveform**

### 3.4. Hardware Evaluation

The 2D Scaler IP Core supports Lattice's IP hardware evaluation capability when used with CrossLink-NX and Certus-NX devices. This makes it possible to create versions of the IP core that operate in hardware for a limited period of time (approximately four hours) without requiring the purchase of an IP license. It may also be used to evaluate the core in hardware in user-defined designs. The hardware evaluation capability may be enabled/disabled in the Strategy dialog box. It is enabled by default. To change this setting, go to Project > Active Strategy > LSE/Synplify Pro Settings.

## 4. Design Considerations

### 4.1. Limitations

- Some IP configurations may have slower Fmax when used in Nexus with fast speed grade. The following Fmax values are approximate and may vary depending on the system-level design:
  - 172 MHz for *Video format* == "Single Color"
  - 165 MHz for *Video format* == "YCbCr4:2:2"
  - 162 MHz for *Video format* == "YCbCr4:4:4" or "RGB"
- Some IP configurations may have slower Fmax when used in Nexus with slow speed grade. The following Fmax values are approximate and may vary depending on the system-level design:
  - 139 MHz for *Video format* == "Single Color"
  - 130 MHz for *Video format* == "YCbCr4:2:2"
  - 132 MHz for *Video format* == "YCbCr4:4:4" or "RGB"
- IP configurations using *Video format* == "YCbCr4:4:4" or "RGB" and *Parallel processing* == unchecked may result in simulation failures due to data mismatches caused by design limitations. To avoid this, consider setting *Parallel processing* == checked.
- IP configurations using *Video format* == "YCbCr4:2:2", *Scaler kernel* == "Lanczos" or "Bicubic", *Line buffer type* == "Distributed", and *Vertical coefficient memory type* == "EBR" may result in simulation failures due to data mismatches caused by design limitations. To avoid this, consider changing at least one of the listed attributes.

## Appendix A. Resource Utilization

2D Scaler IP Core resource utilization are shown on [Table A.1](#) using LIFCL-40-9BG400I device and [Table A.2](#) using LFD2NX-40-9BG256I with Synplify Pro synthesis engine of the Lattice Radiant software 2025.2. Default configuration is used and some attributes are changed from the default value to show the effect on the resource utilization.

**Table A.1. Resource Utilization using LIFCL-40-9BG400I**

| Configuration                                                                                                        | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs <sup>2</sup> | EBRs | DSPs |
|----------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|-------------------|------|------|
| YCbCr422, 720x480 to 1280x720, Parallel Processing and Dynamic parameter updating disabled, Others = Default         | 200                         | 1153      | 1244              | 4    | 4    |
| YCbCr422, 1280x720 to 720x480, Parallel Processing enabled and Dynamic parameter updating disabled, Others = Default | 200                         | 1443      | 1413              | 8    | 8    |
| RGB, 1280x720 to 1920x1080, Parallel Processing enabled and Dynamic parameter updating enabled, Others = Default     | 200                         | 1913      | 2034              | 11   | 12   |

**Notes:**

1. Fmax is generated when the FPGA design only contains 2D Scaler IP core and the target frequency is 200 MHz. These values may be reduced when user logic is added to the FPGA design.
2. The *distributed RAM* utilization is accounted for in the total LUT4s utilization. The actual LUT4 utilization is distribution among *logic*, *distributed RAM*, and *ripple logic*.

**Table A.2. Resource Utilization using LFD2NX-40-9BG256I**

| Configuration                                                                                                        | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs <sup>2</sup> | EBRs | DSPs |
|----------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|-------------------|------|------|
| YCbCr422, 720x480 to 1280x720, Parallel Processing and Dynamic parameter updating disabled, Others = Default         | 200                         | 1153      | 1244              | 4    | 4    |
| YCbCr422, 1280x720 to 720x480, Parallel Processing enabled and Dynamic parameter updating disabled, Others = Default | 200                         | 1443      | 1413              | 8    | 8    |
| RGB, 1280x720 to 1920x1080, Parallel Processing enabled and Dynamic parameter updating enabled, Others = Default     | 200                         | 1913      | 2034              | 11   | 12   |

**Notes:**

1. Fmax is generated when the FPGA design only contains 2D Scaler IP core and the target frequency is 200 MHz. These values may be reduced when user logic is added to the FPGA design.
2. The *distributed RAM* utilization is accounted for in the total LUT4s utilization. The actual LUT4 utilization is distribution among *logic*, *distributed RAM*, and *ripple logic*.

## References

- [2D Scaler IP Release Notes \(FPGA-RN-02050\)](#)
- [Lattice Radiant Timing Constraints Methodology \(FPGA-AN-02059\)](#)
- [Certus-NX web page](#)
- [CertusPro-NX web page](#)
- [CrossLink-NX web page](#)
- [MachXO5-NX web page](#)
- [Lattice Radiant Software 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](http://www.latticesemi.com/techsupport).

For frequently asked questions, refer to the Lattice Answer Database at  
[www.latticesemi.com/Support/AnswerDatabase](http://www.latticesemi.com/Support/AnswerDatabase).

## 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.4, IP v1.4.1, December 2025

| Section                      | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                 | <p>In <a href="#">Table 1.1. Quick Facts</a>:</p> <ul style="list-style-type: none"> <li>Updated IP version from <i>IP Core v1.4.0</i> to <i>IP Core v1.4.1</i>.</li> <li>Updated software version from <i>Lattice Radiant™ software 2025.1</i> to <i>Lattice Radiant™ software 2025.2</i>.</li> <li>Added notes.</li> </ul>                                                                                                                                                                   |
| IP Generation and Evaluation | <ul style="list-style-type: none"> <li>Updated <a href="#">Licensing the IP</a> section, <i>The 2D Scaler IP is provided at no additional cost with the Lattice Radiant software</i>.</li> <li>Updated the following figures: <ul style="list-style-type: none"> <li><a href="#">Figure 3.1. Module/IP Block Wizard</a></li> <li><a href="#">Figure 3.2. Configure User Interface of 2D Scaler IP Core</a></li> <li><a href="#">Figure 3.3. Check Generating Result</a></li> </ul> </li> </ul> |
| Ordering Part Number         | Removed this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Design Considerations        | <ul style="list-style-type: none"> <li>Added this section.</li> <li>Added <a href="#">Limitations</a> subsection.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                   |
| Resource Utilization         | Updated resource utilization for the latest software version.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Revision History             | Added note.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### Revision 1.3, IP v1.4.0, July 2025

| Section                      | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                 | <p>Updated Table 1.1. Quick Facts as follows:</p> <ul style="list-style-type: none"> <li>Renamed <i>Supported FPGA Families</i> to <i>Supported Devices</i>.</li> <li>Added support for MachXO5-NX devices.</li> <li>Removed the <i>Targeted Devices</i> row.</li> <li>Added IP version.</li> </ul>                                                                                                                 |
| IP Generation and Evaluation | <p>Updated the following figures:</p> <ul style="list-style-type: none"> <li><a href="#">Figure 3.1. Module/IP Block Wizard</a></li> <li><a href="#">Figure 3.2. Configure User Interface of 2D Scaler IP Core</a></li> <li><a href="#">Figure 3.3. Check Generating Result</a></li> <li><a href="#">Figure 3.4. Simulation Wizard</a></li> <li><a href="#">Figure 3.5. Adding and Reordering Source</a></li> </ul> |
| Ordering Part Number         | <ul style="list-style-type: none"> <li>Added OPN for MachXO5-NX devices.</li> <li>Changed <i>Multi-site Perpetual</i> to <i>Single Seat Perpetual</i>.</li> </ul>                                                                                                                                                                                                                                                   |
| Resource Utilization         | Updated resource utilization for the latest software version.                                                                                                                                                                                                                                                                                                                                                       |
| References                   | Updated references.                                                                                                                                                                                                                                                                                                                                                                                                 |

### Revision 1.2, IP v1.3.0, December 2024

| Section            | Change Summary                                                                                                                                                        |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                | Renamed document from <i>2D Scaler IP Core - Lattice Radiant Software</i> to <i>2D Scaler IP</i> .                                                                    |
| Disclaimers        | Updated disclaimers.                                                                                                                                                  |
| Inclusive Language | Added the inclusive language boilerplate.                                                                                                                             |
| Introduction       | <p>Updated Table 1.1. Quick Facts.</p> <ul style="list-style-type: none"> <li>Added support for LFD2NX-9 and LFD2NX-28 devices.</li> <li>Added IP changes.</li> </ul> |

| Section                      | Change Summary                                                                         |
|------------------------------|----------------------------------------------------------------------------------------|
|                              | <ul style="list-style-type: none"> <li>Updated IP version.</li> </ul>                  |
| IP Generation and Evaluation | Changed <i>black box</i> to <i>closed-box</i> in the Generation and Synthesis section. |
| Ordering Part Number         | Updated the OPN for the devices.                                                       |
| References                   | Updated references.                                                                    |
| Technical Support Assistance | Added link to the Lattice Answer Database.                                             |

**Document Revision 1.1, Lattice Radiant SW Version 3.0, June 2021**

| Section              | Change Summary                                                    |
|----------------------|-------------------------------------------------------------------|
| All                  | Minor adjustment in formatting.                                   |
| Introduction         | Updated content, including Table 1.1 to add CertusPro-NX support. |
| Ordering Part Number | Added part number for CertusPro-NX.                               |
| References           | Updated this section to add CertusPro-NX web page.                |

**Document Revision 1.0, Lattice Radiant SW Version 2.1, December 2020**

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





[www.latticesemi.com](http://www.latticesemi.com)