# MAX 10 Embedded Multipliers User Guide



UG-M10DSP 2017.02.21

101 Innovation Drive San Jose, CA 95134 www.altera.com



# Contents

| MAX <sup>®</sup> 10Embedded Multipliers Features and Architecture | 2-1 |
|-------------------------------------------------------------------|-----|
| Embedded Multipliers Architecture                                 |     |
| Input Register                                                    |     |
| Multiplier Stage                                                  |     |
| Output Register                                                   |     |
| Embedded Multipliers Operational Modes                            |     |
| 18-Bit Multipliers                                                |     |
| 9-Bit Multipliers                                                 | 2-4 |
| MAX 10 Embedded Multipliers Implementation Guides                 |     |
| Files Generated by IP Cores                                       | 3-1 |
| Verilog HDL Prototype Location                                    |     |
| VHDL Component Declaration Location                               |     |
| LPM_MULT (Multiplier) IP Core References for MAX 10               |     |
| LPM_MULT Parameter Settings                                       | 4-1 |
| Signals                                                           |     |
| ALTMULT_ACCUM (Multiply-Accumulate) IP Core References for        |     |
| MAX 10                                                            | 5-1 |
| ALTMULT_ACCUM Parameter Settings                                  |     |
| ALTMULT_ACCUM Ports                                               |     |
| ALTMULT_ADD (Multiply-Adder) IP Core References for MAX 10        | 6-1 |
| ALTMULT_ADD Parameter Settings                                    |     |
| ALTMULT_ADD Ports                                                 |     |
| ALTMULT_COMPLEX (Complex Multiplier) IP Core References for       |     |
| MAX 10                                                            | 7-1 |
| ALTMULT_COMPLEX Parameter Settings                                |     |
| Signals                                                           | 7.2 |

| Additional Information for MAX 10 Embedded Multipliers User Guide    | B-1 |
|----------------------------------------------------------------------|-----|
| Document Revision History for MAX 10 Embedded Multipliers User Guide | B-1 |

# MAX<sup>®</sup> 10Embedded Multiplier Block Overview



The embedded multiplier is configured as either one 18 x 18 multiplier or two 9 x 9 multipliers. For multiplications greater than 18 x 18, the Quartus<sup>®</sup> Prime software cascades multiple embedded multiplier blocks together. There are no restrictions on the data width of the multiplier but the greater the data width, the slower the multiplication process.

#### Figure 1-1: Embedded Multipliers Arranged in Columns with Adjacent LABS



#### Table 1-1: Number of Embedded Multipliers in the MAX<sup>®</sup> 10 Devices

| Device | Embedded<br>Multipliers | 9 x 9 Multipliers <sup>(1)</sup> | 18 x 18 Multipliers <sup>(1)</sup> |
|--------|-------------------------|----------------------------------|------------------------------------|
| 10M02  | 16                      | 32                               | 16                                 |
| 10M04  | 20                      | 40                               | 20                                 |
| 10M08  | 24                      | 48                               | 24                                 |
| 10M16  | 45                      | 90                               | 45                                 |

<sup>(1)</sup> These columns show the number of 9 x 9 or 18 x 18 multipliers for each device. The total number of multipliers for each device is not the sum of all the multipliers.

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.

ISO 9001:2015 Registered



#### 1-2 MAX<sup>®</sup> 10Embedded Multiplier Block Overview

| Device | Embedded<br>Multipliers | 9 x 9 Multipliers <sup>(1)</sup> | 18 x 18 Multipliers <sup>(1)</sup> |
|--------|-------------------------|----------------------------------|------------------------------------|
| 10M25  | 55                      | 110                              | 55                                 |
| 10M40  | 125                     | 250                              | 125                                |
| 10M50  | 144                     | 288                              | 144                                |

You can implement soft multipliers by using the M9K memory blocks as look-up tables (LUTs). The LUTs contain partial results from multiplying input data with coefficients implementing variable depth and width high-performance soft multipliers for low-cost, high-volume DSP applications. The availability of soft multipliers increases the number of available multipliers in the device.

#### Table 1-2: Number of Multipliers in the MAX<sup>®</sup> 10 Devices

| Device | Embedded<br>Multipliers | Soft Multipliers<br>(16 x 16) <sup>(2)</sup> | Total Multipliers <sup>(3)</sup> |
|--------|-------------------------|----------------------------------------------|----------------------------------|
| 10M02  | 16                      | 12                                           | 28                               |
| 10M04  | 20                      | 21                                           | 41                               |
| 10M08  | 24                      | 42                                           | 66                               |
| 10M16  | 45                      | 61                                           | 106                              |
| 10M25  | 55                      | 75                                           | 130                              |
| 10M40  | 125                     | 140                                          | 265                              |
| 10M50  | 144                     | 182                                          | 326                              |

#### **Related Information**

MAX 10 Embedded Multipliers User Guide Archives on page 8-1 Provides a list of user guides for previous versions of the LPM\_MULT, ALTMULT\_ACCUM, ALTMULT\_ADD, and ALTMULT\_COMPLEX IP cores.

MAX 10Embedded Multiplier Block Overview



<sup>&</sup>lt;sup>(1)</sup> These columns show the number of 9 x 9 or 18 x 18 multipliers for each device. The total number of multipliers for each device is not the sum of all the multipliers.

<sup>&</sup>lt;sup>(2)</sup> Soft multipliers are implemented in sum of multiplication mode. M9K memory blocks are configured with 18-bit data widths to support 16-bit coefficients. The sum of the coefficients requires 18-bits of resolution to account for overflow.

<sup>&</sup>lt;sup>(3)</sup> The total number of multipliers may vary, depending on the multiplier mode you use.

# MAX<sup>®</sup> 10Embedded Multipliers Features and Architecture 2

2017.02.21

UG-M10DSP Subscribe Send Feedback

Each embedded multiplier consists of three elements. Depending on the application needs, you can use an embedded multiplier block in one of two operational modes.

## **Embedded Multipliers Architecture**

Each embedded multiplier consists of the following elements:

- Multiplier stage
- Input and output registers
- Input and output interfaces

#### Figure 2-1: Multiplier Block Architecture



#### **Input Register**

Depending on the operational mode of the multiplier, you can send each multiplier input signal into either one of the following:

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.

ISO 9001:2015 Registered



#### 2-2 Multiplier Stage

- An input register
- The multiplier in 9- or 18-bit sections

Each multiplier input signal can be sent through a register independently of other input signals. For example, you can send the multiplier Data A signal through a register and send the Data B signal directly to the multiplier.

The following control signals are available to each input register in the embedded multiplier:

- Clock
- Clock enable
- Asynchronous clear

All input and output registers in a single embedded multiplier are fed by the same clock, clock enable, and asynchronous clear signals.

#### **Multiplier Stage**

The multiplier stage of an embedded multiplier block supports  $9 \times 9$  or  $18 \times 18$  multipliers and other multipliers in between these configurations. Depending on the data width or operational mode of the multiplier, a single embedded multiplier can perform one or two multiplications in parallel.

Each multiplier operand is a unique signed or unsigned number. Two signals, signa and signb, control an input of a multiplier and determine if the value is signed or unsigned. If the signa signal is high, the Data A operand is a signed number. If the signa signal is low, the Data A operand is an unsigned number.

The following table lists the sign of the multiplication results for the various operand sign representations. The results of the multiplication are signed if any one of the operands is a signed value.

| Data A      |             | Data B      |             | Result   |  |
|-------------|-------------|-------------|-------------|----------|--|
| signa Value | Logic Level | signb Value | Logic Level | nesuit   |  |
| Unsigned    | Low         | Unsigned    | Low         | Unsigned |  |
| Unsigned    | Low         | Signed      | High        | Signed   |  |
| Signed      | High        | Unsigned    | Low         | Signed   |  |
| Signed      | High        | Signed      | High        | Signed   |  |

