[go: up one dir, main page]

US20060256875A1 - Communication system and encoding method having low overhead - Google Patents

Communication system and encoding method having low overhead Download PDF

Info

Publication number
US20060256875A1
US20060256875A1 US11/431,929 US43192906A US2006256875A1 US 20060256875 A1 US20060256875 A1 US 20060256875A1 US 43192906 A US43192906 A US 43192906A US 2006256875 A1 US2006256875 A1 US 2006256875A1
Authority
US
United States
Prior art keywords
block
bit
words
packet
word
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US11/431,929
Other versions
US7809021B2 (en
Inventor
Brett McClellan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Marvell Asia Pte Ltd
Original Assignee
Solarflare Communications Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US10/194,741 external-priority patent/US7065167B2/en
Application filed by Solarflare Communications Inc filed Critical Solarflare Communications Inc
Priority to US11/431,929 priority Critical patent/US7809021B2/en
Assigned to SOLARFLARE COMMUNICATIONS, INC. reassignment SOLARFLARE COMMUNICATIONS, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MCCLELLAN, BRETT A.
Publication of US20060256875A1 publication Critical patent/US20060256875A1/en
Priority to US12/924,565 priority patent/US8472478B2/en
Publication of US7809021B2 publication Critical patent/US7809021B2/en
Application granted granted Critical
Assigned to MARVELL INTERNATIONAL LTD. reassignment MARVELL INTERNATIONAL LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SOLARFLARE COMMUNICATIONS, INC.
Priority to US13/925,605 priority patent/US9451057B1/en
Assigned to CAVIUM INTERNATIONAL reassignment CAVIUM INTERNATIONAL ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MARVELL INTERNATIONAL LTD.
Assigned to MARVELL ASIA PTE, LTD. reassignment MARVELL ASIA PTE, LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CAVIUM INTERNATIONAL
Adjusted expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/22Parsing or analysis of headers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/004Arrangements for detecting or preventing errors in the information received by using forward error control
    • H04L1/0041Arrangements at the transmitter end
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/02Details
    • H04J3/06Synchronising arrangements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/02Details
    • H04J3/06Synchronising arrangements
    • H04J3/0602Systems characterised by the synchronising information used
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/16Time-division multiplex systems in which the time allocation to individual channels within a transmission cycle is variable, e.g. to accommodate varying complexity of signals, to vary number of channels transmitted
    • H04J3/1605Fixed allocated frame structures
    • H04J3/1611Synchronous digital hierarchy [SDH] or SONET
    • H04J3/1617Synchronous digital hierarchy [SDH] or SONET carrying packets or ATM cells
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/16Time-division multiplex systems in which the time allocation to individual channels within a transmission cycle is variable, e.g. to accommodate varying complexity of signals, to vary number of channels transmitted
    • H04J3/1605Fixed allocated frame structures
    • H04J3/1652Optical Transport Network [OTN]
    • H04J3/1658Optical Transport Network [OTN] carrying packets or ATM cells
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L25/00Baseband systems
    • H04L25/02Details ; arrangements for supplying electrical power along data transmission lines
    • H04L25/03Shaping networks in transmitter or receiver, e.g. adaptive shaping networks
    • H04L25/03006Arrangements for removing intersymbol interference
    • H04L25/03012Arrangements for removing intersymbol interference operating in the time domain
    • H04L25/03019Arrangements for removing intersymbol interference operating in the time domain adaptive, i.e. capable of adjustment during data reception
    • H04L25/03057Arrangements for removing intersymbol interference operating in the time domain adaptive, i.e. capable of adjustment during data reception with a recursive structure

Definitions

  • the invention relates to communication systems and in particular to a method and apparatus for coding data to minimize overhead.
  • Ethernet which utilizes twisted pairs of copper wires as its transmission medium.
  • twisted pair copper is bandwidth limited.
  • data signals transmitted at a high rate over the twisted pair copper, or other medium are subject to significant levels of distortion and error rates. Upon reception, recovering the transmitted signal may be impossible due to this distortion.
  • a communication system configured to processes blocks of input data that include control words and a packet of information words.
  • the packet has a start preceded by ones of the control words and an end followed by others of the control words.
  • a one bit block header having a first sense is appended to the block to form a frame.
  • the block is condensed to accommodate a TYPE word, the TYPE word is generated and inserted into the block and a one bit block header is appended to the block to form the frame.
  • the one bit block header has a second sense, opposite to the first sense. Use of a one bit block header reduces overhead. Error correction is also utilized.
  • a 64B/65B coding method for coding a packet of information words into frames for transmission over 4 twisted pair conductor.
  • a system receives blocks of input data such that the input data includes control words and the packet of information words.
  • the packets have a start preceded by ones of the control words and an ending followed by others of the control words and the blocks are smaller than the packet.
  • This method determines when a block consists exclusively of information words and, when the block consists exclusively of information words, then the method appends to the block a one bit block header having a first sense to form one of the frames.
  • the method condenses the block to accommodate a TYPE word.
  • the method also generates the TYPE word having a value that indicates one of the following structural properties of the block: (a) a position of the start of the packer in the block, (b) a position of the end of the packet in the block, and/or (c) the block being composed exclusively of control words.
  • the method may also insert a TYPE word into the block and append to the block a one bit block header having a second sense, opposite to the first sense, to form the one of the frames. As such, this method reduces overhead to less than 3%.
  • this method includes re-coding at least one of the control words using fewer bits.
  • the type word may be selected from a set of type words having a specified mutual Hamming distance.
  • the type words each consist of T bits and the method additionally comprises generating the set of possible bit patterns by a process comprising: adopting a (T/2)-bit binary pattern as a first half of a bit pattern in the set of possible bit patterns, and generating a second half of the bit pattern by duplicating or complementing the first half of the bit pattern depending on a bit parity value of the first half of the bit pattern.
  • the one bit block header in the first sense comprises a 1 and a one bit block header in the second sense comprises a 0 value.
  • the method may be performed in a conjunction with forward error correction.
  • the step of condensing the block includes removing from the block a control word that indicates one of (a) the start of the packet and (b) the end of packet.
  • condensing the block may include re-coding remaining the control words using fewer bits. This method may be utilized in a 10 gigabit/second communication system.
  • the input data includes control words and a packet of information words such that the packet has a start preceded by ones of the control words and an ending followed by others of the control words.
  • the blocks may be smaller than the packet and the frames may include a frame corresponding to the block.
  • the coder comprises a type word generator that receives the block and generates a TYPE word for a block such that the TYPE word has a value that indicates one of the following structural properties of the block, namely, (a) whether the block is composed exclusively of control words, (b) a position of the start of the packet in the block, (c) a position of the end of the packet in the block, and (d) whether the block is composed exclusively of control words.
  • the coder also has a one bit block header generator that operates in response to the TYPE word and generates a one bit block header in a first sense when the TYPE word indicates that the block is composed exclusively of information words, and otherwise generates the one bit block header in a second sense, opposite to the first sense, wherein use of a one bit block header reduces overhead to less than 3%.
  • a payload field generator that operates in response to the TYPE word. It adopts the block to form a payload field of the frame when the TYPE word indicates that the block is composed exclusively of information words, and otherwise condenses the block and inserts the TYPE word into the block to form the payload field.
  • a frame assembler is also included and configured to append the block header to the payload field to form the frame.
  • the payload field generator includes a re-coder that condenses the block by re-coding remaining ones of the control words using fewer bits. It is contemplated that the type word is selected from a set of type words having a specified mutual Hamming distance.
  • the type words may each consist of T bits and the coder may additionally comprises a type word generator that generates the set of possible bit patterns, and the type word generator may include: a first-half generator that adopts a (T/2)-bit binary pattern as a first half of a bit pattern in the set of possible bit patterns, and a second-half generator that generates a second half of the bit pattern by duplicating or complementing the first half of the bit pattern depending on a bit parity value of the first half of the bit pattern.
  • the coder operates in conjunction with forward error correction.
  • the coder may be used in a communication system utilizing a channel of 4 twisted pair conductors and the coder's use of a one bit block header establishes an overhead of 1.5625%.
  • the payload field generator includes a control word removal module that condenses the block by removing from the block a control word that indicates one of (a) the start of the packet and (b) the end of the packet.
  • the payload field generator may additionally includes a re-coder that condenses the block by re-coding remaining ones of the control words using fewer bits.
  • the re-coder may re-code the control words using codes having a specified mutual Hamming distance.
  • FIG. 1A illustrates a block diagram of an example embodiment of a pair of transceivers configured to communicate over a channel.
  • FIG. 1B illustrates a block diagram of a multi-channel point to point communication system.
  • FIG. 1C illustrates a block diagram of an example embodiment of a transmit system configured in accordance with one embodiment of the invention.
  • FIG. 1D illustrates a block diagram of an example embodiment of a receiver system configured in accordance with one embodiment of the invention.
  • FIG. 1E is a block diagram showing an example of a 10 Gb/s Ethernet interface including a coder according to the invention.
  • FIG. 2 schematically shows exemplary quads of the input data received by the coder according to the invention.
  • FIGS. 3A-3D show the twelve possible types of blocks that can be received by the coder according to the invention.
  • FIGS. 4A-4C show the basic structure and the two kinds of frame that the coder generates from a block of input data.
  • FIG. 5 is a flow chart showing a first embodiment of a coding method according to the invention.
  • FIG. 6 is a flow chart showing an example of the processing performed in process 205 of the method shown in FIG. 5 .
  • FIGS. 7A-7L show specific examples of the frames generated from each of the twelve block types shown in FIGS. 3A-3D , including the block header and the TYPE word, where used.
  • FIG. 8 is a block diagram showing a first embodiment of a coder according to the invention.
  • FIG. 9A is a flow chart showing an example of a decoding method for decoding the frames generated by the coding method and coder according to the invention.
  • FIG. 9B is a flow chart showing an example of the processing performed in process 276 of the method shown in FIG. 9A .
  • FIG. 10 is a block diagram showing a first embodiment of a decoder for decoding the frames generated by the coding method and coder according to the invention.
  • the method and apparatus disclosed herein performs data transmission using forward error correction coding in a multi-pair or multi-channel system to achieve data transmission rates and error rates that are better than that achievable by systems of the prior art.
  • the disclosure provided herein is similar to that disclosed in U.S. Pat. No. 6,781,491 which is disclosed herein in its entirety by reference.
  • FIG. 1A a block diagram of a receiver/transmitter pair is shown. This is one possible example environment of the method and apparatus disclosed herein.
  • a channel 312 connects a first transceiver 330 to a second transceiver 334 .
  • the first transceiver 330 connects to the channel 312 via an interface 344 .
  • the interface 344 is configured to isolate the incoming from outgoing signals.
  • the channel 312 may comprises numerous conductors and hence the interface 344 performs isolation and separates the conductors based on direction of data flow to either of a receiver module 338 or a transmitter module 342 .
  • the receive module 338 and transmit module 342 may comprise any assembly of hardware, software, or both configured to operate in accordance with the principles described herein.
  • the receive module 338 and transmit module 342 communicate with a processor 346 .
  • the processor 346 may include or communicate with memory 350 .
  • the memory 350 may comprise one or more of the following types of memory: RAM, ROM, hard disk drive, flash memory, or EPROM.
  • the processor 346 may be configured to perform one or more calculations or any form of signal analysis.
  • the processor 346 is configured to execute machine readable code stored on the memory 350 .
  • the processor 346 may perform additional signal processing tasks as described below.
  • the second transceiver 334 is configured similarly to the first transceiver 330 .
  • the second transceiver 334 comprises an interface 352 connected to a receiver module 356 and a transmitter module 360 .
  • the receiver module 356 and a transmitter module 360 communicate with a processor 364 , which in turn connects to a memory 368 . Operation occurs as described below in more detail.
  • the communication system illustrated in FIG. 1B is configured as an exemplary multi-channel point-to-point communication system.
  • One exemplary application is a 10 gigabit transceiver utilizing a Category 5 UTP cable supporting Ethernet protocols. As shown it includes a physical coding sublayer 302 and 304 , shown as coupled together over a channel 312 . In one embodiment each channel comprises twisted pair conductors.
  • Each of the channels 312 is coupled between transceiver blocks 320 through a line interface 306 and each channel is configured to communicate information between transmitter/receiver circuits (transceivers) and the physical coding sublayer (PCS) blocks 302 , 304 . Any number of channels and associated circuitry may be provided.
  • the transceivers 320 are capable of full-duplex bi-directional operation. In one embodiment, the transceivers 320 operate at an effective rate of about 2.5 Gigabits per second.
  • FIG. 1C illustrates a block diagram of an example embodiment of a transmit system configured in accordance with the invention.
  • an input 300 from a data source or other component provides data to a scrambler 310 .
  • the data source or other component may comprise any source of data, any aspect of the physical coding sublayer, software or hardware interface, multiplexer, or any other device.
  • the input to the scrambler 310 may comprise the output of the multiplexer 34 , shown and discussed below in connection with FIG. 1E .
  • the scrambler 310 operates in a manner understood in the art.
  • the output of the scrambler connects to a CRC encoder 314 .
  • the CRC encoder 314 calculates a cyclic redundancy check which is appended to a group of N blocks of encoded data. At the receiver this CRC may be checked to determine if a transmission error has occurred.
  • the output of the CRC encoder 314 feeds into a FEC unit 316 configured to perform forward error correction on the signal.
  • Any type of forward error correction may occur, including, but not limited to low density parity check (LDPC) coding, such as for example with a 10 GBASE-T system, or any other type of forward error correction method including a concatenation of Reed-Solomon (RS) coding with trellis coded modulation (TCM).
  • LDPC low density parity check
  • RS Reed-Solomon
  • TCM trellis coded modulation
  • error correction encoding may be performed: trellis coding, convolutional coding, block coding, product coding or any other type of coding.
  • the output(s) of the FEC unit connect to a mapper 321 . It is contemplated that any number of mappers 321 may be provided, up through N where N is any positive integer value.
  • the mapper 321 is configured to transform or map the arriving data into one or more values, such as symbols.
  • the mapping comprises pulse amplitude modulation (PAM).
  • PAM-type mapping assigns incoming groups of bits to a symbol value.
  • a symbol comprises a value that represents one or more bits that are transmitted during a transmit opportunity in place of the one or more bits. Mapping of this nature is known by one of ordinary skill in the art and accordingly is not discussed in detail herein.
  • the mapper 321 performs four-dimensional mapping. As a result, in such an embodiment each mapper 321 outputs four symbols during each clock cycle.
  • the output of the mapper 321 connects to precoding modules 324 A- 324 N.
  • the mapper 321 includes four outputs, each of which feed into a precode module 324 , it is contemplated that the precoding operations may be distributed among any number of precode modules, up to N modules, where N is a positive whole number.
  • Precoding may comprise any type signal processing that may occur in the transmitter to counter the effects of the channel.
  • the precoding comprises processing by a finite impulse response filter.
  • the output of the precoders 324 A- 324 N connect to one or more transmit processing systems 332 A- 332 N. Any number of transmit processing systems 332 A- 332 N may be utilized where N is any positive whole number. Transmit processing comprises processing to facilitate transmission of the signal over one or more channels.
  • the transmit processing systems 332 A- 332 N may comprise line interfaces, amplifiers, transformers, filtering, shaping filters, hybrids, digital to analog converters, and the like as may be desired to facilitate transmission of a signal or data to a remote location.
  • the transmit system of FIG. 1C may include constellation shaping within the mapper 321 .
  • FIG. 1D illustrates a block diagram of an example embodiment of a receiver system for use with a transmitter, such as the transmitter shown in FIG. 1C .
  • a transmitter such as the transmitter shown in FIG. 1C .
  • This is but one example embodiment of a receiver. It is contemplated that one of ordinary skill in the art may design other configurations that differ from the exact configuration shown in FIG. 1D , but are within the scope of the invention and claims that follow.
  • inputs I 1 -I N receive signals from one or more channels 384 . Any number of N inputs may exist where N equals any positive whole number.
  • the inputs 384 connect to line interfaces 388 A- 388 N, where N equals any positive whole number.
  • the line interfaces 388 A- 388 N may comprise any configuration of hardware, software or both configured to receive a signal over one or more channels and process the signal to prepare the signal for subsequent processing.
  • a line interface 388 may comprise amplifiers, filters, and hybrids.
  • the output of the line interfaces 388 connect to an equalizer module 390 .
  • the equalizer module 390 comprises hardware, software, or both configured to perform equalization on the received signal. In one configuration the equalization occurs to reduce intersymbol interference. In one configuration the equalizer module comprises a feedforward filter and decision feedback equalizer.
  • Co-pending patent application, entitled Method and Apparatus for Channel Equalization, by inventor William Jones, which was filed on Jul. 1, 2002, and issued as U.S. Pat. No. 6,961,373 is incorporated in its entirety herein and describes an equalization system as is compatible for use with one or more embodiments of the invention. It is contemplated that any equalizer system or other apparatus configured to generate an accurate decision of the transmitted signal may be utilized. It is contemplated that the equalization module 390 may include a slicer or other decision device and be located or distributed at any point in the receiver.
  • the output of the equalizer 390 feeds into an error correction decoder 393 .
  • the decoder 393 reverses the error correction coding.
  • the module decoder 393 there may exist several decoder sub-modules configured in association. This provides the advantage of distributing the processing burden of the error correction decoding across numerous subsystems. As a result, high-speed channel throughput may be achieved in a realizable architecture.
  • the receiver may be configured with M number of decoders 393 where M is any positive whole number.
  • the error correction decoding is matched to that utilized in an associated transmitter.
  • the decoders may be configured to perform continuous trellis decoding. This is in contrast to packet based trellis coding/decoding. As a result, the benefits of continuous trellis decoding are gained. These benefits include but are not limited to a reduction in the total number of symbols that must be sent to fully error correction decode the received signal.
  • the continuous trellis decoder embodiment operates on a continuous stream of trellis encoded data and control symbols and does not require that the trellis be terminated at the end of each packet. In other embodiments trellis coding/decoding may be omitted.
  • the decoder 393 outputs the error corrected signal or data to a demapping system which is configured to reverse the effects of mapping that occurred during the transmit processing.
  • the output of the demapping module 393 connects to an optional CRC check unit 396 which performs as understood in the art.
  • the output of the optional CRC check unit connects to a descrambler 398 to reverse the effects of the scrambler, if utilized and located in the transmitter.
  • FIG. 1E is a block diagram showing an example of a 10 Gb/s Ethernet interface 10 including the physical coding sublayer module (PCS) 30 that includes the encoder 100 according to the invention.
  • the interface 10 is composed of the medium access controller (MAC) 12 , the XGMII Extender Sublayer module (XGXS) 14 and the Physical Coding Sublayer (PCS) 30 .
  • the MAC sends data including user data received from the host system (not shown) to the XGXS via the 37-conductor XGMII bus 16 .
  • the MAC additionally receives data that include user data from the XGXS 14 via the 37-conductor XGMII bus 17 for supply to the host system.
  • the XGXS 14 sends a coded serial bitstream, to be described below, to the PCS 30 via the 4-lane XAUI bus 18 and receives a coded serial bitstream from the PCS via the 4-lane XAUI bus 19 .
  • the physical coding sublayer module (PCS) 30 includes the transmission path 20 and the reception path 22 .
  • the transmission path 20 is composed of a serial arrangement of the 4 ⁇ 8b/10b decoder 32 , the encoder 100 according to the invention, additional processing and the multiplexer 34 .
  • the input of the 4 ⁇ 8b/10b decoder is connected to one output of the XGXS 14 by the XAUI bus 18 .
  • the output of the 4 ⁇ 8b/10b decoder is connected to the input of the encoder by the 37-conductor pseudo-XGMII bus 42 .
  • the output of the encoder 100 is connected to one or more additional processing elements 35 A by the bus 44 .
  • the bus 44 is 65 conductors wide, but the encoder and the multiplexer may be configured to use a bus that is substantially narrower than this.
  • the output of the multiplexer is a serial bitstream that is fed to the Ethernet medium 40 A or to other processing elements.
  • the output of the multiplexer 34 may be provided as an input to the scrambler 310 shown in FIG. 1C .
  • the reception path 22 is composed of a serial arrangement of the demultiplexer 36 , the decoder 120 and the 4 ⁇ 8b/10b encoder 38 .
  • the demultiplexer receives a serial bitstream from the Ethernet medium 40 B.
  • the input of the demultiplexer may be provided from the output of the descrambler 398 shown in FIG. 1D when used with a multi-conductor channel.
  • the output of the demultiplexer 36 is connected to the input of the decoder 120 by the bus 45 .
  • the bus 45 is 65 conductors wide, but the demultiplexer and the decoder may be configured to use a bus substantially narrower than this.
  • the output of the decoder is connected to the input of the 4.times.8b/10b encoder by the 37-conductor pseudo-XGMII bus 43 .
  • the output of the 4 ⁇ 8b/10b encoder is connected to one input of the XGXS 14 by the XAUI bus 19 .
  • An optional processing element 35 B may be included in the path as shown, and may comprise any type of processing. Element 35 B may be omitted in certain embodiments.
  • the MAC 12 receives user data from, and provides user data to, a host system (not shown).
  • the MAC takes any number of words of user data between 64 and 1500, adds 22 words of address and other data to the front of the user data and four words of a CRC-32 checksum to the end of the user data to form a packet.
  • the contents of a packet will be called information words.
  • the MAC additionally generates a Start of Packet (SOP) control word S that it adds to the start of each packet to mark the start of the packet.
  • the MAC additionally generates an End of Packet (EOP) control word T that it adds to the end of each packet to mark the end of the packet.
  • the MAC also generates additional control words and inserts them between consecutive packets to generate a continuous stream of words for transmission to the XGXS 14 .
  • the continuous stream is required to maintain receiver phase alignment.
  • the additional control words include Idle I,Comma K, Skip R, Align A and Error E. This disclosure uses the letter Z as a generic term to indicate any one of the control words.
  • the MAC 12 feeds the continuous stream of words to the XGXS 14 via the XGMII bus 16 .
  • 32 are allocated to four, parallel, eight-bit words; four are allocated to control word flags, each of which indicates whether a respective one of the four words is an information word or a control word; and one is allocated to a clock signal.
  • a set of four eight-bit words transported in parallel by the XGMII busses 16 and 17 and by the pseudo-XGMII busses 42 and 43 will be referred to as a quad.
  • the MAC 12 receives from the XGXS 14 via the XGMII bus 17 a continuous stream of quads.
  • the quads are composed of information words arranged in packets and code words interspersed between consecutive packets, as just described.
  • the start and end of each packet are marked with an SOP and an EOP control word, respectively.
  • the MAC extracts the packet of information words from the stream of quads received from the XGXS using the control word flags received in parallel with the quads to indicate the information words.
  • the MAC also checks the validity of each packet using the CRC-32 checksum that constitutes the last four words of the packet.
  • the MAC then extracts the user data from the packet, and forwards the user data to the host system (not shown).
  • the XGXS 14 receives the continuous stream of quads from the MAC 12 .
  • the MAC and the XGXS are elements of conventional Ethernet system. Consequently, the XGXS module applies 8b/10b line code to each word in the quads received from the MAC. Each word is coded in response to its respective control word flag so that information words and control words having the same eight-bit code are represented by different ten-bit codes.
  • the XGXS also serializes the 10-bit line code words and feeds them to the input of the PCS 30 via the XAUI bus 18 .
  • the XAUI bus is standardized for 10 Gb/s Ethernet and is composed of four parallel conductors, called lanes, each of which carries serial 10-bit line code words at a bit rate of 3.125 Gb/s.
  • the four conductors constituting the XAUI bus collectively transfer the serial 10-bit line code words to the PCS 30 at an effective bit rate of 12.5 Gb/s.
  • the XAUI busses 18 and 19 use four parallel conductors to achieve a total bit rate of 12.5 Gb/s.
  • the XGXS 14 also receives four serial bitstreams from the PCS 30 via the XAUI bus 19 .
  • the XGXS parallelizes the bitstreams, decodes the 8b/10b coding of the 10-bit line code words constituting the bitstream, and feeds the resulting continuous stream of quads composed of information words and control words to the MAC 12 via the XGMII bus 17 .
  • the XGXS additionally feeds a control word flag for each of the words constituting the quads to the MAC via the XGMII bus.
  • the 4.times.8b/10b decoder 32 is connected to the XAUI bus 18 to receive incoming serial 10-bit line code words at a bit rate of 4.times.3.125 Gb/s.
  • the 4.times.8b/10b decoder decodes the 8b/10b coding of the 10-bit line code words to recover respective 8-bit words, and generates, for each word, a word type bit that indicates whether the word is an information word or a control word.
  • the 4.times.8b/10b decoder feeds quads of the 8-bit words and their respective control word flags to the encoder 100 via the pseudo-XGMII bus 42 .
  • the pseudo-XGMII bus has the same structure as the XGMII bus 16 , but is called pseudo-XGMII in this disclosure to indicate that this bus does not form part of the 10 Gb/s Ethernet standard.
  • the pseudo-XGMII bus is composed of 37 conductors. Thirty-two of the conductors are allocated to the quads, four of the conductors are allocated to the control word flags for the quads, and one conductor is allocated to a clock signal.
  • the encoder 100 receives the quads from the pseudo-XGMII bus 42 as input data, encodes consecutive pairs of the quads to generate respective 65-bit packets, as will be described in more detail below, and feeds the packets to one or more additional processing elements 35 A as shown herein and which are shown generally as additional processing elements 35 A.
  • the additional processing elements may comprise, but are not limited to any type additional processing. Alternatively, this processing element 35 A may be left out of the system if no such additional processing is desired.
  • the output of the additional processing elements 35 A feeds into the multiplexer 34 via the bus 44 A.
  • the multiplexer 34 receives the 65-bit packets, serializes them and transmits them to the Ethernet medium 40 A at a bit rate of 10 Gb/s.
  • the output of the multiplexer 34 may feed as the input 300 into the scrambler 310 for transmission over a multi-conductor channel.
  • the demultiplexer separates the serial data received at a bit rate of 10 Gb/s from the Ethernet medium 40 B into 65-bit packets, and feeds through additional and optional processing elements 35 B and then to the decoder 120 via the bus 45 .
  • the decoder decodes the 65-bit packets to generate two consecutive quads of eight-bit words and a control word flag for each word.
  • the decoder transfers the quads and their respective control word flags in parallel to the 4 ⁇ 8b/10b encoder 38 via the pseudo-XGMII bus 43 .
  • the 4 ⁇ 8b/10b encoder 38 applies 8b/10b encoding to the quads received via the pseudo-XGMII bus 43 , operating in response to the control word flag for each word constituting the quads.
  • the 4.times.8b/10b encoder transfers the resulting 10-bit line code words via the XAUI bus 19 to the XGXS module 14 at a bit rate of 12.5 Gb/s.
  • the 10-bit line code words are processed by the XGXS and the MAC 12 to provide the received user data to the host system (not shown), as described above.
  • the XGXS 14 and corresponding 8b10b encoder 38 , and decoder 32 may be optional and hence, embodiment may be enabled without these elements.
  • the XGMII interface 16 and 17 can be connected directly to the 64b/65b encoder 100 and decoder 120 .
  • the XGMII interface may be configured to extend over long PCB distances by using the XGMII Extender sublayer as shown.
  • FIG. 2 schematically shows exemplary quads of the input data received by the encoder 100 via the four lanes of the pseudo-XGMII bus 42 .
  • the input data include the exemplary packet 130 composed of information words D.
  • the number of information words in the packet 130 is substantially fewer than the minimum number of information words in a standard Ethernet packet.
  • the encoder 100 Prior to the start of the packet 130 , the encoder 100 receives control words on all four input lanes of the pseudo-XGMII bus 42 .
  • the control words in the four lanes denote an interpacket gap.
  • a set of alignment characters A that can be used to synchronize the lanes is also shown.
  • the start of the packet 130 is indicated by the SOP control word S, shown at 131 .
  • the SOP control word always appears in lane 0 and never appears in any other lane. If the SOP control word appears in a lane other than lane 0, this indicates an error and the packet is filled with error codes E.
  • the information words D constituting the packet 130 are then consecutively received, followed by the EOP control word T, shown at 132 .
  • the EOP control word can appear in any of the lanes of the pseudo-XGMII bus 42 .
  • the lane in which the EOP control word appears depends on the number of information words in the packet.
  • the packet can be composed of any number of information words between 64 and 1500. The minimum number of control words between consecutive packets is 12.
  • the encoder 100 receives control words that denote an interpacket gap via all four lanes of the pseudo-XGMII bus. The control words continue until the SOP control word (not shown) indicating the start of the next packet.
  • the encoder 100 applies 64b/65b encoding to blocks composed of two quads of the input data consecutively received from the pseudo-XGMII bus 42 , i.e., the 64b/65b coding is applied to a total of 64 received bits.
  • the 64b/65b coding uses 65 bits to represent the 64 received bits.
  • the 64b/65b coding adds a block header composed of one bits to the start of the block to form a frame. Use of a single bit for the block header has numerous advantages, which are discussed below in more detail.
  • the block header serves both as a reference for frame synchronization and as a flag that indicates when the frame is composed exclusively of information words.
  • the 64b/65b coding has a coding efficiency of 64/65, or an overhead of 1.5625%, which is an advtantage over prior art encoding schemes. Since each word received from the pseudo-XGMII bus 42 can be either a control word or an information word, as indicated by the word's respective control word flag, also received from the pseudo-XGMII bus, a fully-general code would need to transmit the control word flag for each word to tell the receiver what type of word is being received. The maximum efficiency of such a code would be 8/9, or a 12.5% overhead.
  • the 64b/65b coding achieves a substantially lower overhead than this by taking advantage of features of the XAUI interface and the Ethernet packet structure that reduce the number of possible ways in which information words and control words can be arranged in the input data.
  • each packet of information words received by the encoder 100 is composed of at least 64 words, always starts with the SOP control word S and always ends with the EOP control word T, and consecutive packets are separated by at least 12 control words.
  • each block can contain information words exclusively, control words exclusively, a single transition from control words to information words or a single transition from information words to control words.
  • the block header that constitutes the first bit of the frame operates as a flag to indicate when the frame is composed exclusively of information words.
  • this number of bits can be used to represent a TYPE word that is included in all frames that are not composed exclusively of information words.
  • Different values of the TYPE word indicate one of the following structural properties of the block: 1) whether the block from which the frame is derived is composed exclusively of control words, 2) the position of the start of a packet in the block from which the frame was derived and 3) the position of the end of a packet in the block from which the frame was derived. Since the number of states represented by the eight-bit TYPE word is relatively small, TYPE words having a large mutual Hamming distance can be chosen. For example, the TYPE words can be chosen so that more than three bit errors are required to convert one TYPE word to another.
  • XAUI semantics guarantee that the SOP control word S appears in lane 0 exclusively. This reduces the number of ways in which the packet start can appear in the frame to two, which further reduces the total number of ways in which the start of the packet or the end of the packet can appear in the frame.
  • the set of control words is sufficiently small (I, K, R, S, T, A, E, . . . ) to allow the control words to be coded using fewer than eight bits, and to be coded by a set of codes having a large mutual Hamming distance.
  • the bits saved by coding the control words using fewer than eight bits can then be used to condense the block to enable the frame to accommodate the above-described TYPE word.
  • the codes are chosen to enable the control word coding to be highly resistant to bit errors.
  • FIGS. 3A-3D show the twelve possible types of blocks that the encoder 100 can receive from the pseudo-XGMII bus 42 .
  • FIG. 3A shows a block generated from two consecutive quads located in the middle of the packet, where both quads consist exclusively of information words.
  • the block composed of two consecutive quads of exclusively information words is called a Type 1 block.
  • FIGS. 3B shows the one block Type that includes two consecutive quads located in the middle of the gap between two consecutive packets, where both quads consist exclusively of control words.
  • the block composed of two consecutive quads of exclusively information words is called a Type 2 block.
  • FIG. 3C shows the two different block Types in which the start of the packet appears.
  • the start of the packet is indicated by SOP control word S. Because the SOP control word can only appear in lane 0 of the pseudo-XGMII bus, the SOP control word can appear in only two possible locations in the block.
  • the block in which the SOP control word appears in the even-numbered quad is called a Type 3 block, and that in which the SOP control word appears in the odd-numbered quad is called a Type 4 block.
  • FIG. 3D shows the eight different block Types in which the end of the packet appears.
  • the end of the packet is indicated by the EOP control word T. Because the EOP control word can appear in any one of the four lanes of the pseudo-XGMII bus, the EOP control word can appear in any location in the block.
  • the blocks in which the EOP control word appears as word 1 through 8 of the block are called Type 5 through Type 12 blocks, respectively.
  • the 12 different types of blocks are indicated by a code that uses a combination of the 1 bit block header and the TYPE word.
  • the 12 types of blocks are divided into two different categories, namely, blocks composed exclusively of information words, i.e., the Type 1 block shown in FIG. 3A , and blocks that include at least one control word, i.e., the Type 2-12 blocks shown in FIGS. 3B-3D .
  • the 10GBASE-R physical layer device utilizes a coding technique to reduce the control bit overhead from 12.5% down to 3.125%, a 4 ⁇ reduction.
  • This 64B/66B code is essentially a simple compression algorithm using a lookup table based on the contents of the current 8 bytes plus the associated 8 control bits. In this manner 72 bits (64 data bits+8 control bits) are mapped into a 66-bit code word. This code word is then transmitted serial through a fiber optic system to a remote unit that will decode the 66-bit code word back into the original 72 bits using the reverse lookup table.
  • 64B/66B encoding is used in a 4 pair UTP transmission system.
  • the use of the 64B/66B encoding reduces the needed bit rate of the proposed system from 11.25 Gbit/sec to 10.3125 Gbit/sec.
  • an additional Forward Error Correction (FEC) code may optionally be used that adds additional overhead.
  • the 64B/66B encoder described in IEEE 802.3 (Ethernet) Standard Clause 49 is intended for a 10.3 Gbit/sec serial bit stream in fiber optic transmission system.
  • This system does not employ a FEC and as such requires a robust mechanism to distinguish between a 66B code block containing control words and a code block that does not. This was accomplished by using a 2-bit sync header prepended to the 64-bit payload.
  • the header takes only 2 possible values: 01 for a data only payload, and 10 for a payload containing control symbols.
  • a multi-gigabit 4 pair UTP transceiver is configured with a single bit header. With a one bit header, for example the value ‘01’ is replaced by ‘0’ and ‘10’ is replaced by ‘1’.
  • the effective encoder rate is 65/64 rather than 66/64 with a one bit header.
  • IEEE 802.3 (Ethernet) Standard Clause 49 is hereby incorporated by reference.
  • One benefit of this invention is that the reduction in overhead makes it possible, in one embodiment, to concatenate the 64B/65B code, a Reed-Solomon ( 255 , 239 ) code and a TCM code using 1-bit of parity per symbol using 12PAM modulation at a baud rate of around 833 Mbaud/sec.
  • the original 11.25 Gbit/sec bit stream is encoded using 64B/66B into a 10.3125 Gbit/sec bit stream. After dropping a sync bit the bit stream is 10.15625 Gbit/sec.
  • RS encoding the bit stream is 10.8362 Gbit/sec. Grouping the bits into 13-bit symbols yields an 833.55 Mbaud/sec rate.
  • a TCM code adds a single bit per baud for 14-bits per symbol at 833.55 Mbaud/sec.
  • the unused constellation points may be chosen such that the constellation has a lower transmit power with an associated shaping gain.
  • FIG. 4A shows the basic structure of the frame 150 that the encoder 100 generates from a block of input data.
  • the frame is composed of a one bit sync. field 151 followed by the 64-bit payload field 152 .
  • the sync. field accommodates the one bit block header.
  • the encoder 100 generates two different kinds of frame having the basic structure shown in FIG. 4A , but differing in the structure of their payload fields.
  • the structure of the payload field depends on whether or not the block from which the frame is generated is a Type 1 block composed exclusively of information words.
  • the structure of the payload field is indicated by the 1 bit block header stored in the sync. field.
  • FIG. 4B shows the structure of the frame 153 generated when the block is a Type 1 block.
  • the 1 bit block header in the sync field 151 is ‘1’
  • the payload field 152 is composed of the eight information words constituting the block, i.e., 64 bits.
  • FIG. 4C shows the structure of the frame 156 generated when the block is a Type 2 through Type 12 block that includes at least one control word.
  • the one bit block header in the sync. field 151 is ‘0’
  • the payload field 152 is composed of the 8-bit sub-field 157 and the 56-bit sub-field 158 .
  • the eight-bit sub-field 157 is occupied by the TYPE word and the 56-bit sub-field 158 is occupied by a condensed version of the block.
  • all information words included in the block are included unchanged in the sub-field 158 .
  • the 56-bit sub-field 158 can accommodate up to seven information words, the maximum number of information words in a block that includes at least one control word.
  • control words S and T if they appear in the block, are discarded and are not transferred to the sub-field 158 .
  • all remaining control words in the block are re-coded using fewer than eight bits and the re-coded control words are included in the sub-field 158 .
  • the remaining control words are re-coded using seven-bit codes chosen to have a mutual Hamming distance of four bits.
  • the control words S and T can be omitted from the sub-field 158 because position of the start of the packet or the end of the packet in the frame is indicated by the TYPE word included in the sub-field 157 . Omitting the control words S and T allows the payload field 158 to accommodate the TYPE word and all seven information words in full when the block is composed of seven information words and either the SOP control word S or the EOP control word T, as in the Type 3 block shown in FIG. 3C and the Type 12 block shown in FIG. 3D . Re-coding the remaining control words as 7-bit words enables the payload field 158 to accommodate the TYPE word and all eight control words when the block is composed exclusively of control words, as in the Type 2 block shown in FIG. 3B . All other combinations of information words and control words are composed of fewer than 56 bits after the S and T control words have been removed and the remaining control words have been re-coded using fewer bits.
  • FIG. 5 is a flow chart showing a first embodiment 200 of a method according to the invention for applying 64b/65b coding to input data that include a packet of information data. The processing performed in process 205 of the method will be described in more detail below with reference to FIG. 6 .
  • the method starts at process 202 .
  • blocks of the input data are received.
  • the input data include the above-mentioned control words in addition to the packet of information words.
  • the control words precede and follow the packet of information words.
  • the blocks are smaller than the packet.
  • each block is composed of two successive quads of four parallel words received from the pseudo-XGMII bus 42 .
  • a test is performed on a block of the input data to determine whether the block is composed exclusively of information words.
  • this test can be performed simply by examining the control word flags for the eight words that constitute the block.
  • the control word flags are received together with the words that constitute the block via the pseudo-XGMII bus 42 .
  • test result When the test result is NO, execution advances to process 205 , which will be described below.
  • test result When the test result is YES, execution advances to process 207 wherein a frame is formed by preceding the block with a one bit block header in the first sense.
  • the one bit block header in the first sense is provided by the bit ‘1’.
  • Execution then advances to process 208 , where the frame is transmitted, and to process 209 , where a test is performed to determine whether all the blocks of the input data have been processed.
  • process 208 where the frame is transmitted
  • process 209 where a test is performed to determine whether all the blocks of the input data have been processed.
  • execution advance to process 210 , where it ends.
  • execution returns to process 204 via process 211 so that the next block can be processed.
  • process 204 When the test result in process 204 is NO, this indicates that the block includes at least one control word.
  • the TYPE word indicates one of the following structural properties of the block: 1) whether the block is composed exclusively of control words, 2) the position in the block of the start of the frame and 3) the position of the end of the frame the block.
  • Block Types are described in detail above with reference to FIGS. 3A-3D . The processing performed in process 205 will be described in more detail below with reference to FIGS. 6 .
  • Execution then advances to process 213 , where a frame is formed by preceding the block with a one bit block header in a second sense, opposite to the first sense.
  • the block header in the second sense is provided by the one bit ‘0’.
  • Execution then advances to process 208 , where the frame is transmitted, as described above.
  • FIG. 6 shows an example of the processing performed in process 205 .
  • the block is condensed and a TYPE word indicating the structural properties of the block is inserted into the block.
  • the structure includes the position of the start or the end of the packet in the block, and whether the block is composed exclusively of control words.
  • Execution starts in process 220 .
  • a test is performed to determine whether the block includes the SOP control word S that indicates that the packet starts in the block.
  • the test result is NO
  • execution advances to process 222 , which will be described below.
  • the test result is YES
  • execution advances to process 223 , where a test is performed to determine whether the SOP control word appears in the first quad constituting the block.
  • Each block processed by the encoder 100 is composed of two consecutively-received quads.
  • test result generated by process 223 is NO
  • execution advances to process 224 , where a TYPE word indicating that the block is a Type 4 block is generated.
  • a Type 4 block is one in which the SOP control word appears in the second quad. Block types are described in detail above with reference to FIGS. 3A-3D .
  • Execution then advances to process 226 , which will be described below.
  • process 225 When the test result generated in process 223 is YES, execution advances to process 225 , where a TYPE word indicating that the block is a Type 3 block is generated.
  • a Type 3 block is one in which the SOP control word appears in the first quad.
  • Process 227 the block is condensed by re-coding any control words in the block using fewer bits. If either process 226 or process 233 has previously been executed, the effect of executing process 227 is to compress the block further.
  • Process 233 will be described below. The purpose of condensing the block is described above.
  • the 8-bit control words are re-coded using fewer bits.
  • the set of control words is sufficiently small to allow the control words to be coded using 7-bit codes chosen to have a mutual Hamming distance of four bits.
  • the re-coding process can refer to the TYPE word for the block to find the locations of the control words in the block.
  • Execution then advances to process 228 , where the TYPE word is inserted at the head of the block. Space to accommodate the TYPE word has been created in the block by executing one or more of processes 226 , 227 and 233 . Process 233 is described below. Execution then advances to process 229 , whence it returns to the main routine.
  • test result in process 221 is NO
  • execution advances to process 222 where a test is performed to determine whether the block includes the EOP control word T that indicates that the end of the packet appears in the block.
  • execution advances to process 230 which will be described below.
  • execution advances to process 231 where the position of the EOP control word in the block is determined. As shown in FIG. 3D , any of the eight words in the block can be the EOP control word.
  • Execution then advances to process 232 , where a TYPE word is generated in accordance with the position of the EOP control word in the block.
  • the TYPE word indicates that the block is one of a Type 5 through Type 12 block.
  • Type 5 through Type 12 blocks are blocks in which the EOP control word appears in one of the eight word positions in the block, as described above with reference to FIG. 3D .
  • Execution then advances to process 233 , where the block is condensed by removing the EOP control word from the block.
  • the purpose of condensing the block is described above.
  • Execution then advances to process 227 , where the block is further condensed by re-coding any control words remaining in the block are re-coded using fewer bits, as described above.
  • a test result of NO in process 222 indicates that the block is composed exclusively of control words.
  • execution advances to process 230 where a TYPE word indicating that the block is a Type 2 block is generated.
  • a Type 2 block is a block composed exclusively of control words.
  • Execution then advances to process 227 , where the block is condensed by re-coding the control words included in the block using fewer bits, as described above. In this case, all eight words in the block are control words and are re-coded.
  • FIGS. 7A-7L show specific examples of the frames generated from each of the twelve block types shown in FIGS. 3A-3D , including the block header and the TYPE word, where used.
  • FIG. 7A shows the frame 153 generated from the Type 1 block shown in FIG. 3A . This block is composed exclusively of information words.
  • the sync field 151 is filled with the one bit block header ‘1’ and the payload field 152 is filled with the eight information words located in the eight positions 0 through 7 in the block 160 , as shown.
  • Each of the information words in the payload field is labeled with the letter D, a number and the numeral 8 .
  • the letter D indicates an information word
  • the number indicates the location of the information word in the block 162
  • the numeral 8 indicates that the information word is composed of eight bits.
  • FIG. 7B shows a frame generated from the Type 2 block shown in FIG. 3B .
  • FIGS. 7C and 7D respectively show frames generated from the Type 3 and Type 4 blocks shown in FIG. 3C .
  • FIGS. 7E-7L respectively show frames generated from the Type 5 through 12 blocks shown in FIG. 3D .
  • FIG. 7D shows the frame 156 generated from the Type 4 block shown in FIG. 3C .
  • the Type 4 block is composed partly of control words, i.e., the SOP control word S and the unspecified control words Z, and partly of information words D. In the frame 156 , the sync.
  • the sub-field 157 is occupied by the 8-bit TYPE word, in this example, the hexadecimal number 33.sub.H.
  • the TYPE word indicates that the frame is generated from a Type 4 block in which the start of a packet appears in the odd-numbered quad constituting the block.
  • the sub-field 158 of the payload field is occupied by three coded control words Z and three eight-bit information words D.
  • Each of the data elements in the sub-field 158 is labeled with the letter D or Z, a number and the numeral 7 or 8 .
  • the letter D indicates an information word
  • the letter Z indicates a control word
  • the number indicates the location of the information word or control word in the block using the convention described above with reference to FIG. 7A
  • the numeral 7 or 8 indicates the number of bits in the data element, i.e., seven bits for each coded control word and eight bits for each information word.
  • the SOP control word S is discarded and is not transferred to the sub-field 158 .
  • the function of the SOP control word indicating that the packet starts at position 4 of the block is provided by the TYPE code 33.sub.H instead.
  • the three coded control words Z coded as 7-bit words and three eight-bit information words D do not fully occupy the sub-field 158 of the frame 156 .
  • the unoccupied region 164 of the sub-field is filled with suitable idle bits.
  • functions can be assigned to the bits used to fill the unoccupied portions of the sub-field 158 .
  • the TYPE words illustrated in FIGS. 7B-7L are chosen to have a mutual Hamming distance of four bits to ensure that the start and the end of the packet are reliably identified.
  • the TYPE words are additionally chosen to be easy to generate and to test.
  • the set of chosen TYPE words is an eleven-element sub-set of a 16-element set generated as follows: the first four bits of each successive element in the set increments from 0 to 15 in binary.
  • the second four bits of each element provide the minimum Hamming distance protection and are either 1) a duplication of the first four bits when the parity of the first four bits is even, or 2) the complement of the first four bits when the parity of the first four bits is odd.
  • the 16-element set is optimum in that it provides for a very simple implementation with low gate delay and latency.
  • the error correction decoder will correct bit errors prior to the decoder such that the decoder can reliably use the single bit header for deciding whether the block contains information or control words. Furthermore when the error correction decoder fails to correct the bit errors, the error correction decoder and/or the CRC check may flag the affected blocks such that they will replaced by error symbols (E) such that they will not be incorrectly decoded.
  • E error symbols
  • FIG. 8 is a block diagram showing a first embodiment of the encoder 100 according to the invention.
  • the encoder is composed of the type word generator 181 , the payload field generator 182 , one bit the block header generator 184 and the frame assembler 185 .
  • the type word generator 181 and the payload field generator 182 are connected to receive blocks of input data from the 4.times.8b/10b decoder 32 via the pseudo-XGMII bus 42 ( FIG. 1E ).
  • the input data are composed of control words and a packet of information words.
  • the packet is preceded and followed by the control words.
  • the blocks are eight words, i.e., 64 bits, long and are smaller than the smallest size of the packet.
  • the blocks are also smaller than the number of control words between consecutive packets.
  • the encoder processes the input data block-by-block to generate respective frames for transmission.
  • the type word generator 181 generates a TYPE word whose value indicates one of the following mutually-exclusive structural properties of the block: 1) whether the block is composed exclusively of control words, 2) a position of the start of the packet in the block and 3) a position of the end of the packet in the block and 4) whether the block is composed exclusively of information words.
  • the type word generator feeds the TYPE word to the payload field generator 182 and the one bit block header generator 184 .
  • the value of the TYPE word that indicates whether the block is composed exclusively of information words may take the form of a flag bit fed to the block header generator 184 and, optionally, to the payload field generator 182 .
  • the payload field generator 182 operates in response to the TYPE word.
  • the payload field generator adopts the block to form a payload field. Otherwise, when the TYPE word indicates that the block is not composed exclusively of information words, the payload field generator condenses the block and inserts the TYPE word into the block to form the payload field.
  • the payload field generator 182 condenses the block by performing one or both of the following operations: 1) removing any start-of-packet control word or an end-of-packet control word from the block, and 2) re-coding any other control words in the block using fewer bits.
  • the control words are re-coded using seven-bit codes having a mutual Hamming distance of four bits. Whether the payload field generator simply adopts the block as the payload field, or processes the block further before forming the payload field may be determined by the above-mentioned flag bit in lieu of the full TYPE word.
  • the TYPE word indicates the location in the block of the start-of-packet control word or the end-of-packet control word (if any) and the locations in the block of the other control words (if any).
  • the payload field generator 182 feeds the payload field PF generated from the block to the frame assembler 185 .
  • the one bit block header generator 184 operates in response to the TYPE word, or, alternatively, to the flag bit described above, and generates the one bit block header.
  • the one bit block header generator generates the block header in a first sense when the TYPE word, or flag bit, indicates that the block is composed exclusively of information words. Otherwise, when the TYPE word, or flag bit, indicates that the block is not composed exclusively of information words, the block header generator generates the block header in a second sense, opposite to the first sense. In the preferred embodiment, the one bit block header in the first sense is ‘1’, and the one bit block header in the second sense is ‘0’. Transitions opposite to those shown could alternatively be used.
  • the one bit block header generator 184 feeds the block header BH to the frame assembler 185 .
  • the frame assembler 185 receives the payload field from the payload field generator 182 and the one bit block header from the one bit block header generator 184 and appends the one bit block header to the payload field to form the frame for transmission.
  • the frame assembler preferably locates the one bit block header before the payload field, but could alternatively locate the one bit block header after the payload field.
  • the frame assembler feeds the 65-bit frame to one or more additional processing elements 35 A via the bus 44 ( FIG. 1E ).
  • FIG. 9A is a flow chart showing an example 280 of a decoding method for decoding the frames generated by the coding method and coder according to the invention.
  • the method starts in process 271 .
  • a frame is received from the demultiplexer 36 via the bus 45 .
  • a test is performed on the block header of the frame to determine whether the one bit block header is in the first state.
  • the first state is ‘1’ in the preferred embodiment.
  • the test result is YES, which indicates that the payload field of the frame is composed exclusively of information words
  • execution advances to process 277 , which will be described below.
  • execution advances to process 275 .
  • a NO result in process 274 indicates that the payload field of the frame is not composed exclusively of information words, and therefore includes a TYPE word.
  • the TYPE word is extracted from the payload field.
  • the payload field of the frame is expanded using the information provided by the TYPE word regarding the structure of the payload field. Expanding the payload field reverses the condensing that was applied by the encoder to the block from which the frame was generated. Thus, when the payload field is expanded, the coded control words are re-coded to yield eight-bit control words. Additionally, when the start of the packet or the end of the packet appears in the payload field, a start-of-packet control word or an end-of-packet control word, respectively, is inserted into the payload field.
  • the TYPE word indicates what portion of the payload field is occupied by coded control words, and the location in the payload field of the start of the packet or the end of packet.
  • the processing performed in process 276 will be described in more detail below with reference to FIG. 9B .
  • Execution then advances to process 277 .
  • the payload field is adopted as a block of received data.
  • process 278 a test is performed to determine whether all frames have been processed.
  • execution advances to process 279 , where it ends.
  • execution returns to process 272 via process 280 so that the next frame can be processed.
  • Process 276 of the method described above with reference to FIG. 9A will now be described with reference to FIG. 9B where execution starts at process 291 .
  • a test is performed to determine whether the TYPE word indicates that any coded control words appear in the payload field, i.e., whether the encoder 100 derived the payload field from a Type 2 block or a Type 4 through Type 11 block.
  • the test result is NO
  • execution advances to process 296 , which will be described below.
  • the test result is YES
  • execution advances to process 294 .
  • the TYPE word is used to identify the portion of the payload field occupied by one or more coded control words, and the number of coded control words. It can be seen from FIGS. 7A-7L that the coded control words in the frame derived from each block Type differ in number but are always contiguous. However, in some frames, the coded control words abut the head of the payload field, whereas in others, the coded control words abut the end of the payload field. In process 295 , the coded control words identified by process 294 are decoded to yield the original control words.
  • a test is performed to determine whether the TYPE word indicates that a packet starts or ends in the payload field, i.e., whether the encoder 100 derived the payload field from a Type 3 through Type 12 block.
  • the test result is NO, this indicates that the payload field was derived from a Type 2 block.
  • execution advances to process 299 , which will be described below.
  • the test result is YES, execution advances to process 297 .
  • process 297 the position of the start of the packet or the end of the packet in the payload field is identified from the TYPE word.
  • process 298 an SOP control word S or an EOP control word T is inserted into the payload field.
  • the control word inserted i.e., whether the control word S or T is inserted, and the position in the payload field at which the SOP or EOP control word is inserted are defined by the TYPE word. Execution then advances to process 299 .
  • execution returns to the main routine.
  • Either or both of the control word decoding performed in process 295 and the control word insertion performed in process 298 insert 8-bit control words into the payload field. This fills the space in the payload field formerly occupied by the TYPE word and, in some frames, fill bits.
  • FIG. 10 is a block diagram showing a first embodiment of the decoder 120 .
  • the decoder is composed of the frame decoder 191 , the type word extractor 193 , the block generator 194 and the block sequence detector 195 .
  • the frame decoder 191 receives each 65-bit frame from the demultiplexer 36 via the 65-bit bus 45 ( FIG. 1 ).
  • the frame decoder reads the one bit block header at the front of the frame and feeds the one bit block header BH to the type word extractor 193 .
  • the frame decoder feeds the remaining 64 bits constituting the payload field PF of the frame to the type word extractor 193 and the block generator 194 .
  • the type word extractor 193 receives the payload field PF and additionally receives the one bit block header BH from the frame decoder 191 .
  • the type word extractor operates only when the one bit block header is in its second state, corresponding to a frame whose payload field is not composed exclusively of information words.
  • the type word extractor extracts the TYPE word from the sub-field 157 of the payload field 152 ( FIG. 4C ) and feeds the TYPE word to the block generator 194 and the block sequence detector 195 .
  • the block generator 194 receives the payload field PF, the TYPE word from the type word extractor 193 and the one bit block header BH from the frame decoder 191 .
  • the block generator operates in response to the one bit block header.
  • the block generator adopts the payload field PF as a block of received data.
  • the block generator expands the payload field using the information provided by the type word regarding the structure of the payload field. Expanding the payload field reverses the condensing that was applied by the encoder to the block from which the frame was generated.
  • the coded control words are re-coded to yield eight-bit control words.
  • a start-of-packet control word or an end-of-packet control word, respectively, is inserted into the payload field.
  • the TYPE word indicates what portion of the payload field is occupied by coded control words, and the location in the payload field of the start of the packet or the end of packet.
  • the block generator adopts the payload field after expansion as the block of received data.
  • the block generator 194 feeds the block of received data to the 4.times.8b/10b decoder 120 via the bus 43 ( FIG. 1 ).
  • the decoder also includes the block sequence detector 195 .
  • the block sequence detector receives the TYPE word from the type word extractor 193 and the one bit block header BH from the frame decoder 191 .
  • the one bit block header of a frame and the TYPE word of the frame when present, collectively define what kind of frame the frame is.
  • the frame can be one of four different kinds, namely, one composed exclusively information words D (generated from Type 1 block), one that includes the start of a packet S (generated from Type 3 or Type 4 block), one that includes the end of a packet T (generated from one of Type 5 through Type 12 block) and one composed exclusively control words Z (generated from Type 2 block).
  • the encoder generates the four different kinds of frames in a predetermined order, namely: S, D, . . . , D, T, Z, . . . Z, S, D, . . . , D, T, Z, . . . , Z, etc.
  • the frames must be received by the decoder 120 in the same predetermined order.
  • the block sequence detector monitors the order of the kinds of frame received, and generates the error flag ERR when the TYPE word and the one bit block header indicate that the frame is of a kind that violates the predetermined order.
  • the block generator 194 adds the error control word E to the block of received data generated from the frame in response to the error signal.
  • the error control word causes the MAC 12 ( FIG. 1 ) to void the packet of which the block forms part.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Power Engineering (AREA)
  • Computer Security & Cryptography (AREA)
  • Detection And Prevention Of Errors In Transmission (AREA)

