

# **Divider Core User Guide**

UG-CORE-DIVIDER-v4.4 February 2023 www.efinixinc.com



Copyright © 2023. All rights reserved. Efinix, the Efinix logo, the Titanium logo, Quantum, Trion, and Efinity are trademarks of Efinix, Inc. All other trademarks and service marks are the property of their respective owners. All specifications subject to change without notice.

# Contents

| Introduction                         |    |
|--------------------------------------|----|
| Features                             | 3  |
| Resource Utilization and Performance | 3  |
| Functional Description               | 5  |
| Functional Description<br>Ports      | 6  |
| Divider Operations                   | 6  |
| IP Manager                           |    |
| Customizing the Divider              | 9  |
| Divider Example Design               |    |
| Divider Testbench                    | 11 |
| Revision History                     | 12 |

# Introduction

The Divider core divides a numerator input value by a denominator input value to produce a quotient and a remainder.

Use the IP Manager to select IP, customize it, and generate files. The Divider core has an interactive wizard to help you set parameters. The wizard also has options to create a testbench and/or example design targeting an Efinix<sup>®</sup> development board.

### Features

i

- Supports a data width of 2 to 64 bits
- Supports signed and unsigned data representation format for both the numerator and denominator
- Supports adjustable latency and disabling Divider latency
- Supports optional asynchronous clear and clock enable ports
- Verilog HDL RTL and simulation testbench
- Includes example designs targeting the Trion<sup>®</sup> T20 BGA256 Development Board and Titanium Ti60 F225 Development Board

### **FPGA Support**

The Divider core supports all Trion® and Titanium FPGAs.

# **Resource Utilization and Performance**

**Note:** The resources and performance values provided are just guidance and change depending on the device resource utilization, design congestion, and user design.

| FPGA         | Mode / Width<br>(bit) / Latency | Logic and<br>Adders | Flip-flops | Memory<br>Blocks | DSP48<br>Blocks | f <sub>MAX</sub><br>(MHz) <sup>(1)</sup> | Efinity <sup>®</sup><br>Version <sup>(2)</sup> |
|--------------|---------------------------------|---------------------|------------|------------------|-----------------|------------------------------------------|------------------------------------------------|
| Ti60 F225 C4 | Signed / 8 / 8                  | 121                 | 87         | 0                | 0               | 576                                      | 2021.2                                         |
|              | Signed / 32 / 32                | 2,027               | 1,122      | 0                | 0               | 314                                      |                                                |
|              | Unsigned / 8 / 8                | 121                 | 86         | 0                | 0               | 672                                      |                                                |
|              | Unsigned / 32 / 32              | 2,025               | 1,116      | 0                | 0               | 320                                      |                                                |
|              | Signed / 8 / 4                  | 169                 | 79         | 0                | 0               | 325                                      |                                                |
|              | Signed / 32 / 16                | 2,530               | 719        | 0                | 0               | 50                                       |                                                |
|              | Unsigned / 8 / 4                | 130                 | 50         | 0                | 0               | 379                                      |                                                |
|              | Unsigned / 32 / 16              | 2,604               | 786        | 0                | 0               | 50                                       | 1                                              |

### Titanium Resource Utilization and Performance

<sup>&</sup>lt;sup>(1)</sup> Using default parameter settings.

<sup>&</sup>lt;sup>(2)</sup> Using Verilog HDL.

| FPGA | Mode / Width<br>(bit) / Latency | Logic and<br>Adders | Flip-flops | Memory<br>Blocks | DSP48<br>Blocks | f <sub>MAX</sub><br>(MHz) <sup>(1)</sup> | Efinity <sup>®</sup><br>Version <sup>(2)</sup> |
|------|---------------------------------|---------------------|------------|------------------|-----------------|------------------------------------------|------------------------------------------------|
|      | Signed / 8 / 0                  | 205                 | 0          | 0                | 0               | -                                        |                                                |
|      | Signed / 32 / 0                 | 3,407               | 0          | 0                | 0               | -                                        |                                                |
|      | Unsigned / 8 / 0                | 175                 | 0          | 0                | 0               | -                                        |                                                |
|      | Unsigned / 32 / 0               | 3,310               | 0          | 0                | 0               | -                                        |                                                |

### TrionResource Utilization and Performance