You can dynamically change the signa and signb signals to modify the sign representation of the input operands at run time. You can send the signa and signb signals through a dedicated input register. The multiplier offers full precision, regardless of the sign representation.

When the signa and signb signals are unused, the Quartus Prime software sets the multiplier to perform unsigned multiplication by default.

#### **Output Register**

You can register the embedded multiplier output using output registers in either 18- or 36-bit sections. This depends on the operational mode of the multiplier. The following control signals are available for each output register in the embedded multiplier:



- Clock
- Clock enable
- Asynchronous clear

All input and output registers in a single embedded multiplier are fed by the same clock, clock enable, and asynchronous clear signals.

## **Embedded Multipliers Operational Modes**

You can use an embedded multiplier block in one of two operational modes, depending on the application needs:

- One 18-bit x 18-bit multiplier
- Up to two 9-bit x 9-bit independent multipliers

You can also use embedded multipliers of the MAX<sup>®</sup> 10 devices to implement multiplier adder and multiplier accumulator functions. The multiplier portion of the function is implemented using embedded multipliers. The adder or accumulator function is implemented in logic elements (LEs).

#### **18-Bit Multipliers**

You can configure each embedded multiplier to support a single 18 x 18 multiplier for input widths of 10 to 18 bits.

The following figure shows the embedded multiplier configured to support an 18-bit multiplier.







#### 2-4 9-Bit Multipliers

All 18-bit multiplier inputs and results are independently sent through registers. The multiplier inputs can accept signed integers, unsigned integers, or a combination of both. Also, you can dynamically change the signa and signb signals and send these signals through dedicated input registers.

#### 9-Bit Multipliers

You can configure each embedded multiplier to support two  $9 \times 9$  independent multipliers for input widths of up to 9 bits.

The following figure shows the embedded multiplier configured to support two 9-bit multipliers.

#### Figure 2-3: 9-Bit Multiplier Mode



All 9-bit multiplier inputs and results are independently sent through registers. The multiplier inputs can accept signed integers, unsigned integers, or a combination of both.



Each embedded multiplier block has only one signa and one signb signal to control the sign representation of the input data to the block. If the embedded multiplier block has two  $9 \times 9$  multipliers the following applies:

- The Data A input of both multipliers share the same signa signal •
- The Data B input of both multipliers share the same signb signal



# MAX 10 Embedded Multipliers Implementation Guides 3

2017.02.21

UG-M10DSP

Subscribe Send Feedback

The Quartus Prime software contains tools for you to create and compile your design, and configure your device.

You can prepare for device migration, set pin assignments, define placement restrictions, setup timing constraints, and customize IP cores using the Quartus Prime software.

#### **Related Information**

- Introduction to Intel FPGA IP Cores Provides general information about all Intel FPGA IP cores, including parameterizing, generating, upgrading, and simulating IP cores.
- Creating Version-Independent IP and Qsys Simulation Scripts Create simulation scripts that do not require manual updates for software or IP version upgrades.
- **Project Management Best Practices** Guidelines for efficient management and portability of your project and IP files.

### **Files Generated by IP Cores**

The following integer arithmetic IP cores use the MAX 10 device embedded multipliers block:

- LPM\_MULT
- ALTMULT\_ACCUM (MAC)
- ALTMULT\_ADD
- ALTMULT\_COMPLEX

#### **Verilog HDL Prototype Location**

You can view the Verilog HDL prototype for the IP cores in the following Verilog Design Files (.v):

#### Table 3-1: Verilog HDL Prototype Location

| Integer Arithmetic Megafunctions | Directory                                                                  | Verilog Design File (.v) |
|----------------------------------|----------------------------------------------------------------------------|--------------------------|
| LPM_MULT                         | <quartus installation<br="" prime="">directory&gt;\eda\synthesis</quartus> | lpm.v                    |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered



| Integer Arithmetic Megafunctions                                            | Directory                                                                  | Verilog Design File (.v) |
|-----------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------|
| <ul><li>ALTMULT_ACCUM</li><li>ALTMULT_ADD</li><li>ALTMULT_COMPLEX</li></ul> | <quartus installation<br="" prime="">directory&gt;\eda\synthesis</quartus> | altera_mf.v              |

#### **VHDL Component Declaration Location**

You can view the VHDL component declaration for the IP cores in the following VHDL Design Files (.vhd):

| Integer Arithmetic Megafunctions                                            | Directory                                                                                  | VHDL Design File (.vhd)  |
|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------|
| LPM_MULT                                                                    | <quartus installation<br="" prime="">directory&gt;\libraries\vhdl\lpm</quartus>            | LPM_PACK.vhd             |
| <ul><li>ALTMULT_ACCUM</li><li>ALTMULT_ADD</li><li>ALTMULT_COMPLEX</li></ul> | <quartus installation<br="" prime="">directory&gt;\libraries\vhdl\altera_<br/>mf</quartus> | altera_mf_components.vhd |



## LPM\_MULT (Multiplier) IP Core References for MAX 10

2017.02.21

UG-M10DSP

Subscribe Send Feedback

## LPM\_MULT Parameter Settings

There are three groups of options: General, General2, and Pipeling.

#### Table 4-1: LPM\_MULT Parameters - General

| This table lists the IP core parameters applicable to MAX 10 devices.                                  |                |                                                                                                                |                                                                                                                                                    |                                               |
|--------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| GUI Parameter                                                                                          | Parameter      | Condition                                                                                                      | Value                                                                                                                                              | Description                                   |
| Multiplier configuration                                                                               | _              | _                                                                                                              | <ul> <li>Multiply<br/>'dataa' input<br/>by 'datab' input</li> <li>Multiply<br/>'dataa' input<br/>by itself<br/>(squaring<br/>operation)</li> </ul> | Specifies the multiplier<br>configuration.    |
| How wide should the<br>'dataa' input be?                                                               | LPM_<br>WIDTHA |                                                                                                                | 1–256                                                                                                                                              | Specifies the width of the dataa[] port.      |
| How wide should the 'datab' input be?                                                                  | LPM_<br>WIDTHB |                                                                                                                | 1–256                                                                                                                                              | Specifies the width of the datab[] port.      |
| How should the width of<br>the 'result' output be<br>determined?                                       | LPM_<br>WIDTHP | _                                                                                                              | <ul> <li>Automatically calculate the width</li> <li>Restrict the width to [] bits</li> </ul>                                                       | Specifies how the result width is determined. |
| How should the width of<br>the 'result' output be<br>determined? ><br>Restrict the width to []<br>bits | LPM_<br>WIDTHP | How should the<br>width of the<br>'result' output be<br>determined? ><br>Restrict the width<br>to [] bits = On | 1–256                                                                                                                                              | You can set the result<br>width.              |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered



#### Table 4-2: LPM\_MULT Parameters - General2

This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                                           | Parameter                              | Condition | Value                                                                                                                                                                                         | Description                                                                |
|---------------------------------------------------------|----------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| Does the 'datab' input<br>bus have a constant<br>value? | _                                      |           | <ul><li>No</li><li>Yes, the value is</li></ul>                                                                                                                                                | You can specify the<br>constant value of the<br>'datab' input bus, if any. |
| Which type of multiplica-<br>tion do you want?          | LPM_<br>REPRESENTATIO<br>N             | _         | <ul><li>Unsigned</li><li>Signed</li></ul>                                                                                                                                                     | Specifies the type of<br>multiplication<br>performed.                      |
| Which multiplier<br>implementation should<br>be used?   | DEDICATED_<br>MULTIPLIER_<br>CIRCUITRY |           | <ul> <li>Use default<br/>implementa-<br/>tion</li> <li>Use the<br/>dedicated<br/>multiplier<br/>circuitry (Not<br/>available for all<br/>families)</li> <li>Use logic<br/>elements</li> </ul> | Specifies the multiplier<br>implementation.                                |