Abstract

A communication system processes blocks of input data that include control words and a packet of information words are received. The packet has a start preceded by ones of the control words and an end followed by others of the control words. When the block consists exclusively of information words, a one bit block header having a first sense is appended to the block to form a frame. When the block does not consist exclusively of information words, the block is condensed to accommodate a TYPE word, the TYPE word is generated and inserted into the block and a one bit block header is appended to the block to form the frame. When the block does not consist exclusively of information words the one bit block header has a second sense, opposite to the first sense. Use of a one bit block header reduces overhead. Forward error correction is also utilized.

Description

    1. PRIORITY CLAIM
  • This application claims priority to Provisional Patent Application No. 60/679,336 filed on May 10, 2005 and also claims priority to pending patent application Ser. No. 10/194,741 filed on Jul. 10, 2002.
  • 2. FIELD OF THE INVENTION
  • The invention relates to communication systems and in particular to a method and apparatus for coding data to minimize overhead.
  • 3. RELATED ART
  • Demand for high rate data transmission continues to increase in response to new service offerings and expanded communication network usage, such as for home and business tasks. For example, audio and video content is growing in popularity and is generally bandwidth intensive. In addition, many tasks are now commonly handled via a computer network, such as ordering business supplies, exchanging documents, and information gathering. Moreover, bandwidth demand placed upon a company's local area network is increasing. Often networks are being burdened with more users and larger and more complex software applications. These applications are bandwidth intensive and the complex software applications create larger files. Although many networks are currently at bandwidth capacity additional demands are continually being placed on these network.
  • While there are numerous proposed solutions to alleviate network congestion by increasing network speeds, many of these proposed solutions require migration to a different communication standard or a different communication medium than is currently in use. While different communication standards (SONET, ATM) and different communication mediums (fiber optic cable, coaxial cable) may make it possible to increase data rates, the cost associated with migration is extremely prohibitive. For example, installation of an optical network to each computer in a local area network requires significant software and hardware upgrades on each end user's platform and installation of fiber optic cable. The cabling cost alone is tremendous.
  • Another proposed solution is to increase the transmission rate of existing networks. One widely deployed network standard is Ethernet, which utilizes twisted pairs of copper wires as its transmission medium. Although widely deployed and inexpensive to manufacture, twisted pair copper is bandwidth limited. As a result, data signals transmitted at a high rate over the twisted pair copper, or other medium, are subject to significant levels of distortion and error rates. Upon reception, recovering the transmitted signal may be impossible due to this distortion.
  • While it is possible to perform signal processing or error correction coding, such prior art attempts have been insufficient to achieve desired data transmission rates with acceptable error rates. For example, some attempts to maximize the throughput and signal to noise margin of the channel through use of integrated circuit systems are simply not possible or feasible with existing semiconductor manufacturing processes.
  • Previous attempts to achieve these above-mentioned goals have not achieved the desired results, which is high data rate, low error rate, data communication or are not capable of performing as required in different environments. One such example of a prior art system that is configured to code data to reduce effective data rate is set forth in U.S. Pat. No. 6,718,491, issued to Walker on Apr. 6, 2004 and entitled Coding Method and Coder for Coding Packetized Serial Data with Low Overhead. This proposed method of coding utilizes 64b/66b encoding which is adopted for optical communication. This encoding scheme utilizes 66 bits to represent the 64 received bits. It has however, an undesirably large overhead which makes this encoding scheme, as set forth in the Walker reference undesirable for use in other communication systems.
  • As a result, there is a need for a method and apparatus to facilitate high-speed data transmission while maintaining low error rates that is capable of overcoming the drawbacks of the art.
  • SUMMARY
  • Disclosed herein is a communication system configured to processes blocks of input data that include control words and a packet of information words. The packet has a start preceded by ones of the control words and an end followed by others of the control words. When the block consists exclusively of information words, a one bit block header having a first sense is appended to the block to form a frame. When the block does not consist exclusively of information words, the block is condensed to accommodate a TYPE word, the TYPE word is generated and inserted into the block and a one bit block header is appended to the block to form the frame. When the block does not consist exclusively of information words the one bit block header has a second sense, opposite to the first sense. Use of a one bit block header reduces overhead. Error correction is also utilized.
  • In one embodiment a 64B/65B coding method for coding a packet of information words into frames for transmission over 4 twisted pair conductor is disclosed. In this example method a system receives blocks of input data such that the input data includes control words and the packet of information words. The packets have a start preceded by ones of the control words and an ending followed by others of the control words and the blocks are smaller than the packet. This method then determines when a block consists exclusively of information words and, when the block consists exclusively of information words, then the method appends to the block a one bit block header having a first sense to form one of the frames. When the block does not consist exclusively of information words then the method condenses the block to accommodate a TYPE word. The method also generates the TYPE word having a value that indicates one of the following structural properties of the block: (a) a position of the start of the packer in the block, (b) a position of the end of the packet in the block, and/or (c) the block being composed exclusively of control words. The method may also insert a TYPE word into the block and append to the block a one bit block header having a second sense, opposite to the first sense, to form the one of the frames. As such, this method reduces overhead to less than 3%.
  • In one embodiment, this method includes re-coding at least one of the control words using fewer bits. In addition, the type word may be selected from a set of type words having a specified mutual Hamming distance. In one embodiment, the type words each consist of T bits and the method additionally comprises generating the set of possible bit patterns by a process comprising: adopting a (T/2)-bit binary pattern as a first half of a bit pattern in the set of possible bit patterns, and generating a second half of the bit pattern by duplicating or complementing the first half of the bit pattern depending on a bit parity value of the first half of the bit pattern.
  • It is also contemplated that the one bit block header in the first sense comprises a 1 and a one bit block header in the second sense comprises a 0 value. In addition, the method may be performed in a conjunction with forward error correction. In this method, the step of condensing the block includes removing from the block a control word that indicates one of (a) the start of the packet and (b) the end of packet. Alternatively, condensing the block may include re-coding remaining the control words using fewer bits. This method may be utilized in a 10 gigabit/second communication system.
  • Also disclosed herein is a communication coder for 64B/65B type coding of blocks of input data into respective frames for transmission over twisted pair conductors. In this example embodiment, the input data includes control words and a packet of information words such that the packet has a start preceded by ones of the control words and an ending followed by others of the control words. The blocks may be smaller than the packet and the frames may include a frame corresponding to the block. In this embodiment the coder comprises a type word generator that receives the block and generates a TYPE word for a block such that the TYPE word has a value that indicates one of the following structural properties of the block, namely, (a) whether the block is composed exclusively of control words, (b) a position of the start of the packet in the block, (c) a position of the end of the packet in the block, and (d) whether the block is composed exclusively of control words. The coder also has a one bit block header generator that operates in response to the TYPE word and generates a one bit block header in a first sense when the TYPE word indicates that the block is composed exclusively of information words, and otherwise generates the one bit block header in a second sense, opposite to the first sense, wherein use of a one bit block header reduces overhead to less than 3%. Also part of the coder is a payload field generator that operates in response to the TYPE word. It adopts the block to form a payload field of the frame when the TYPE word indicates that the block is composed exclusively of information words, and otherwise condenses the block and inserts the TYPE word into the block to form the payload field. A frame assembler is also included and configured to append the block header to the payload field to form the frame.
  • In one embodiment the payload field generator includes a re-coder that condenses the block by re-coding remaining ones of the control words using fewer bits. It is contemplated that the type word is selected from a set of type words having a specified mutual Hamming distance. For example, the type words may each consist of T bits and the coder may additionally comprises a type word generator that generates the set of possible bit patterns, and the type word generator may include: a first-half generator that adopts a (T/2)-bit binary pattern as a first half of a bit pattern in the set of possible bit patterns, and a second-half generator that generates a second half of the bit pattern by duplicating or complementing the first half of the bit pattern depending on a bit parity value of the first half of the bit pattern. In one embodiment, the coder operates in conjunction with forward error correction. In addition, the coder may be used in a communication system utilizing a channel of 4 twisted pair conductors and the coder's use of a one bit block header establishes an overhead of 1.5625%.
  • In one embodiment, the payload field generator includes a control word removal module that condenses the block by removing from the block a control word that indicates one of (a) the start of the packet and (b) the end of the packet. In addition, the payload field generator may additionally includes a re-coder that condenses the block by re-coding remaining ones of the control words using fewer bits. Moreover, the re-coder may re-code the control words using codes having a specified mutual Hamming distance.
  • Other systems, methods, features and advantages of the invention will be or will become apparent to one with skill in the art upon examination of the following figures and detailed description. It is intended that all such additional systems, methods, features and advantages be included within this description, be within the scope of the invention, and be protected by the accompanying claims.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention. In the figures, like reference numerals designate corresponding parts throughout the different views.
  • FIG. 1A illustrates a block diagram of an example embodiment of a pair of transceivers configured to communicate over a channel.
  • FIG. 1B illustrates a block diagram of a multi-channel point to point communication system.
  • FIG. 1C illustrates a block diagram of an example embodiment of a transmit system configured in accordance with one embodiment of the invention.
  • FIG. 1D illustrates a block diagram of an example embodiment of a receiver system configured in accordance with one embodiment of the invention.
  • FIG. 1E is a block diagram showing an example of a 10 Gb/s Ethernet interface including a coder according to the invention.
  • FIG. 2 schematically shows exemplary quads of the input data received by the coder according to the invention.
  • FIGS. 3A-3D show the twelve possible types of blocks that can be received by the coder according to the invention.
  • FIGS. 4A-4C show the basic structure and the two kinds of frame that the coder generates from a block of input data.
  • FIG. 5 is a flow chart showing a first embodiment of a coding method according to the invention.
  • FIG. 6 is a flow chart showing an example of the processing performed in process 205 of the method shown in FIG. 5.
  • FIGS. 7A-7L show specific examples of the frames generated from each of the twelve block types shown in FIGS. 3A-3D, including the block header and the TYPE word, where used.
  • FIG. 8 is a block diagram showing a first embodiment of a coder according to the invention.
  • FIG. 9A is a flow chart showing an example of a decoding method for decoding the frames generated by the coding method and coder according to the invention.
  • FIG. 9B is a flow chart showing an example of the processing performed in process 276 of the method shown in FIG. 9A.
  • FIG. 10 is a block diagram showing a first embodiment of a decoder for decoding the frames generated by the coding method and coder according to the invention.
  • DETAILED DESCRIPTION
  • In general, the method and apparatus disclosed herein performs data transmission using forward error correction coding in a multi-pair or multi-channel system to achieve data transmission rates and error rates that are better than that achievable by systems of the prior art. The disclosure provided herein is similar to that disclosed in U.S. Pat. No. 6,781,491 which is disclosed herein in its entirety by reference. In reference to FIG. 1A, a block diagram of a receiver/transmitter pair is shown. This is one possible example environment of the method and apparatus disclosed herein. A channel 312 connects a first transceiver 330 to a second transceiver 334. The first transceiver 330 connects to the channel 312 via an interface 344. The interface 344 is configured to isolate the incoming from outgoing signals. In another embodiment the channel 312 may comprises numerous conductors and hence the interface 344 performs isolation and separates the conductors based on direction of data flow to either of a receiver module 338 or a transmitter module 342. The receive module 338 and transmit module 342 may comprise any assembly of hardware, software, or both configured to operate in accordance with the principles described herein.
  • The receive module 338 and transmit module 342 communicate with a processor 346. The processor 346 may include or communicate with memory 350. The memory 350 may comprise one or more of the following types of memory: RAM, ROM, hard disk drive, flash memory, or EPROM. The processor 346 may be configured to perform one or more calculations or any form of signal analysis. In one embodiment the processor 346 is configured to execute machine readable code stored on the memory 350. The processor 346 may perform additional signal processing tasks as described below.
  • The second transceiver 334 is configured similarly to the first transceiver 330. The second transceiver 334 comprises an interface 352 connected to a receiver module 356 and a transmitter module 360. The receiver module 356 and a transmitter module 360 communicate with a processor 364, which in turn connects to a memory 368. Operation occurs as described below in more detail.
  • The communication system illustrated in FIG. 1B is configured as an exemplary multi-channel point-to-point communication system. One exemplary application is a 10 gigabit transceiver utilizing a Category 5 UTP cable supporting Ethernet protocols. As shown it includes a physical coding sublayer 302 and 304, shown as coupled together over a channel 312. In one embodiment each channel comprises twisted pair conductors. Each of the channels 312 is coupled between transceiver blocks 320 through a line interface 306 and each channel is configured to communicate information between transmitter/receiver circuits (transceivers) and the physical coding sublayer (PCS) blocks 302, 304. Any number of channels and associated circuitry may be provided. In one embodiment, the transceivers 320 are capable of full-duplex bi-directional operation. In one embodiment, the transceivers 320 operate at an effective rate of about 2.5 Gigabits per second.
  • FIG. 1C illustrates a block diagram of an example embodiment of a transmit system configured in accordance with the invention. This is but one example embodiment and it is contemplated that one of ordinary skill in the art may enable other embodiments that do not depart from the scope of the invention. As shown, an input 300 from a data source or other component provides data to a scrambler 310. The data source or other component may comprise any source of data, any aspect of the physical coding sublayer, software or hardware interface, multiplexer, or any other device. The input to the scrambler 310 may comprise the output of the multiplexer 34, shown and discussed below in connection with FIG. 1E. The scrambler 310 operates in a manner understood in the art. The output of the scrambler connects to a CRC encoder 314. The CRC encoder 314 calculates a cyclic redundancy check which is appended to a group of N blocks of encoded data. At the receiver this CRC may be checked to determine if a transmission error has occurred.
  • The output of the CRC encoder 314 feeds into a FEC unit 316 configured to perform forward error correction on the signal. Any type of forward error correction may occur, including, but not limited to low density parity check (LDPC) coding, such as for example with a 10 GBASE-T system, or any other type of forward error correction method including a concatenation of Reed-Solomon (RS) coding with trellis coded modulation (TCM).
  • In other embodiments the following types of error correction encoding may be performed: trellis coding, convolutional coding, block coding, product coding or any other type of coding.
  • The output(s) of the FEC unit connect to a mapper 321. It is contemplated that any number of mappers 321 may be provided, up through N where N is any positive integer value. The mapper 321 is configured to transform or map the arriving data into one or more values, such as symbols. In one embodiment the mapping comprises pulse amplitude modulation (PAM). PAM-type mapping assigns incoming groups of bits to a symbol value. In PAM mapping, a symbol comprises a value that represents one or more bits that are transmitted during a transmit opportunity in place of the one or more bits. Mapping of this nature is known by one of ordinary skill in the art and accordingly is not discussed in detail herein. In one embodiment the mapper 321 performs four-dimensional mapping. As a result, in such an embodiment each mapper 321 outputs four symbols during each clock cycle.
  • The output of the mapper 321 connects to precoding modules 324A-324N. Although in one embodiment the mapper 321 includes four outputs, each of which feed into a precode module 324, it is contemplated that the precoding operations may be distributed among any number of precode modules, up to N modules, where N is a positive whole number. Precoding may comprise any type signal processing that may occur in the transmitter to counter the effects of the channel. In one embodiment the precoding comprises processing by a finite impulse response filter.
  • The output of the precoders 324A-324N connect to one or more transmit processing systems 332A-332N. Any number of transmit processing systems 332A-332N may be utilized where N is any positive whole number. Transmit processing comprises processing to facilitate transmission of the signal over one or more channels. The transmit processing systems 332A-332N may comprise line interfaces, amplifiers, transformers, filtering, shaping filters, hybrids, digital to analog converters, and the like as may be desired to facilitate transmission of a signal or data to a remote location.
  • As an advantage to the configuration shown in FIG. 1C, the combined effects of forward error correction, encoding, mapping and preceding are combined to reduce error rates while maximizing transmit rates. In addition, the transmit system of FIG. 1C may include constellation shaping within the mapper 321.
  • FIG. 1D illustrates a block diagram of an example embodiment of a receiver system for use with a transmitter, such as the transmitter shown in FIG. 1C. This is but one example embodiment of a receiver. It is contemplated that one of ordinary skill in the art may design other configurations that differ from the exact configuration shown in FIG. 1D, but are within the scope of the invention and claims that follow. As shown, inputs I1-IN receive signals from one or more channels 384. Any number of N inputs may exist where N equals any positive whole number. The inputs 384 connect to line interfaces 388A-388N, where N equals any positive whole number. The line interfaces 388A-388N may comprise any configuration of hardware, software or both configured to receive a signal over one or more channels and process the signal to prepare the signal for subsequent processing. In one embodiment a line interface 388 may comprise amplifiers, filters, and hybrids.
  • The output of the line interfaces 388 connect to an equalizer module 390. The equalizer module 390 comprises hardware, software, or both configured to perform equalization on the received signal. In one configuration the equalization occurs to reduce intersymbol interference. In one configuration the equalizer module comprises a feedforward filter and decision feedback equalizer. Co-pending patent application, entitled Method and Apparatus for Channel Equalization, by inventor William Jones, which was filed on Jul. 1, 2002, and issued as U.S. Pat. No. 6,961,373 is incorporated in its entirety herein and describes an equalization system as is compatible for use with one or more embodiments of the invention. It is contemplated that any equalizer system or other apparatus configured to generate an accurate decision of the transmitted signal may be utilized. It is contemplated that the equalization module 390 may include a slicer or other decision device and be located or distributed at any point in the receiver.
  • The output of the equalizer 390 feeds into an error correction decoder 393. As discussed above, the decoder 393 reverses the error correction coding. In the module decoder 393 there may exist several decoder sub-modules configured in association. This provides the advantage of distributing the processing burden of the error correction decoding across numerous subsystems. As a result, high-speed channel throughput may be achieved in a realizable architecture. The receiver may be configured with M number of decoders 393 where M is any positive whole number.
  • It is contemplated that the error correction decoding is matched to that utilized in an associated transmitter. In one embodiment the decoders may be configured to perform continuous trellis decoding. This is in contrast to packet based trellis coding/decoding. As a result, the benefits of continuous trellis decoding are gained. These benefits include but are not limited to a reduction in the total number of symbols that must be sent to fully error correction decode the received signal. In contrast to packet based decoding which requires that additional symbols be sent to terminate the trellis, the continuous trellis decoder embodiment operates on a continuous stream of trellis encoded data and control symbols and does not require that the trellis be terminated at the end of each packet. In other embodiments trellis coding/decoding may be omitted.
  • The decoder 393 outputs the error corrected signal or data to a demapping system which is configured to reverse the effects of mapping that occurred during the transmit processing. The output of the demapping module 393 connects to an optional CRC check unit 396 which performs as understood in the art. The output of the optional CRC check unit connects to a descrambler 398 to reverse the effects of the scrambler, if utilized and located in the transmitter.
  • FIG. 1E is a block diagram showing an example of a 10 Gb/s Ethernet interface 10 including the physical coding sublayer module (PCS) 30 that includes the encoder 100 according to the invention. The interface 10 is composed of the medium access controller (MAC) 12, the XGMII Extender Sublayer module (XGXS) 14 and the Physical Coding Sublayer (PCS) 30. The MAC sends data including user data received from the host system (not shown) to the XGXS via the 37-conductor XGMII bus 16. The MAC additionally receives data that include user data from the XGXS 14 via the 37-conductor XGMII bus 17 for supply to the host system.
  • The XGXS 14 sends a coded serial bitstream, to be described below, to the PCS 30 via the 4-lane XAUI bus 18 and receives a coded serial bitstream from the PCS via the 4-lane XAUI bus 19.
  • The physical coding sublayer module (PCS) 30 includes the transmission path 20 and the reception path 22. The transmission path 20 is composed of a serial arrangement of the 4×8b/10b decoder 32, the encoder 100 according to the invention, additional processing and the multiplexer 34. The input of the 4×8b/10b decoder is connected to one output of the XGXS 14 by the XAUI bus 18. The output of the 4×8b/10b decoder is connected to the input of the encoder by the 37-conductor pseudo-XGMII bus 42.
  • The output of the encoder 100 is connected to one or more additional processing elements 35A by the bus 44. In one embodiment, the bus 44 is 65 conductors wide, but the encoder and the multiplexer may be configured to use a bus that is substantially narrower than this. The output of the multiplexer is a serial bitstream that is fed to the Ethernet medium 40A or to other processing elements. For example, the output of the multiplexer 34 may be provided as an input to the scrambler 310 shown in FIG. 1C.
  • The reception path 22 is composed of a serial arrangement of the demultiplexer 36, the decoder 120 and the 4×8b/10b encoder 38. The demultiplexer receives a serial bitstream from the Ethernet medium 40B. The input of the demultiplexer may be provided from the output of the descrambler 398 shown in FIG. 1D when used with a multi-conductor channel.
  • The output of the demultiplexer 36 is connected to the input of the decoder 120 by the bus 45. In one embodiment, the bus 45 is 65 conductors wide, but the demultiplexer and the decoder may be configured to use a bus substantially narrower than this. The output of the decoder is connected to the input of the 4.times.8b/10b encoder by the 37-conductor pseudo-XGMII bus 43. The output of the 4×8b/10b encoder is connected to one input of the XGXS 14 by the XAUI bus 19. An optional processing element 35B may be included in the path as shown, and may comprise any type of processing. Element 35B may be omitted in certain embodiments.
  • In the Ethernet interface 10, the MAC 12 receives user data from, and provides user data to, a host system (not shown). The MAC takes any number of words of user data between 64 and 1500, adds 22 words of address and other data to the front of the user data and four words of a CRC-32 checksum to the end of the user data to form a packet. In this disclosure, the contents of a packet will be called information words.
  • The MAC additionally generates a Start of Packet (SOP) control word S that it adds to the start of each packet to mark the start of the packet. The MAC additionally generates an End of Packet (EOP) control word T that it adds to the end of each packet to mark the end of the packet. The MAC also generates additional control words and inserts them between consecutive packets to generate a continuous stream of words for transmission to the XGXS 14. The continuous stream is required to maintain receiver phase alignment. The additional control words include Idle I,Comma K, Skip R, Align A and Error E. This disclosure uses the letter Z as a generic term to indicate any one of the control words.
  • The MAC 12 feeds the continuous stream of words to the XGXS 14 via the XGMII bus 16. Of the 37 conductors in each of the XGMII buses 16 and 17, 32 are allocated to four, parallel, eight-bit words; four are allocated to control word flags, each of which indicates whether a respective one of the four words is an information word or a control word; and one is allocated to a clock signal. A set of four eight-bit words transported in parallel by the XGMII busses 16 and 17 and by the pseudo-XGMII busses 42 and 43 will be referred to as a quad.
  • In addition, the MAC 12 receives from the XGXS 14 via the XGMII bus 17 a continuous stream of quads. The quads are composed of information words arranged in packets and code words interspersed between consecutive packets, as just described. The start and end of each packet are marked with an SOP and an EOP control word, respectively. The MAC extracts the packet of information words from the stream of quads received from the XGXS using the control word flags received in parallel with the quads to indicate the information words. The MAC also checks the validity of each packet using the CRC-32 checksum that constitutes the last four words of the packet. The MAC then extracts the user data from the packet, and forwards the user data to the host system (not shown).
  • The XGXS 14 receives the continuous stream of quads from the MAC 12. The MAC and the XGXS are elements of conventional Ethernet system. Consequently, the XGXS module applies 8b/10b line code to each word in the quads received from the MAC. Each word is coded in response to its respective control word flag so that information words and control words having the same eight-bit code are represented by different ten-bit codes. The XGXS also serializes the 10-bit line code words and feeds them to the input of the PCS 30 via the XAUI bus 18. The XAUI bus is standardized for 10 Gb/s Ethernet and is composed of four parallel conductors, called lanes, each of which carries serial 10-bit line code words at a bit rate of 3.125 Gb/s. Thus, the four conductors constituting the XAUI bus collectively transfer the serial 10-bit line code words to the PCS 30 at an effective bit rate of 12.5 Gb/s.
  • The XAUI busses 18 and 19 use four parallel conductors to achieve a total bit rate of 12.5 Gb/s.
  • The XGXS 14 also receives four serial bitstreams from the PCS 30 via the XAUI bus 19. The XGXS parallelizes the bitstreams, decodes the 8b/10b coding of the 10-bit line code words constituting the bitstream, and feeds the resulting continuous stream of quads composed of information words and control words to the MAC 12 via the XGMII bus 17. The XGXS additionally feeds a control word flag for each of the words constituting the quads to the MAC via the XGMII bus.
  • In the transmission path 20 of the PCS 30, the 4.times.8b/10b decoder 32 is connected to the XAUI bus 18 to receive incoming serial 10-bit line code words at a bit rate of 4.times.3.125 Gb/s. The 4.times.8b/10b decoder decodes the 8b/10b coding of the 10-bit line code words to recover respective 8-bit words, and generates, for each word, a word type bit that indicates whether the word is an information word or a control word. The 4.times.8b/10b decoder feeds quads of the 8-bit words and their respective control word flags to the encoder 100 via the pseudo-XGMII bus 42. The pseudo-XGMII bus has the same structure as the XGMII bus 16, but is called pseudo-XGMII in this disclosure to indicate that this bus does not form part of the 10 Gb/s Ethernet standard. The pseudo-XGMII bus is composed of 37 conductors. Thirty-two of the conductors are allocated to the quads, four of the conductors are allocated to the control word flags for the quads, and one conductor is allocated to a clock signal.
  • It might appear that a substantial simplification could be achieve by omitting the XGXS 14, the XAUI busses 18 and 19, the 4.times.8b/10b decoder 32 the 4×8b/10b encoder 38 and the pseudo-XGMII busses 42 and 42, and simply connecting the encoder 100 and the decoder 120 to the MAC 12 via the XGMII busses 16 and 17. However, the maximum transmission distance of current embodiments of the XGMII bus is of the order of 100 mm, whereas that of the XAUI bus is of the order of 1 m. Thus, the above-described simplification can be made if the length of the XGMII bus is less than the maximum transmission distance of such bus.
  • The encoder 100 receives the quads from the pseudo-XGMII bus 42 as input data, encodes consecutive pairs of the quads to generate respective 65-bit packets, as will be described in more detail below, and feeds the packets to one or more additional processing elements 35A as shown herein and which are shown generally as additional processing elements 35A. The additional processing elements may comprise, but are not limited to any type additional processing. Alternatively, this processing element 35A may be left out of the system if no such additional processing is desired.
  • The output of the additional processing elements 35A feeds into the multiplexer 34 via the bus 44A. The multiplexer 34 receives the 65-bit packets, serializes them and transmits them to the Ethernet medium 40A at a bit rate of 10 Gb/s. The output of the multiplexer 34 may feed as the input 300 into the scrambler 310 for transmission over a multi-conductor channel. In the reception path 22 of the PCS 30, the demultiplexer separates the serial data received at a bit rate of 10 Gb/s from the Ethernet medium 40B into 65-bit packets, and feeds through additional and optional processing elements 35B and then to the decoder 120 via the bus 45. The decoder decodes the 65-bit packets to generate two consecutive quads of eight-bit words and a control word flag for each word. The decoder transfers the quads and their respective control word flags in parallel to the 4×8b/10b encoder 38 via the pseudo-XGMII bus 43.
  • The 4×8b/10b encoder 38 applies 8b/10b encoding to the quads received via the pseudo-XGMII bus 43, operating in response to the control word flag for each word constituting the quads. The 4.times.8b/10b encoder transfers the resulting 10-bit line code words via the XAUI bus 19 to the XGXS module 14 at a bit rate of 12.5 Gb/s. The 10-bit line code words are processed by the XGXS and the MAC 12 to provide the received user data to the host system (not shown), as described above.
  • It should be noted that the XGXS 14 and corresponding 8b10b encoder 38, and decoder 32 may be optional and hence, embodiment may be enabled without these elements. In such an embodiment the XGMII interface 16 and 17 can be connected directly to the 64b/65b encoder 100 and decoder 120. Or, in one embodiment the XGMII interface may be configured to extend over long PCB distances by using the XGMII Extender sublayer as shown.
  • The 64b/65b coding applied by the encoder 100 according to the invention will now be described with reference to FIGS. 2, 3A-3D and 4A-4C.
  • FIG. 2 schematically shows exemplary quads of the input data received by the encoder 100 via the four lanes of the pseudo-XGMII bus 42. The input data include the exemplary packet 130 composed of information words D. To simplify the drawing, the number of information words in the packet 130 is substantially fewer than the minimum number of information words in a standard Ethernet packet.
  • Prior to the start of the packet 130, the encoder 100 receives control words on all four input lanes of the pseudo-XGMII bus 42. The control words in the four lanes denote an interpacket gap. A set of alignment characters A that can be used to synchronize the lanes is also shown. The start of the packet 130 is indicated by the SOP control word S, shown at 131. The SOP control word always appears in lane 0 and never appears in any other lane. If the SOP control word appears in a lane other than lane 0, this indicates an error and the packet is filled with error codes E.
  • The information words D constituting the packet 130 are then consecutively received, followed by the EOP control word T, shown at 132. The EOP control word can appear in any of the lanes of the pseudo-XGMII bus 42. The lane in which the EOP control word appears depends on the number of information words in the packet. The packet can be composed of any number of information words between 64 and 1500. The minimum number of control words between consecutive packets is 12. Following the EOP control word 131, the encoder 100 receives control words that denote an interpacket gap via all four lanes of the pseudo-XGMII bus. The control words continue until the SOP control word (not shown) indicating the start of the next packet.
  • The encoder 100 according to the invention applies 64b/65b encoding to blocks composed of two quads of the input data consecutively received from the pseudo-XGMII bus 42, i.e., the 64b/65b coding is applied to a total of 64 received bits. Thus, the 64b/65b coding uses 65 bits to represent the 64 received bits. The 64b/65b coding adds a block header composed of one bits to the start of the block to form a frame. Use of a single bit for the block header has numerous advantages, which are discussed below in more detail. The block header serves both as a reference for frame synchronization and as a flag that indicates when the frame is composed exclusively of information words. The 64b/65b coding has a coding efficiency of 64/65, or an overhead of 1.5625%, which is an advtantage over prior art encoding schemes. Since each word received from the pseudo-XGMII bus 42 can be either a control word or an information word, as indicated by the word's respective control word flag, also received from the pseudo-XGMII bus, a fully-general code would need to transmit the control word flag for each word to tell the receiver what type of word is being received. The maximum efficiency of such a code would be 8/9, or a 12.5% overhead. The 64b/65b coding achieves a substantially lower overhead than this by taking advantage of features of the XAUI interface and the Ethernet packet structure that reduce the number of possible ways in which information words and control words can be arranged in the input data.
  • First, each packet of information words received by the encoder 100 is composed of at least 64 words, always starts with the SOP control word S and always ends with the EOP control word T, and consecutive packets are separated by at least 12 control words. This means that when blocks of eight words (64 bits) of the input data are coded, each block can contain information words exclusively, control words exclusively, a single transition from control words to information words or a single transition from information words to control words. As noted above, the block header that constitutes the first bit of the frame operates as a flag to indicate when the frame is composed exclusively of information words. This means that, instead of including eight control word flags in each frame to indicate whether the eight words constituting the frame are each an information word or a control word, this number of bits can be used to represent a TYPE word that is included in all frames that are not composed exclusively of information words. Different values of the TYPE word indicate one of the following structural properties of the block: 1) whether the block from which the frame is derived is composed exclusively of control words, 2) the position of the start of a packet in the block from which the frame was derived and 3) the position of the end of a packet in the block from which the frame was derived. Since the number of states represented by the eight-bit TYPE word is relatively small, TYPE words having a large mutual Hamming distance can be chosen. For example, the TYPE words can be chosen so that more than three bit errors are required to convert one TYPE word to another.
  • Second, as noted above, XAUI semantics guarantee that the SOP control word S appears in lane 0 exclusively. This reduces the number of ways in which the packet start can appear in the frame to two, which further reduces the total number of ways in which the start of the packet or the end of the packet can appear in the frame.
  • Third, the set of control words is sufficiently small (I, K, R, S, T, A, E, . . . ) to allow the control words to be coded using fewer than eight bits, and to be coded by a set of codes having a large mutual Hamming distance. The bits saved by coding the control words using fewer than eight bits can then be used to condense the block to enable the frame to accommodate the above-described TYPE word. The codes are chosen to enable the control word coding to be highly resistant to bit errors.
  • FIGS. 3A-3D show the twelve possible types of blocks that the encoder 100 can receive from the pseudo-XGMII bus 42. FIG. 3A shows a block generated from two consecutive quads located in the middle of the packet, where both quads consist exclusively of information words. The block composed of two consecutive quads of exclusively information words is called a Type 1 block.
  • FIGS. 3B shows the one block Type that includes two consecutive quads located in the middle of the gap between two consecutive packets, where both quads consist exclusively of control words. The block composed of two consecutive quads of exclusively information words is called a Type 2 block.
  • FIG. 3C shows the two different block Types in which the start of the packet appears. The start of the packet is indicated by SOP control word S. Because the SOP control word can only appear in lane 0 of the pseudo-XGMII bus, the SOP control word can appear in only two possible locations in the block. The block in which the SOP control word appears in the even-numbered quad is called a Type 3 block, and that in which the SOP control word appears in the odd-numbered quad is called a Type 4 block.
  • FIG. 3D shows the eight different block Types in which the end of the packet appears. The end of the packet is indicated by the EOP control word T. Because the EOP control word can appear in any one of the four lanes of the pseudo-XGMII bus, the EOP control word can appear in any location in the block. The blocks in which the EOP control word appears as word 1 through 8 of the block (see FIG. 7A) are called Type 5 through Type 12 blocks, respectively.
  • The 12 different types of blocks are indicated by a code that uses a combination of the 1 bit block header and the TYPE word. The 12 types of blocks are divided into two different categories, namely, blocks composed exclusively of information words, i.e., the Type 1 block shown in FIG. 3A, and blocks that include at least one control word, i.e., the Type 2-12 blocks shown in FIGS. 3B-3D.
  • As described herein and in U.S. Pat. No. 6,718,491, and adopted in the IEEE 802.3 (Ethernet) Standard Clause 49, the 10GBASE-R physical layer device utilizes a coding technique to reduce the control bit overhead from 12.5% down to 3.125%, a 4× reduction. This 64B/66B code is essentially a simple compression algorithm using a lookup table based on the contents of the current 8 bytes plus the associated 8 control bits. In this manner 72 bits (64 data bits+8 control bits) are mapped into a 66-bit code word. This code word is then transmitted serial through a fiber optic system to a remote unit that will decode the 66-bit code word back into the original 72 bits using the reverse lookup table. In this way the additional overhead required by the control bits increases the serial bit stream through the fiber optic system to be 10.3125 Gigabit per second. U.S. Pat. Nos. 6,718,491 and 6,650,638 are hereby incorporated herein, in their entirety, by reference.
  • In one example embodiment 64B/66B encoding is used in a 4 pair UTP transmission system. The use of the 64B/66B encoding reduces the needed bit rate of the proposed system from 11.25 Gbit/sec to 10.3125 Gbit/sec. Following the 64B/66B encoder, an additional Forward Error Correction (FEC) code may optionally be used that adds additional overhead.
  • In a multi-gigabit transmission system for 4-pair UTP, it may be advantageous to use a more powerful FEC than a TCM solution. Examples of such an FEC include Turbo-Coding, Low-Density Parity Check (LDPC) coding and the concatenation of two or more codes such as TCM and Reed-Solomon codes. In a system such as this it may not be possible or desirable to use extra constellation points to transmit control symbols.
  • Therefore it may be desirable to reduce the overhead used to transmit Ethernet control bits to the minimum required to accurately reproduce the bit stream at the remote end.
  • The 64B/66B encoder described in IEEE 802.3 (Ethernet) Standard Clause 49 is intended for a 10.3 Gbit/sec serial bit stream in fiber optic transmission system. This system does not employ a FEC and as such requires a robust mechanism to distinguish between a 66B code block containing control words and a code block that does not. This was accomplished by using a 2-bit sync header prepended to the 64-bit payload. The header takes only 2 possible values: 01 for a data only payload, and 10 for a payload containing control symbols.
  • This invention proposes to use the 64B/66B encoder as described herein. In one example embodiment, a multi-gigabit 4 pair UTP transceiver is configured with a single bit header. With a one bit header, for example the value ‘01’ is replaced by ‘0’ and ‘10’ is replaced by ‘1’. The effective encoder rate is 65/64 rather than 66/64 with a one bit header. The IEEE 802.3 (Ethernet) Standard Clause 49 is hereby incorporated by reference.
  • The system described in U.S. Pat. No. 6,718,491 utilizes a two bit header and a two bit header is necessary for operation of such a system because first it maintains a balance of 1's and 0's necessary for a balanced line code in a bit serial transmission system, second it guarantees a transition of 1 to 0 or from 0 to 1 for the purposes of clock recovery and third it provides redundancy such that more than one bit of the block header must be in error to incorrectly decode the block. Use of the one bit header, as described herein, would not operate in a desirable manner because a single bit error can result in the improper decoding of a block.
  • In a system using powerful FEC, there is little or no advantage to using a 2-bit header instead of a 1-bit header. The header was designed to provide protection from low-probability independent errors. In the case where a powerful FEC is used, a single error event will corrupt a large block of data bits. Therefore the extra bit is just as likely to be in error and provides no protection. The two bit header however, undesirably increases the number of bits which must be processed and transmitted thereby increasing overhead. This can lead to a increased bit error rate or may result in a lower effective data rate. For example, in the embodiment described herein the required overhead can be reduced from 3.125% to 1.5625% if only 1-bit is used in the sync header. A scrambler placed after the encoder sufficiently balances the line code and provides for data transitions for clock recovery.
  • One benefit of this invention is that the reduction in overhead makes it possible, in one embodiment, to concatenate the 64B/65B code, a Reed-Solomon (255,239) code and a TCM code using 1-bit of parity per symbol using 12PAM modulation at a baud rate of around 833 Mbaud/sec. For example the original 11.25 Gbit/sec bit stream is encoded using 64B/66B into a 10.3125 Gbit/sec bit stream. After dropping a sync bit the bit stream is 10.15625 Gbit/sec. After RS encoding, the bit stream is 10.8362 Gbit/sec. Grouping the bits into 13-bit symbols yields an 833.55 Mbaud/sec rate. A TCM code adds a single bit per baud for 14-bits per symbol at 833.55 Mbaud/sec. The 14-bit symbol is mapped into 2ˆ14=16,384 constellation points of a 4D-12PAM constellation containing 12ˆ4=20,736 points. The unused constellation points may be chosen such that the constellation has a lower transmit power with an associated shaping gain.
  • FIG. 4A shows the basic structure of the frame 150 that the encoder 100 generates from a block of input data. The frame is composed of a one bit sync. field 151 followed by the 64-bit payload field 152. The sync. field accommodates the one bit block header.
  • The encoder 100 generates two different kinds of frame having the basic structure shown in FIG. 4A, but differing in the structure of their payload fields. The structure of the payload field depends on whether or not the block from which the frame is generated is a Type 1 block composed exclusively of information words. The structure of the payload field is indicated by the 1 bit block header stored in the sync. field.
  • FIG. 4B shows the structure of the frame 153 generated when the block is a Type 1 block. In this, the 1 bit block header in the sync field 151 is ‘1’, and the payload field 152 is composed of the eight information words constituting the block, i.e., 64 bits.
  • FIG. 4C shows the structure of the frame 156 generated when the block is a Type 2 through Type 12 block that includes at least one control word. In this, the one bit block header in the sync. field 151 is ‘0’, and the payload field 152 is composed of the 8-bit sub-field 157 and the 56-bit sub-field 158. The eight-bit sub-field 157 is occupied by the TYPE word and the 56-bit sub-field 158 is occupied by a condensed version of the block. In particular, all information words included in the block are included unchanged in the sub-field 158. The 56-bit sub-field 158 can accommodate up to seven information words, the maximum number of information words in a block that includes at least one control word. Moreover, the control words S and T, if they appear in the block, are discarded and are not transferred to the sub-field 158. Finally, all remaining control words in the block are re-coded using fewer than eight bits and the re-coded control words are included in the sub-field 158. In the preferred embodiment, the remaining control words are re-coded using seven-bit codes chosen to have a mutual Hamming distance of four bits.
  • The control words S and T can be omitted from the sub-field 158 because position of the start of the packet or the end of the packet in the frame is indicated by the TYPE word included in the sub-field 157. Omitting the control words S and T allows the payload field 158 to accommodate the TYPE word and all seven information words in full when the block is composed of seven information words and either the SOP control word S or the EOP control word T, as in the Type 3 block shown in FIG. 3C and the Type 12 block shown in FIG. 3D. Re-coding the remaining control words as 7-bit words enables the payload field 158 to accommodate the TYPE word and all eight control words when the block is composed exclusively of control words, as in the Type 2 block shown in FIG. 3B. All other combinations of information words and control words are composed of fewer than 56 bits after the S and T control words have been removed and the remaining control words have been re-coded using fewer bits.
  • FIG. 5 is a flow chart showing a first embodiment 200 of a method according to the invention for applying 64b/65b coding to input data that include a packet of information data. The processing performed in process 205 of the method will be described in more detail below with reference to FIG. 6.
  • The method starts at process 202. In process 203, blocks of the input data are received. The input data include the above-mentioned control words in addition to the packet of information words. The control words precede and follow the packet of information words. The blocks are smaller than the packet. In the preferred embodiment, each block is composed of two successive quads of four parallel words received from the pseudo-XGMII bus 42.
  • In process 204, a test is performed on a block of the input data to determine whether the block is composed exclusively of information words. In the preferred embodiment, this test can be performed simply by examining the control word flags for the eight words that constitute the block. The control word flags are received together with the words that constitute the block via the pseudo-XGMII bus 42.
  • When the test result is NO, execution advances to process 205, which will be described below. When the test result is YES, execution advances to process 207 wherein a frame is formed by preceding the block with a one bit block header in the first sense. In the preferred embodiment, the one bit block header in the first sense is provided by the bit ‘1’.
  • Execution then advances to process 208, where the frame is transmitted, and to process 209, where a test is performed to determine whether all the blocks of the input data have been processed. When the test result is YES, execution advance to process 210, where it ends. When the test result is NO, execution returns to process 204 via process 211 so that the next block can be processed.
  • When the test result in process 204 is NO, this indicates that the block includes at least one control word. Execution advances to process 205, where a TYPE word that identifies the structural properties of the block is generated, the block is condensed and the TYPE word is inserted into the block. The TYPE word indicates one of the following structural properties of the block: 1) whether the block is composed exclusively of control words, 2) the position in the block of the start of the frame and 3) the position of the end of the frame the block. Block Types are described in detail above with reference to FIGS. 3A-3D. The processing performed in process 205 will be described in more detail below with reference to FIGS. 6.
  • Execution then advances to process 213, where a frame is formed by preceding the block with a one bit block header in a second sense, opposite to the first sense. In the preferred embodiment, the block header in the second sense is provided by the one bit ‘0’.
  • Execution then advances to process 208, where the frame is transmitted, as described above.
  • FIG. 6 shows an example of the processing performed in process 205. In this process, the block is condensed and a TYPE word indicating the structural properties of the block is inserted into the block. The structure includes the position of the start or the end of the packet in the block, and whether the block is composed exclusively of control words.
  • Execution starts in process 220. In process 221, a test is performed to determine whether the block includes the SOP control word S that indicates that the packet starts in the block. When the test result is NO, execution advances to process 222, which will be described below. When the test result is YES, execution advances to process 223, where a test is performed to determine whether the SOP control word appears in the first quad constituting the block. Each block processed by the encoder 100 is composed of two consecutively-received quads.
  • When the test result generated by process 223 is NO, execution advances to process 224, where a TYPE word indicating that the block is a Type 4 block is generated. A Type 4 block is one in which the SOP control word appears in the second quad. Block types are described in detail above with reference to FIGS. 3A-3D. Execution then advances to process 226, which will be described below. When the test result generated in process 223 is YES, execution advances to process 225, where a TYPE word indicating that the block is a Type 3 block is generated. A Type 3 block is one in which the SOP control word appears in the first quad.
  • Execution advances from process 224 or process 225 to process 226, where the block is condensed by removing the SOP control word from the block. Condensing the block creates space in the block for the TYPE word generated in process 224 or process 225 to be inserted into the block in process 228, to be described below.
  • Execution then advances to process 227, where the block is condensed by re-coding any control words in the block using fewer bits. If either process 226 or process 233 has previously been executed, the effect of executing process 227 is to compress the block further. Process 233 will be described below. The purpose of condensing the block is described above. In the preferred embodiment, the 8-bit control words are re-coded using fewer bits. The set of control words is sufficiently small to allow the control words to be coded using 7-bit codes chosen to have a mutual Hamming distance of four bits. The re-coding process can refer to the TYPE word for the block to find the locations of the control words in the block.
  • Execution then advances to process 228, where the TYPE word is inserted at the head of the block. Space to accommodate the TYPE word has been created in the block by executing one or more of processes 226, 227 and 233. Process 233 is described below. Execution then advances to process 229, whence it returns to the main routine.
  • When the test result in process 221 is NO, execution advances to process 222, where a test is performed to determine whether the block includes the EOP control word T that indicates that the end of the packet appears in the block. When the test result is NO, execution advances to process 230, which will be described below. When the test result is YES, execution advances to process 231, where the position of the EOP control word in the block is determined. As shown in FIG. 3D, any of the eight words in the block can be the EOP control word.
  • Execution then advances to process 232, where a TYPE word is generated in accordance with the position of the EOP control word in the block. The TYPE word indicates that the block is one of a Type 5 through Type 12 block. Type 5 through Type 12 blocks are blocks in which the EOP control word appears in one of the eight word positions in the block, as described above with reference to FIG. 3D.
  • Execution then advances to process 233, where the block is condensed by removing the EOP control word from the block. The purpose of condensing the block is described above.
  • Execution then advances to process 227, where the block is further condensed by re-coding any control words remaining in the block are re-coded using fewer bits, as described above.
  • A test result of NO in process 222 indicates that the block is composed exclusively of control words. In this case, execution advances to process 230 where a TYPE word indicating that the block is a Type 2 block is generated. A Type 2 block is a block composed exclusively of control words.
  • Execution then advances to process 227, where the block is condensed by re-coding the control words included in the block using fewer bits, as described above. In this case, all eight words in the block are control words and are re-coded.
  • Note that in the above processing, such information words as are included in the block remain unchanged.
  • FIGS. 7A-7L show specific examples of the frames generated from each of the twelve block types shown in FIGS. 3A-3D, including the block header and the TYPE word, where used. FIG. 7A shows the frame 153 generated from the Type 1 block shown in FIG. 3A. This block is composed exclusively of information words. In the frame 153, the sync field 151 is filled with the one bit block header ‘1’ and the payload field 152 is filled with the eight information words located in the eight positions 0 through 7 in the block 160, as shown. Each of the information words in the payload field is labeled with the letter D, a number and the numeral 8. The letter D indicates an information word, the number indicates the location of the information word in the block 162 and the numeral 8 indicates that the information word is composed of eight bits.
  • FIG. 7B shows a frame generated from the Type 2 block shown in FIG. 3B. FIGS. 7C and 7D respectively show frames generated from the Type 3 and Type 4 blocks shown in FIG. 3C. FIGS. 7E-7L respectively show frames generated from the Type 5 through 12 blocks shown in FIG. 3D. As an example, FIG. 7D shows the frame 156 generated from the Type 4 block shown in FIG. 3C. The Type 4 block is composed partly of control words, i.e., the SOP control word S and the unspecified control words Z, and partly of information words D. In the frame 156, the sync. field 151 is occupied by the one bit block header ‘0’ and, in the payload field 152, the sub-field 157 is occupied by the 8-bit TYPE word, in this example, the hexadecimal number 33.sub.H. The TYPE word indicates that the frame is generated from a Type 4 block in which the start of a packet appears in the odd-numbered quad constituting the block. The sub-field 158 of the payload field is occupied by three coded control words Z and three eight-bit information words D.
  • Each of the data elements in the sub-field 158 is labeled with the letter D or Z, a number and the numeral 7 or 8. The letter D indicates an information word, the letter Z indicates a control word, the number indicates the location of the information word or control word in the block using the convention described above with reference to FIG. 7A, the numeral 7 or 8 indicates the number of bits in the data element, i.e., seven bits for each coded control word and eight bits for each information word. As noted above, the SOP control word S is discarded and is not transferred to the sub-field 158. The function of the SOP control word indicating that the packet starts at position 4 of the block is provided by the TYPE code 33.sub.H instead.
  • The three coded control words Z coded as 7-bit words and three eight-bit information words D do not fully occupy the sub-field 158 of the frame 156. The unoccupied region 164 of the sub-field is filled with suitable idle bits. Alternatively, functions can be assigned to the bits used to fill the unoccupied portions of the sub-field 158.
  • The TYPE words illustrated in FIGS. 7B-7L are chosen to have a mutual Hamming distance of four bits to ensure that the start and the end of the packet are reliably identified. The TYPE words are additionally chosen to be easy to generate and to test. The set of chosen TYPE words is an eleven-element sub-set of a 16-element set generated as follows: the first four bits of each successive element in the set increments from 0 to 15 in binary. The second four bits of each element provide the minimum Hamming distance protection and are either 1) a duplication of the first four bits when the parity of the first four bits is even, or 2) the complement of the first four bits when the parity of the first four bits is odd. The 16-element set is optimum in that it provides for a very simple implementation with low gate delay and latency.
  • It should be noted that the error correction decoder will correct bit errors prior to the decoder such that the decoder can reliably use the single bit header for deciding whether the block contains information or control words. Furthermore when the error correction decoder fails to correct the bit errors, the error correction decoder and/or the CRC check may flag the affected blocks such that they will replaced by error symbols (E) such that they will not be incorrectly decoded.
  • FIG. 8 is a block diagram showing a first embodiment of the encoder 100 according to the invention. The encoder is composed of the type word generator 181, the payload field generator 182, one bit the block header generator 184 and the frame assembler 185.
  • In the encoder 100, the type word generator 181 and the payload field generator 182 are connected to receive blocks of input data from the 4.times.8b/10b decoder 32 via the pseudo-XGMII bus 42 (FIG. 1E). The input data are composed of control words and a packet of information words. The packet is preceded and followed by the control words. In the preferred embodiment, the blocks are eight words, i.e., 64 bits, long and are smaller than the smallest size of the packet. The blocks are also smaller than the number of control words between consecutive packets. The encoder processes the input data block-by-block to generate respective frames for transmission.
  • The type word generator 181 generates a TYPE word whose value indicates one of the following mutually-exclusive structural properties of the block: 1) whether the block is composed exclusively of control words, 2) a position of the start of the packet in the block and 3) a position of the end of the packet in the block and 4) whether the block is composed exclusively of information words. The type word generator feeds the TYPE word to the payload field generator 182 and the one bit block header generator 184. The value of the TYPE word that indicates whether the block is composed exclusively of information words may take the form of a flag bit fed to the block header generator 184 and, optionally, to the payload field generator 182.
  • The payload field generator 182 operates in response to the TYPE word. When the TYPE word indicates that the block is composed exclusively of information words, the payload field generator adopts the block to form a payload field. Otherwise, when the TYPE word indicates that the block is not composed exclusively of information words, the payload field generator condenses the block and inserts the TYPE word into the block to form the payload field.
  • The payload field generator 182 condenses the block by performing one or both of the following operations: 1) removing any start-of-packet control word or an end-of-packet control word from the block, and 2) re-coding any other control words in the block using fewer bits. In the preferred embodiment, the control words are re-coded using seven-bit codes having a mutual Hamming distance of four bits. Whether the payload field generator simply adopts the block as the payload field, or processes the block further before forming the payload field may be determined by the above-mentioned flag bit in lieu of the full TYPE word. The TYPE word indicates the location in the block of the start-of-packet control word or the end-of-packet control word (if any) and the locations in the block of the other control words (if any).
  • The payload field generator 182 feeds the payload field PF generated from the block to the frame assembler 185.
  • The one bit block header generator 184 operates in response to the TYPE word, or, alternatively, to the flag bit described above, and generates the one bit block header. The one bit block header generator generates the block header in a first sense when the TYPE word, or flag bit, indicates that the block is composed exclusively of information words. Otherwise, when the TYPE word, or flag bit, indicates that the block is not composed exclusively of information words, the block header generator generates the block header in a second sense, opposite to the first sense. In the preferred embodiment, the one bit block header in the first sense is ‘1’, and the one bit block header in the second sense is ‘0’. Transitions opposite to those shown could alternatively be used. The one bit block header generator 184 feeds the block header BH to the frame assembler 185.
  • The frame assembler 185 receives the payload field from the payload field generator 182 and the one bit block header from the one bit block header generator 184 and appends the one bit block header to the payload field to form the frame for transmission. The frame assembler preferably locates the one bit block header before the payload field, but could alternatively locate the one bit block header after the payload field. The frame assembler feeds the 65-bit frame to one or more additional processing elements 35A via the bus 44 (FIG. 1E).
  • FIG. 9A is a flow chart showing an example 280 of a decoding method for decoding the frames generated by the coding method and coder according to the invention. The method starts in process 271. In process 272, a frame is received from the demultiplexer 36 via the bus 45. In process 274, a test is performed on the block header of the frame to determine whether the one bit block header is in the first state. The first state is ‘1’ in the preferred embodiment. When the test result is YES, which indicates that the payload field of the frame is composed exclusively of information words, execution advances to process 277, which will be described below. When the test result is NO, execution advances to process 275.
  • A NO result in process 274 indicates that the payload field of the frame is not composed exclusively of information words, and therefore includes a TYPE word. In process 275, the TYPE word is extracted from the payload field.
  • In process 286, the payload field of the frame is expanded using the information provided by the TYPE word regarding the structure of the payload field. Expanding the payload field reverses the condensing that was applied by the encoder to the block from which the frame was generated. Thus, when the payload field is expanded, the coded control words are re-coded to yield eight-bit control words. Additionally, when the start of the packet or the end of the packet appears in the payload field, a start-of-packet control word or an end-of-packet control word, respectively, is inserted into the payload field. As noted above, the TYPE word indicates what portion of the payload field is occupied by coded control words, and the location in the payload field of the start of the packet or the end of packet. The processing performed in process 276 will be described in more detail below with reference to FIG. 9B. Execution then advances to process 277. In process 277 the payload field is adopted as a block of received data.
  • In process 278, a test is performed to determine whether all frames have been processed. When the test result is YES, execution advances to process 279, where it ends. When the test result is NO, execution returns to process 272 via process 280 so that the next frame can be processed.
  • Process 276 of the method described above with reference to FIG. 9A will now be described with reference to FIG. 9B where execution starts at process 291.
  • In process 293, a test is performed to determine whether the TYPE word indicates that any coded control words appear in the payload field, i.e., whether the encoder 100 derived the payload field from a Type 2 block or a Type 4 through Type 11 block. When the test result is NO, execution advances to process 296, which will be described below. When the test result is YES, execution advances to process 294.
  • In process 294, the TYPE word is used to identify the portion of the payload field occupied by one or more coded control words, and the number of coded control words. It can be seen from FIGS. 7A-7L that the coded control words in the frame derived from each block Type differ in number but are always contiguous. However, in some frames, the coded control words abut the head of the payload field, whereas in others, the coded control words abut the end of the payload field. In process 295, the coded control words identified by process 294 are decoded to yield the original control words.
  • In process 296, a test is performed to determine whether the TYPE word indicates that a packet starts or ends in the payload field, i.e., whether the encoder 100 derived the payload field from a Type 3 through Type 12 block. When the test result is NO, this indicates that the payload field was derived from a Type 2 block. In this case, execution advances to process 299, which will be described below. When the test result is YES, execution advances to process 297.
  • In process 297, the position of the start of the packet or the end of the packet in the payload field is identified from the TYPE word. In process 298, an SOP control word S or an EOP control word T is inserted into the payload field. The control word inserted, i.e., whether the control word S or T is inserted, and the position in the payload field at which the SOP or EOP control word is inserted are defined by the TYPE word. Execution then advances to process 299.
  • In process 299, execution returns to the main routine. Either or both of the control word decoding performed in process 295 and the control word insertion performed in process 298 insert 8-bit control words into the payload field. This fills the space in the payload field formerly occupied by the TYPE word and, in some frames, fill bits.
  • FIG. 10 is a block diagram showing a first embodiment of the decoder 120. The decoder is composed of the frame decoder 191, the type word extractor 193, the block generator 194 and the block sequence detector 195.
  • The frame decoder 191 receives each 65-bit frame from the demultiplexer 36 via the 65-bit bus 45 (FIG. 1). The frame decoder reads the one bit block header at the front of the frame and feeds the one bit block header BH to the type word extractor 193. The frame decoder feeds the remaining 64 bits constituting the payload field PF of the frame to the type word extractor 193 and the block generator 194.
  • The type word extractor 193 receives the payload field PF and additionally receives the one bit block header BH from the frame decoder 191. The type word extractor operates only when the one bit block header is in its second state, corresponding to a frame whose payload field is not composed exclusively of information words. The type word extractor extracts the TYPE word from the sub-field 157 of the payload field 152 (FIG. 4C) and feeds the TYPE word to the block generator 194 and the block sequence detector 195.
  • The block generator 194 receives the payload field PF, the TYPE word from the type word extractor 193 and the one bit block header BH from the frame decoder 191. The block generator operates in response to the one bit block header. When the one bit block header is in the first state, the block generator adopts the payload field PF as a block of received data. When the block header is in the second state, the block generator expands the payload field using the information provided by the type word regarding the structure of the payload field. Expanding the payload field reverses the condensing that was applied by the encoder to the block from which the frame was generated. Thus, when the payload field is expanded, the coded control words are re-coded to yield eight-bit control words. Additionally, when the start of the packet or the end of the packet appears in the payload field, a start-of-packet control word or an end-of-packet control word, respectively, is inserted into the payload field. As noted above, the TYPE word indicates what portion of the payload field is occupied by coded control words, and the location in the payload field of the start of the packet or the end of packet. Finally, the block generator adopts the payload field after expansion as the block of received data.
  • The block generator 194 feeds the block of received data to the 4.times.8b/10b decoder 120 via the bus 43 (FIG. 1).
  • The decoder also includes the block sequence detector 195. The block sequence detector receives the TYPE word from the type word extractor 193 and the one bit block header BH from the frame decoder 191. The one bit block header of a frame and the TYPE word of the frame, when present, collectively define what kind of frame the frame is. As noted above, the frame can be one of four different kinds, namely, one composed exclusively information words D (generated from Type 1 block), one that includes the start of a packet S (generated from Type 3 or Type 4 block), one that includes the end of a packet T (generated from one of Type 5 through Type 12 block) and one composed exclusively control words Z (generated from Type 2 block). The encoder generates the four different kinds of frames in a predetermined order, namely: S, D, . . . , D, T, Z, . . . Z, S, D, . . . , D, T, Z, . . . , Z, etc. The frames must be received by the decoder 120 in the same predetermined order. The block sequence detector monitors the order of the kinds of frame received, and generates the error flag ERR when the TYPE word and the one bit block header indicate that the frame is of a kind that violates the predetermined order. The block generator 194 adds the error control word E to the block of received data generated from the frame in response to the error signal. The error control word causes the MAC 12 (FIG. 1) to void the packet of which the block forms part.
  • While various embodiments of the invention have been described, it will be apparent to those of ordinary skill in the art that many more embodiments and implementations are possible that are within the scope of this invention. In addition, the various features, elements, and embodiments described herein may be claimed or combined in any combination or arrangement.