| FPGA       | Mode / Width<br>(bit) / Latency | Logic<br>Utilization<br>(LUTs) | Registers | Memory<br>Blocks | Multipliers | f <sub>MAX</sub><br>(MHz) <sup>(1)</sup> | Efinity <sup>®</sup><br>Version <sup>(2)</sup> |
|------------|---------------------------------|--------------------------------|-----------|------------------|-------------|------------------------------------------|------------------------------------------------|
| T20 BGA256 | Signed / 8 / 8                  | 167                            | 211       | 0                | 0           | 240                                      | 2021.2                                         |
| C4         | Signed / 32 / 32                | 1,687                          | 1,569     | 0                | 0           | 165                                      |                                                |
|            | Unsigned / 8 / 8                | 116                            | 141       | 0                | 0           | 263                                      | -                                              |
|            | Unsigned / 32 / 32              | 1,616                          | 1,459     | 0                | 0           | 168                                      | -                                              |
|            | Signed / 8 / 4                  | 147                            | 86        | 0                | 0           | 104                                      |                                                |
|            | Signed / 32 / 16                | 2,122                          | 557       | 0                | 0           | 12                                       |                                                |
|            | Unsigned / 8 / 4                | 126                            | 81        | 0                | 0           | 144                                      |                                                |
|            | Unsigned / 32 / 16              | 2,008                          | 620       | 0                | 0           | 24                                       |                                                |
|            | Signed / 8 / 0                  | 206                            | 0         | 0                | 0           | -                                        |                                                |
|            | Signed / 32 / 0                 | 3,407                          | 0         | 0                | 0           | -                                        | -                                              |
|            | Unsigned / 8 / 0                | 176                            | 0         | 0                | 0           | -                                        | 1                                              |
|            | Unsigned / 32 / 0               | 3,310                          | 0         | 0                | 0           | -                                        |                                                |

 <sup>&</sup>lt;sup>(1)</sup> Using default parameter settings.
 <sup>(2)</sup> Using Verilog HDL.

### **Functional Description**

The Divider division result is shown in the following equation:

|Numerator| = |Quotient \* Denominator| + |Remainder|

For signed mode, the remainder always stays positive, and the quotient depends on the signed bit of both numerator and denominator. Example:

- 3/2 = 1 Remainder 1
- 3/-2 = -1 Remainder 1
- -3/2 = -1 Remainder 1
- -3/-2 = 1 Remainder 1

**Note:** The quotient, remainder, and fractional results of division by zero are undefined. The Divider core outputs the highest possible value based on the data width for the quotient and 0 for the remainder.

You can set the numerator and denominator bit widths independently. The bit width of the quotient is equal to the bit width of the numerator, WIDTHN, and the bit width of the remainder is equal to the width of the denominator, WIDTHD.

Figure 1: Divider System Block Diagram



### Ports

#### Table 1: Divider Ports

| Port                  | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| numer [WIDTHN-1:0]    | Input     | Numerator input to the Divider core for calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| denom [WIDTHD-1:0]    | Input     | Denominator input to the Divider core for calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| quotient [WIDTHN-1:0] | Output    | Quotient output from the Divider core after calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| remain [WIDTHD-1:0]   | Output    | Remainder output from the Divider core after calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| rfd                   | Output    | <ul> <li>Ready for data signal. When Latency set to 0, this signal is constantly high.</li> <li>1: Divider core calculation completed and ready for the next input.</li> <li>The output quotient and remainder of the previous numerator and denominator combination are updated.</li> <li>0: Calculation is in progress.</li> <li>This port is available only when PIPELINE parameter = 0. When PIPELINE is enabled, you can issue the next numerator and denominator at any clock cycle when clken is asserted. Quotient and remainder is available after <i>x</i> clock cycles where <i>x</i> = LATENCY.</li> </ul> |
| clken                 | Input     | Clock enable. When clken is high, the Divider must wait for one clock<br>cycle before operation continues.<br>1: Division operation in progress.<br>0: Idle.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| clk                   | Input     | System clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| reset                 | Input     | Asynchronous active high reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### **Divider Operations**

The Divider starts taking in the numerator and denominator inputs for operation after the first clock cycle of clken signal assertion.

The Divider supports adjustable latency from 0 (pipeline disabled) to numerator bit width, WIDTHN (full pipeline). The following figures show the full, half, and disabled pipeline Divider operation examples.

Figure 2: 8 Bit Width with 8 Clock Latency (Pipeline Disabled) Waveform



In pipeline mode, latency value from 1 to WIDTHN, the Divider goes into idle when the clken is low, and resumes operation 1 clock cycle after the clken is high. The following figure shows a full pipeline divider operation where the latency is equal to the bit width.



Figure 3: 8 Bit Width with 8 Clock Latency Waveform

Similar to the full pipeline operation but the Divider only needs 4 cycle for each output. The following figure shows a half pipeline divider operation where the latency is half of the bit width.





### **IP** Manager