#### Table 4-3: LPM\_MULT Parameters - Pipeling

#### This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                                  | Parameter          | Condition                                                                                            | Value                                                                                     | Description                                                                                                                                   |
|------------------------------------------------|--------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Do you want to<br>pipeline the function?       | LPM_PIPELINE       |                                                                                                      | <ul> <li>No</li> <li>Yes, I want<br/>output latency<br/>of [] clock<br/>cycles</li> </ul> | You can add extra<br>latency to the outputs,<br>if any.                                                                                       |
| Create an 'aclr'<br>asynchronous clear<br>port |                    | Do you want to<br>pipeline the<br>function? = Yes, I<br>want output<br>latency of []<br>clock cycles | On or off                                                                                 | Specifies asynchronous<br>clear for the complex<br>multiplier. Clears the<br>function asynchro-<br>nously when aclr port<br>is asserted high. |
| Create a 'clken' clock<br>enable clock         | _                  | Do you want to<br>pipeline the<br>function? = Yes, I<br>want output<br>latency of []<br>clock cycles | On or off                                                                                 | Specifies active high<br>clock enable for the<br>clock port of the<br>complex multiplier                                                      |
| What type of optimiza-<br>tion do you want?    | MAXIMIZE_<br>SPEED | —                                                                                                    | <ul><li> Default</li><li> Speed</li><li> Area</li></ul>                                   | You can specify if the<br>type of optimization is<br>determined by Quartus<br>Prime, speed, or area.                                          |

LPM\_MULT (Multiplier) IP Core References for MAX 10



## Signals

#### Table 4-4: LPM\_MULT Input Signals

| Signal Name | Required | Description                                                                                                                                                                                                                 |
|-------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dataa[]     | Yes      | Data input.                                                                                                                                                                                                                 |
|             |          | The size of the input signal depends on the LPM_WIDTHA parameter value.                                                                                                                                                     |
| datab[]     | Yes      | Data input.                                                                                                                                                                                                                 |
|             |          | The size of the input signal depends on the LPM_WIDTHB parameter value.                                                                                                                                                     |
| clock       | No       | Clock input for pipelined usage.                                                                                                                                                                                            |
|             |          | For LPM_PIPELINE values other than 0 (default), the clock signal must be enabled.                                                                                                                                           |
| clken       | No       | Clock enable for pipelined usage. When the clken signal is asserted high, the adder/subtractor operation takes place. When the signal is low, no operation occurs. If omitted, the default value is 1.                      |
| aclr        | No       | Asynchronous clear signal used at any time to reset the pipeline to all 0s, asynchronously to the clock signal. The pipeline initializes to an undefined (X) logic level. The outputs are a consistent, but non-zero value. |
| sclr        | No       | Synchronous clear signal used at any time to reset the pipeline to all 0s, synchronously to the clock signal. The pipeline initializes to an undefined (X) logic level. The outputs are a consistent, but non-zero value.   |

#### Table 4-5: LPM\_MULT Output signals

| signal Name | Required | Description                                                                                                                                                                                                                                  |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| result[]    | Yes      | Data output.                                                                                                                                                                                                                                 |
|             |          | For Stratix V, Arria V and Cyclone V, the size of the output signal depends on the LPM_WIDTHP parameter value. If LPM_WIDTHP < max (LPM_WIDTHA + LPM_WIDTHB, LPM_WIDTHS) or (LPM_WIDTHA + LPM_WIDTHS), only the LPM_WIDTHP MSBs are present. |



# ALTMULT\_ACCUM (Multiply-Accumulate) IP Core References for MAX 10

2017.02.21

UG-M10DSP

Subscribe

## ALTMULT\_ACCUM Parameter Settings

There are four groups of options: General, Extra Modes, Multipliers, and Accumulator.

Send Feedback

#### Table 5-1: ALTMULT\_ACCUM Parameters - General

| This table lists the IP core parameters applicable to MAX 10 devices. |                           |           |                                                            |                                                                                                       |
|-----------------------------------------------------------------------|---------------------------|-----------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| GUI Parameter                                                         | Parameter                 | Condition | Value                                                      | Description                                                                                           |
| What is the number of multipliers?                                    | NUMBER_OF_<br>MULTIPLIERS | _         | 1                                                          | By default, only 1<br>multiplier is supported.                                                        |
| All multipliers have similar configurations                           | _                         | —         | On                                                         | By default all<br>multipliers have similar<br>configurations                                          |
| How wide should the A input buses be?                                 | WIDTH_A                   |           | 1-256                                                      | Specifies the width of A input buses.                                                                 |
| How wide should the B input buses be?                                 | WIDTH_B                   | _         | 1–256                                                      | Specifies the width of B input buses.                                                                 |
| How wide should the 'result' output bus be?                           | WIDTH_<br>RESULT          |           | 1–256                                                      | Specifies the width of<br>'result' output bus.                                                        |
| Create a 4 <sup>th</sup> asynchro-<br>nous clear input option         | —                         | -         | On or Off                                                  | Turn on this option if<br>you want to create a 4 <sup>th</sup><br>asynchronous clear<br>input option. |
| Create an associated<br>clock enable for each<br>clock                | _                         | _         | On or Off                                                  | Turn on this option if<br>you want to create an<br>associated clock enable<br>for each clock.         |
| What is the representa-<br>tion format for A<br>inputs?               | REPRESENTATI<br>ON_A      | _         | <ul><li>Signed</li><li>Unsigned</li><li>Variable</li></ul> | Specifies the represen-<br>tation format for A<br>inputs.                                             |

ISO 9001:2015 Registered



Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

| GUI Parameter                                                                 | Parameter                    | Condition                                                                                           | Value                                                      | Description                                                                            |
|-------------------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------|
| 'signa' input controls<br>the sign (1 signed/0<br>unsigned)                   | PORT_SIGNA                   | Input<br>Representation ><br>What is the<br>representation<br>format for A<br>inputs? =<br>Variable | More Options                                               | High 'signa' input<br>indicates signed and<br>low 'signa' input<br>indicates unsigned. |
| Register 'signa' input                                                        | —                            | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>register of 'signa' input          |
| Add an extra pipeline<br>register                                             | _                            | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>extra pipeline register            |
| Input Register > What<br>is the source for clock<br>input?                    | SIGN_REG_A                   | Input<br>Representation ><br>More Options                                                           | Clock0-Clock3                                              | Specifies the source for clock input.                                                  |
| Input Register > What<br>is the source for<br>asynchronous clear<br>input?    | SIGN_ACLR_A                  | Input<br>Representation ><br>More Options                                                           | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>                 | Specifies the source for<br>asynchronous clear<br>input.                               |
| Pipeline Register ><br>What is the source for<br>clock input?                 | SIGN_<br>PIPELINE_<br>REG_A  | Input<br>Representation ><br>More Options                                                           | Clock0-Clock3                                              | Specifies the source for clock input.                                                  |
| Pipeline Register ><br>What is the source for<br>asynchronous clear<br>input? | SIGN_<br>PIPELINE_<br>ACLR_A | Input<br>Representation ><br>More Options                                                           | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>                 | Specifies the source for<br>asynchronous clear<br>input.                               |
| What is the representa-<br>tion format for B<br>inputs?                       | REPRESENTATI<br>ONS_B        |                                                                                                     | <ul><li>Signed</li><li>Unsigned</li><li>Variable</li></ul> | Specifies the represen-<br>tation format for B<br>inputs.                              |
| 'signb' input controls<br>the sign (1 signed/0<br>unsigned)                   | PORT_SIGNB                   | Input<br>Representation ><br>What is the<br>representation<br>format for B<br>inputs? =<br>Variable | More Options                                               | High 'signb' input<br>indicates signed and<br>low 'signb' input<br>indicates unsigned. |
| Register 'signb' input                                                        | _                            | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>register of 'signb' input          |
| Add an extra pipeline<br>register                                             |                              | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>extra pipeline register            |



