# **Nios II Performance Benchmarks**



DS-N28162004-5.0

## **Performance Benchmarks Overview**

This data sheet lists the performance and logic element (LE) usage for the Nios® II soft processor and peripherals. The Nios II soft processor is configurable and designed for implementation in Altera® FPGAs. The following Nios II processors were used for these benchmarks:

- Nios II/f—The Nios II/f "fast" processor is designed for high performance while presenting the most configuration options which are unavailable in the other Nios II processors.
- Nios II/s—The Nios II/s "standard" processor is designed for small size while maintaining moderate performance.
- Nios II/e—The Nios II/e "economy" processor is designed for the smallest possible processor size while providing adequate performance.

The default options for the Nios II processor were chosen for these benchmarks, unless specified otherwise.



Results may vary slightly depending on the version of the Quartus<sup>®</sup> II software, the version of the Nios II processor, and the target device. Also, any changes to the system logic design might change the performance and LE usage.

Table 1 and Table 2 list the  $f_{MAX}$  and millions of instructions per second (MIPS) for a system with the following components:

- Nios II processor with JTAG debug module
- JTAG UART
- 64 kilobytes (KB) on-chip memory (Cyclone® designs use one megabyte [MB] of off-chip SDR SDRAM)
- Avalon® Memory-Mapped (Avalon-MM) pipeline bridge
- Timer



The MIPS reports were obtained using the MIPS\* (\*Dhrystones 2.1 benchmark). You can download the Dhrystones 2.1 benchmark software from the Nios II Embedded Processor Design Examples page on the Altera website. For more information about the Dhrystones 2.1 benchmark software, refer to the **readme.txt** file which is included in the Dhrystones 2.1 benchmark design example.



The Fast design example illustrates a system that has all the components listed. You can download the Fast design example from the Nios II Embedded Processor Design Examples page on the Altera website. For more information about the Fast design example, refer to the **readme.txt** file which is included in the Fast design example.

**Table 1.**  $f_{MAX}$  for Nios II Processor System (MHz) (Note 1)

| Device Family                       | Device Used      | Nios II/f | Nios II/s | Nios II/e |
|-------------------------------------|------------------|-----------|-----------|-----------|
| Stratix® IV (2)                     | EP4SGX230HF35C2  | 290       | 250       | 340       |
| Stratix III                         | EP3SL150F1152C2  | 290       | 230       | 340       |
| Stratix II                          | EP2S60F1020C3    | 220       | 170       | 285       |
| Stratix                             | EP1S80F1020C5    | 150       | 130       | 170       |
| HardCopy <sup>®</sup> IV <i>(2)</i> | HC4E35FF1152     | 305       | 295       | 315       |
| HardCopy III (2)                    | HC322FF1152      | 230       | 220       | 210       |
| HardCopy II                         | HC230F1020C      | 200       | 200       | 320       |
| HardCopy Stratix                    | EP1S80F1020C5_HC | 150       | 130       | 175       |
| Cyclone IV GX (2)                   | EP4CGX30CF19C6   | 165       | 110       | 175       |
| Cyclone III LS (2), (3)             | EP3CLS70F484C7   | 140       | 105       | 150       |
| Cyclone III (3)                     | EP3C40F324C6     | 175       | 145       | 215       |
| Cyclone II                          | EP2C20F484C6     | 140       | 110       | 195       |
| Cyclone                             | EP1C20F400C6     | 135       | 120       | 175       |
| Arria® II GX <i>(2)</i>             | EP2AGX95DF25C4   | 250       | 190       | 250       |
| Arria GX                            | EP1AGX60CF484C6  | 140       | 100       | 150       |

## Notes to Table 1:

- (1) These results were generated using push button Analysis, Synthesis and Fitter settings in the Quartus II software.
- (2) Arria II GX, Cyclone IV GX, Cyclone III LS, HardCopy IV, HardCopy III, and Stratix IV results are based on preliminary timing models.
- (3) When comparing Cyclone III LS and Cyclone III results in Table 1, note that a speed grade 6 device was used for the Cyclone III device, whereas a speed grade 7 device was used for the Cyclone III LS device.

Table 2 lists the value of MIPS for the different types of Nios II processors, while Table 3 lists the ratio of MIPS over the system clock (MIPS/MHz).

**Table 2.** MIPS for Nios II Processor System (Note 1) (Part 1 of 2)