Claims (18)

1. A 64B/65B coding method for coding a packet of information words into frames for transmission over 4 twisted pair conductor, the method comprising:
receiving blocks of input data, the input data including control words and the packet of information words, the packet having a start preceded by ones of the control words and an ending followed by others of the control words, the blocks being smaller than the packet;
determining when a block consists exclusively of information words and:
when the block consists exclusively of information words,
appending to the block a one bit block header having a first sense to form one of the frames;
when the block does not consist exclusively of information words:
condensing the block to accommodate a TYPE word; and
generating the TYPE word having a value that indicates one of the following structural properties of the block:
(a) a position of the start of the packer in the block,
(b) a position of the end of the packet in the block, and
(c) the block being composed exclusively of control words, and inserting a TYPE word into the block, and appending to the block a one bit block header having a second sense, opposite to the first sense, to form the one of the frames, wherein the method reduces overhead to less than 3%.
2. The method of claim 1, in which compressing the block includes re-coding ones of the control words using fewer bits.
3. The method of claim 1, in which the type word is selected from a set of type words having a specified mutual Hamming distance.
4. The method of claim 3, in which: the type words each consist of T bits; and the method additionally comprises generating the set of possible bit patterns by a process including: adopting a (T/2)-bit binary pattern as a first half of a bit pattern in the set of possible bit patterns, and generating a second half of the bit pattern by duplicating or complementing the first half of the bit pattern depending on a bit parity value of the first half of the bit pattern.
5. The method of claim 1, wherein a one bit block header in the first sense comprises a 1 and a one bit block header in the second sense comprises a 0 value.
6. The method of claim 5, wherein the method is performed in a conjunction with forward error correction.
7. The method of claim 1, in which condensing the block includes removing from the block a control word that indicates one of (a) the start of the packet and (b) the end of packet.
8. The method of claim 7, in which condensing the block includes re-coding remaining ones of the control words using fewer bits.
9. The method of claim 1, wherein the method is utilized in a 10 gigabit/second communication system.
10. A communication coder for 64B/65B type coding of blocks of input data into respective frames for transmission over twisted pair conductor, the input data including control words and a packet of information words, the packet having a start preceded by ones of the control words and an ending followed by others of the control words, the blocks being smaller than the packet, the frames including a frame corresponding to the block, the coder comprising:
a type word generator that receives the block and generates a TYPE word for a block, the TYPE word having a value that indicates one of the following structural properties of the block:
(a) whether the block is composed exclusively of control words,
(b) a position of the start of the packet in the block,
(c) a position of the end of the packet in the block, and
(d) whether the block is composed exclusively of control words;
a one bit block header generator that operates in response to the TYPE word and generates a one bit block header in a first sense when the TYPE word indicates that the block is composed exclusively of information words, and otherwise generates the one bit block header in a second sense, opposite to the first sense, wherein use of a one bit block header reduces overhead to less than 3%;
a payload field generator that operates in response to the TYPE word and that adopts the block to form a payload field of the frame when the TYPE word indicates that the block is composed exclusively of information words, and that otherwise condenses the block and inserts the TYPE word into the block to form the payload field; and
a frame assembler that appends the block header to the payload field to form the frame.
11. The coder of claim 10, in which the payload field generator includes a re-coder that condenses the block by re-coding remaining ones of the control words using fewer bits.
12. The coder of claim 10, in which the type word is selected from a set of type words having a specified mutual Hamming distance.
13. The coder of claim 12, in which: the type words each consist of T bits; and the coder additionally comprises a type word generator that generates the set of possible bit patterns, the type word generator including: a first-half generator that adopts a (T/2)-bit binary pattern as a first half of a bit pattern in the set of possible bit patterns, and a second-half generator that generates a second half of the bit pattern by duplicating or complementing the first half of the bit pattern depending on a bit parity value of the first half of the bit pattern.
14. The coder of claim 10, wherein the communication coder operation in conjunction with forward error correction.
15. The coder of claim 10, wherein the twisted pair conductors comprise 4 twisted pair conductors and the communication coder's use of a one bit block header establish a overhead of 1.5625%.
16. The coder of claim 10, in which the payload field generator includes a control word removal module that condenses the block by removing from the block a control word that indicates one of (a) the start of the packet and (b) the end of the packet.
17. The coder of claim 16, in which the payload field generator additionally includes a re-coder that condenses the block by re-coding remaining ones of the control words using fewer bits.
18. The coder of claim 17, in which the re-coder re-codes the control words using codes having a specified mutual Hamming distance.
US11/431,929 2002-07-10 2006-05-09 Communication system and encoding method having low overhead Expired - Lifetime US7809021B2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
US11/431,929 US7809021B2 (en) 2002-07-10 2006-05-09 Communication system and encoding method having low overhead
US12/924,565 US8472478B2 (en) 2002-07-10 2010-09-28 Communication system and encoding method having low overhead
US13/925,605 US9451057B1 (en) 2002-07-10 2013-06-24 Communication system and encoding method having low overhead

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US10/194,741 US7065167B2 (en) 2002-07-10 2002-07-10 Method and apparatus for constellation shaping
US67933605P 2005-05-10 2005-05-10
US11/431,929 US7809021B2 (en) 2002-07-10 2006-05-09 Communication system and encoding method having low overhead

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/194,741 Continuation-In-Part US7065167B2 (en) 2002-07-10 2002-07-10 Method and apparatus for constellation shaping

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US12/924,565 Continuation US8472478B2 (en) 2002-07-10 2010-09-28 Communication system and encoding method having low overhead