| GUI Parameter                                                                 | Parameter                    | Condition                                 | Value                                      | Description                                              |
|-------------------------------------------------------------------------------|------------------------------|-------------------------------------------|--------------------------------------------|----------------------------------------------------------|
| Input Register > What<br>is the source for clock<br>input?                    | SIGN_REG_B                   | Input<br>Representation ><br>More Options | Clock0-Clock3                              | Specifies the source for clock input.                    |
| Input Register > What<br>is the source for<br>asynchronous clear<br>input?    | SIGN_ACLR_B                  | Input<br>Representation ><br>More Options | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input. |
| Pipeline Register ><br>What is the source for<br>clock input?                 | SIGN_<br>PIPELINE_<br>REG_B  | Input<br>Representation ><br>More Options | Clock0-Clock3                              | Specifies the source for clock input.                    |
| Pipeline Register ><br>What is the source for<br>asynchronous clear<br>input? | SIGN_<br>PIPELINE_<br>ACLR_B | Input<br>Representation ><br>More Options | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input. |

#### Table 5-2: ALTMULT\_ACCUM Parameters - Extra Modes

| GUI Parameter                                                      | Parameter   | Condition                                  | Value                                      | Description                                                                                   |
|--------------------------------------------------------------------|-------------|--------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------|
| Create a shiftout output<br>from A input of the last<br>multiplier |             |                                            | On or Off                                  | Turn on this option to<br>create a shiftout output<br>from A input of the last<br>multiplier. |
| Create a shiftout output<br>from B input of the last<br>multiplier | -           | -                                          | On or Off                                  | Turn on this option to<br>create a shiftout output<br>from B input of the last<br>multiplier. |
| Add extra register(s) at the output                                | _           | _                                          | On                                         | By default, output<br>register must be<br>enabled for<br>accumulator.                         |
| What is the source for clock input?                                | OUTPUT_REG  | Outputs<br>Configuration ><br>More Options | Clock0-Clock3                              | Specifies the clock<br>signal for the registers<br>on the outputs.                            |
| What is the source for asynchronous clear input?                   | OUTPUT_ACLR | Outputs<br>Configuration ><br>More Options | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the asynchro-<br>nous clear signal for the<br>registers on the<br>outputs.          |
| Add [] extra latency to the output                                 | —           | Outputs<br>Configuration ><br>More Options | 0, 1, 2, 3, 4, 5, 6,<br>7, 8, or 12        | Specifies the extra<br>latency to add to the<br>output.                                       |



| GUI Parameter                                                | Parameter                              | Condition | Value                                                                                                                                                       | Description                                        |
|--------------------------------------------------------------|----------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| Which multiplier-<br>adder implementation<br>should be used? | DEDICATED_<br>MULTIPLIER_<br>CIRCUITRY |           | <ul> <li>Use the default implementation</li> <li>Use dedicated multiplier circuitry (Not available for all families)</li> <li>Use logic elements</li> </ul> | Specifies the multiplier-<br>adder implementation. |

#### Table 5-3: ALTMULT\_ACCUM Parameters - Multipliers

This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                                          | Parameter        | Condition                                                                                                                                                                                                                  | Value                                      | Description                                                         |
|--------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|---------------------------------------------------------------------|
| Register input A of the multiplier                     | _                | _                                                                                                                                                                                                                          | On or Off                                  | Turn on to enable<br>register input A of the<br>multiplier.         |
| What is the source for clock input?                    | INPUT_REG_A      | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input A of the<br/>multiplier =<br/>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More<br/>Options</li> </ul> </li> </ul>           | Clock0-Clock3                              | Specifies the clock port<br>for the dataa[] port.                   |
| What is the source for<br>asynchronous clear<br>input? | INPUT_ACLR_<br>A | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input A of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul> | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the asynchro-<br>nous clear port for the<br>dataa[] port. |
| Register input B of the multiplier                     | _                | _                                                                                                                                                                                                                          | On or Off                                  | Turn on to enable<br>register input B of the<br>multiplier.         |



| GUI Parameter                                             | Parameter          | Condition                                                                                                                                                                                                                   | Value                                      | Description                                                                                   |
|-----------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------|
| What is the source for clock input?                       | INPUT_REG_B        | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input B of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul>  | Clock0-Clock3                              | Specifies the clock port<br>for the datab[] port.                                             |
| What is the source for<br>asynchronous clear<br>input?    | INPUT_ACLR_<br>B   | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input B of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul>  | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the asynchro-<br>nous clear port for the<br>datab[] port.                           |
| What is the input A of<br>the multiplier<br>connected to? | _                  | _                                                                                                                                                                                                                           | Multiplier input                           | By default, input A of<br>the multiplier is always<br>connected to the<br>multiplier's input. |
| What is the input B of<br>the multiplier<br>connected to? | _                  | -                                                                                                                                                                                                                           | Multiplier input                           | By default, input B of<br>the multiplier is always<br>connected to the<br>multiplier's input. |
| Register output of the multiplier                         | _                  | _                                                                                                                                                                                                                           | On or Off                                  | Turn on to enable<br>register output of the<br>multiplier.                                    |
| What is the source for clock input?                       | MULTIPLIER_<br>REG | <ul> <li>Output<br/>Configuration         <ul> <li>Register</li> <li>output of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Output<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul> | Clock0-Clock3                              | Specifies the clock<br>signal for the register<br>that immediately<br>follows the multiplier. |



| GUI Parameter                                          | Parameter           | Condition                                                                                                                                                            | Value                                      | Description                                                                                                      |
|--------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| What is the source for<br>asynchronous clear<br>input? | MULTIPLIER_<br>ACLR | <ul> <li>Output<br/>Configuration<br/>&gt; Register<br/>output of the<br/>multiplier =<br/>On</li> <li>Output<br/>Configuration<br/>&gt; More<br/>Options</li> </ul> | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the asynchro-<br>nous clear signal of the<br>register that follows the<br>corresponding<br>multiplier. |

#### Table 5-4: ALTMULT\_ACCUM Parameters - Accumulator

This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                          | Parameter | Condition                                                           | Value     | Description                                                                                                                                                                        |
|----------------------------------------|-----------|---------------------------------------------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Create an 'accum_<br>sload' input port | _         | _                                                                   | On or off | Dynamically specifies<br>whether the<br>accumulator value is<br>constant. If the accum_<br>sload port is high,<br>then the multiplier<br>output is loaded into<br>the accumulator. |
| Register 'accum_sload'<br>input        | _         | <ul> <li>Accumulator         <ul> <li>Create an</li></ul></li></ul> | On or off | Turn on to enable<br>register 'accum_sload'<br>input.                                                                                                                              |
| Add an extra pipeline<br>register      | _         | <ul> <li>Accumulator         <ul> <li>Create an</li></ul></li></ul> | On or off | Turn on this option if<br>you want to enable the<br>extra pipeline register                                                                                                        |



