Rev. 0 — February 24, 2021 Application Note ### 1 Introduction The i.MX 8M Plus family focuses on Machine Learning (ML) and vision, advanced multimedia, and industrial IoT with high reliability. It is built to meet the needs of Smart Home, Building, City and Industry 4.0 applications. PCI Express technology provides a high-speed scalable solution for reliable data transport. The PCIe IP of i.MX 8M Plus provides PCI Express Gen 3.0 x1 functionality. #### Contents | 1 | Introduction | 1 | |-----|----------------------------|---| | 2 | Purpose | 1 | | 3 | Acronyms and Abbreviations | 1 | | 4 | Overview | 1 | | 4.1 | Software environment | 1 | | 4.2 | Hardware setup | 2 | | 5 | Results | 2 | | 6 | Regulte analysis | 1 | # 2 Purpose This document presents various usage scenarios for PCIe on the i.MX 8M Plus to provide a more clear understanding of the cases where near Gen3 x1 line rate bandwidth (8 Gbits/s) can be achieved after protocol overhead. # 3 Acronyms and Abbreviations Table 1. Acronyms and abbreviations | Acronyms and abbreviations | Description | |----------------------------|-------------------------------------------------| | PCle | Peripheral Component Interconnect (PCI) Express | | RC | Root Complex | | EP | End Point | | DMA | Direct Memory Access | | DUT | Device Under Test | | TLP | Transaction Layer Packet | | MWr | Memory Write | | MRd | Memory Read | ## 4 Overview ## 4.1 Software environment Linux BSP release 5.4.70\_2.3.0 (GA for i.MX 8M Plus) was used to obtain the results presented in this document. The test procedure is based on the standard Linux PCI test. The PCIe DMA benchmarking procedure made use of the new EP framework introduced starting with the 5.4.y release line. The 5.4.70 release includes fine tuning of the PCIe PHY registers, that allows to avoid bandwith impact due to the signal quality of the connection in test system hardware. ## 4.2 Hardware setup The measurements were performed in two scenarios: - . i.MX 8M Plus End Point ↔ i.MX 8M Plus Root Complex - i.MX 8M Plus End Point ↔ i.MX 8QuadMax Root Complex In both cases the boards were connected using a PCIe M2 connector board. Both i.MX 8M Plus and i.MX 8QuadMax are PCle 3.0 capable. #### 5 Results Table 2 presents the performance results obtained when transferring a buffer size of 8MB. The data is transferred using DMA. Table 2. Performance results | EP (PCIe DMA transfer initiator) | Data Transfer Type related to i.MX 8M Plus | RC | Avg. Throughput (MB/s) | |----------------------------------|------------------------------------------------|---------------|------------------------| | i.MX 8M Plus | READ FROM<br>(i.MX 8M Plus EP<br>Outbound MRd) | i.MX 8QuadMax | 753 | | i.MX 8M Plus | WRITE TO (i.MX 8M Plus EP Outbound MWr) | i.MX 8QuadMax | 809 | | i.MX 8QuadMax | READ FROM<br>(i.MX 8M Plus RC<br>Inbound MRd) | i.MX 8M Plus | 793 | | i.MX 8QuadMax | WRITE TO (i.MX 8M Plus RC Inbound MWr) | i.MX 8M Plus | 480 | | i.MX 8M Plus | READ FROM (i.MX 8M DUT-DUT) | i.MX 8M Plus | 768 | | i.MX 8M Plus | WRITE TO (i.MX 8M DUT-DUT) | i.MX 8M Plus | 441 | Figure 1, Figure 2, and Figure 3 present how the throughput scales for various amounts of data being transferred. Application Note 2/5 3/5 Figure 1. i.MX 8MP PCIe DUT-DUT Throughput Analysis 8MP - EP (DMA transfer initiator); 8MP - RC # 6 Results analysis As shown in Table 2, one can notice that while in some cases the bandwidth fits Gen 3 expectations, in other cases it is limited to the performance slightly better than the realistic Gen2 throughput. This is due to an i.MX 8M Plus limitation decribed below. When the outstanding inbound write data transfer size exceeds 400 Bytes, the number of inbound MWr TLP transactions that the i.MX 8M Plus PCIe Controller can support is up to the combination of 12 headers and 400 bytes of data payload. This remains true as long as neither is exceeded. Higher performance can be obtained to achieve the same goal by having the i.MX 8M Plus issue outbound MRd transactions instead of using inbound MWr. How To Reach Us Home Page: nxp.com Web Support: nxp.com/support Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein. NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.com/SalesTermsandConditions. **Right to make changes** - NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof. Security — Customer understands that all NXP products may be subject to unidentified or documented vulnerabilities. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP. NXP has a Product Security Incident Response Team (PSIRT) (reachable at PSIRT@nxp.com) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products. NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX,EMBRACE, GREENCHIP, HITAG, ICODE, JCOP, LIFE, VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, CodeWarrior, ColdFire, ColdFire+, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorlQ, QorlQ Qonverge, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, Tower, TurboLink, EdgeScale, EdgeLock, elQ, and Immersive3D are trademarks of NXP B.V. All other product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org. © NXP B.V. 2021. All rights reserved. For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com Date of release: February 24, 2021 Document identifier: AN13164