Publications (2)

Publication Number Publication Date
US20060256875A1 true US20060256875A1 (en) 2006-11-16
US7809021B2 US7809021B2 (en) 2010-10-05

Family

ID=37419096

Family Applications (3)

Application Number Title Priority Date Filing Date
US11/431,929 Expired - Lifetime US7809021B2 (en) 2002-07-10 2006-05-09 Communication system and encoding method having low overhead
US12/924,565 Expired - Lifetime US8472478B2 (en) 2002-07-10 2010-09-28 Communication system and encoding method having low overhead
US13/925,605 Expired - Lifetime US9451057B1 (en) 2002-07-10 2013-06-24 Communication system and encoding method having low overhead

Family Applications After (2)

Application Number Title Priority Date Filing Date
US12/924,565 Expired - Lifetime US8472478B2 (en) 2002-07-10 2010-09-28 Communication system and encoding method having low overhead
US13/925,605 Expired - Lifetime US9451057B1 (en) 2002-07-10 2013-06-24 Communication system and encoding method having low overhead

Country Status (1)

Country Link
US (3) US7809021B2 (en)

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7440513B2 (en) * 2005-05-24 2008-10-21 Avago Technologies General Ip (Singapore) Pte. Ltd. Coding and decoding packetized data
US20080267634A1 (en) * 2007-04-30 2008-10-30 Futurewei Technologies, Inc. 9b10b Code for Passive Optical Networks
US20090187778A1 (en) * 2008-01-21 2009-07-23 Broadcom Corporation System and method for reducing power consumption during periods of low link utilization
US20100111100A1 (en) * 2008-09-02 2010-05-06 Howard Baumer Systems and methods for digital interface translation
US20100215060A1 (en) * 2009-02-20 2010-08-26 Avalon Microelectronics, Inc. Method of Multiple Lane Distribution (MLD) Deskew
US20110191656A1 (en) * 2010-01-29 2011-08-04 Broadcom Corporation Systems for High-Speed Backplane Applications Using Pre-Coding
WO2012015473A1 (en) * 2010-07-28 2012-02-02 Omron Network Products, Llc Method and apparatus for transporting an 8b/10b coded video stream across a 64b/66b coded link
US20130077962A1 (en) * 2011-09-23 2013-03-28 Fujitsu Network Communications, Inc. Methods and systems for block alignment in a communication system
WO2015084895A1 (en) * 2013-12-02 2015-06-11 Oe Solutions America, Inc. Optical transceiver and data mapping method using thereof
US20150280895A1 (en) * 2014-04-01 2015-10-01 Apple Inc. Apparatus and methods for flexible provision of control data in large data structures
US20160043840A1 (en) * 2014-08-06 2016-02-11 Samsung Electronics Co., Ltd. Packet transmitter, interface device and computing system including the same
US9509409B2 (en) 2013-12-02 2016-11-29 Oe Solutions America, Inc. Optical transceiver and optical communication system
US10372527B2 (en) * 2013-07-15 2019-08-06 Intel Corporation Method of encoding data
US10636506B2 (en) * 2016-10-08 2020-04-28 Shannon Systems Ltd. Methods for testing a storage unit and apparatuses using the same
US20200228229A1 (en) * 2012-11-07 2020-07-16 Marvell Asia Pte, Ltd. Flexible data transmission scheme adaptive to communication channel quality
US11275704B2 (en) * 2018-09-27 2022-03-15 Melexis Technologies Sa Method and system for communicating over a bus
US20220321490A1 (en) * 2021-04-06 2022-10-06 Apple Inc. Data Encoding and Packet Sharing in a Parallel Communication Interface
WO2024044150A1 (en) * 2022-08-23 2024-02-29 Ascenium, Inc. Parallel processing architecture with bin packing