| 02.21                                                                     |            |                                                                                                                                                                                                          | _                                          | 3                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GUI Parameter                                                             | Parameter  | Condition                                                                                                                                                                                                | Value                                      | Description                                                                                                                                                                                                                     |
| Input Register > W<br>is the source for clo<br>input?                     |            | <ul> <li>Accumulator         <ul> <li>Create an</li></ul></li></ul>                                                                                                                                      | Clock0-Clock3                              | Specifies the clock<br>signal for the accum_<br>sload port.                                                                                                                                                                     |
| Input Register > W<br>is the source for<br>asynchronous clean<br>input?   | SLOAD_ACLR | <ul> <li>Accumulator         <ul> <li>Create an</li></ul></li></ul>                                                                                                                                      | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the asynchro-<br>nous clear source for<br>the first register on the<br>accum_sload input.                                                                                                                             |
| Pipeline Register ><br>What is the source<br>clock input?                 |            | <ul> <li>Accumulator         <ul> <li>Create an</li> <li>`accum_</li> <li>sload' input</li> <li>port = On</li> </ul> </li> <li>Accumulator         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul> | Clock0-Clock3                              | Specifies the source for<br>clock input.                                                                                                                                                                                        |
| Pipeline Register ><br>What is the source<br>asynchronous clean<br>input? | for SLOAD_ | <ul> <li>Accumulator         <ul> <li>Create an</li> <li>`accum_soad'</li> <li>input port =</li> <li>On</li> </ul> </li> <li>Accumulator         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul>   | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input.                                                                                                                                                                        |
| Create an 'overflo<br>output port                                         | w' —       | _                                                                                                                                                                                                        | On or Off                                  | Overflow port for the accumulator                                                                                                                                                                                               |
| Add [] extra latenc<br>the multiplier outp                                |            |                                                                                                                                                                                                          | 0, 1, 2, 3, 4, 5, 6,<br>7, 8, or 12        | Specifies the number of<br>clock cycles of latency<br>for the multiplier<br>portion of the DSP<br>block. If the<br>MULTIPLIER_REG<br>parameter is specified,<br>then the specified clock<br>port is used to add the<br>latency. |



## ALTMULT\_ACCUM Ports

#### Table 5-5: ALTMULT\_ACCUM IP Core Input Ports

| Port Name   | Required | Description                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|-------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| accum_sload | No       | Causes the value on the accumulator feedback path to go to<br>zero (0) or to accum_sload_upper_data when concatenated<br>with 0. If the accumulator is adding and the accum_sload port<br>is high, then the multiplier output is loaded into the<br>accumulator. If the accumulator is subtracting, then the<br>opposite (negative value) of the multiplier output is loaded<br>into the accumulator. |  |  |  |
| aclr0       | No       | The first asynchronous clear input. The aclr0 port is active high.                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| aclrl       | No       | The second asynchronous clear input. The aclr1 port is active high.                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| aclr2       | No       | The third asynchronous clear input. The aclr2 port is active high.                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| aclr3       | No       | The fourth asynchronous clear input. The aclr3 port is active high.                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| addnsub     | No       | Controls the functionality of the adder. If the addnsub port is high, the adder performs an add function; if the addnsub port is low, the adder performs a subtract function.                                                                                                                                                                                                                         |  |  |  |
| clock0      | No       | Specifies the first clock input, usable by any register in the IP core.                                                                                                                                                                                                                                                                                                                               |  |  |  |
| clockl      | No       | Specifies the second clock input, usable by any register in the IP core.                                                                                                                                                                                                                                                                                                                              |  |  |  |
| clock2      | No       | Specifies the third clock input, usable by any register in the IP core.                                                                                                                                                                                                                                                                                                                               |  |  |  |
| clock3      | No       | Specifies the fourth clock input, usable by any register in the IP core.                                                                                                                                                                                                                                                                                                                              |  |  |  |
| dataa[]     | Yes      | Data input to the multiplier. The size of the input port depends<br>on the wIDTH_A parameter value.                                                                                                                                                                                                                                                                                                   |  |  |  |
| datab[]     | Yes      | Data input to the multiplier. The size of the input port depends<br>on the WIDTH_B parameter value.                                                                                                                                                                                                                                                                                                   |  |  |  |
| ena0        | No       | Clock enable for the clock0 port.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| enal        | No       | Clock enable for the clock1 port.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| ena2        | No       | Clock enable for the clock2 port.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| ena3        | No       | Clock enable for the clock3 port.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |



|   | Port Name | Required | Description                                                                                                                                                                                                                                                |  |  |  |
|---|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| _ | signa     | No       | Specifies the numerical representation of the dataa[] port. If<br>the signa port is high, the multiplier treats the dataa[] port<br>as signed two's complement. If the signa port is low, the<br>multiplier treats the dataa[] port as an unsigned number. |  |  |  |
|   | signb     | No       | Specifies the numerical representation of the datab[] port. If<br>the signb port is high, the multiplier treats the datab[] port<br>as signed two's complement. If the signb port is low, the<br>multiplier treats the datab[]port as an unsigned number.  |  |  |  |

#### Table 5-6: ALTMULT\_ACCUM IP Core Output Ports

| Port Name  | Required | Description                                                                                                                                                                                                                                                                          |  |  |  |
|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| overflow   | No       | Overflow port for the accumulator.                                                                                                                                                                                                                                                   |  |  |  |
| result[]   | Yes      | Accumulator output port. The size of the output port depends<br>on the WIDTH_RESULT parameter value.                                                                                                                                                                                 |  |  |  |
| scanouta[] | No       | Output of the first shift register. The size of the output port<br>depends on the WIDTH_A parameter value. When instantiating<br>the ALTMULT_ACCUM IP core with the MegaWizard Plug-<br>In Manager, the MegaWizard Plug-In Manager renames the<br>scanouta[] port to shiftouta port. |  |  |  |
| scanoutb[] | No       | Output of the second shift register. The size of the input port<br>depends on the WIDTH_B parameter value. When instantiating<br>the ALTMULT_ACCUM IP core with the MegaWizard Plug-<br>In Manager, the MegaWizard Plug-In Manager renames the<br>scanoutb[] port to shiftoutb port. |  |  |  |



# ALTMULT\_ADD (Multiply-Adder) IP Core References for MAX 10 6

2017.02.21

UG-M10DSP

Subscribe

## **ALTMULT\_ADD** Parameter Settings

There are three groups of options: General, Extra Modes, and Multipliers.

Send Feedback

#### Table 6-1: ALTMULT\_ADD Parameters - General

| This table lists the IF                                       | This table lists the IP core parameters applicable to MAX 10 devices. |           |               |                                                                                                       |  |  |
|---------------------------------------------------------------|-----------------------------------------------------------------------|-----------|---------------|-------------------------------------------------------------------------------------------------------|--|--|
| GUI Parameter                                                 | Parameter                                                             | Condition | Value         | Description                                                                                           |  |  |
| What is the number of multipliers?                            | NUMBER_OF_<br>MULTIPLIERS                                             | _         | 1, 2, 3, or 4 | Specifies the number of<br>multipliers. You can<br>specify up to four<br>multipliers.                 |  |  |
| All multipliers have similar configurations                   | _                                                                     | _         | On or Off     | Turn on this option if<br>you want all multipliers<br>to have similar configu-<br>rations.            |  |  |
| How wide should the A input buses be?                         | WIDTH_A                                                               |           | 1–256         | Specifies the width of A input buses.                                                                 |  |  |
| How wide should the B input buses be?                         | WIDTH_B                                                               |           | 1–256         | Specifies the width of B input buses.                                                                 |  |  |
| How wide should the<br>'result' output bus be?                | WIDTH_<br>RESULT                                                      |           | 1–256         | Specifies the width of<br>'result' output bus.                                                        |  |  |
| Create a 4 <sup>th</sup> asynchro-<br>nous clear input option | _                                                                     | _         | On or Off     | Turn on this option if<br>you want to create a 4 <sup>th</sup><br>asynchronous clear<br>input option. |  |  |
| Create an associated<br>clock enable for each<br>clock        | _                                                                     | _         | On or Off     | Turn on this option if<br>you want to create an<br>associated clock enable<br>for each clock.         |  |  |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered

now part of Intel



| GUI Parameter                                                                 | Parameter                          | Condition                                                                                           | Value                                                      | Description                                                                            |
|-------------------------------------------------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------|
| What is the representa-<br>tion format for A<br>inputs?                       | REPRESENTATI<br>ON_A               | _                                                                                                   | <ul><li>Signed</li><li>Unsigned</li><li>Variable</li></ul> | Specifies the represen-<br>tation format for A<br>inputs.                              |
| ʻsigna' input controls<br>the sign (1 signed/0<br>unsigned)                   | PORT_SIGNA                         | Input<br>Representation ><br>What is the<br>representation<br>format for A<br>inputs? =<br>Variable | More Options                                               | High 'signa' input<br>indicates signed and<br>low 'signa' input<br>indicates unsigned. |
| Register 'signa' input                                                        | _                                  | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>register of 'signa' input          |
| Add an extra pipeline<br>register                                             | _                                  | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>extra pipeline register            |
| Input Register > What<br>is the source for clock<br>input?                    | SIGNED_<br>REGISTER_A              | Input<br>Representation ><br>More Options                                                           | Clock0-Clock3                                              | Specifies the source for clock input.                                                  |
| Input Register > What<br>is the source for<br>asynchronous clear<br>input?    | SIGNED_ACLR_<br>A                  | Input<br>Representation ><br>More Options                                                           | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>                 | Specifies the source for<br>asynchronous clear<br>input.                               |
| Pipeline Register ><br>What is the source for<br>clock input?                 | SIGNED_<br>PIPELINE_<br>REGISTER_A | Input<br>Representation ><br>More Options                                                           | Clock0-Clock3                                              | Specifies the source for clock input.                                                  |
| Pipeline Register ><br>What is the source for<br>asynchronous clear<br>input? | SIGNED_<br>PIPELINE_<br>ACLR_A     | Input<br>Representation ><br>More Options                                                           | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>                 | Specifies the source for<br>asynchronous clear<br>input.                               |
| What is the representa-<br>tion format for B<br>inputs?                       | REPRESENTATI<br>ONS_B              | —                                                                                                   | <ul><li>Signed</li><li>Unsigned</li><li>Variable</li></ul> | Specifies the represen-<br>tation format for B<br>inputs.                              |
| 'signb' input controls<br>the sign (1 signed/0<br>unsigned)                   | PORT_SIGNB                         | Input<br>Representation ><br>What is the<br>representation<br>format for B<br>inputs? =<br>Variable | More Options                                               | High 'signb' input<br>indicates signed and<br>low 'signb' input<br>indicates unsigned. |
| Register 'signb' input                                                        |                                    | Input<br>Representation ><br>More Options                                                           | On or Off                                                  | Turn on this option if<br>you want to enable the<br>register of 'signb' input          |

ALTMULT\_ADD (Multiply-Adder) IP Core References for MAX 10



| GUI Parameter                                                                 | Parameter                          | Condition                                 | Value                                      | Description                                                                 |
|-------------------------------------------------------------------------------|------------------------------------|-------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------|
| Add an extra pipeline<br>register                                             |                                    | Input<br>Representation ><br>More Options | On or Off                                  | Turn on this option if<br>you want to enable the<br>extra pipeline register |
| Input Register > What<br>is the source for clock<br>input?                    | SIGNED_<br>REGISTER_B              | Input<br>Representation ><br>More Options | Clock0-Clock3                              | Specifies the source for clock input.                                       |
| Input Register > What<br>is the source for<br>asynchronous clear<br>input?    | SIGNED_ACLR_<br>B                  | Input<br>Representation ><br>More Options | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input.                    |
| Pipeline Register ><br>What is the source for<br>clock input?                 | SIGNED_<br>PIPELINE_<br>REGISTER_B | Input<br>Representation ><br>More Options | Clock0-Clock3                              | Specifies the source for clock input.                                       |
| Pipeline Register ><br>What is the source for<br>asynchronous clear<br>input? | SIGNED_<br>PIPELINE_<br>ACLR_B     | Input<br>Representation ><br>More Options | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input.                    |

#### Table 6-2: ALTMULT\_ADD Parameters - Extra Modes

This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                                                      | Parameter           | Condition                                                                                                                                                                           | Value         | Description                                                  |
|--------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------------|
| Create a shiftout output<br>from A input of the last<br>multiplier | _                   | _                                                                                                                                                                                   | On or Off     | Turn on to create a signal from A input.                     |
| Create a shiftout output<br>from B input of the last<br>multiplier | _                   | _                                                                                                                                                                                   | On or Off     | Turn on to create a signal from B input.                     |
| Register output of the adder unit                                  | _                   | _                                                                                                                                                                                   | On or Off     | Turn on to create a<br>register output of the<br>adder unit. |
| What is the source for clock input?                                | OUTPUT_<br>REGISTER | <ul> <li>Outputs<br/>Configuration         <ul> <li>Register<br/>output of the<br/>adder unit =<br/>On</li> <li>Outputs<br/>Configuration             <ul></ul></li></ul></li></ul> | Clock0-Clock3 | Specifies the clock<br>signal for the output<br>register.    |



| GUI Parameter                                                                            | Parameter                                           | Condition                                                                                                                                                                           | Value                                                   | Description                                                                                                                                                                         |
|------------------------------------------------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| What is the source for<br>asynchronous clear<br>input?                                   | OUTPUT_ACLR                                         | <ul> <li>Outputs<br/>Configuration         <ul> <li>Register<br/>output of the<br/>adder unit =<br/>On</li> <li>Outputs<br/>Configuration             <ul></ul></li></ul></li></ul> | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>              | Specifies the source for<br>asynchronous clear<br>input.                                                                                                                            |
| What operation should<br>be performed on<br>outputs of the first pair<br>of multipliers? | MUTIPLIER1_<br>DIRECTION                            | General > What<br>is the number of<br>multipliers? = 2,<br>3, or 4                                                                                                                  | <ul><li>Add</li><li>Subtract</li><li>Variable</li></ul> | Specifies whether the<br>second multiplier adds<br>or subtracts its value<br>from the sum. Values<br>are add and subtract. If<br>Variable is selected the<br>addnsub1 port is used. |
| 'addnsub1' input<br>controls the operation<br>(1 add/0 sub)                              | _                                                   | Adder Operation<br>> What<br>operation should<br>be performed on<br>outputs of the<br>first pair of<br>multipliers? =<br>Variable                                                   | More Options                                            | High 'addnsub1' input<br>indicates add and low<br>'addnsub1' input<br>indicates subtract.                                                                                           |
| Register 'addnsub1'<br>input                                                             |                                                     | _                                                                                                                                                                                   | On or Off                                               | Turn on this option if<br>you want to enable the<br>register of 'addnsub1'<br>input                                                                                                 |
| Add an extra pipeline<br>register                                                        | _                                                   |                                                                                                                                                                                     | On or Off                                               | Turn on this option if<br>you want to enable the<br>extra pipeline register                                                                                                         |
| Input Register > What<br>is the source for clock<br>input?                               | ADDNSUB_<br>MULTIPLIER_<br>REGISTER[1]              | Adder Operation<br>> More Options                                                                                                                                                   | Clock0-Clock3                                           | Specifies the source for clock input.                                                                                                                                               |
| Input Register > What<br>is the source for<br>asynchronous clear<br>input?               | ADDSUB_<br>MULTIPLIER_<br>ACLR[1]                   | Adder Operation<br>> More Options                                                                                                                                                   | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>              | Specifies the source for<br>asynchronous clear<br>input.                                                                                                                            |
| Pipeline Register ><br>What is the source for<br>clock input?                            | ADDNSUB_<br>MULTIPLIER_<br>PIPELINE_<br>REGISTER[1] | Adder Operation<br>> More Options                                                                                                                                                   | Clock0-Clock3                                           | Specifies the source for clock input.                                                                                                                                               |



