The present invention relates generally to digital interface translators and more specifically to multilane to single lane and single lane to multilane digital interface translators.
Digital devices, such as personal computers and digital set top boxes, can be used to drive display devices such as monitors, projectors, and televisions. A variety of digital interfaces exist for communicating audio and video information in a digital format to a digital display device for rendering. These interfaces include Digital Visual Interface (DVI) specified by the Digital Display Working Group of Vancouver, Wash., the High Definition Multimedia Interface (HDMI) promoted by HDMI Licensing, LLC of Sunnyvale Calif., and the Display Port standard issued by the Video Electronics Standards Association of Milpitas, Calif. Each of these standards supports the use of multiple channels for the transmission of video information and additional channels for the transmission of auxiliary information.
Cables are typically used to connect digital devices with digital displays. The length of the cable is typically limited by signal attenuation. In many instances, the extent of signal attenuation in a cable can be impacted by the construction quality and materials that were used. Signal attenuation and intersymbol interference in long cables can be compensated for by using adaptive equalization. A number of manufacturers offer amplifiers, equalizers, and repeaters that can be used to combat attenuation. HDMI extenders that are based on dual Category 5/Category 6 cable have been used to extend HDMI to 50 meters and HDMI extenders based on optical fiber can extend HDMI several hundreds of meters.
Digital interface translators and methods of digital interface translation are described in accordance with embodiments of the invention. One embodiment of the invention includes multiple receiver lanes, where at least one of the receiver lanes is configured to receive a data channel at a first data rate and encoded in accordance with an input digital interface standard, an auxiliary channel input configured to receive an auxiliary data channel, and a single transmitter lane configured to output a single data channel at a second data rate and encoded in accordance with an output digital interface standard. In addition, the multilane to single lane digital interface translator is configured to decode the received data into data streams, and interleave the data streams to form packets, the multilane to single lane digital interface translator is configured to insert auxiliary data received via the auxiliary channel input and idle data between the packets to produce an output data stream that is rate matched to the second data rate, and the multilane to single lane digital interface translator is configured to encode the output data stream in accordance with the output digital interface standard.
In a further embodiment, the multiple receiver lanes are configurable to decode data channels encoded in accordance with one of a plurality of digital interface standards.
In another embodiment, a plurality of receiver lanes are configured to receive input data channels, data received via the plurality of data channels is encoded in accordance with the input digital interface standard, the multilane to single lane digital interface translator is configured to decode the received data to produce code groups, where the same type of code group is on each lane at any given time, and the type of the code group is determined by the coding scheme used to encode the received data, the multilane to single lane digital interface translator is configured to interleave the code groups by mapping the code groups to packets, where each packet includes a specific type of code group, and the multilane to single lane digital interface translator is configured to insert auxiliary data and idle data between the packets to form the output data stream, which is rate matched to the second data rate.
In a still further embodiment, the output digital interface standard is the 10 Gigabit IEEE 802.3 Clause 49 standard.
In still another embodiment, the input digital interface standard is the Display Port standard.
In a yet further embodiment, the digital interface translator is configured to utilize the following definitions:
In yet another embodiment, the digital interface translator is configured to replace ∥I∥ columns with auxiliary data received via the auxiliary channel.
In a further embodiment again, the input digital interface standard is the HDMI standard.
In another embodiment again, the digital interface translator is configured to utilize the following definitions:
In a further additional embodiment, the digital interface translator is configured to replace ∥I∥ columns with auxiliary data received via the auxiliary channel.
In another additional embodiment, the input digital interface standard is the DVI standard.
A still yet further embodiment includes a single receiver lane configured to receive a single input data channel encoded in accordance with an input digital interface standard, where the input data channel includes packets, and auxiliary data and idle data inserted between the packets, multiple transmitter lanes, where at least one of the transmitter lanes is configured to transmit an output data channel encoded in accordance with an output digital interface standard, and an auxiliary channel output configured to transmit an auxiliary data channel. In addition, the single lane to multilane digital interface translator is configured to extract auxiliary data inserted between received packets and output the auxiliary data via the auxiliary channel, the single lane to multilane digital interface translator is configured to decode the data within the packets received on the single receiver lane to produce code groups, the single lane to multilane digital interface translator is configured to deinterleave the code groups and to decode the deinterleaved code groups to obtain at least one output stream, and the single lane to multilane digital interface translator is configured to encode the at least one output stream in accordance with the output digital interface standard.
In still yet another embodiment, the multiple transmitter lanes are configurable to encode the decoded code groups for output on at least one data channel in accordance with one of a plurality of digital interface standards.
In a still further embodiment again, each packet contains encoded code groups, where the code groups are encoded in accordance with the input digital interface specification and all of the code groups in each packet are of the same type, the single lane to multilane digital interface translator is configured to decode the data in each packet and to deinterleave the code groups so that code groups of the same type are on each of the transmitter lanes at any given time; and the single lane to multilane digital interface translator is configured to encode the decoded code groups according to the type of the code group.
In still another embodiment again, the input digital interface standard is the 10 Gigabit IEEE 802.3 Clause 49 standard.
In still a further additional embodiment, the output digital interface standard is the Display Port standard.
In still another additional embodiment, the digital interface translator is configured to utilize the following definitions:
In a yet further embodiment again, the input digital interface standard is the HDMI standard.
In yet another embodiment again, the digital interface translator is configured to utilize the following definitions:
In a yet further additional embodiment, the input digital interface standard is the DVI standard.
Yet another additional embodiment includes receiving the multiple channels of data via multiple input lanes, receiving the at least one channel of auxiliary data via an auxiliary input, decoding the multiple channels of data to produce code groups, where the code groups are defined so that the same type of code group is present on each of the receiver lanes at any given time, interleaving the data code groups by mapping the code groups to packets, where each packet includes a specific type of code group to produce an output data stream, inserting idle data and auxiliary data into the output data stream to match the rate of the output data stream to the rate of an output lane, encoding the rate matched output data stream in accordance with the output digital interface, and outputting the encoded rate matched data stream via an output lane.
A further additional embodiment again also includes inserting idle data into the single data stream to match the rate of the single data stream to the rate of the output lane, and replacing idle data with auxiliary data.
Another additional embodiment again includes receiving the single input channel via a single input lane, extracting the auxiliary data from the received single input channel, decoding the data in each packet to obtain code groups, deinterleaving the code groups and decoding the code groups to produce multiple output data streams, encoding the multiple output data streams, where the encoding of each code group is determined by the type of the code group, and outputting the encoded output data streams via multiple transmitter lanes in accordance with the output digital interface specification.
a and 4b are flow charts showing processes for interleaving multiple lanes to a single lane and for deinterleaving a single lane to multiple lanes in accordance with embodiments of the invention.
a and 11b conceptually illustrate the mapping of decoded data, originally encoded according to the Display Port standard, to XGMII in accordance with an embodiment of the invention.
a is a block diagram of a Display Port mapper block in accordance with an embodiment of the invention.
b is a state diagram for a Display Port mapping process in accordance with an embodiment of the invention.
a, 13b, and 13c conceptually illustrate the mapping of decoded data, originally encoded according to the HDMI standard, to XGMII in accordance with an embodiment of the invention.
a is a block diagram of a HDMI mapper block in accordance with an embodiment of the invention.
b is a state diagram for an HDMI mapping process in accordance with an embodiment of the invention.
c is a state diagram for an alternative HDMI mapping process in accordance with an embodiment of the invention.
a is a block diagram of a Display Port Transmitter Mapper block in accordance with an embodiment of the invention.
b is a state diagram of a Display Port Transmitter process in accordance with an embodiment of the invention.
a is a block diagram of a HDMI Transmitter Mapper block in accordance with an embodiment of the invention.
b is a state diagram of an HDMI Transmitter process in accordance with an embodiment of the invention.
Turning now to the drawings, digital interface translators are disclosed. In many embodiments, the digital interface translators can interleave data received via multiple lanes into a single data stream output on a single lane. In several embodiments, the digital interface translators can operate in multiple modes where each mode enables the interleaving of digital data provided in accordance with a different digital interface standard. In a number of embodiments, the data received on the multiple input channels is decoded to code groups in such a way that the same type of code group is on each lane at any given time. The code groups are then mapped to XGMII so that the data code groups are transmitted over optical fiber as Ethernet packets. Idle columns can also be inserted into the data stream to achieve rate matching with the single lane output. Following mapping, information from auxiliary channels can be inserted in place of the idle columns. Inserting information from auxiliary channels into idle columns results in a single data stream, output via the single lane output of the digital interface translator that includes interleaved data received via the multiple lanes and auxiliary data. When a data stream generated by a digital interface translator in accordance with an embodiment of the invention is received on a single lane of a second digital interface translator, the second digital interface translator can apply the reverse processes to generate a multiple channel output data stream, which is output via a multiple lane output of the digital interface translator. The digital interface translator can also extract auxiliary data from the received data stream and output the auxiliary data via one or more auxiliary channel(s).
Digital interface translators in accordance with embodiments of the invention are discussed below. The term “block” is frequently used to refer to a group of circuits that perform a specific function or set of functions within the digital interface translator. A digital interface translator is typically fabricated as an integrated circuit and the actual circuits used to implement the “blocks” described below are determined based upon the type of process used in the fabrication of the integrated circuit. Although specific reference is made to “blocks” in the context of an integrated circuit, digital interface translators can be implemented using a variety of techniques, including the application of microprocessors in combination with other devices, in accordance with embodiments of the invention.
Basic Architecture
A system including a pair of digital interface translators positioned between cables and an optical fiber to connect a digital device to a digital display in accordance with an embodiment of the invention is shown in
In the illustrated embodiment, the cable connects to a digital interface translator 16 that is also connected to an optical fiber 18. The digital interface translator interleaves the multiple channels of information received via the cable and outputs a single channel of information that is transmitted via the optical fiber. In several embodiments, the digital interface translator is configurable and can translate from one of a number of input digital interfaces to a fixed output optical interface or one of a selection of output optical interfaces. In other embodiments, the digital interface translator outputs information formatted in accordance with a single channel interface standard appropriate to the application.
The optical fiber 18 is connected to a second digital interface translator 20, which is also connected to a second cable 22. The second digital interface translator translates the data channel received via the optical fiber to the original digital interface format, which is transmitted to a digital display device 24 via the cable 22. The characteristics of source/transmit digital interface translators and sink/receive digital interface translators are discussed further below.
Digital Interface Translators
A digital interface translator in accordance with an embodiment of the invention is shown in
The receive high speed data path receives a single high speed data channel via a single lane input and outputs multiple channels on multiple lanes. In many embodiments, the digital interface translator also outputs a separate auxiliary channel. As discussed above, many digital interface translators in accordance with embodiments of the invention support multiple digital interfaces and the digital interface translator can be configured to output data formatted in accordance with a digital interface standard selected from a number of possible digital interface standards.
Many digital interface standards accommodate transmission of auxiliary data. For example the HDMI standard provides for an independent auxiliary data channel such as a DDC channel, a CEO channel, and/or a USB 2.0 channel, and the Display Port standard provides for an independent auxiliary data channel such as an AUX channel, and/or a USB 2.0 channel. In the illustrated embodiment, auxiliary data is provided to the transceiver data block 32 by the auxiliary data block 34 and the transceiver data block 32 inserts the auxiliary data into the interleaved data stream in a manner that enables recovery of the auxiliary data. The amount of bandwidth available for insertion of auxiliary data depends upon the digital interface standard being used in a specific application. The insertion and recovery of auxiliary data is discussed further below.
The auxiliary data block can be constructed in a conventional manner in accordance with the requirements of a specific application. In many embodiments, the auxiliary data block also handles management functions that enable configuration of the transceiver data block and communication between the transceiver data block and external devices.
Transceiver Data Blocks
A transceiver data block in accordance with an embodiment of the invention is illustrated in
Transmit High Speed Path
A process for translating multiple channels of data encoded according to a predetermined digital interface standard received via multiple lanes and auxiliary data to a single data stream including auxiliary data output on a single lane in accordance with an embodiment of the invention is shown in
Receive High Speed Path
A process that is substantially the reverse of the process illustrated in
The flow charts illustrated in
Multilane Rx Blocks
A multilane Rx block that can be used in the construction of a multilane serdes of a digital interface translator in accordance with an embodiment of the invention is shown in
Multilane Rx PCS Blocks
A multilane Rx PCS block in accordance with an embodiment of the invention is shown in
Each byte sync block 100 aligns bytes received via the different lanes per the requirements of the specific digital interface standard and provides the bytes to a decoder block 102. The configuration of each decoder block 102 depends upon the digital interface standard with which the received data complies. In embodiments where multiple digital interface standards are supported, separate decode groups can be provided to decode data for each of the digital interface standards. Alternatively, a single decode group can be provided for each lane that is configurable to decode data formatted in accordance with one of a number of different digital interface standards. The decode groups are typically standards based. For example, Display Port and XAUI decoders are used in many embodiments of the invention. In a number of embodiments, custom decoders are used. For example, several embodiments use custom HDMI or DVI decoders. A feature of decoder blocks in accordance with many embodiments of the invention is that no matter the number of lanes upon which data is received (i.e. no matter whether the input is utilizing 1, 2, 3 or 4 of the input channels), the decoder blocks ensure that the received data is decoded to code groups so that the same type of code group is on each lane at any given time. Various implementations of byte sync blocks and decoder blocks are discussed below with reference to
The skew blocks 104 correct for any known lane to lane skew that was purposefully inserted, providing an output where the code groups on each lane are the same and are aligned with each other. Skew blocks can be implemented in accordance with an appropriate conventional design. The deskewed lanes are provided to a lane alignment block 106, which looks for alignment mark boundaries to further align the code groups. The alignment block 106 then interleaves the code groups from the aligned lanes and provides the single interleaved stream to the multiple lane Rx mapper block 108. As with the decoder, the implementation of the multiple lane Rx mapper block depends upon the digital interface standard with which the received data complies. In many embodiments, the multiple lane Rx mapper block maps the code groups so that data code groups are formatted as Ethernet packets and so that idle columns are inserted into the stream to match the output stream to the rate of the single lane output of the multilane Rx PCS block. In other embodiments, the multiple lane Rx mapper block maps the code groups so that code groups are formatted in accordance with another appropriate format. Implementations of alignment blocks and multiple lane Rx mapper blocks in accordance with embodiments of the invention are discussed below with reference to
Byte Sync Blocks
A byte sync block in accordance with an embodiment of the invention is shown in
In embodiments where multiple digital interface standards are supported, separate ALM compare blocks 124 can be implemented for each digital interface standard and the appropriate ALM compare block selected depending upon the mode of the digital interface translator. In other embodiments, a single ALM compare block 124 is implemented that can be configured for each of a number of digital interface standards.
Decoder Blocks
Decoder blocks in accordance with embodiments of the invention decode received data into data streams that can then be mapped to a predetermined single lane format by the multilane Rx mapper block. In many embodiments, the predetermined single lane format is the 10 Gigabit Media Independent Interface (XGMII) standard, which includes data code groups (Dx.y) and special code groups (Kx.y).
The nature of the decoder depends upon the encoding of the received data. Many digital interface standards utilize 8B10B encoding. 8B10B is a line code that maps 8-bit symbols to 10-bit symbols to achieve DC balance and bounded disparity, while providing sufficient state changes to enable reasonable clock recovery. A decoder block for decoding 8B10B code from a Display Port interface or a XAUI interface can be implemented in accordance with IEEE 802.3 Clauses 36 and 48. The Display Port standard is defined so that the same type of data is on each of the lanes at the same time. When a 1 or 2 lane configuration is used in compliance with the Display Port standard, the data from lane 1 or lanes 1 and 2 is replicated.
A number of digital interface standards such as the HDMI standard do not employ 8B10B encoding. The HDMI standard is particularly complex in that it uses four different encoding schemes: video data coding (VDC), which is rate 10/8; guard band (GB), which is rate 10/1; TERC4 coding, which is rate 10/4; and control period coding (CPC), which is rate 10/2. The application of the encoding techniques during the different periods specified within the HDMI format can be understood with reference to
An HDMI Decoder
An HDMI decoder block in accordance with an embodiment of the invention is shown in
The decoders and the decode state machine can be implemented in accordance with a desired output format. In a number of embodiments, HDMI encoded data can be decoded to a format, similar to the format of decoded 8B10B encoded data, which facilitates mapping of the decoded data to XGMII. In a number of embodiments, the decoding of the HDMI encoded data applies the following rules:
As will be discussed further below, when the decoded data streams are mapped to XGMII, the sop signal can be used to indicate the location of ∥C∥ columns and ∥D∥ columns. The am signal indicates the CPC to VDC boundary for lane alignment. Although specific decoding techniques are indicated above, other rules can be used for decoding HDMI in accordance with embodiments of the invention that are appropriate to a specific output interface standard.
Note that the similarities between the DVI standard and the HDMI standard enable processes similar to those outlined herein to be used in the decoding of data encoded in accordance with the DVI standard.
Lane Alignment Blocks
Once the data has been decoded, the data is deskewed and aligned to enable mapping of the decoded data to a format suitable for transmission via a single lane. Many embodiments use the same implementation for the lane alignment block irrespective of the digital interface standard of the received data. A lane alignment block in accordance with an embodiment of the invention is shown in
Mapping Decoded Data to an Output Format
The composition of the single data stream output by the lane alignment block depends upon the digital interface standard used to encode the received data. In many embodiments, the output of the lane alignment block is desired to be mapped to a predetermined format compatible with the output lane of the digital interface translator. In a number of embodiments, the predetermined standard is XGMII. The nature of the mapping performed for received data formatted according to various digital interface standards is discussed below.
Mapping Decoded Display Port to XGMII
Due to the property of the decoded Display Port data the same type of code group is on each lane, the following columns can be defined:
The following rules can then be applied to the mapping of data code groups (Dx.y) and special code groups (Kx.y) to XGMII:
The mapping of decoded data, originally encoded according to the Display Port standard, using the rules outlined above in accordance with an embodiment of the invention is illustrated in
Display Port Mapper Blocks
A Display Port Rx mapper block that can map decoded Display Port data to XGMII in accordance with an embodiment of the invention is shown in
The implementation of a Display Port state machine in mapping decoded Display Port data to XGMII in accordance with an embodiment of the invention can be understood with reference to the state diagram shown in
Mapping Decoded HDMI to XGMII
The variation in the number of input channels allowed by the HDMI standard results in a decoded data stream that is significantly more complicated to map to XGMII than decoded Display Port data. A mapping can be achieved in accordance with embodiments of the invention by applying the following definitions:
Given the above definitions, the mapping of HDMII to XGMII is completed in accordance with embodiments of the invention by applying the following rules:
Following ∥S∥, 1st ∥D∥=/D0/D1/D2/D0/, 2nd ∥D∥=/D1/D2/D0/D1/, 3rd ∥D∥=/D2/D0/D1/D21, etc.
The mapping of decoded three channel HDMI received data using the rules outlined above in accordance with an embodiment of the invention is illustrated in
The XGMII data shown in
A further alternative mapper output is generated by defining:
Given the above definitions, the alternative mapping of HDMII to XGMII is completed in accordance with embodiments of the invention by applying the following rules:
After any ∥S∥ 1st ∥DZ∥=/D0/D1/D2/D0/, 2nd ∥DZ∥=/D1/D2/D0/D1/, 3rd ∥DZ∥=/D2/D0/D1/D2/, etc.
Although specific mappings are described above with respect to HDMI and XGMII, other mappings can be applied in accordance with embodiments of the invention as are appropriate to the formatting of the output channel of the digital interface translator. Implementations of HDMI Rx mapper blocks in accordance with embodiments of the invention are discussed below.
HDMI RX Mapper Blocks
An HDMI Rx mapper block that can map decoded HDMI data to XGMII in accordance with an embodiment of the invention is shown in
Auxiliary Channel Arbiter Blocks
The single data stream output by the Rx mapper block includes additional capacity. The amount of additional capacity depends upon the digital interface standard used in the formatting of the received data. An arbiter block that can be used to insert auxiliary data into an XGMII data stream output by a Rx mapper block in accordance with an embodiment of the invention is illustrated in
The operation of the arbiter block state machine during the insertion of auxiliary data into the idle stream can be understood with reference to the state diagram shown in
The state machine 200 can be reset to the XGM_DATA state 202. In this state, XGM is output as XGS. The state machine stays in the XGM_DATA state until XGM is an ∥I∥ column and auxiliary data is available (i.e. ˜empty), which causes a transition to the AUX_DATA state 204 in which XGS is selected as an ∥Fax∥ column from the FIFO 190. The state machine remains in the AUX_DATA state 204 until either XGM is no longer an ∥I∥ column or there is no more auxiliary data. Although a specific state machine is illustrated in
Single Lane Tx Block
The data stream output by an arbiter block is provided to a single lane Tx block of a single lane serdes in accordance with an embodiment of the invention. A single lane Tx block in accordance with an embodiment of the invention is shown in
The Receive High Speed Path
A receive high speed path of a digital interface translator in accordance with an embodiment of the invention involves performing the inverse operations to those described above with respect to the transmit high speed path. Components of receive high speed paths and their operation in accordance with various aspects of the invention can be understood by reviewing
A single lane receiver in accordance with an embodiment of the invention is illustrated in
Auxiliary data is extracted from the decoded input data stream. An Auxiliary Channel Extractor block that can be used to extract an auxiliary data channel from an IEEE 802.3 Clause 49 input data stream in accordance with an embodiment of the invention is illustrated in
Once the auxiliary data channel has been extracted, the data stream is passed to a multilane transmitter block. A multilane transmitter block in accordance with an embodiment of the invention is illustrated in
A Transmit Mapper block 244′ suitable for use in extracting Display Port data from an XGMII input stream is illustrated in
A Transmit Mapper block suitable for use in extracting HDMI data from an XGMII input stream is illustrated in
Referring back to
While the above description contains many specific embodiments of the invention, these should not be construed as limitations on the scope of the invention, but rather as an example of one embodiment thereof. Accordingly, the scope of the invention should be determined not by the embodiments illustrated, but by the appended claims and their equivalents.
This application is a continuation of U.S. application Ser. No. 12/552,240 filed Sep. 1, 2009, which application claims priority to U.S. Provisional Application No. 61/093,690, filed Sep. 2, 2008, the disclosures of which are incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6788710 | Knutson et al. | Sep 2004 | B1 |
7065052 | Mcbride | Jun 2006 | B1 |
7913152 | Jeong et al. | Mar 2011 | B2 |
7965744 | Ibaraki et al. | Jun 2011 | B2 |
8315272 | Baumer | Nov 2012 | B2 |
20060256875 | Mcclellan | Nov 2006 | A1 |
20070011570 | Jeong et al. | Jan 2007 | A1 |
20080180518 | Miyazaki | Jul 2008 | A1 |
20080240230 | Oxman et al. | Oct 2008 | A1 |
20090196260 | Stewart et al. | Aug 2009 | A1 |
Entry |
---|
“Physical Coding Sublayer (PCS) and Physical Medium Attachment (PMA) Sublayer, type 10GBASE-X,” IEE 802.3 clause 48 proposed specification, Retrieved from http://www.ieee802.org/3/10GBCX4/public/jan03/WPcls48—1—0.pdf on Jun. 17, 2014, 32 pgs. |
“Physical Coding Sublayer (PCS) for 64B/66B, type 10GBASE-KR,” IEEE 802.3 clause 49 proposed specification, Retrieved from http://www.ieee802.org/3/ap/public/sep05/szczepanek—02—0905.pdf on Jun. 17, 2014, 31 pgs. |
Number | Date | Country | |
---|---|---|---|
20130077662 A1 | Mar 2013 | US |
Number | Date | Country | |
---|---|---|---|
61093690 | Sep 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12552240 | Sep 2009 | US |
Child | 13681150 | US |