Families Citing this family (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060176942A1 (en) * 2005-02-07 2006-08-10 Vladimir Oksman On-line reconfiguration and synchronization protocol for multi-carrier DSL
EP1764980B8 (en) * 2005-09-20 2009-01-07 Panasonic Corporation Method and apparatus for packet segmentation and concatenation signaling in a communication system
US8452229B2 (en) * 2006-02-28 2013-05-28 Panasonic Corporation Radio communication apparatus and relay transmission method
US8495335B2 (en) * 2006-06-16 2013-07-23 Raytheon Company Data translation system and method
US8171370B2 (en) 2006-11-14 2012-05-01 Futurewei Technologies, Inc. Method and apparatus for applying forward error correction in 66b systems
US20090097401A1 (en) * 2007-10-12 2009-04-16 Wael William Diab Method and system for configurable data rate thresholds for energy efficient ethernet
US7995621B2 (en) * 2008-10-01 2011-08-09 Nortel Netwoeks Limited Techniques for time transfer via signal encoding
US8885664B1 (en) 2011-09-29 2014-11-11 Marvell International Ltd. Multi-rate media independent interface over a physical coding sublayer
CN106712893B (en) * 2015-07-23 2020-10-09 华为技术有限公司 Method and device for data transmission
US10644834B1 (en) 2017-08-08 2020-05-05 Marvell International Ltd. Efficient ethernet multi-mode coding and modulation for twisted-pair
US20190068325A1 (en) * 2017-08-23 2019-02-28 Microsemi Storage Solutions, Inc. System and method for block-coding transcoding

Citations (97)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3916095A (en) * 1972-02-17 1975-10-28 Dacom Inc Dual-line data compression method and system for compressing, transmitting and reproducing facsimile data
US4359778A (en) * 1981-02-05 1982-11-16 Zenith Radio Corporation Channel equalizer and method for cancelling ghosts
US4583235A (en) * 1982-11-11 1986-04-15 Siemens Aktiengesellschaft Self-adjusting equalizer configuration which automatically adjusts to the cable length
US4606069A (en) * 1983-06-10 1986-08-12 At&T Bell Laboratories Apparatus and method for compression of facsimile information by pattern matching
US4829422A (en) * 1987-04-02 1989-05-09 Stellar Computer, Inc. Control of multiple processors executing in parallel regions
US4878232A (en) * 1985-11-20 1989-10-31 Stc Plc Data transmission system
US4956838A (en) * 1988-03-15 1990-09-11 Etat Francais Represente Par Le Ministre Des Postes, Telecommunications Et De L'espace (Centre National D'etudes Des Telecommunications) Echo cancelling device with frequency sub-band filtering
US5150381A (en) * 1989-02-16 1992-09-22 Codex Corporation Trellis shaping for modulation systems
US5222084A (en) * 1990-06-25 1993-06-22 Nec Corporation Echo canceler having adaptive digital filter unit associated with delta-sigma modulation circuit
US5249200A (en) * 1991-07-30 1993-09-28 Codex Corporation Device and method for combining precoding with symbol-rate spectral shaping
US5293402A (en) * 1991-05-02 1994-03-08 Bell Communications Research, Inc. Wideband digital equalizers for subscriber loops
US5297170A (en) * 1990-08-21 1994-03-22 Codex Corporation Lattice and trellis-coded quantization
US5301193A (en) * 1990-11-14 1994-04-05 Fujitsu Limited Delay distortion suppressing system for ATM communication system
US5305307A (en) * 1991-01-04 1994-04-19 Picturetel Corporation Adaptive acoustic echo canceller having means for reducing or eliminating echo in a plurality of signal bandwidths
US5307405A (en) * 1992-09-25 1994-04-26 Qualcomm Incorporated Network echo canceller
US5388124A (en) * 1992-06-12 1995-02-07 University Of Maryland Precoding scheme for transmitting data using optimally-shaped constellations over intersymbol-interference channels
US5633863A (en) * 1994-07-07 1997-05-27 Siemens Schweiz Ag Echo canceler
US5646958A (en) * 1994-12-26 1997-07-08 Nec Corporation Decision feedback equalizer for canceling short-and long-multipath components using correspondingly delayed decision symbols
US5778191A (en) * 1995-10-26 1998-07-07 Motorola, Inc. Method and device for error control of a macroblock-based video compression technique
US5822371A (en) * 1997-02-14 1998-10-13 General Datacomm Inc. Mapper for high data rate signalling
US5856970A (en) * 1996-08-05 1999-01-05 Motorola, Inc. Multi-channel echo cancellation method and apparatus
US5862179A (en) * 1997-02-14 1999-01-19 General Datacomm, Inc. Mapper for high data rate signalling
US5896452A (en) * 1996-05-24 1999-04-20 Motorola, Inc. Multi-channel echo canceler and method using convolution of two training signals
US5909466A (en) * 1995-09-15 1999-06-01 France Telecom Adaptive equalizer for digital communications systems
US5991308A (en) * 1995-08-25 1999-11-23 Terayon Communication Systems, Inc. Lower overhead method for data transmission using ATM and SCDMA over hybrid fiber coax cable plant
US6032197A (en) * 1997-09-25 2000-02-29 Microsoft Corporation Data packet header compression for unidirectional transmission
US6081502A (en) * 1997-09-18 2000-06-27 Orckit Communications Ltd. Method and apparatus for reducing probability of clipping
US6088645A (en) * 1996-07-08 2000-07-11 Komatsu Ltd. Control device and control method for transmission with clutch
US6088345A (en) * 1996-11-22 2000-07-11 Sony Corporation Communication method, base station and terminal apparatus
US6088827A (en) * 1997-08-28 2000-07-11 Level One Communications, Inc. 1000BASE-T packetized trellis coder
US6147979A (en) * 1997-08-12 2000-11-14 Lucent Technologies, Inc. System and method for echo cancellation in a communication system
US6160790A (en) * 1996-12-31 2000-12-12 Paradyne Corporation Crosstalk canceller system and method
US6167082A (en) * 1997-03-06 2000-12-26 Level One Communications, Inc. Adaptive equalizers and methods for carrying out equalization with a precoded transmitter
US6201831B1 (en) * 1998-11-13 2001-03-13 Broadcom Corporation Demodulator for a multi-pair gigabit transceiver
US6226332B1 (en) * 1998-11-13 2001-05-01 Broadcom Corporation Multi-pair transceiver decoder system with low computation slicer
US6233104B1 (en) * 1999-04-19 2001-05-15 Agilent Technologies, Inc. System and method for interfacing data stored on a magnetic strip
US6249544B1 (en) * 1998-11-13 2001-06-19 Broadcom Corporation System and method for high-speed decoding and ISI compensation in a multi-pair transceiver system
US6252904B1 (en) * 1998-11-13 2001-06-26 Broadcom Corporation High-speed decoder for a multi-pair gigabit transceiver
US6253345B1 (en) * 1998-11-13 2001-06-26 Broadcom Corporation System and method for trellis decoding in a multi-pair transceiver system
US6259729B1 (en) * 1997-12-19 2001-07-10 Nec Corporation Method of and an apparatus for training tap coefficients of an adaptive equalizer
US6272173B1 (en) * 1998-11-09 2001-08-07 Broadcom Corporation Efficient fir filter for high-speed communication
US6285653B1 (en) * 1998-09-11 2001-09-04 Fluke Corporation Method and apparatus to measure far end crosstalk for the determination of equal level far end crosstalk
US6297647B2 (en) * 1999-07-20 2001-10-02 Agilent Technologies, Inc. Crosstalk test unit and method of calibration
US6304598B1 (en) * 1998-08-28 2001-10-16 Broadcom Corporation Apparatus for, and method of, reducing power dissipation in a communications system
US20010036160A1 (en) * 2000-04-28 2001-11-01 Philip Curran Echo and crosstalk cancellation
US6351531B1 (en) * 2000-01-21 2002-02-26 Motorola, Inc. Method and system for controlling echo cancellation using zero echo path, ringing, and off-hook detection
US6356555B1 (en) * 1995-08-25 2002-03-12 Terayon Communications Systems, Inc. Apparatus and method for digital data transmission using orthogonal codes
US20020067824A1 (en) * 2000-12-04 2002-06-06 Baoli Wang Two-step algorithm for training an echo cancellation filter
US6414956B1 (en) * 1999-12-17 2002-07-02 Texas Instruments Incorporated VLAN tag transport within a switch
US20020106016A1 (en) * 2000-08-21 2002-08-08 Egelmeers Gerardus Paul Maria Partitioned block frequency domain adaptive filter
US6433558B1 (en) * 1999-05-13 2002-08-13 Microtest, Inc. Method for diagnosing performance problems in cabling
US20020129307A1 (en) * 2001-03-06 2002-09-12 Walker Richard C. Data communication system with self-test facility
US6463041B1 (en) * 1998-03-09 2002-10-08 Broadcom Corporation Apparatus for, and method of, reducing noise in a communications system
US6480532B1 (en) * 1999-07-13 2002-11-12 Stmicroelectronics, Inc. Echo cancellation for an ADSL modem
US6483521B1 (en) * 1998-02-02 2002-11-19 Matsushita Electric Industrial Co., Ltd. Image composition method, image composition apparatus, and data recording media
US20020176492A1 (en) * 2001-05-11 2002-11-28 Zangi Kambiz C. Methods for receiving diversity transmissions including prefiltering to provide minimum phase channel characterstics and related receivers
US20020191552A1 (en) * 1999-12-13 2002-12-19 Watkinson Peter Geoffrey Interference cancellation equipment
US20030020803A1 (en) * 2001-07-16 2003-01-30 Yang Chin-Lung Method and apparatus for continuously receiving frames from a plurality of video channels and for alternately continuously transmitting to each of a plurality of participants in a video conference individual frames containing information concerning each of said video channels
US20030023986A1 (en) * 2001-06-29 2003-01-30 Nec Corporation Recording system for digital broadcasting
US20030067888A1 (en) * 2001-10-10 2003-04-10 Bina Bruce M. Seamless redundant echo canceller replacement in a multi-channel echo canceller
US20030095054A1 (en) * 2001-11-21 2003-05-22 Kiyohisa Ichino Code converter and method of code conversion
US20030108092A1 (en) * 2001-08-17 2003-06-12 James Gorecki System and method for high speed digital signaling
US6584160B1 (en) * 1998-08-13 2003-06-24 Globespanvirata, Inc. System and method for reducing the effects of clipping in a DMT transceiver
US6598203B1 (en) * 2000-06-28 2003-07-22 Northrop Grumman Corporation Parallel punctured convolutional encoder
US20030142659A1 (en) * 2002-01-25 2003-07-31 Infineon Technologies North America Corp. Automatic gain control for communication receivers
US6618480B1 (en) * 1997-04-30 2003-09-09 Texas Instruments Incorporated DAC architecture for analog echo cancellation
US20030185251A1 (en) * 2002-03-28 2003-10-02 Nec Corporation Multiplex transmission system capable of using ordinary network packets to transmit a plurality of 8B/10B bit streams
US20030185181A1 (en) * 1998-02-23 2003-10-02 Krishna Balachandran System and method for incremental redundancy transmission in a communication system
US6636531B1 (en) * 1999-05-10 2003-10-21 Mitsubishi Denki Kabushiki Kaisha Communication device and method
US6650638B1 (en) * 2000-03-06 2003-11-18 Agilent Technologies, Inc. Decoding method and decoder for 64b/66b coded packetized serial data
US20040001540A1 (en) * 2002-07-01 2004-01-01 William Jones Method and apparatus for channel equalization
US20040022311A1 (en) * 2002-07-12 2004-02-05 Zerbe Jared L. Selectable-tap equalizer
US6718491B1 (en) * 2000-03-06 2004-04-06 Agilent Technologies, Inc. Coding method and coder for coding packetized serial data with low overhead
US6751255B1 (en) * 2000-03-09 2004-06-15 Orckit Communications, Ltd. Decision feedback analyzer with filter compensation
US20040125487A9 (en) * 2002-04-17 2004-07-01 Mikael Sternad Digital audio precompensation
US6760333B1 (en) * 1999-11-22 2004-07-06 Texas Instruments Incorporated Hybrid digital subscriber loop and voice-band universal serial bus modem
US6813311B1 (en) * 2000-03-14 2004-11-02 Globespan Virata Corporation Non-linear echo cancellation for wireless modems and the like
US6823483B1 (en) * 1999-04-22 2004-11-23 Broadcom Corporation Physical coding sublayer for a multi-pair gigabit transceiver
US6826226B1 (en) * 2000-10-17 2004-11-30 Telefonaktiebolaget Lm Ericsson (Publ) Prefilter design by spectral factorization
US6862326B1 (en) * 2001-02-20 2005-03-01 Comsys Communication & Signal Processing Ltd. Whitening matched filter for use in a communications receiver
US6885679B1 (en) * 2000-09-29 2005-04-26 Nortel Networks Limited System and method for layer 2 frame delineation recovery
US6947483B2 (en) * 2000-08-18 2005-09-20 Nortel Networks Limited Method, apparatus, and system for managing data compression in a wireless network
US20060041826A1 (en) * 2004-08-23 2006-02-23 Santanu Bhattacharya Methods and apparatus for error correction of transparent GFP (generic framing procedure) superblocks
US20060133533A1 (en) * 2004-12-22 2006-06-22 Qualcomm Incorporated Method and apparatus for using multiple modulation schemes for a single packet
US7088398B1 (en) * 2001-12-24 2006-08-08 Silicon Image, Inc. Method and apparatus for regenerating a clock for auxiliary data transmitted over a serial link with video data
US7127653B1 (en) * 2001-07-05 2006-10-24 Pmc-Sierra, Inc. Apparatus and method for efficient data transport using transparent framing procedure
US20070067497A1 (en) * 1998-08-28 2007-03-22 Craft Peter K Network interface device that fast-path processes solicited session layer read commands
US20070101241A1 (en) * 2005-10-17 2007-05-03 Enigma Semiconductor, Inc. 64b/66b Coding apparatus and method
US20070160012A1 (en) * 2004-04-23 2007-07-12 Utstarcom Telecom Co., Ltd. Method and apparatus for multi-antenna signal transmission in rf long-distance wireless bs
US20070195832A1 (en) * 2004-04-09 2007-08-23 Utstarcom Telecom Co. Ltd. Method and system of signal transmission in base transceiver station based on remote radio head
US20070242670A1 (en) * 2000-08-08 2007-10-18 E.F. Johnson Company System and method for multicast communications using real time transport protocol (rtp)
US7292567B2 (en) * 2001-10-18 2007-11-06 Qlogic Corporation Router and methods for distributed virtualization
US7366208B2 (en) * 1999-11-16 2008-04-29 Broadcom Network switch with high-speed serializing/deserializing hazard-free double data rate switch
US7375662B2 (en) * 2002-05-29 2008-05-20 Broadcom Corporation Method of and system for performing differential lossless compression
US20080130655A1 (en) * 1998-07-08 2008-06-05 Broadcom Corporation Memory management unit for a network switch
US7446774B1 (en) * 1998-11-09 2008-11-04 Broadcom Corporation Video and graphics system with an integrated system bridge controller
US20100107032A1 (en) * 2002-07-03 2010-04-29 The Directv Group, Inc. Bit labeling for amplitude phase shift constellation used with low density parity check (ldpc) codes

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5122720A (en) * 1989-12-01 1992-06-16 Martinsound Technologies, Inc. Automated fader system
US5301209A (en) 1991-10-09 1994-04-05 At&T Bell Laboratories Multidimensional trellis-coded modulation for fading channels
US6034968A (en) * 1997-09-22 2000-03-07 Samsung Electronics Co., Ltd. Adaptive multiplexing/demultiplexing method and multiplexer/demultiplexer therefor
DE19801389A1 (en) 1998-01-16 1999-07-22 Cit Alcatel Echo cancellation method with adaptive FIR filters
US6665402B1 (en) 1999-08-31 2003-12-16 Nortel Networks Limited Method and apparatus for performing echo cancellation

