## **Keystone PCIe Usage** # **Agenda** - PCle Overview - Address Translation - Configuration ### **PCIe Topology Example** - PCIe: A tree structure with nodes connected to each other via point-to-point links. - The root node is called the root complex (RC). - The leaf nodes are called end points (EP) and the nodes that connect multiple devices to each other are called switches (SW). ### KeyStone Architecture CorePac & Memory Subsystem Memory Expansion Multicore Navigator Network Coprocessor External Interfaces - SGMII allows two 10/100/1000 Ethernet interfaces - Four high-bandwidth Serial RapidIO (SRIO) lanes for inter-DSP applications - SPI for boot operations - UART for development/testing - Two PCle at 5 Gbps - I<sup>2</sup>C for EPROM at 400 Kbps - Application-specific Interfaces: - Antenna Interface 2 (AIF2) for wireless applications - Telecommunications Serial Port (TSIP) x2 for media applications #### **PCle Features** - PCI-SIG: PCI Express Base Specification (Rev. 2.0) - Root Complex (RC) and End Point (EP) operation modes. - In EP mode, supports both legacy EP mode and native PCIe EP mode. - Set from bootstrap pins PCIESSMODE[1:0] at power-up (00->EP, 01->Legacy EP, 10->RC). - Software overwrites the setting by changing the PCIESSMODE bits in the DEVSTAT register. - Gen1 (2.5 Gbps) and Gen2 (5.0 Gbps) - x2 lanes - Outbound/Inbound max payload size of 128/256 bytes # **Agenda** - PCle Overview - Address Translation - Configuration ### **Address Translation** - PCIe device uses PCIe address to Tx/Rx packets over a PCIe link. - Outbound transfer means the local device initiates the transactions to write to or read from the external device. The CPU or the device-level EDMA is used for outbound data transfer. The PCIe module does not have built-in EDMA. - Inbound transfer means the external device initiates the transactions to write to or read from the local device. The PCIe module has a master port to transfer the data to or from the device memory; No CPU or EDMA is needed for inbound transfer in the local device. - BAR: used to accept/reject TLP (Transport Layer Protocol). - PCIe data space 256 MB (0x6000\_0000~0x6FFF\_FFFF) - Enable/disable through CMD\_STATUS register. - When enabled, the outbound PCIe address (0x6000\_0000~0x6FFF\_FFFF) can be modified to a new address based on the outbound translation rules. - Equally divided into 32 regions - Registers for outbound (OB): - OB\_SIZE: identify the size of 32 equally-sized translation regions to be 1MB/2MB/4MB/8MB - OB\_OFFSET\_INDEXn (n =0;31): represent bits[31:20] of the PCIe address for 32-bit or 64-bit addressing; not all bits will be used (depend on OB\_SIZE); bit[0] enables the outbound region - OB\_OFFSETn\_HI (n =0;31): represent bits[63:32] of the PCIe address for 64-bit addressing; must be zero for 32-bit addressing #### **Outbound Address** | OB_SIZE | internal address bit offset for" Region indexing" | OB_OFFSET_INDEXn bit offset for"Translation" | | |----------|---------------------------------------------------|----------------------------------------------|--| | 0 (1 MB) | [24:20] | [31:20] | | | 1 (2 MB) | [25:21] | [31:21] | | | 2 (4 MB) | [26:22] | [31:22] | | | 3 (8 MB) | [27:23] | [31:23] | | #### Example: - OB\_SIZE: 1 MB; - OB\_OFFSET\_INDEX0 = 0x9000\_0001; - OB\_OFFSET0\_HI = 0x0; - PCIE data space address: 0x6001\_5678; - What is the translated PCIe address? #### Example continues: - Because OB\_SIZE = 1 MB == → using bit [24:20] for region indexing - Thus the index region is 0, and the next 20 bits bit 0 to 19 determine the offset into the region - Using OB\_OFFSET\_INDEX0 and OB\_OFFSET0\_HI - The region upper base address is the OB\_OFFSET0\_HI = 0 and the upper 12 bits of the OB\_OFFSET\_INDEX0 register is bits 31:20 of the base address, so the combined based address of region 0 is 0x0000 0000 900 X XXXX Then the translated PCIe address = bits[31:20] of 0x9000\_0000 + bits[19:0] of 0x6001\_5678 = 0x9001\_5678 ### **Inbound Translation - 1** - Enable/disable through CMD\_STATUS register - During negotiation, the RC and the EP exchange memory requests. These values are saved in the BAR registers - BARn: two BARs (BAR0~1) in RC mode and six BARs (BAR0~5) in EP mode; Each register overlays initial address and MASK (based on DBI\_CS2 bit in the CMD\_STATUS register) - BARO cannot be remapped to any other location than to PCIe application registers (starting from 0x2180\_0000 in KeyStone device). It allows the RC device to control EP in the absence of dedicated software running on EP - During initialization, the values in the BAR are used to build (up to) four memory regions. ### **Inbound Translation - 2** - Each memory region has the following - IB\_BAR Inbound Translation Match Register (write the MASK into IB\_BAR, read gives the BAR set number) - IB\_START\_LO Inbound Translation Start Address Low Register - IB\_START\_HI Inbound Translation Start Address High Register - IB\_OFFSET Inbound Translation device base address - For inbound address A that arrives the following happens: - Using a IB\_BAR MASK register, A is compared with the low and high address to see if there is a match - · If there is no match, the address is rejected - If there is a match, the internal device address is calculated as follows: The difference between A – IB\_START (64 bit, high and low) is calculated The result is added to the device base address ### Inbound example ``` BAR1 = 0x9000_0000 (bits [3:0]=0000b, means 32-bit, non-prefetchable, memory BAR). BAR1 Mask register is set as 0x00FF_FFFF, so BAR1 window size is 16 MB. BAR1 accepts this inbound write request since the window covers the PCIe address of the target packets. ``` ``` IB_BAR0 = 1 (BAR1 is selected for IB Region 0) IB_START0_HI = 0x0 (upper 32 bits are zero for 32-bit addressing) IB_START0_LO= 0x9000_0000 IB_OFFSET0 = 0x1086_0000 Then the starting device memory address = PCIe address - (IB_START0_HI:IB_START0_LO) + IB_OFFSET = (0x9001 5678) - (0x9000 0000) + (0x1086 0000) = 0x1087 5678 ``` # **Agenda** - PCle Overview - Address Translation - Configuration #### **PCIe Initialization** Boot mode: PCIe boot by selecting pins on 6678/6670 EVM boards. | SW3 | SW4 | SW5 | SW6 | SW9 | |-----------------------|------------------|-------------------|-------------------|--------| | (pin1, 2, 3, 4) | (pin1, 2, 3, 4) | (pin1, 2, 3, 4) | (pin1, 2, 3, 4) | (pin1) | | (off/on, on, on, off) | (on, on, on, on) | (on, on, on, off) | (off, on, on, on) | (on) | #### IBL code - PLL workaround (6678 Errata, advisory 8) - Power-up PCle - Configure PLL - Configure PCle registers - Waiting for PCIe link-up - Stay inside IBL, monitor the magic address (6678: 0x87FFFC; 6670: 0x8FFFFC) for secondary boot #### **PCle Boot** #### For More Information - For more information, refer to the <u>PCI Express (PCIe)</u> for KeyStone Devices User's Guide. - PCIe examples in PDK: pdk\_install\_folder\packages\ti\drv\exampleProjects\ PCIE\_exampleProject - PCI bootloader example: mcsdk\_install\_folder\tools\boot\_loader\examples\p cie - For questions regarding topics covered in this training, visit the support forums at the <u>TI E2E Community</u> and <u>Devi forum</u> website.