The Efinity<sup>®</sup> IP Manager is an interactive wizard that helps you customize and generate Efinix<sup>®</sup> IP cores. The IP Manager performs validation checks on the parameters you set to ensure that your selections are valid. When you generate the IP core, you can optionally generate an example design targeting an Efinix development board and/or a testbench. This wizard is helpful in situations in which you use several IP cores, multiple instances of an IP core with different parameters, or the same IP core for different projects.

Note: Not all Efinix IP cores include an example design or a testbench.

#### Generating a Core with the IP Manager

The following steps explain how to customize an IP core with the IP Configuration wizard.

- 1. Open the IP Catalog.
- 2. Choose an IP core and click Next. The IP Configuration wizard opens.
- 3. Enter the module name in the Module Name box.



- 4. Customize the IP core using the options shown in the wizard. For detailed information on the options, refer to the IP core's user guide or on-line help.
- 5. (Optional) In the **Deliverables** tab, specify whether to generate an IP core example design targeting an Efinix<sup>®</sup> development board and/or testbench. For SoCs, you can also optionally generate embedded software example code. These options are turned on by default.
- 6. (Optional) In the Summary tab, review your selections.
- 7. Click Generate to generate the IP core and other selected deliverables.
- 8. In the Review configuration generation dialog box, click Generate. The Console in the Summary tab shows the generation status.



**Note:** You can disable the **Review configuration generation** dialog box by turning off the **Show Confirmation Box** option in the wizard.

9. When generation finishes, the wizard displays the Generation Success dialog box. Click OK to close the wizard.

The wizard adds the IP to your project and displays it under IP in the Project pane.

#### **Generated Files**

The IP Manager generates these files and directories:

- <module name>\_define.vh—Contains the customized parameters.
- **<module name>\_tmpl.v**—Verilog HDL instantiation template.
- **<module name>\_tmpl.vhd**—VHDL instantiation template.
- **<module name>.v**—IP source code.
- settings.json—Configuration file.
- <kit name>\_devkit—Has generated RTL, example design, and Efinity<sup>®</sup> project targeting a specific development board.
- Testbench—Contains generated RTL and testbench files.



**Note:** Refer to the IP Manager chapter of the Efinity<sup>®</sup> Software User Guide for more information about the Efinity<sup>®</sup> IP Manager.

# Customizing the Divider

The core has parameters so you can customize its function. You set the parameters in the General tab of the core's IP Configuration window.

Table 2: Divider Core Parameters

| Parameters                              | Options             | Description                                                                                                                                                                                                |
|-----------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Numerator Sign                          | SIGNED,<br>UNSIGNED | Sign representation of numerator input. When set to SIGNED, the core interprets the numerator input as signed two's complement. Default: UNSIGNED                                                          |
| Numerator and Quotient<br>Data Width    | 2 - 64              | Defines the numerator and quotient data width.<br>Default: 8                                                                                                                                               |
| Denominator and<br>Remainder Data Width | 2 - 64              | Defines the denominator and remainder data width. The value must not<br>be greater than Numerator and Quotient Data Width<br>Default: 8                                                                    |
| Denominator Sign                        | SIGNED,<br>UNSIGNED | Sign representation of denominator input. When set to SIGNED, the core interprets the denominator input as signed two's complement. Default: UNSIGNED                                                      |
| Enable Pipeline                         | Enable,<br>Disable  | Enables or disables the Divider pipeline.<br>When disabled, rfd signal is used. You must wait for the rfd signal to be<br>asserted before inserting the next numerator and denominator.<br>Default: Enable |
| Latency                                 | 0 -<br>WIDTHN       | Defines the latency. Set this to a higher value to achieve a higher $f_{MAX}$ .<br>When the core latency is not a concern, you can set this to the maximum value to achieve the best $f_{MAX}$ .           |

# Divider Example Design

You can choose to generate the example design when generating the core in the IP Manager Configuration window. Compile the example design project and download the **.hex** or **.bit** file to your board.

**Important:** Efinix tested the example design generated with the default parameter options only.

Figure 5: Example Design Block Diagram



The example design targets the Trion<sup>®</sup> T20 BGA256 Development Board and Titanium Ti60 F225 Development Board. This design sends predetermined numerator and denominator combinations to the Divider core and displays the pass/fail results on the LEDs.

**Note:** Additional to the design with default parameters, Efinix<sup>®</sup> also tested the core example design with signed 4 bit parameter.

#### Trion® T20 BGA256 Development Board

Example design input and output for the Trion® T20 BGA256 Development Board:

- *LED D4 to D3*—divider output display:
  - LED D3 turned on: Operation passed
  - LED D4 turned on: Operation failed
- *DIPswitch SW3.2*—clken signal to turn the Divider core on or off.
- *Pushbutton SW4*—Divider core reset.

#### Titanium Ti60 F225 Development Board