Patent Citations (99)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3916095A (en) * 1972-02-17 1975-10-28 Dacom Inc Dual-line data compression method and system for compressing, transmitting and reproducing facsimile data
US4359778A (en) * 1981-02-05 1982-11-16 Zenith Radio Corporation Channel equalizer and method for cancelling ghosts
US4583235A (en) * 1982-11-11 1986-04-15 Siemens Aktiengesellschaft Self-adjusting equalizer configuration which automatically adjusts to the cable length
US4606069A (en) * 1983-06-10 1986-08-12 At&T Bell Laboratories Apparatus and method for compression of facsimile information by pattern matching
US4878232A (en) * 1985-11-20 1989-10-31 Stc Plc Data transmission system
US4829422A (en) * 1987-04-02 1989-05-09 Stellar Computer, Inc. Control of multiple processors executing in parallel regions
US4956838A (en) * 1988-03-15 1990-09-11 Etat Francais Represente Par Le Ministre Des Postes, Telecommunications Et De L'espace (Centre National D'etudes Des Telecommunications) Echo cancelling device with frequency sub-band filtering
US5150381A (en) * 1989-02-16 1992-09-22 Codex Corporation Trellis shaping for modulation systems
US5222084A (en) * 1990-06-25 1993-06-22 Nec Corporation Echo canceler having adaptive digital filter unit associated with delta-sigma modulation circuit
US5297170A (en) * 1990-08-21 1994-03-22 Codex Corporation Lattice and trellis-coded quantization
US5301193A (en) * 1990-11-14 1994-04-05 Fujitsu Limited Delay distortion suppressing system for ATM communication system
US5305307A (en) * 1991-01-04 1994-04-19 Picturetel Corporation Adaptive acoustic echo canceller having means for reducing or eliminating echo in a plurality of signal bandwidths
US5293402A (en) * 1991-05-02 1994-03-08 Bell Communications Research, Inc. Wideband digital equalizers for subscriber loops
US5249200A (en) * 1991-07-30 1993-09-28 Codex Corporation Device and method for combining precoding with symbol-rate spectral shaping
US5388124A (en) * 1992-06-12 1995-02-07 University Of Maryland Precoding scheme for transmitting data using optimally-shaped constellations over intersymbol-interference channels
US5307405A (en) * 1992-09-25 1994-04-26 Qualcomm Incorporated Network echo canceller
US5633863A (en) * 1994-07-07 1997-05-27 Siemens Schweiz Ag Echo canceler
US5646958A (en) * 1994-12-26 1997-07-08 Nec Corporation Decision feedback equalizer for canceling short-and long-multipath components using correspondingly delayed decision symbols
US6356555B1 (en) * 1995-08-25 2002-03-12 Terayon Communications Systems, Inc. Apparatus and method for digital data transmission using orthogonal codes
US5991308A (en) * 1995-08-25 1999-11-23 Terayon Communication Systems, Inc. Lower overhead method for data transmission using ATM and SCDMA over hybrid fiber coax cable plant
US5909466A (en) * 1995-09-15 1999-06-01 France Telecom Adaptive equalizer for digital communications systems
US5778191A (en) * 1995-10-26 1998-07-07 Motorola, Inc. Method and device for error control of a macroblock-based video compression technique
US5896452A (en) * 1996-05-24 1999-04-20 Motorola, Inc. Multi-channel echo canceler and method using convolution of two training signals
US6088645A (en) * 1996-07-08 2000-07-11 Komatsu Ltd. Control device and control method for transmission with clutch
US5856970A (en) * 1996-08-05 1999-01-05 Motorola, Inc. Multi-channel echo cancellation method and apparatus
US6088345A (en) * 1996-11-22 2000-07-11 Sony Corporation Communication method, base station and terminal apparatus
US6160790A (en) * 1996-12-31 2000-12-12 Paradyne Corporation Crosstalk canceller system and method
US5862179A (en) * 1997-02-14 1999-01-19 General Datacomm, Inc. Mapper for high data rate signalling
US5822371A (en) * 1997-02-14 1998-10-13 General Datacomm Inc. Mapper for high data rate signalling
US6167082A (en) * 1997-03-06 2000-12-26 Level One Communications, Inc. Adaptive equalizers and methods for carrying out equalization with a precoded transmitter
US6618480B1 (en) * 1997-04-30 2003-09-09 Texas Instruments Incorporated DAC architecture for analog echo cancellation
US6147979A (en) * 1997-08-12 2000-11-14 Lucent Technologies, Inc. System and method for echo cancellation in a communication system
US6088827A (en) * 1997-08-28 2000-07-11 Level One Communications, Inc. 1000BASE-T packetized trellis coder
US6081502A (en) * 1997-09-18 2000-06-27 Orckit Communications Ltd. Method and apparatus for reducing probability of clipping
US6032197A (en) * 1997-09-25 2000-02-29 Microsoft Corporation Data packet header compression for unidirectional transmission
US6259729B1 (en) * 1997-12-19 2001-07-10 Nec Corporation Method of and an apparatus for training tap coefficients of an adaptive equalizer
US6483521B1 (en) * 1998-02-02 2002-11-19 Matsushita Electric Industrial Co., Ltd. Image composition method, image composition apparatus, and data recording media
US20030185181A1 (en) * 1998-02-23 2003-10-02 Krishna Balachandran System and method for incremental redundancy transmission in a communication system
US6463041B1 (en) * 1998-03-09 2002-10-08 Broadcom Corporation Apparatus for, and method of, reducing noise in a communications system
US20080130655A1 (en) * 1998-07-08 2008-06-05 Broadcom Corporation Memory management unit for a network switch
US6584160B1 (en) * 1998-08-13 2003-06-24 Globespanvirata, Inc. System and method for reducing the effects of clipping in a DMT transceiver
US20070067497A1 (en) * 1998-08-28 2007-03-22 Craft Peter K Network interface device that fast-path processes solicited session layer read commands
US6304598B1 (en) * 1998-08-28 2001-10-16 Broadcom Corporation Apparatus for, and method of, reducing power dissipation in a communications system
US6285653B1 (en) * 1998-09-11 2001-09-04 Fluke Corporation Method and apparatus to measure far end crosstalk for the determination of equal level far end crosstalk
US7446774B1 (en) * 1998-11-09 2008-11-04 Broadcom Corporation Video and graphics system with an integrated system bridge controller
US6272173B1 (en) * 1998-11-09 2001-08-07 Broadcom Corporation Efficient fir filter for high-speed communication
US6226332B1 (en) * 1998-11-13 2001-05-01 Broadcom Corporation Multi-pair transceiver decoder system with low computation slicer
US6252904B1 (en) * 1998-11-13 2001-06-26 Broadcom Corporation High-speed decoder for a multi-pair gigabit transceiver
US6253345B1 (en) * 1998-11-13 2001-06-26 Broadcom Corporation System and method for trellis decoding in a multi-pair transceiver system
US6249544B1 (en) * 1998-11-13 2001-06-19 Broadcom Corporation System and method for high-speed decoding and ISI compensation in a multi-pair transceiver system
US6201831B1 (en) * 1998-11-13 2001-03-13 Broadcom Corporation Demodulator for a multi-pair gigabit transceiver
US6233104B1 (en) * 1999-04-19 2001-05-15 Agilent Technologies, Inc. System and method for interfacing data stored on a magnetic strip
US6823483B1 (en) * 1999-04-22 2004-11-23 Broadcom Corporation Physical coding sublayer for a multi-pair gigabit transceiver
US6636531B1 (en) * 1999-05-10 2003-10-21 Mitsubishi Denki Kabushiki Kaisha Communication device and method
US6433558B1 (en) * 1999-05-13 2002-08-13 Microtest, Inc. Method for diagnosing performance problems in cabling
US6480532B1 (en) * 1999-07-13 2002-11-12 Stmicroelectronics, Inc. Echo cancellation for an ADSL modem
US6297647B2 (en) * 1999-07-20 2001-10-02 Agilent Technologies, Inc. Crosstalk test unit and method of calibration
US7366208B2 (en) * 1999-11-16 2008-04-29 Broadcom Network switch with high-speed serializing/deserializing hazard-free double data rate switch
US6760333B1 (en) * 1999-11-22 2004-07-06 Texas Instruments Incorporated Hybrid digital subscriber loop and voice-band universal serial bus modem
US20020191552A1 (en) * 1999-12-13 2002-12-19 Watkinson Peter Geoffrey Interference cancellation equipment
US6414956B1 (en) * 1999-12-17 2002-07-02 Texas Instruments Incorporated VLAN tag transport within a switch
US6351531B1 (en) * 2000-01-21 2002-02-26 Motorola, Inc. Method and system for controlling echo cancellation using zero echo path, ringing, and off-hook detection
US20040228364A1 (en) * 2000-03-06 2004-11-18 Walker Richard C. Coding method and coder for coding packetized serial data with low overhead
US6718491B1 (en) * 2000-03-06 2004-04-06 Agilent Technologies, Inc. Coding method and coder for coding packetized serial data with low overhead
US6650638B1 (en) * 2000-03-06 2003-11-18 Agilent Technologies, Inc. Decoding method and decoder for 64b/66b coded packetized serial data
US6751255B1 (en) * 2000-03-09 2004-06-15 Orckit Communications, Ltd. Decision feedback analyzer with filter compensation
US6813311B1 (en) * 2000-03-14 2004-11-02 Globespan Virata Corporation Non-linear echo cancellation for wireless modems and the like
US20010036160A1 (en) * 2000-04-28 2001-11-01 Philip Curran Echo and crosstalk cancellation
US6598203B1 (en) * 2000-06-28 2003-07-22 Northrop Grumman Corporation Parallel punctured convolutional encoder
US20070242670A1 (en) * 2000-08-08 2007-10-18 E.F. Johnson Company System and method for multicast communications using real time transport protocol (rtp)
US6947483B2 (en) * 2000-08-18 2005-09-20 Nortel Networks Limited Method, apparatus, and system for managing data compression in a wireless network
US20020106016A1 (en) * 2000-08-21 2002-08-08 Egelmeers Gerardus Paul Maria Partitioned block frequency domain adaptive filter
US6885679B1 (en) * 2000-09-29 2005-04-26 Nortel Networks Limited System and method for layer 2 frame delineation recovery
US6826226B1 (en) * 2000-10-17 2004-11-30 Telefonaktiebolaget Lm Ericsson (Publ) Prefilter design by spectral factorization
US20020067824A1 (en) * 2000-12-04 2002-06-06 Baoli Wang Two-step algorithm for training an echo cancellation filter
US6862326B1 (en) * 2001-02-20 2005-03-01 Comsys Communication & Signal Processing Ltd. Whitening matched filter for use in a communications receiver
US20020129307A1 (en) * 2001-03-06 2002-09-12 Walker Richard C. Data communication system with self-test facility
US20020176492A1 (en) * 2001-05-11 2002-11-28 Zangi Kambiz C. Methods for receiving diversity transmissions including prefiltering to provide minimum phase channel characterstics and related receivers
US20030023986A1 (en) * 2001-06-29 2003-01-30 Nec Corporation Recording system for digital broadcasting
US7127653B1 (en) * 2001-07-05 2006-10-24 Pmc-Sierra, Inc. Apparatus and method for efficient data transport using transparent framing procedure
US20030020803A1 (en) * 2001-07-16 2003-01-30 Yang Chin-Lung Method and apparatus for continuously receiving frames from a plurality of video channels and for alternately continuously transmitting to each of a plurality of participants in a video conference individual frames containing information concerning each of said video channels
US20030108092A1 (en) * 2001-08-17 2003-06-12 James Gorecki System and method for high speed digital signaling
US20030067888A1 (en) * 2001-10-10 2003-04-10 Bina Bruce M. Seamless redundant echo canceller replacement in a multi-channel echo canceller
US7292567B2 (en) * 2001-10-18 2007-11-06 Qlogic Corporation Router and methods for distributed virtualization
US20030095054A1 (en) * 2001-11-21 2003-05-22 Kiyohisa Ichino Code converter and method of code conversion
US7088398B1 (en) * 2001-12-24 2006-08-08 Silicon Image, Inc. Method and apparatus for regenerating a clock for auxiliary data transmitted over a serial link with video data
US20030142659A1 (en) * 2002-01-25 2003-07-31 Infineon Technologies North America Corp. Automatic gain control for communication receivers
US20030185251A1 (en) * 2002-03-28 2003-10-02 Nec Corporation Multiplex transmission system capable of using ordinary network packets to transmit a plurality of 8B/10B bit streams
US20040125487A9 (en) * 2002-04-17 2004-07-01 Mikael Sternad Digital audio precompensation
US7375662B2 (en) * 2002-05-29 2008-05-20 Broadcom Corporation Method of and system for performing differential lossless compression
US6961373B2 (en) * 2002-07-01 2005-11-01 Solarflare Communications, Inc. Method and apparatus for channel equalization
US20040001540A1 (en) * 2002-07-01 2004-01-01 William Jones Method and apparatus for channel equalization
US20100107032A1 (en) * 2002-07-03 2010-04-29 The Directv Group, Inc. Bit labeling for amplitude phase shift constellation used with low density parity check (ldpc) codes
US20040022311A1 (en) * 2002-07-12 2004-02-05 Zerbe Jared L. Selectable-tap equalizer
US20070195832A1 (en) * 2004-04-09 2007-08-23 Utstarcom Telecom Co. Ltd. Method and system of signal transmission in base transceiver station based on remote radio head
US20070160012A1 (en) * 2004-04-23 2007-07-12 Utstarcom Telecom Co., Ltd. Method and apparatus for multi-antenna signal transmission in rf long-distance wireless bs
US20060041826A1 (en) * 2004-08-23 2006-02-23 Santanu Bhattacharya Methods and apparatus for error correction of transparent GFP (generic framing procedure) superblocks
US20060133533A1 (en) * 2004-12-22 2006-06-22 Qualcomm Incorporated Method and apparatus for using multiple modulation schemes for a single packet
US20070101241A1 (en) * 2005-10-17 2007-05-03 Enigma Semiconductor, Inc. 64b/66b Coding apparatus and method