| GUI Parameter                                                                             | Parameter                                           | Condition                                              | Value                                      | Description                                                                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pipeline Register ><br>What is the source for<br>asynchronous clear<br>input?             | ADDNSUB_<br>MULTIPLIER_<br>PIPELINE_<br>ACLR[1]     | Adder Operation<br>> More Options                      | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for asynchronous clear input.                                                                                                                                                                                  |
| What operation should<br>be performed on<br>outputs of the second<br>pair of multipliers? | MUTIPLIER3_<br>DIRECTION                            | General > What<br>is the number of<br>multipliers? = 4 | _                                          | Specifies whether the<br>fourth and all<br>subsequent odd-<br>numbered multipliers<br>add or subtract their<br>results from the total.<br>Values are add and<br>subtract. If Variable is<br>selected, the addnsub3<br>port is used. |
| 'addnsub3' input<br>controls the sign (1<br>add/0 sub) - More<br>Options                  | _                                                   | _                                                      | _                                          | High 'addnsub3' input<br>indicates add and low<br>'addnsub3' input<br>indicates subtract.                                                                                                                                           |
| Register 'addnsub3'<br>input                                                              | _                                                   | -                                                      | On or Off                                  | Turn on this option if<br>you want to enable the<br>register of 'addnsub3'<br>input.                                                                                                                                                |
| Add an extra pipeline<br>register                                                         | _                                                   | _                                                      | On or Off                                  | Turn on this option if<br>you want to enable the<br>extra pipeline register.                                                                                                                                                        |
| Input Register > What<br>is the source for clock<br>input?                                | ADDNSUB_<br>MULTIPLIER_<br>REGISTER[3]              | Adder Operation<br>> More Options                      | Clock0-Clock3                              | Specifies the source for clock input.                                                                                                                                                                                               |
| Input Register > What<br>is the source for<br>asynchronous clear<br>input?                | ADDSUB_<br>MULTIPLIER_<br>ACLR[3]                   | Adder Operation<br>> More Options                      | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input.                                                                                                                                                                            |
| Pipeline Register ><br>What is the source for<br>clock input?                             | ADDNSUB_<br>MULTIPLIER_<br>PIPELINE_<br>REGISTER[3] | Adder Operation<br>> More Options                      | Clock0-Clock3                              | Specifies the source for clock input.                                                                                                                                                                                               |
| Pipeline Register ><br>What is the source for<br>asynchronous clear<br>input?             | ADDNSUB_<br>MULTIPLIER_<br>PIPELINE_<br>ACLR[3]     | Adder Operation<br>> More Options                      | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input.                                                                                                                                                                            |



| GUI Parameter                                                | Parameter                              | Condition | Value                                                                                                                                                       | Description                                        |
|--------------------------------------------------------------|----------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| Which multiplier-<br>adder implementation<br>should be used? | DEDICATED_<br>MULTIPLIER_<br>CIRCUITRY | _         | <ul> <li>Use the default implementation</li> <li>Use dedicated multiplier circuitry (Not available for all families)</li> <li>Use logic elements</li> </ul> | Specifies the multiplier-<br>adder implementation. |

#### Table 6-3: ALTMULT\_ADD Parameters - Multipliers

This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                                          | Parameter                    | Condition                                                                                                                                                                                                                  | Value                                      | Description                                                 |
|--------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------|
| Register input A of the multiplier                     | _                            | _                                                                                                                                                                                                                          | On or Off                                  | Turn on to enable<br>register input A of the<br>multiplier. |
| What is the source for clock input?                    | INPUT_<br>REGISTER_<br>A[03] | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input A of the<br/>multiplier =</li> <li>On</li> <li>Input<br/>Configuration             <ul></ul></li></ul></li></ul>                                 | Clock0-Clock3                              | Specifies the source for<br>clock input.                    |
| What is the source for<br>asynchronous clear<br>input? | INPUT_ACLR_<br>A[03]         | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input A of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul> | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input.    |
| Register input B of the multiplier                     | _                            | _                                                                                                                                                                                                                          | On or Off                                  | Turn on to enable<br>register input B of the<br>multiplier. |



| GUI Parameter                                              | Parameter                    | Condition                                                                                                                                                                                                                   | Value                                                        | Description                                                                                                   |
|------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| What is the source for<br>clock input?                     | INPUT_<br>REGISTER_<br>B[03] | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input B of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul>  | Clock0–Clock3                                                | Specifies the source for clock input.                                                                         |
| <br>What is the source for<br>asynchronous clear<br>input? | INPUT_ACLR_<br>B[03]         | <ul> <li>Input<br/>Configuration         <ul> <li>Register</li> <li>input B of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Input<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul>  | <ul><li>Aclr0–Aclr2</li><li>None</li></ul>                   | Specifies the source for<br>asynchronous clear<br>input.                                                      |
| What is the input A of<br>the multiplier<br>connected to?  | INPUT_<br>SOURCE_<br>A[03]   | _                                                                                                                                                                                                                           | <ul><li>Multiplier<br/>input</li><li>Shiftin input</li></ul> | Specifies the input A of<br>the multiplier is<br>connected to either<br>multiplier input or<br>shiftin input. |
| What is the input B of<br>the multiplier<br>connected to?  | INPUT_<br>SOURCE_B[03]       | -                                                                                                                                                                                                                           | <ul><li>Multiplier<br/>input</li><li>Shiftin input</li></ul> | Specifies the input B of<br>the multiplier is<br>connected to either<br>multiplier input or<br>shiftin input. |
| Register output of the<br>multiplier                       | _                            | _                                                                                                                                                                                                                           | On or Off                                                    | Turn on to enable the<br>register for output of<br>the multiplier.                                            |
| What is the source for<br>clock input?                     | MULTIPLIER_<br>REGISTER[]    | <ul> <li>Output<br/>Configuration         <ul> <li>Register</li> <li>output of the<br/>multiplier =</li> <li>On</li> </ul> </li> <li>Output<br/>Configuration         <ul> <li>More</li> <li>Options</li> </ul> </li> </ul> | Clock0-Clock3                                                | Specifies the source for<br>clock input.                                                                      |



| GUI Parameter                                          | Parameter             | Condition                                                                                                                                                            | Value                                      | Description                                              |
|--------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|----------------------------------------------------------|
| What is the source for<br>asynchronous clear<br>input? | MULTIPLIER_<br>ACLR[] | <ul> <li>Output<br/>Configuration<br/>&gt; Register<br/>output of the<br/>multiplier =<br/>On</li> <li>Output<br/>Configuration<br/>&gt; More<br/>Options</li> </ul> | <ul><li>Aclr0–Aclr2</li><li>None</li></ul> | Specifies the source for<br>asynchronous clear<br>input. |

## ALTMULT\_ADD Ports

#### Table 6-4: ALTMULT\_ADD IP Core Input Ports