In the unsigned and signed mode, the LEDs blink from D16 blue, D16 green, D16 red, and D17 blue continuously.

Example design input and output for the Titanium Ti60 F225 Development Board:

- *LED D16 to D17*—divider output display:
  - LED D16 turned on (blue): Operation passed
  - LED D17 turned on (blue): Operation failed
- DIPswitch SW2.2—clken signal to turn the Divider core on or off.
- *Pushbutton SW5*—Divider core reset.

| Table 3: | <b>Trion</b> <sup>®</sup> | Example | Design | Implementation |
|----------|---------------------------|---------|--------|----------------|
|----------|---------------------------|---------|--------|----------------|

| FPGA             | Mode / Width<br>(bit) / Latency | Logic<br>Utilization<br>(LUTs) | Registers | Memory<br>Blocks | Multipliers | f <sub>MAX</sub><br>(MHz) <sup>(3)</sup> | Efinity <sup>®</sup><br>Version <sup>(4)</sup> |
|------------------|---------------------------------|--------------------------------|-----------|------------------|-------------|------------------------------------------|------------------------------------------------|
| T20 BGA256<br>C4 | Unsigned / 8 / 8                | 349                            | 332       | 0                | 0           | 50                                       | 2021.2                                         |

Table 4: Titanium Example Design Implementation

| FPGA         | Mode /<br>Width (bit) /<br>Latency (bit) | Logic and<br>Adders | Flip-flops | Memory<br>Blocks | DSP48<br>Blocks | f <sub>MAX</sub><br>(MHz) <sup>(3)</sup> | Efinity <sup>®</sup><br>Version <sup>(4)</sup> |
|--------------|------------------------------------------|---------------------|------------|------------------|-----------------|------------------------------------------|------------------------------------------------|
| Ti60 F225 C4 | Unsigned / 8 / 8                         | 331                 | 209        | 0                | 0               | 180                                      | 2021.2                                         |

# Divider Testbench

i

You can choose to generate the testbench when generating the core in the IP Manager Configuration window.

Note: You must include all .v files generated in the /testbench directory in your simulation.

Efinix provides a simulation script for you to run the testbench quickly using the Modelsim software. To run the Modelsim testbench script, run vsim -do modelsim.do in a terminal application. You must have Modelsim installed in your computer to use this script.

The testbench compares the divider output to a Verilog division operation results. You can set the numerator and denominator values in the **divider\_demo.v** file. After running the simulation successfully, the test prints the following message:

100500 ns---PASSED---

When the operation failed, the test prints the following message:

100500 ns---FAILED---

<sup>&</sup>lt;sup>(3)</sup> Using default parameter settings.

<sup>&</sup>lt;sup>(4)</sup> Using Verilog HDL.

# Revision History

### Table 5: Revision History

| Date          | Version | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| February 2023 | 4.4     | Added note about the resource and performance values in the resource and utilization table are for guidance only.                                                                                                                                                                                                                                                                        |
| April 2022    | 4.3     | Improved Latency parameter description. (DOC-796)                                                                                                                                                                                                                                                                                                                                        |
| March 2022    | 4.2     | Updated latency parameter description. (DOC-755)                                                                                                                                                                                                                                                                                                                                         |
| January 2022  | 4.1     | Updated rfq port and Enable Pipeline parameter descriptions.<br>Updated testbench.<br>Updated operation waveforms.<br>Updated Resource Utilization and Performance tables.                                                                                                                                                                                                               |
| December 2021 | 4.0     | Updated simulation testbench.<br>Added new IP Manager parameters.<br>Updated example design.<br>Added Divider operation waveforms.                                                                                                                                                                                                                                                       |
| October 2021  | 3.1     | Added note to state that the f <sub>MAX</sub> in Resource Utilization and<br>Performance, and Example Design Implementation tables were<br>based on default parameter settings.<br>Updated design example target board to production Titanium<br>Ti60 F225 Development Board and updated Resource Utilization<br>and Performance, and Example Design Implementation tables.<br>(DOC-553) |
| June 2021     | 3.0     | Added note about including all <b>.v</b> generated in testbench folder is<br>required for simulation.<br>Updated resource utilization and performance table.<br>Updated example design output and implementation table.<br>Added support for Titanium FPGAs and example design for<br>Titanium Ti60 F225 Development Board.<br>Updated for Efinity v2021.1.                              |
| December 2020 | 2.0     | Updated user guide for Efinix <sup>®</sup> IP Manager which includes added IP Manager topics, updated parameters, and user guide structure.                                                                                                                                                                                                                                              |
| May 2020      | 1.0     | Initial release.                                                                                                                                                                                                                                                                                                                                                                         |