Cited By (52)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7440513B2 (en) * 2005-05-24 2008-10-21 Avago Technologies General Ip (Singapore) Pte. Ltd. Coding and decoding packetized data
US20090010362A1 (en) * 2005-05-24 2009-01-08 Thaler Patricia A Coding And Decoding Packetized Data
US7738601B2 (en) 2005-05-24 2010-06-15 Avago Technologies General Ip (Singapore) Pte. Ltd. Coding and decoding packetized data
US20080267634A1 (en) * 2007-04-30 2008-10-30 Futurewei Technologies, Inc. 9b10b Code for Passive Optical Networks
US20090187778A1 (en) * 2008-01-21 2009-07-23 Broadcom Corporation System and method for reducing power consumption during periods of low link utilization
US8417978B2 (en) 2008-01-21 2013-04-09 Broadcom Corporation System and method for reducing power consumption during periods of low link utilization
US8185761B2 (en) * 2008-01-21 2012-05-22 Broadcom Corporation “Subset PHY” approach for reducing power consumption during periods of low link utilization
US20100111100A1 (en) * 2008-09-02 2010-05-06 Howard Baumer Systems and methods for digital interface translation
US8879608B2 (en) 2008-09-02 2014-11-04 Entropic Communications, Inc. Systems and methods for digital interface translation
US8315272B2 (en) * 2008-09-02 2012-11-20 Mobius Semiconductor, Inc. Systems and methods for digital interface translation
US9281911B1 (en) 2009-02-20 2016-03-08 Altera Canada Co. Method of multiple lane distribution (MLD) deskew
US20100215060A1 (en) * 2009-02-20 2010-08-26 Avalon Microelectronics, Inc. Method of Multiple Lane Distribution (MLD) Deskew
US8199782B2 (en) * 2009-02-20 2012-06-12 Altera Canada Co. Method of multiple lane distribution (MLD) deskew
US20120147905A1 (en) * 2009-02-20 2012-06-14 Altera Canada Co. Method of multiple lane distribution (mld) deskew
US8363684B2 (en) * 2009-02-20 2013-01-29 Altera Canada Co. Method of multiple lane distribution (MLD) deskew
US8705581B1 (en) 2009-02-20 2014-04-22 Altera Canada Co. Method of multiple lane distribution (MLD) deskew
TWI474658B (en) * 2010-01-29 2015-02-21 Broadcom Corp System for high-speed backplane applications using pre-coding
US8661309B2 (en) 2010-01-29 2014-02-25 Broadcom Corporation Systems for high-speed backplane applications using pre-coding
EP2362564A3 (en) * 2010-01-29 2013-11-20 Broadcom Corporation High data rate ethernet for backplane applications
US8788917B2 (en) 2010-01-29 2014-07-22 Broadcom Corporation Systems for high-speed backplane applications using FEC encoding
US20110191656A1 (en) * 2010-01-29 2011-08-04 Broadcom Corporation Systems for High-Speed Backplane Applications Using Pre-Coding
US8990654B2 (en) 2010-01-29 2015-03-24 Broadcom Corporation Systems for high-speed backplane applications using pre-coding
WO2012015473A1 (en) * 2010-07-28 2012-02-02 Omron Network Products, Llc Method and apparatus for transporting an 8b/10b coded video stream across a 64b/66b coded link
US9307243B2 (en) 2010-07-28 2016-04-05 Omron Management Center Of America, Inc. Method and apparatus for transporting an 8B/10B coded video stream across a 64B/66B coded link
US8705633B2 (en) * 2010-07-28 2014-04-22 Omron Management Center Of America, Inc. Method and apparatus for transporting an 8B/10B coded video stream across a 64B/66B coded link
US20120027099A1 (en) * 2010-07-28 2012-02-02 Herrity Kenneth R Method and apparatus for transporting an 8B/10B coded video stream across a 64B/66B coded link
US8768172B2 (en) * 2011-09-23 2014-07-01 Fujitsu Limited Methods and systems for block alignment in a communication system
US20130077962A1 (en) * 2011-09-23 2013-03-28 Fujitsu Network Communications, Inc. Methods and systems for block alignment in a communication system
US10855395B2 (en) * 2012-11-07 2020-12-01 Marvell Asia Pte, Ltd. Flexible data transmission scheme adaptive to communication channel quality
US20200228229A1 (en) * 2012-11-07 2020-07-16 Marvell Asia Pte, Ltd. Flexible data transmission scheme adaptive to communication channel quality
US11347580B2 (en) 2013-07-15 2022-05-31 Intel Corporation Method of encoding data
US10997016B2 (en) 2013-07-15 2021-05-04 Intel Corporation Method of encoding data
US10372527B2 (en) * 2013-07-15 2019-08-06 Intel Corporation Method of encoding data
WO2015084895A1 (en) * 2013-12-02 2015-06-11 Oe Solutions America, Inc. Optical transceiver and data mapping method using thereof
KR20160097239A (en) * 2013-12-02 2016-08-17 오이솔루션 아메리카 인코퍼레이티드 Optical transceiver and data mapping method using thereof
US9509409B2 (en) 2013-12-02 2016-11-29 Oe Solutions America, Inc. Optical transceiver and optical communication system
EP3078128A4 (en) * 2013-12-02 2017-07-26 OE Solutions America Inc. Optical transceiver and data mapping method using thereof
KR101865560B1 (en) 2013-12-02 2018-06-08 오이솔루션 아메리카 인코퍼레이티드 Optical transceiver and data mapping method using thereof
US10044468B2 (en) 2013-12-02 2018-08-07 Oe Solutions America, Inc. Optical transceiver and data mapping method using thereof
CN106134118A (en) * 2013-12-02 2016-11-16 Oe解决方案美国股份有限公司 Optical transceiver and use the data mapping method of this optical transceiver
US9559882B2 (en) * 2014-04-01 2017-01-31 Apple Inc. Apparatus and methods for flexible provision of control data in large data structures
US20150280895A1 (en) * 2014-04-01 2015-10-01 Apple Inc. Apparatus and methods for flexible provision of control data in large data structures
US10075566B2 (en) * 2014-08-06 2018-09-11 Samsung Electronics Co., Ltd. Packet transmitter, interface device and computing system including the same
KR20160017494A (en) * 2014-08-06 2016-02-16 삼성전자주식회사 Packet transmitter and interface device including the same
KR102195069B1 (en) * 2014-08-06 2020-12-24 삼성전자주식회사 Packet transmitter and interface device including the same
US20160043840A1 (en) * 2014-08-06 2016-02-11 Samsung Electronics Co., Ltd. Packet transmitter, interface device and computing system including the same
US10636506B2 (en) * 2016-10-08 2020-04-28 Shannon Systems Ltd. Methods for testing a storage unit and apparatuses using the same
US11275704B2 (en) * 2018-09-27 2022-03-15 Melexis Technologies Sa Method and system for communicating over a bus
US20220321490A1 (en) * 2021-04-06 2022-10-06 Apple Inc. Data Encoding and Packet Sharing in a Parallel Communication Interface
US11706150B2 (en) * 2021-04-06 2023-07-18 Apple Inc. Data encoding and packet sharing in a parallel communication interface
US12047302B2 (en) 2021-04-06 2024-07-23 Apple Inc. Data encoding and packet sharing in a parallel communication interface
WO2024044150A1 (en) * 2022-08-23 2024-02-29 Ascenium, Inc. Parallel processing architecture with bin packing

