The invention relates generally to a transceiver and, more particularly, to a physical transceiver (PHY) having a flexible architecture.
Turning to
Of interest here, however, are PHYs 110-1 to 110-N, and, as can be seen in greater detail in
As can be seen in
Of interest here are the scrambler 308 and descrambler 314. In this example, the scrambler 308 and descrambler 314 are able to perform data scrambling/descrambling and error checking. One purpose in scrambling/descrambling data with the PHYs 110-1 to 110-N is to substantially randomize the data to reduce the impact of electromagnetic interference (EMI) and improve signal integrity. This is typically accomplished by the use of a pseudorandom bit sequence (PRBS) generated with a specified polynomial. For example, for 8b/10b encoding, a PRBS-7 (or 1+x6+x7) can be employed, and, for synchronous optical networking or SONET (as specified in ITU O.150), PRBS-23 (or X23+X18+1). Similarly, this PRBS signaling can be employed for error checking.
However, as demonstrated above, one polynomial is generally not applicable to all standards (e.g., 802.3-2008 and SONET); each standard usually specifies its own polynomial. Conventionally, this meant that each PHY (e.g., 110-1) would be designed for a particular standard (e.g., PRBS-7 for 802.3-2008) and would lack the flexibility to be used with other standards. A reason for this is that the serial and parallel implementations for the PHYs (e.g., 110-1) would be too costly in terms of area, price, and power consumption to be generally applicable.
Therefore, there is a need for a flexible transceiver architecture.
Some examples of conventional systems are: U.S. Pat. No. 4,744,104; U.S. Pat. No. 5,267,316; U.S. Pat. No. 6,820,230; U.S. Pat. No. 6,907,062; U.S. Pat. No. 7,124,158; U.S. Pat. No. 7,414,112; U.S. Pat. No. 7,486,725; U.S. Pat. No. 7,505,589; U.S. Patent Pre-Grant Publ. No. 2003/0014451; U.S. Patent Pre-Grant Publ. No. 2007/008997; and U.S. Patent Pre-Grant Publ. No. 2007/0098160.
In accordance with an embodiment of the present invention, an apparatus is provided. The apparatus comprises a polynomial register having a plurality of bits, wherein the polynomial register is configured to store a user-defined polynomial; a first bus; a second bus; and a transceiver that is coupled to the first bus, the second bus, and the polynomial register, wherein the transceiver includes: a self-synchronous scrambler that is configured to generate a scrambled signal from a first signal using the user-defined polynomial; and a self-synchronous descrambler that is configured to generate a descrambled signal from a second signal using the user-defined polynomial.
In accordance with an embodiment of the present invention, the first bus further comprises a first input bus and a second input bus, and wherein the second bus further comprises a first output bus and a second output bus, and wherein the transceiver further comprises: a transmitter having an encoder that is coupled to the first input bus and the self-synchronous scrambler, wherein the self-synchronous scrambler is coupled of the first output bus; and a receiver having a decoder that is coupled to the second output bus and the self-synchronous descrambler, wherein the self-synchronous descrambler is coupled to the second input bus.
In accordance with an embodiment of the present invention, the first input bus has a programmable width.
In accordance with an embodiment of the present invention, each of the self-synchronous scrambler and self-synchronous descrambler further comprises: a first matrix circuit that is configured to include a first matrix corresponding to the user-defined polynomial; a second matrix circuit that is configured to include a first matrix corresponding to the user-defined polynomial; a first multiplier that is coupled to the second matrix circuit and that is coupled to the respective one of the encoder and the second input bus; a data register; a second multiplier that is coupled to the first matrix circuit and the data register; and an XOR circuit that is coupled to the first and second multipliers and that is coupled to the respective one of the first output bus and the decoder.
In accordance with an embodiment of the present invention, the data register of the self-synchronous scrambler is coupled to the encoder, and wherein the data register of the self-synchronous descrambler is coupled to the second input bus.
In accordance with an embodiment of the present invention, the polynomial register has 32 bits.
In accordance with an embodiment of the present invention, a method is provided. The method comprises retrieving a user-defined polynomial from a polynomial register having a plurality of bits; generating first and second matrices based at least in part on the user-defined polynomial; multiplying the first matrix by a first data set to generate a second data set; retrieving a third data set from a data register; multiplying the third data set by the second matrix to generate a fourth data set; XORing the second and fourth data sets to generate a fifth data set; and outputting the fifth data set.
In accordance with an embodiment of the present invention, the method further comprises loading the fifth data set into the data register to form the third data set.
In accordance with an embodiment of the present invention, the step of outputting further comprises outputting the fifth data set over a bus.
In accordance with an embodiment of the present invention, the method further comprises loading the first data set into the data register to form the third data set.
In accordance with an embodiment of the present invention, an apparatus is provided. The apparatus comprises a media access control (MAC) circuit; a interface that is coupled to the MAC circuit; a physical transceiver (PHY) having: physical coding sublayer (PCS) logic having: a polynomial register having a plurality of bits, wherein the polynomial register is configured to store a user-defined polynomial; a bus that is coupled to the interface; an encoder that is coupled to the first bus; a self-synchronous scrambler that is coupled to the encoder and the first output bus, wherein that is configured to generate a scrambled signal from a first signal using the user-defined polynomial; a decoder that is coupled to the bus; and a self-synchronous descrambler that is configured to generate a descrambled signal from a second signal using the user-defined polynomial; forward error correction (FEC) logic that is coupled to the PCS logic; physical medium attachment (PMA) logic that is coupled to the FEC logic; and physical dependent medium (PMD) logic that is coupled to the PMA logic.
In accordance with an embodiment of the present invention, the PCS logic further comprises: a first gearbox that is coupled between the self-synchronous scrambler and the FEC logic; and a second gearbox that is coupled between the self-synchronous descrambler and the FEC logic.
In accordance with an embodiment of the present invention, the bus has a programmable width.
In accordance with an embodiment of the present invention, the each of the self-synchronous scrambler and self-synchronous descrambler further comprises: a first matrix circuit that is configured to include a first matrix corresponding to the user-defined polynomial; a second matrix circuit that is configured to include a first matrix corresponding to the user-defined polynomial; a first multiplier that is coupled to the second matrix circuit and that is coupled to the respective one of the encoder and the second input bus; a data register; a second multiplier that is coupled to the first matrix circuit and the data register; and an XOR circuit that is coupled to the first and second multipliers.
In accordance with an embodiment of the present invention, the apparatus further comprises: a host that is coupled to the MAC circuit; and a communications medium that is coupled to the PHY.
For a more complete understanding of the present invention, and the advantages thereof, reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
Refer now to the drawings wherein depicted elements are, for the sake of clarity, not necessarily shown to scale and wherein like or similar elements are designated by the same reference numeral through the several views.
Turning to
Turning to
Also, as can be seen in the example of
Thus, for an example register (e.g., 601) having a width of 32 bits, the user can specify any of approximately 2×109 polynomials. This user-defined polynomial (which can be retrieved from register 601) can be used by the scrambler 502, PRBS generator 504, descrambler 506, and PRBS checker 508 accordingly. Alternatively, there can be multiple polynomial registers (e.g. 510), and each of the scrambler 502, PRBS generator 504, descrambler 506, and PRBS checker 508 may have a separate polynomial register (e.g., 510).
Turning to
The identity matrix ID is generally comprised of the matrix IP that is shifted or adjusted based on the desired input bus width. For example, the identity matrix ID (which is derived from the matrix IP shown above) can be as follows for a 20-bit bus width:
An adjustment vector {right arrow over (A)} is also determined. Typically, when the signal POLY1 is transmitted, the lowest bit is truncated, and a ‘0’ is appended to signal POLY1 to form adjustment vector {right arrow over (A)}. For example, with the PRBS-7 polynomial used above, the adjustment vector {right arrow over (A)} would be:
The P- and D-matrices P and D can then be determined.
Looking first to the P-matrix P, it can be determined on a row-by-row basis through the use of a set of matrices (e.g., 32-32×32 matrices), which can be referred to a working matrices WP[r], where r denote the P-matrix P row. These working matrices WP[r], in this example, are based at least in part on the identity matrix IP and can be determined using the following formula:
The P-matrix P can then be extracted from working matrices WP[r] by application of the following equation:
where BW is the bus width. For example, with the PRBS-7 polynomial used above and a 20-bit bus width BW, the P-matrix P should be:
Similarly, with D-matrix D, it can be determined on a row-by-row basis through the use of a set of matrices (e.g., 32-32×32 matrices) or working matrices WD[r]. These working matrices WD[r], in this example, are based at least in part on the identity matrix ID and can be determined using the following formula:
The D-matrix D can then be extracted from working matrices WD[r] by application of the following equation:
Once the P- and D-matrices P and D have been generated by matrix circuits 602 and 604, respectively, the input data DATAIN1 for scrambler 502. The multiplier 606 can multiply the input data DATAIN1 (which can for example be 20-bits wide data vector) by the D-matrix D. The P-matrix P can be multiplied by the information (e.g., vector) stored in register 610 with multiplier 612. The outputs of multipliers 606 and 612 can then be XORed with circuit 608, written to register 610, and output (e.g., as an output data vector DATAOUT1). Thus, the scrambler 502 can function as a self-synchronous scrambler or parallel multiplicative scrambler that uses a user-defined polynomial so as to allow the scrambler 502 to be compliant with a wide variety of standards (e.g., communication protocols).
As can be seen in
Having thus described the present invention by reference to certain of its preferred embodiments, it is noted that the embodiments disclosed are illustrative rather than limiting in nature and that a wide range of variations, modifications, changes, and substitutions are contemplated in the foregoing disclosure and, in some instances, some features of the present invention may be employed without a corresponding use of the other features. Accordingly, it is appropriate that the appended claims be construed broadly and in a manner consistent with the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
4744104 | Popischil | May 1988 | A |
5199072 | White et al. | Mar 1993 | A |
5267316 | Gonzalez et al. | Nov 1993 | A |
6167515 | Lin | Dec 2000 | A |
6820230 | Sweeney | Nov 2004 | B2 |
6907062 | Carlson | Jun 2005 | B2 |
7124158 | Ruthstein et al. | Oct 2006 | B2 |
7414112 | Grimaldi et al. | Aug 2008 | B2 |
7486725 | Chen et al. | Feb 2009 | B2 |
7505589 | Lablans | Mar 2009 | B2 |
20030014451 | Peyser et al. | Jan 2003 | A1 |
20030133568 | Stein et al. | Jul 2003 | A1 |
20070008997 | Mochizuki et al. | Jan 2007 | A1 |
20070098160 | Lablans | May 2007 | A1 |
20090010362 | Thaler | Jan 2009 | A1 |
20090092246 | Fujisaki et al. | Apr 2009 | A1 |
20090161439 | Aiika et al. | Jun 2009 | A1 |
20100070822 | Leung et al. | Mar 2010 | A1 |
20100095185 | Ganga et al. | Apr 2010 | A1 |
Number | Date | Country |
---|---|---|
2292644 | Jan 2007 | RU |
Entry |
---|
Schneier, Bruce. Applied Cryptography. 1996. John Wiley & Sons, Inc. Second edition. 198-199. |
IEEE Standard 802.3-2008. |
Advanced Encryption Standard (AES), Federal Information Processing Standards Publication 197, Nov. 26, 2001. |
Szczepanek et al., 10GBASE-KR FEC Tutorial, IEEE802 Plenary Jul. 2006. |
Number | Date | Country | |
---|---|---|---|
20140119413 A1 | May 2014 | US |