| Port Name | Required | Description                                                                                                                                                                                                                                                         |
|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dataa[]   | Yes      | Data input to the multiplier. Input port [NUMBER_OF_MULTIPLIERS * WIDTH_A - 10] wide.                                                                                                                                                                               |
| datab[]   | Yes      | Data input to the multiplier. Input port [NUMBER_OF_MULTIPLIERS * WIDTH_B - 10] wide.                                                                                                                                                                               |
| clock[]   | No       | Clock input port [03] to the corresponding register. This port can be used by any register in the IP core.                                                                                                                                                          |
| aclr[]    | No       | Input port [03]. Asynchronous clear input to the corresponding register.                                                                                                                                                                                            |
| ena[]     | No       | Input port [03]. Clock enable for the corresponding clock[] port.                                                                                                                                                                                                   |
| signa     | No       | Specifies the numerical representation of the dataa[] port. If the signa<br>port is high, the multiplier treats the dataa[] port as a signed two's<br>complement number. If the signa port is low, the multiplier treats the<br>dataa[] port as an unsigned number. |
| signb     | No       | Specifies the numerical representation of the datab[] port. If the signb<br>port is high, the multiplier treats the datab[] port as a signed two's<br>complement number. If the signb port is low, the multiplier treats the<br>datab[] port as an unsigned number. |

#### Table 6-5: ALTMULT\_ADD IP Core Output Ports

| Port Name  | Required | Description                                                           |
|------------|----------|-----------------------------------------------------------------------|
| result[]   | Yes      | Multiplier output port. Output port [WIDTH_RESULT - 10] wide.         |
| overflow   | No       | Overflow flag. If output_saturation is enabled, overflow flag is set. |
| scanouta[] | No       | Output of scan chain A. Output port [WIDTH_A - 10] wide.              |
| scanoutb[] | No       | Output of scan chain B. Output port [WIDTH_B - 10] wide.              |

ALTMULT\_ADD (Multiply-Adder) IP Core References for MAX 10



# ALTMULT\_COMPLEX (Complex Multiplier) IP Core References for MAX 10

2017.02.21

UG-M10DSP

Subscribe

## **ALTMULT\_COMPLEX** Parameter Settings

There are two groups of options: General and Implementation Style/Pipelining.

Send Feedback

#### Table 7-1: ALTMULT\_COMPLEX Parameters - General

This table lists the IP core parameters applicable to MAX 10 devices.

| GUI Parameter                                           | GUI Parameter Parameter |   | Value                                     | Description                                               |
|---------------------------------------------------------|-------------------------|---|-------------------------------------------|-----------------------------------------------------------|
| How wide should the A input buses be?                   | WIDTH_A                 |   | 1–256                                     | Specifies the width of A input buses.                     |
| How wide should the B input buses be?                   | WIDTH_B                 |   | 1–256                                     | Specifies the width of B input buses.                     |
| How wide should the 'result' output bus be?             | WIDTH_<br>RESULT        |   | 1-256                                     | Specifies the width of 'result' output bus.               |
| What is the representa-<br>tion format for A<br>inputs? | REPRESENTATI<br>ON_A    | — | <ul><li>Signed</li><li>Unsigned</li></ul> | Specifies the represen-<br>tation format for A<br>inputs. |
| What is the representa-<br>tion format for B<br>inputs? | REPRESENTATI<br>ONS_B   | _ | <ul><li>Signed</li><li>Unsigned</li></ul> | Specifies the represen-<br>tation format for B<br>inputs. |

#### Table 7-2: ALTMULT\_COMPLEX Parameters - Implementation Style/Pipelining

This table lists the IP core parameters applicable to MAX 10 devices.

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered



| GUI Parameter                                      | Parameter                | Condition | Value                                                                                | Description                                                                                                                                                                                                 |
|----------------------------------------------------|--------------------------|-----------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Which implementa-<br>tion style should be<br>used? | IMPLEMENTATIO<br>N_STYLE |           | Automatically<br>select a style for<br>best trade-off for<br>the current<br>settings | By default automatic<br>selection for MAX 10<br>device is selected.<br>Quartus Prime<br>software will<br>determine the best<br>implementation based<br>on the selected device<br>family and input<br>width. |
| Output latency []<br>clock cycles                  | PIPELINE                 |           | 0-14                                                                                 | Specifies the number<br>of clock cycles for<br>output latency.                                                                                                                                              |
| Create an asynchro-<br>nous Clear input            |                          | _         | On or off                                                                            | Specifies synchronous<br>clear for the complex<br>multiplier. Clears the<br>function asynchro-<br>nously when the aclr<br>port is asserted high.                                                            |
| Create clock enable input                          | _                        | —         | On or off                                                                            | Specifies active high<br>clock enable for the<br>clock port of the<br>complex multiplier.                                                                                                                   |

# Signals

#### Table 7-3: ALTMULT\_COMPLEX Input Signals

| Signal       | Required | Description                                                                                                                                 |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| aclr         | No       | Asynchronous clear for the complex multiplier. When the aclr signal is asserted high, the function is asynchronously cleared.               |
| sclr         | No       | Synchronous clear for the complex multiplier. When the sclr signal is asserted high, the function is asynchronously cleared.                |
| clock        | Yes      | Clock input to the ALTMULT_COMPLEX function.                                                                                                |
| dataa_imag[] | Yes      | Imaginary input value for the data A signal of the complex multiplier. The size of the input signal depends on the WIDTH_A parameter value. |
| dataa_real[] | Yes      | Real input value for the data A signal of the complex multiplier.<br>The size of the input signal depends on the WIDTH_A parameter value.   |
| datab_imag[] | Yes      | Imaginary input value for the data B signal of the complex multiplier. The size of the input signal depends on the WIDTH_B parameter value. |



| Signal       | Required | Description                                                                                                                               |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| datab_real[] | Yes      | Real input value for the data B signal of the complex multiplier.<br>The size of the input signal depends on the WIDTH_B parameter value. |
| ena          | No       | Active high clock enable for the clock signal of the complex multiplier.                                                                  |
| complex      | No       | Optional input to enable dynamic switching between $36 \times 36$ normal model and $18 \times 18$ complex mode.                           |
|              |          | This input is only available in Stratix V devices. In the GUI, this parameter is referred as Dynamic Complex Mode.                        |

#### Table 7-4: ALTMULT\_COMPLEX Output Signals

| Signal      | Required | Description                                                                                                          |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------|
| result_imag | Yes      | Imaginary output value of the multiplier. The size of the output signal depends on the WIDTH_RESULT parameter value. |
| result_real | Yes      | Real output value of the multiplier. The size of the output signal depends<br>on the WIDTH_RESULT parameter value.   |



# MAX 10 Embedded Multipliers User Guide Archives

2017.02.21

UG-M10DSP

Subscribe Send Feedback

If an IP core version is not listed, the user guide for the previous IP core version applies.

| IP Core Version | User Guide                             |  |  |
|-----------------|----------------------------------------|--|--|
| 15.1            | MAX 10 Embedded Multipliers User Guide |  |  |
| 14.1            | MAX 10 Embedded Multipliers User Guide |  |  |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered



## Additional Information for MAX 10 Embedded Multipliers User Guide

2017.02.21

UG-M10DSP

Subscribe Send Feedback

### Document Revision History for MAX 10 Embedded Multipliers User Guide

| Date              | Version     | Changes                                                                                                                                                                                                                                                                                    |
|-------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| February 2017     | 2017.02.021 | • Rebranded as Intel.                                                                                                                                                                                                                                                                      |
| May 2016          | 2016.05.02  | <ul><li>Updated MAX 10 to each chapter in the user guide.</li><li>Added MAX 10 Embedded Multipliers User Guide Archives chapter.</li></ul>                                                                                                                                                 |
| November<br>2015  | 2015.11.02  | <ul> <li>Changed instances of <i>Quartus II</i> to <i>Quartus Prime</i>.</li> <li>Removed topics on generating IP cores and added links to Introduction to Altera IP Cores, Creating Version-Independent IP and Qsys Simulation Scripts, and Project Management Best Practices.</li> </ul> |
| September<br>2014 | 2014.09.22  | Initial release.                                                                                                                                                                                                                                                                           |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered

