The present application relates to data transmission via PCI express (Peripheral Component Interconnect express). For example, the present application may relate to corresponding devices or methods.
PCI express (PCIe) is a high-speed serial computer expansion bus standard designed to couple for example periphery devices with a chipset of a main processor (e.g. CDU). The PCI express electrical interface is also used in a variety of other standardized interfaces, for example in ExpressCard which is a laptop expansion card interface and in SATA Express which is a computer storage interface. PCI express essentially defines separate serial point-to-point connections. Separate endpoints may be coupled via switches. This enables an establishment of direct couplings between PCI express devices.
Applications running at higher layers on top of PCI express, for example applications related to a peripheral device, may use various data unit sizes, for example various frame sizes or various packet sizes. Conventional implementations of PCI express and point devices read an exact amount of data available over a bus. Such data units may be not aligned with double words (DWORDS) used in PCI data transfer. In some cases, this may lead to performance losses.
In the following, various embodiments will be discussed in detail with reference to the attached drawings. It should be noted that the embodiments shown in the drawings or described herein serve merely as illustrative examples and are not to be construed as limiting. For example, while embodiments may be described comprising a plurality of features or elements, in other embodiments some of these features or elements may be omitted and/or replaced by alternative features or elements. In other embodiments, additional features or elements may be provided. Features from different embodiments may be combined with each other to form further embodiments unless noted otherwise.
Any direct connection or couplings between elements shown in the drawings or described herein may be a direct connection or coupling, i.e. a connection or coupling without additional intervening elements, or an indirect connection or coupling, i.e. a connection or coupling with one or more intervening element, as long as the basic function of the connection or coupling, for example to transmit a certain kind of information or a certain kind of signal, is essentially maintained.
Embodiments relate to PCI express devices. Any terminology used herein is intended to have the meaning commonly used in the art of PCI express devices, for example as defined in various applicable PCI express standards, unless noted otherwise. PCI express devices may be devices having or using an interface based on PCI express, including e.g. ExpressCard devices or SATA Express devices.
Turning now to the figures, in
For example, PCIe device 10 may be an endpoint device, and PCIe device 11 may be a PCIe host device, or sometimes also referred to as root complex. In other embodiments, communication may be between two PCIe endpoints.
First PCIe device 10 comprises a transaction layer 13, a data link layer 14 and a physical layer 15. Second PCIe device 11 comprises a transaction layer 17, a data link layer 18 and a physical layer 19. These layers in some embodiments may essentially be defined or implemented as in conventional PCIe devices.
Furthermore, PCIe device 10 comprises one or more higher layers or other circuits 12 to implement a desired functionality of PCIe device 10 and/or techniques disclosed herein, and PCIe device 11 comprises one or more higher layers or other circuits 16 to implement a desired functionality of PCIe device 11 and/or techniques disclosed herein.
The PCIe functionality, i.e. communicating for example according to a PCIe standard or PCIe related standard, is implemented by layers 13 to 15 in PCIe device 10 and by layers 17 to 19 of PCIe device 11. Apart from differences discussed below in more detail, communication may essentially be a standard PCIe communication.
Physical layer 15 or 19 corresponds to the physical implementation of the PCIe interface and may be divided into two sub-layers corresponding to electrical and logical specification. Physical layer 15 or 19 may include for example a next switch.
Data link layer 14 or 18 sequences transaction layer packets (TLPs) received from the transaction layer 13 or 17, respectively, ensures reliable delivery of transaction layer packets between two PCIe endpoints, for example between devices 10 and 11, via an acknowledgement protocol and initializes and manages flow control credits in some embodiments. Transaction layer 13 or 17 transports payload data between a logic transmitter and receiver (for example between circuits 12 and 16) disregarding for example switches therebetween. In the transaction layers 13 or 17, for example transaction layer packets (TLPs) may be formed.
The above is only intended to be a short overview over the functioning of the layers, and any functionalities known in the art of PCI express devices may be implemented.
As mentioned, the transaction layer 13 or 17 for transmitting data generates a third transaction layer packet (TLPs) which comprises a plurality of 32 bit words, also referred to a DWORDS (double words) in the following. A TLP may comprise a header which may e.g. be three of four DWORDs long and one or more DWORDs containing actual data, for example data to be written.
For example, when transmitting data, transaction layer 13 receives data to be written (transmitted) from higher layers or other circuits 12. Higher layers or other circuits 12 may use data units which are not aligned with DWORDs, for example having a length not corresponding to an integer number of DWORDs. Such data units may for example be frames or packets. In embodiments, transaction layers 13, 17 or an entity above transaction layers 13, 17 within PCIe device 10 in case of a misalignment adds for example additional data, e.g. dummy data, such that data to be written is aligned with a DWORD. After transmitting the data, this additional data may be removed again or refrained from being processed. Similar techniques may be employed when receiving data. In some embodiments, after the data transfer, an associated data descriptor used for the transfer does not include the extra data like extra bytes or extra bits such that further processing stages processing received data disregard the additional data
A schematic example for such an alignment is illustrated in
In some embodiments, by such an DWORD length adjustment a transfer initiated by a PCI express endpoint may be enhanced. While in some embodiments in case of non-DWORD length aligned data as illustrated in
In
The PCIe endpoint device comprises a PCIe endpoint 35, for example hardware associated with transmitting or receiving data, an endpoint direct memory access (DMA) machine 33 to initiate and perform data transfers, an endpoint descriptor handling machine 34, an endpoint packet memory 30, an endpoint descriptor memory 31 and an intelligent transfer adjustment block 32. Apart from intelligent transfer adjustment block 32 and its interaction with the other components, the endpoint device may be implemented in any conventional manner using hardware, software, firmware or combinations thereof. Various functions described in the following of the components illustrated in
The host device comprises a PCIe host hardware 37, a system memory 38, a host packet memory 39 and a host descriptor memory 310 and may be implemented in a conventional manner.
In the embodiment of
Next, a data flow for transmitting data from endpoint to host will be illustrated with reference to
At 60 in
At 61, this pointer is handed over to endpoint descriptor handling machine 34, as indicated by an arrow B in
Next, at 62, the endpoint descriptor handling machine 34 prepares a packet descriptor for endpoint DMA machine 33, and stores it in memory 31, which in this case serves for storing transmission (TX) DMA descriptors. This is indicated by an arrow C in
At 63, as indicated by an arrow D in
The transferring of the aligned data may be essentially performed by conventional PCIe techniques using transfer layer, data link layer and physical layer. For example, the aligned data may be used to form transaction layer packets (TLPs), which may then be processed normally. The functions implemented by intelligent transfer adjustment block 32 may be implemented in a layer above the transaction layer.
After the transfer at 64, at 65, DMA machine updates the descriptor stored in descriptor memory 31 corresponding to the transmission of data, as indicated by an arrow F in
Next, at 66, the transfer adjustment block 32 modifies this descriptor to adjust data length back to the original length without the added data for alignment. In other words, the descriptor after this adjustment describes the transferred data as if it were transferred without the additional data, for example additional bytes. This is indicated by arrow G in
At 67, the just adjusted descriptor is handed over to the endpoint descriptor handling machine 34, as indicated by arrow H in
In some embodiments, by providing the adjusted descriptor corresponding to the original length, e.g. without the added dummy data, the transfer of the dummy bytes is transparent for blocks, devices or layers handling the data subsequently, for example on the host side. In other words, the DMA hardware receives a descriptor including the extra data, but a next instance, for example on the host side, receives an adjusted descriptor corresponding to the actual data length without dummy data added. Therefore, subsequent instances essentially do not notice the added dummy data, but process the data in a regular way.
Next, with reference to
At 70 of
In conventional systems, this descriptor would then be provided to endpoint DMA machine 33 to enable endpoint DMA machine 33 to retrieve data from the host corresponding to the descriptor. In embodiments, instead at 71, the descriptor is provided to adjustment block 32, as indicated by an arrow L in
At 72, the adjusted descriptor is provided to endpoint memory 31 as indicated by an arrow M in
At 74, the DMA machine then transfers data according to the adjusted descriptor, i.e. DWORD length aligned data, from a host side memory like host packet memory 39 to an endpoint memory like endpoint packet memory 30. This is indicated by an arrow O in
At 75, the descriptor is then updated to reflect the completed transfer, as indicated by an arrow P in
At 76, as indicated by an arrow Q in
At 77, this adjusted descriptor is then handed over to the endpoint descriptor handling machine as indicated by an arrow R in
While in
To illustrate the effect of techniques disclosed herein,
Conventional PCIe devices enabling writing and reading data from a device, for example endpoint, to another device, for example route complex, via an address map. In embodiments, as explained above, for aligned data transfer, this address map is essentially modified.
In a PCIe system, a root complex for example at start-scans, the PCIe connections for the presence of devices, also referred to as endpoint. The transfer of data between these PCIe devices is based on transaction layer packets. The data written or read via PCIe connections are therefore partitions into transaction layer packets. In embodiments, the data is aligned to a multiple of a DWORD length, for example by inserting dummy bytes, for example prior to performing the transaction layer packets.
The above-described embodiments serve merely as example, and are not to be construed as limiting.
This application claims the benefit of U.S. provisional application No. 61/861,470 filed Aug. 2, 2013.
Number | Name | Date | Kind |
---|---|---|---|
5590378 | Thayer | Dec 1996 | A |
5687328 | Lee | Nov 1997 | A |
5983305 | Szczepanek | Nov 1999 | A |
7243172 | Oner | Jul 2007 | B2 |
7373437 | Seigneret | May 2008 | B2 |
8312190 | Wang | Nov 2012 | B2 |
20040123013 | Clayton et al. | Jun 2004 | A1 |
20060271721 | Beukema | Nov 2006 | A1 |
20070263629 | Cornett et al. | Nov 2007 | A1 |
20080123638 | Liao | May 2008 | A1 |
20080195781 | Kim | Aug 2008 | A1 |
20080294799 | Ward | Nov 2008 | A1 |
20130082851 | Pardo | Apr 2013 | A1 |
Entry |
---|
“PCIe-DMA ConfigFPGA Design User Interface Manual Rev. 1.19”; Aug. 27, 2012, p. 1-30. |
Number | Date | Country | |
---|---|---|---|
20150039804 A1 | Feb 2015 | US |
Number | Date | Country | |
---|---|---|---|
61861470 | Aug 2013 | US |