Also Published As

Publication number Publication date
US7809021B2 (en) 2010-10-05
US20110075683A1 (en) 2011-03-31
US8472478B2 (en) 2013-06-25
US9451057B1 (en) 2016-09-20

Similar Documents

Publication Publication Date Title
US9451057B1 (en) Communication system and encoding method having low overhead
CN109286416B (en) Multi-channel communication method and transceiver
CN103797742B (en) The method of processing data, physical chip and ethernet device in Ethernet
JP5321981B2 (en) Method and apparatus for encoding and decoding data
US6650638B1 (en) Decoding method and decoder for 64b/66b coded packetized serial data
US7055073B2 (en) Coding method for coding packetized serial data with low overhead
US7804855B2 (en) Method and system for exploiting spare link bandwidth in a multilane communication channel
US7738601B2 (en) Coding and decoding packetized data
US8488450B2 (en) Method and system for physical layer aggregation
EP2999152A1 (en) Data processing method and related device for fec coding and decoding
US7835401B2 (en) System and method for inverse multiplexing using transcoding and frame alignment markers
WO2002080479A1 (en) Method and system for encoding data for transmission over a serial link
US9166618B2 (en) Data encoding and decoding
US20030172336A1 (en) Self synchronous scrambler apparatus and method for use in dense wavelength division multiplexing
US8239738B2 (en) Transparent in-band forward error correction for signal conditioning-encoded signals
JP7728986B2 (en) System device initialization for packet-based data transmission
US20040071224A1 (en) Protocol-independent packet delineation for backplane architecture
JP2025511622A (en) Efficiently transmittable bit sequences with limited disparity

Legal Events

Date Code Title Description
AS Assignment

Owner name: SOLARFLARE COMMUNICATIONS, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MCCLELLAN, BRETT A.;REEL/FRAME:018084/0203

Effective date: 20060720

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: MARVELL INTERNATIONAL LTD., BERMUDA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SOLARFLARE COMMUNICATIONS, INC.;REEL/FRAME:026434/0922

Effective date: 20110418

FEPP Fee payment procedure

Free format text: PAT HOLDER NO LONGER CLAIMS SMALL ENTITY STATUS, ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: STOL); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FPAY Fee payment

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552)

Year of fee payment: 8

AS Assignment

Owner name: CAVIUM INTERNATIONAL, CAYMAN ISLANDS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MARVELL INTERNATIONAL LTD.;REEL/FRAME:052918/0001

Effective date: 20191231

AS Assignment

Owner name: MARVELL ASIA PTE, LTD., SINGAPORE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CAVIUM INTERNATIONAL;REEL/FRAME:053475/0001

Effective date: 20191231

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12