| Device Family    | Device Used      | Nios II/f | Nios II/s | Nios II/e |
|------------------|------------------|-----------|-----------|-----------|
| Stratix IV (1)   | EP4SGX230HF35C2  | 340       | 150       | 48        |
| Stratix III      | EP3SL150F1152C2  | 340       | 140       | 48        |
| Stratix II       | EP2S60F1020C3    | 250       | 110       | 45        |
| Stratix          | EP1S80F1020C5    | 170       | 80        | 27        |
| HardCopy IV      | HC4E35FF1152     | 345       | 189       | 47        |
| HardCopy III (1) | HC322FF1152      | 260       | 140       | 30        |
| HardCopy II      | HC230F1020C      | 230       | 130       | 50        |
| HardCopy Stratix | EP1S80F1020C5_HC | 165       | 85        | 27        |
| Cyclone IV GX    | EP4CGX30CF19C6   | 186       | 70        | 26        |
| Cyclone III LS   | EP3CLS70F484C7   | 158       | 67        | 23        |
| Cyclone III      | EP3C40F324C6     | 195       | 90        | 30        |
| Cyclone II       | EP2C20F484C6     | 145       | 55        | 18        |
| Cyclone          | EP1C20F400C6     | 130       | 52        | 17        |
| Arria II GX      | EP2AGX95DF25C4   | 283       | 122       | 38        |

**Table 2.** MIPS for Nios II Processor System (*Note 1*) (Part 2 of 2)

| Device Family | Device Used     | Nios II/f | Nios II/s | Nios II/e |
|---------------|-----------------|-----------|-----------|-----------|
| Arria GX      | EP1AGX60CF484C6 | 150       | 65        | 25        |

## Notes to Table 2:

- (1) These results were generated using push button Analysis, Synthesis, and Fitter settings in the Quartus II software.
- (2) Cyclone III LS, Cyclone IV GX, HardCopy III, HardCopy IV, and Stratix IV MIPS results are based on estimations.

Table 3 lists the ratio of MIPS over system clock (MIPS/MHz).

Table 3. MIPS/MHz Ratio for Nios II Processor System on Various Device Families

|                |           | -         |           |
|----------------|-----------|-----------|-----------|
| Device Family  | Nios II/f | Nios II/s | Nios II/e |
| Stratix IV     | 1.183     | 0.611     | 0.138     |
| Stratix III    | 1.183     | 0.611     | 0.138     |
| Stratix II     | 1.183     | 0.611     | 0.138     |
| Cyclone IV GX  | 1.13      | 0.64      | 0.15      |
| Cyclone III LS | 1.13      | 0.64      | 0.15      |
| Cyclone III    | 1.109     | 0.604     | 0.138     |
| Cyclone II     | 1.105     | 0.518     | 0.107     |
| HardCopy IV    | 1.13      | 0.64      | 0.15      |
| Arria II GX    | 1.13      | 0.64      | 0.15      |

Table 4 lists the LE usage for the Nios II processor cores and most of the common peripherals for Stratix IV, Stratix III, Stratix II and Stratix devices.

 Table 4.
 LE Usage for Nios II Processor Cores and Peripherals—Stratix IV, Stratix III, Stratix II, and Stratix Devices (Note 1)

| Processor Core / Peripheral | Stratix IV (ALUTs) $(1)$ | Stratix III (ALUTs) | Stratix II (ALUTs) | Stratix (LEs) |
|-----------------------------|--------------------------|---------------------|--------------------|---------------|
| Nios II/f (3)               | 1,020                    | 1,020               | 1,320              | 1,800         |
| Nios II/s (4)               | 850                      | 800                 | 1,030              | 1,170         |
| Nios II/e (5)               | 520                      | 520                 | 500                | 530           |
| Nios II JTAG debug module   | 110                      | 110                 | 430                | 390           |
| UART                        | 40                       | 40                  | 130                | 150           |
| JTAG UART                   | 115                      | 115                 | 205                | 210           |
| SDR SDRAM Controller        | 310                      | 310                 | 520                | 760           |
| Timer                       | 120                      | 120                 | 185                | 160           |

## Notes to Table 4:

- (1) Resource utilization results for Stratix IV and Stratix III devices were generated using moderate Analysis and Synthesis settings or Fitter settings in the Quartus II software. These results represent typical results. Your results may vary.
- (2) An adaptive look-up table (ALUT) is the cell used in the Quartus II software for logic synthesis for the Stratix II device and later device families. It is equivalent to about 1.25 LEs.
- (3) The Nios II/f processor used has 512-bytes instruction and data caches, and no hardware multiplier.
- (4) The Nios II/s processor used has 512-bytes instruction, no data caches and hardware multiplier.
- (5) The Nios II/e processor used has no instruction, data caches, and hardware multiplier.

Page 3

Table 5 lists the LE usage for the Nios II processor cores and most of the common peripherals for HardCopy IV, HardCopy II, HardCopy Stratix, Cyclone IV GX, Cyclone III LS, Cyclone III, Cyclone II and Cyclone devices.

**Table 5.** LE Usage for Nios II Processor Cores and Peripherals—HardCopy IV, HardCopy II, HardCopy Stratix, Cyclone IV GX, Cyclone III LS, Cyclone III, Cyclone II, and Cyclone Devices (Note 1)

| Processor Core / Peripheral | HardCopy IV | HardCopy II (HCells) (2) | HardCopy Stratix (LEs) | Cyclone IV GX | Cyclone III LS | Cyclone III (LEs) | Cyclone II (LEs) | Cyclone (LEs) |
|-----------------------------|-------------|--------------------------|------------------------|---------------|----------------|-------------------|------------------|---------------|
| Nios II/f (3)               | 6420        | 8,900                    | 1,770                  | 1798          | 1817           | 1,800             | 1,600            | 1,680         |
| Nios II/s (4)               | 4838        | 6,500                    | 1,200                  | 1313          | 1308           | 1,300             | 1,030            | 1,140         |
| Nios II/e (5)               | 3362        | 2,250                    | 520                    | 726           | 728            | 650               | 540              | 520           |
| Nios II JTAG debug module   | 900         | 350                      | 390                    | 230           | 230            | 250               | 450              | 450           |
| UART                        | 500         | 520                      | 150                    | 145           | 140            | 75                | 140              | 155           |
| JTAG UART                   | 650         | 620                      | 210                    | 170           | 170            | 170               | 165              | 200           |
| SDR SDRAM Controller        | 1600        | 1,740                    | 760                    | 370           | 360            | 420               | 750              | 760           |
| Timer                       | 690         | 700                      | 160                    | 150           | 150            | 150               | 150              | 155           |

## Notes to Table 5:

- (1) Resource utilization results for HardCopy II, HardCopy IV, Cyclone III, Cyclone III LS, and Cyclone IV GX devices were generated using moderate Analysis and Synthesis settings or Fitter settings in the Quartus II software. These results represent typical results. Your results may vary.
- (2) HCells are logic blocks that implement both logic and DSP functions. DSP block functions are implemented using HCells instead of dedicated DSP blocks.
- (3) The Nios II/f processor used has 512-bytes instruction and data caches, and no hardware multiplier.
- (4) The Nios II/s processor used has 512-bytes instruction, no data caches and hardware multiplier.
- (5) The Nios II/e processor used has no instruction, data caches, and hardware multiplier.

Table 6 lists the LE usage for the Nios II processor cores and most of the common peripherals for HardCopy III, Arria II GX, and Arria GX devices.

**Table 6.** LE Usage for Nios II Processor Cores and Peripherals—HardCopy III, Arria II GX, and Arria GX Devices (Note 1) (Part 1 of 2)

| Processor Core / Peripheral | HardCopy III (HCells) (2) | Arria II GX (ALUTs) (3) | Arria GX (ALUTs) |
|-----------------------------|---------------------------|-------------------------|------------------|
| Nios II/f (4)               | 9,100                     | 989                     | 1,000            |
| Nios II/s (5)               | 6.900                     | 774                     | 800              |
| Nios II/e (6)               | 4,000                     | 560                     | 550              |
| Nios II JTAG debug module   | 1,200                     | 110                     | 110              |
| UART                        | 700                       | 100                     | 100              |
| JTAG UART                   | 850                       | 110                     | 110              |
| SDR SDRAM Controller        | 1,900                     | 200                     | 300              |

Document Revision History Page 5

**Table 6.** LE Usage for Nios II Processor Cores and Peripherals—HardCopy III, Arria II GX, and Arria GX Devices (Note 1) (Part 2 of 2)

| Processor Core / Peripheral | HardCopy III (HCells) (2) | Arria II GX (ALUTs) (3) | Arria GX (ALUTs) |
|-----------------------------|---------------------------|-------------------------|------------------|
| Timer                       | 800                       | 110                     | 110              |

## Notes to Table 6:

- (1) Resource utilization results for HardCopy III, Arria II GX, and Arria GX devices were generated using moderate Analysis and Synthesis settings or Fitter settings in the Quartus II software. These results represent typical results. Your results may vary.
- (2) HCells are logic blocks that implement both logic and DSP functions. DSP block functions are implemented using HCells instead of dedicated DSP blocks.
- (3) An ALUT is the cell used in the Quartus II software for logic synthesis for Stratix II and later device families. It is equivalent to about 1.25 LEs.
- (4) The Nios II/f processor used has 512-bytes instruction and data caches, and no hardware multiplier.
- (5) The Nios II/s processor used has 512-bytes instruction, no data caches and hardware multiplier.
- (6) The Nios II/e processor used has no instruction, data caches, and hardware multiplier.



Additional performance benchmarking information for the Nios II processor can be found at the following links:

- For more information about the Nios II interrupt latency performance, refer to the *Exception Handling* chapter of the *Nios II Software Developer's Handbook*.
- For more information about the Nios II floating-point custom instruction performance, refer to the *Using Nios II Floating-Point Custom Instructions Tutorial*.
- For more information about the Nios II networking applications performance, refer to *AN440*: Accelerating Nios II Networking Applications.

# **Document Revision History**

Table 7 shows the revision history for this document.

**Table 7.** Document Revision History (Part 1 of 2)

| Date and Document<br>Version | Changes Made                                                                                                                                         | Summary of Changes                                         |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| February 2010<br>v5.0        | <ul> <li>Measured performance and LE usage with the Quartus II<br/>version 9.1 software and the Nios II version 9.1 processor</li> </ul>             | Updated Table 1, Table 2,<br>Table 3, Table 5, and Table 6 |
|                              | <ul> <li>Added new information for the Cyclone III LS, Cyclone IV GX,<br/>and HardCopy IV devices</li> </ul>                                         | with new data.                                             |
|                              | <ul> <li>Updated information for Arria II GX devices</li> </ul>                                                                                      |                                                            |
| June 2009<br>v4.0            | <ul> <li>Measured performance and LE usage with the Quartus II<br/>version 9.0 SP1 software and the Nios II version 9.0 SP1<br/>processor</li> </ul> | Updated Tables 1 and 2 with new data. Added Table 6.       |
|                              | <ul> <li>Added information for the HardCopy III, Arria II GX, and<br/>Arria GX devices</li> </ul>                                                    |                                                            |
| July 2008<br>v3.0            | <ul> <li>Measured performance and LE usage with the Quartus II<br/>version 8.0 software and the Nios II version 8.0 processor</li> </ul>             | Updated Tables 1, 2, 4 and 5 with new data. Added Table 3. |
|                              | <ul> <li>Added information for the Stratix IV device</li> </ul>                                                                                      |                                                            |
|                              | <ul> <li>Added links for additional information on Nios II benchmark performance</li> </ul>                                                          |                                                            |

Page 6 Document Revision History

**Table 7.** Document Revision History (Part 2 of 2)

| Date and Document<br>Version | Changes Made                                                                                                     | Summary of Changes                        |
|------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| August 2007<br>v2.0          | Measured performance and LE usage with the Quartus II version 6.1 software and the Nios II version 6.1 processor | Updated Tables 1, 2, and 3 with new data. |
|                              | <ul> <li>Added information for the Stratix III, HardCopy II, and<br/>Cyclone III devices</li> </ul>              |                                           |
| October 2004<br>v1.0         | ■ Initial release                                                                                                | _                                         |



101 Innovation Drive San Jose, CA 95134 www.altera.com Technical Support www.altera.com/support Copyright © 2010 Altera Corporation. All rights reserved. Altera, The Programmable Solutions Company, the stylized Altera logo, specific device designations, and all other words and logos that are identified as trademarks and/or service marks are, unless noted otherwise, the trademarks and service marks of Altera Corporation in the U.S. and other countries. All other product or service names are the property of their respective holders. Altera products are protected under numerous U.S. and foreign patents and pending applications, maskwork rights, and copyrights. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera 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 Altera Corporation. Altera 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.