Power saving in a twisted wire pair communication network
A first device receives a block encoded communication frame from a second device via a single communication channel on a twisted wire pair. The communication frame comprises a plurality of partial frames. The first device maintains a first counter that indicates a count of partial frames corresponding to communication frames exchanged between the first device and the second device. While the first device is in a low power mode of operation: the first device uses the first counter to determine timing of a window, powers up at least a receive portion of the first network interface device, and determines, during the window, whether the second device transmitted a signal configured to prompt the first device to exit the low power mode of operation. In response to the second device transmitting the signal, the first device exits the low power mode of operation.
Latest Marvell International Ltd. Patents:
- Systems and methods for an inductor structure having an unconventional turn-ratio in integrated circuits
- ON-CHIP PARAMETER GENERATION SYSTEM WITH AN INTEGRATED CALIBRATION CIRCUIT
- PROCESSING UNIT AND METHOD FOR COMPUTING A CONVOLUTION USING A HARDWARE-IMPLEMENTED SPIRAL ALGORITHM
- ROW ADDRESS COMPARATOR FOR A ROW REDUNDANCY CONTROL CIRCUIT IN A MEMORY
- Methods and apparatus for combining received uplink transmissions
This application is a continuation of U.S. patent application Ser. No. 15/985,238, entitled “Power Saving in a Communication Network for a Motor Vehicle,” filed on May 21, 2018, which is a continuation of U.S. patent application Ser. No. 14/814,203, entitled “Methods and Network Device for Generating Communication Frames in 1000BASE-T1 Ethernet,” filed on Jul. 30, 2015, which claims the benefit of U.S. Provisional Patent Application No. 62/030,896, entitled “1000BASE-T1 Training and Energy Efficient Ethernet,” filed on Jul. 30, 2014. The disclosures of all of the applications referenced above are incorporated herein by reference in their entireties.
FIELD OF THE DISCLOSUREThe present application is related generally to communication networks and, more particularly, to generation of communication frames for training purposes and for supporting Energy Efficient Ethernet.
BACKGROUNDGigabit Ethernet is designed to transmit Ethernet frames at a rate of one gigabits per second (1 Gb/s). Gigabit Ethernet utilizes physical layer (PHY) processing devices such as 1000BASE-T1, as defined by the Institute of Electrical and Electronics Engineers (IEEE) 802.3 bp Ethernet Standard. A 1000BASE-T1 PHY processing device supports full-duplex operation at 1 Gb/s over a single twisted copper wire pair. A 1000BASE-T1 PHY processing device can operate in severely constrained environments, such as automotive and industrial environments in which certain requirements (e.g., electromagnetic compatibility and temperature requirements) must be met.
SUMMARYIn an embodiment, a method includes: receiving, at a first network interface device, a block encoded communication frame from a second network interface device via a single communication channel on a twisted wire pair, wherein the communication frame comprises a plurality of partial frames; maintaining, at a first network interface device, a first counter that indicates a count of partial frames corresponding to communication frames exchanged between the first network interface device and the second network interface device via the single communication channel, wherein communication frames respectively include multiple partial frames; entering, at the first network interface device, a low power mode of operation; and while the first network interface device is in the low power mode of operation: using, at the first network interface device, the first counter to determine timing of a window, powering up at least a receive portion of the first network interface device, and determining, with at least the receive portion, during the window, whether the second network interface device transmitted via the single communication channel a signal configured to prompt the first network interface device to exit the low power mode of operation. The method also includes: in response to having determined that the second network interface device transmitted, during the window, the signal configured to prompt the first network interface device to exit the low power mode of operation, exiting, at the first network interface device, the low power mode of operation.
In another embodiment, a first network interface device comprises: one or more integrated circuits; a receive portion implemented on the one or more integrated circuits; a transmit portion implemented on the one or more integrated circuits; and a first counter implemented on the one or more integrated circuits, the first counter indicating a count of partial frames corresponding to communication frames exchanged between the first network interface device and a second network interface device via a single communication channel on a twisted wire pair. The first network interface device includes circuitry implemented on the one or more integrated circuits, wherein the circuitry is configured to: receive a block encoded communication frame from a second network interface device via the single communication channel, maintain the first counter to indicate a count of partial frames corresponding to communication frames exchanged between the first network interface device and the second network interface device via the single communication channel, wherein communication frames respectively include multiple partial frames, and enter the first network interface device into a low power mode of operation. The circuitry is also configured to: while the first network interface device is in the low power mode of operation: use the first counter to determine timing of a window, power up at least the receive portion of the first network interface device, and determine, with at least the receive portion, during the window, whether the second network interface device transmitted via the single communication channel a signal configured to prompt the first network interface device to exit the low power mode of operation. The circuitry is also configured to: in response to having determined that the second network interface device transmitted, during the window, the signal configured to prompt the first network interface device to exit the low power mode of operation, exiting, at the first network interface device, the low power mode of operation.
In embodiments described below, a network interface device (e.g., which is included in a communication device such as an endpoint device (e.g., a server, a desktop computer, a laptop computer, etc.) or an intermediate network device (e.g., a network switch, a network bridge, a network hub, a network router, etc.) or other suitable network device) includes a PHY processing device, for example, a 1000BASE-T1 PHY processing device. According to various embodiments, a network interface device includes a 1000BASE-T1 PHY processing device having finer communication frame resolution, which (i) allows quicker clock locking and synchronization between the 1000BASE-T1 PHY processing device and its link partner and (ii) provides support for Energy Efficient Ethernet (EEE) with only one channel in the link.
The PHY transmitter 200 includes at least an 8N/(8N+1) encoder 202, a Reed-Solomon (RS) error correction encoder 204, a scrambler 206, a modulator 208, and a driver 210. In various embodiments, the PHY transmitter 200 is configured to receive a plurality of bits from a MAC processing device (e.g., the MAC processing device 110) via a GMII (e.g., the GMII 130). The 8N/(8N+1) encoder 202 is configured to encode the received bits according to the 8N/(8N+1) pointer based coding scheme as described in U.S. Pat. No. 7,251,699, entitled “Low Overhead Coding with Arbitrary Control Symbol Placement”, the entirety of which is incorporated by reference herein. Then, forward error correction encoding is performed on the 8N/(8N+1)-encoded bits via the RS encoder 204 to generate RS parity bits. The RS encoder 204 is further configured to aggregate the RS parity bits with the 8N/(8N+1)-encoded bits to form a RS-encoded frame. The scrambler 206 is configured to scramble the bits in RS-encoded frame. The RS-encoded frame is modulated via the modulator 208, which utilizes 3 level pulse amplitude modulation (PAM3) transmitted at a rate of 750 MHz. Then, the driver 210 of the PHY transmitter 200 is configured to provide the PAM3 symbols to a medium dependent interface (MDI), which in turn couples to a transmission medium. In other embodiments, the PHY transmitter 200 further includes a shaper (not shown in
The PHY receiver 220 includes at least an analog to digital converter (ADC) 222, a digital signal processor (DSP) 224, a demodulator 224, a de-scrambler 228, a RS decoder 230, and an 8N/(8N+1) decoder 232. In various embodiments, the PHY receiver 220 is configured to receive an analog signal from a medium via a MDI. The ADC 222 is configured to convert the received analog signal into a digital signal, which is then processed by the DSP 224, which outputs a digital signal having PAM3 symbols. Next, the demodulator 226 is configured to demodulate the PAM3 symbols into binary bits. The bits are then de-scrambled via the de-scrambler 228. The RS decoder 230 is configured to decode the de-scrambled bits and perform error correction. The error-corrected bits are then further decoded via the 8N/(8N+1) decoder 232 before being transmitted to a MAC processing device (e.g., the MAC processing device 110) via a GMII (e.g., GMII 130).
In various embodiments, a 1000BASE-T1 PHY processing device can be configured either as a master PHY processing device or a slave PHY processing device. A master PHY processing device uses a free running local clock to determine the timing of transmitter operations. A slave PHY processing device recovers the clock from the signal received from the master PHY processing device and uses the received signal to determine the timing of transmitter operations. Furthermore, the master PHY processing device and the slave PHY processing device are configured to synchronize their clocks and timing of transmitter operations during a training mode before entering normal data transmission mode.
Referring again to
The training frame 300 is a communication frame having a defined duration, where the training frame 300 includes training signals and/or training information. In
In operation, the PHY processing device 120 is configured to transmit the training frame 300, including the info frame field 304, to its link partner. In turn, the link partner is configured to determine the number of partial frames 302 transmitted by the PHY processing device 120 by counting the number of inverted bits 302-1. Referring to
The master PHY processing device has a free running local clock and is configured to maintain a count of partial frames (PFC), which indicates a number of partial frames that have been generated. The master PHY processing device is configured to generate a plurality of training frames, e.g. a first training frame 410, a second training frame 420, and a third training frame 430, with each training frame having the same duration as a RS-encoded frame. In another embodiment, each training frame has the same duration as another error correction encoded frame. Each training frame is divided into PF partial frames, e.g., the first training frame 410 is divided into PF partial frames 412. Each partial frame includes PRS number of symbols (e.g., PAM3 symbols). The boundary of each partial frame (except for at least one partial frame, e.g., the last partial frame) is marked by an inverted first bit, e.g., the boundary of the partial frame 412 is denoted by its inverted first bit 412-1.
Each training frame further includes an info field frame, which contains various parameters of the link. For example, the first training frame 410 includes a first info field frame 414, the second training frame 420 includes a second info field frame 424, and the third training frame 430 includes a third info field frame 434. Each info field frame includes a partial frame count (PFC) field, which indicates the number of partial frames that have been generated. For example, the PFC field in the first info field frame 424 is N, since N partial frames have been generated; the PFC field in the second info field frame 434 is N+PF, since PF partial frames have been generated since the first info field frame 424; and the PFC field in the third info field frame 434 is N+2*PF, since PF partial frames have been generated since the second info field frame 424, or 2*PF partial frames have been generated since the first info field frame 414. For each training frame generated, the PFC field in the info field frame is incremented by PF.
In various embodiments, the master PHY processing device is configured to transmit the training frames, including the info field frames, to the slave PHY processing device. The slave PHY processing device is configured to recover the clock based on the signal received from the master PHY processing device. The slave PHY processing device is further configured to use the received signal to determine the timing of transmitter operations. For example, the slave PHY processing device is configured to maintain a PFC based on the PFC fields received from the master PHY processing device. In an embodiment, the PFC maintained by the PHY processing device should be the same as the PFC maintained by the master processing device, but with a delay. In an embodiment, the slave PHY processing device is configured to accept the PFC field transmitted by the master PHY processing device only if a cyclic redundancy check (e.g., CRC-16) returns no errors.
Referring to
The slave PHY processing device is further configured to generate one info field frame per training frame. For example, the slave PHY processing device is configured to generate a fourth info field frame 444 in the fourth training frame 440, a fifth info field frame 454 in the fifth training frame 450, and a sixth info field frame 464 in the sixth training frame 460. Like the info field frame generated by the master PHY processing device, each info field frame generated by the slave PHY processing device includes a PFC field. The PFC field generated by the slave PHY processing device indicates the PFC maintained by the slave PHY processing device. A PFC field from the slave PHY processing device should be transmitted within between zero to one partial frame duration (PRST) after the master PHY processing device transmits a PFC field, and the PFC field from the slave PHY processing device should have the same value as the PFC transmitted by the master PHY processing device. For example, the PFC field in the fourth info field frame 444 is N, which is based on the PFC field in the first info field frame 414; the PFC field in the fifth info field frame 454 is N+PF, which is based on the PFC field in the second info field frame 424; and the PFC field in the sixth info field frame 464 is N+2*PF, which is based on the PFC field in the third info field frame 434.
The slave PHY processing device is configured to transmit the training frames (e.g., the fourth training frame 440, the fifth training frame 450, and the sixth training frame 450) to the master PHY processing device. To synchronize timing with the master PHY processing device, the slave PHY processing device is configured to transmit the info field frame (having the PFC count that matches the PFC count received from the master PHY processing device) within one (1) partial frame duration (PRST) of receiving the info field frame from the master PHY processing device. For example, the slave PHY processing device is configured to transmit the fourth info field frame 444 within one PRST of receiving the first info field frame 414 from the master PHY processing device. The slave PHY processing device is then configured to transmit the fifth info field frame 454 within one PRST of receiving the second info field frame 424 from the master PHY processing device. Next, the slave PHY processing device is configured to transmit the sixth info field frame 464 within one PRST of receiving the third info field frame 434 from the master PHY processing device.
The timing synchronization signals 500 are similar to the timing synchronization signals 400 of
A PFC field from the slave PHY processing device should be transmitted within between Y*PRST and (Y+1)*PRST after the master PHY processing device transmits a PFC field, where Y is a suitable positive integer, and the PFC field from the slave PHY processing device should have a value that is Y plus the PFC transmitted by the master PHY processing device.
In
Each info field frame generated by the slave PHY processing device includes a PFC field. The PFC field generated by the slave PHY processing device is based on the info field frame (e.g., info field frames 414, 424, and 434) generated and transmitted by the master PHY processing device. However, unlike the time synchronization technique 400 of
According to various embodiments, a 1000BASE-T1 PHY processing device is configured to support Energy Efficient Ethernet (EEE). The EEE capability is a mechanism by which the 1000BASE-T1 PHY processing device is able to reduce power consumption during periods of low link utilization. The 1000BASE-T1 PHY processing device can enter a low power idle (LPI) mode of operation after reaching normal operation (i.e., after completing training and entering data mode). The 1000BASE-T1 PHY processing device is configured to enable LPI mode separately in each transmit and receive directions.
To further illustrate the operation of a PHY processing device in LPI mode,
To keep the PHY processing device and its link partner synchronized during LPI mode, a Refresh pattern is periodically sent by the PHY processing device and its link partner, and vice versa. In
In
After entering the LPI mode, the slave PHY processing device is configured to power up (at least receiver circuitry) to be prepared to receive an alert signal in each of a plurality of second alert windows 614. The slave PHY processing device is configured to exit the LPI mode only when an alert signal is received within a second alert window 614, the alert signal having been transmitted by the master PHY processing device. Outside the second alert windows 614, a receiver of the slave PHY processing device is allowed to power down.
The first alert windows 604 (at the master PHY processing device) and the second alert windows 614 (at the slave PHY processing device) are staggered from one another so Alert signals do not overlap. In various embodiments, a second alert window 614 is offset from a first alert window 604 by AF×PRS symbols, where AF is a number of partial frame durations separating valid Alert signal starting points. The first alert windows 604 are separated from one another by 2*AF×PRS symbols, and the second alert windows 614 are also separated from one another by 2*AF×PRS symbols.
In an embodiment, the master PHY processing device is configured to transmit refresh signals only during alert windows of the slave PHY processing device. Similarly, the slave PHY processing device is configured to transmit refresh signals only during alert windows of the master PHY processing device. For example, the master PHY processing device receives the refresh pattern 602 during one of the first alert windows 604. The slave PHY processing device receives a refresh pattern 613 during one of the second alert windows 614.
Table 700 illustrates example parameter values according to three RS encoding schemes. The first RS encoding scheme 702 is represented by the notation RS(180, 154), in which 180 symbols are encoded to make a 154 symbol RS codeword. The second RS encoding scheme 704 is represented by the notation RS(360, 308), in which 360 11-bit symbols are encoded to make a 308 symbol RS codeword. The third RS encoding scheme 706 is represented by the notation RS(630, 539), in which 630 11-bit symbols are encoded to make a 539 symbol RS codeword. In some embodiments, each symbol consists of 11 bits. In other embodiments, each symbol consists of another suitable number of bits. Although three RS encoding schemes are shown in table 700, in other embodiments, the PHY processing device 120 is configured to implement other RS encoding schemes compliant with 1000BASE-T1.
The example parameters shown in table 700 include the following:
RS: number of PAM3 symbols per RS-encoded frame duration;
RST: duration of a RS-encoded frame in ns;
PRS: number of PAM3 symbols per partial frame in a RS-encoded frame duration;
PRST: duration of a partial frame in ns;
PF: number of partial frames per RS-encoded frame duration;
QF: number of RS-encoded frame durations per quiet/refresh cycle in LPI mode;
AF: number of partial frames separate alert windows;
Refresh_LPI: number of partial frames for a Refresh pattern;
Enter_LPI_RS: number of partial frames with LPI signal to enter LPI mode;
Alert_LPI: number of alert sequences to exit LPI mode;
Exit_LPI_RS: number of RS frame durations with all idle signals upon exiting LPI mode;
and
Alert_sym: number of RS symbols in an alert sequence.
In other embodiments, the parameters shown in table 700 are assigned different values based on the RS encoding scheme chosen by the PHY processing device. In still other embodiments, parameters other than those shown in table 700 are used based on the error correction encoding scheme(s) used by the PHY processing device.
In some embodiments, the number of partial frames in a frame having the same duration as an RS-encoded frame is an integer, i.e., PF=RS/PRS=RST/PRST is an integer. In an embodiment, the frame duration of a partial frame is an integer multiple of 8*N ns, where N is the number of symbols encoded in each RS-encoded frame.
At 802, the PHY processing device 120, according to an embodiment, is configured to generate a training frame (e.g., first training frame 410). The training frame includes a plurality of partial frames (e.g., partial frames 412) that include training information. The training frame has a defined duration. In
According to another embodiment, the PHY processing device 120 is configured to generate the info field frame to include a partial frame count (PFC) field. In an embodiment, the PFC field has a value (e.g., N) that is based on the number of partial frames generated at the master PHY processing device. At 806, the PHY processing device 120 is configured to receive another info field frame (e.g., fourth info field 444) within one partial frame duration of transmitting the info field frame (e.g., first info field 414), and the other info field frame includes a partial frame count field having the same value (e.g., N), the other info field frame having been generated by the slave PHY processing device.
According to another embodiment, the PHY processing device 120 is configured to receive another info field frame after transmitting the info field frame, the other info field frame having been generated by the slave PHY processing device. The other info field includes a partial frame count field having another value, where the other value is a sum of the value (e.g., N) and a skew value (e.g., Y), where the other info field frame is received between Y*PRST and (Y+1)*PRST after the beginning of the info field frame generated by the PHY processing device 120.
According to yet another embodiment, the PHY processing device 120 is configured to generate each partial frame to have same number of symbols. According to still another embodiment, the PHY processing device 120 is configured to generate the info field frame as a last partial frame in the training frame.
According to an embodiment, the PHY processing device 120 is configured to generate a second training frame (e.g., second training frame 420). The second training frame includes a plurality of second partial frames. The PHY processing device 120 is configured to generate the second training frame by inverting a first bit in each second partial frame (except for at least one partial frame), and including a second info field frame (e.g., second info field frame 424) in the second training frame. In addition, a number of partial frames in the training frame is the same as a number of second partial frames in the second training frame.
According to another embodiment, the PHY processing device 120 is configured to generate the info field frame to include a first partial frame count field having a first value (e.g., N), and to generate the second info field frame to a second partial frame count field having a second value. The second value is a sum of the first value (e.g., N) and the number of partial frames (e.g., PF) in the first training frame. In another embodiment, the second value is the first value (e.g., N) incremented by 1 (e.g., N+1).
According to still another embodiment, the PHY processing device 120 is configured to receive a third info field frame (e.g., fifth info field frame 454) within one partial frame duration of transmitting the second info field frame (e.g., second info field frame 424), the third info field frame having been generated by the slave PHY processing device. The third info field frame includes a partial frame count field having the second value (e.g., N+PF).
According to another embodiment, the PHY processing device 120 is configured to receive a third info field frame after transmitting the second info field frame, the third info field frame having been generated by the slave PHY processing device. The third info field frame includes a partial frame count field having a third value, where the third value is a sum of the second value and a skew value Y, where the third info field frame is received between (N+PF+Y)*PRST and (N+PF+Y+1)*PRST after the beginning of the second field frame generated by the PHY processing device 120.
At 902, the PHY processing device 120, according to an embodiment, is configured to maintain a first counter that increments for each partial frame transmitted by the PHY processing device 120. At 904, the PHY processing device 120 is configured to generate a training frame for training purposes. The training frame includes a plurality of partial frames that include training information. The PHY processing device 120 is configured to generate the training frame by including a first info field frame in the training frame. The first info field frame includes a first partial frame count field having a first value corresponding to a first count of the first counter, and the first partial frame count field is for synchronizing a second counter of the second network interface device with the first counter of the PHY processing device 120, where the second network interface device corresponds to a link partner of the PHY processing device 120 (e.g., a slave PHY processing device).
Then at 906, the PHY processing device 120 is configured to transmit the training frame to the second network interface device. At 908, the PHY processing device 120 is configured to receive a second info field frame from the second network interface device, where a beginning of the second info field frame is received within one partial frame duration of transmission of a beginning of the first info field frame. The second info field includes a second partial frame count field having a second value corresponding to a second count of the second counter, and the first value is the same as the second value.
At 910, the PHY processing device 120 is configured to enter a LPI mode. At 912, at least a receive portion of the PHY processing device 120 is configured to exit a low power state during a plurality of alert windows (e.g., first alert window 604), where the receive portion of the PHY processing device 120 is configured to be prepared to receive an alert signal during the alert windows. In an embodiment, the alert windows are spaced apart from one another by a defined number of partial frames (e.g., 2*AF partial frames). At 914, the PHY processing device 120 is configured to exit the low power idle mode only when an alert signal is received within one of the alert windows, the alert signal having been generated by a slave device.
In the method 900, a duration of the training frame is the same as a duration of a RS-encoded frame. In other embodiments, however, the duration of the training frame is the same as a duration of each error correction encoded frame exchanged between the PHY processing device 120 and the second network interface device.
According to another embodiment, the PHY processing device 120 is communicatively coupled to the second network interface device (e.g., a slave PHY processing device). In this case, at 910, the PHY processing device 120 is configured to transmit an alert signal to the second network interface device so that the alert signal is received within one of a second plurality of alert windows (e.g., second alert window 614) of the second network interface device.
According to yet another embodiment, a plurality of second alert windows of the second network interface device is offset from the plurality of alert windows of the PHY processing device 120 by a duration corresponding to one half of the time between the start of adjacent alert windows of the PHY processing device 120.
According to still another embodiment, the PHY processing device 120 is configured to transmit an alert signal to the second network interface device so that the alert signal is received within one of the second alert windows of the second network interface device.
According to an embodiment, the PHY processing device 120 is configured to transmit a refresh signal (e.g., slave Refresh pattern 613) to the second network interface device so that the refresh signal is received within one of a second plurality of alert windows (e.g., second alert window 614) at the second network interface device.
According to another embodiment, the PHY processing device 120 is configured to refresh a receiver of PHY processing device 120 only when a refresh signal (e.g., master Refresh pattern 602) is received within an alert window (e.g., alert window 604).
At 1002, the PHY processing device 120, according to an embodiment, is configured to maintain a partial frame count (PFC) based on partial frame count fields and inverted first bits in first training frames received from a master device.
At 1004, the PHY processing device 120, is configured to generate a second training frame (e.g., second training frame 440). The second training frame includes a plurality of partial frames (e.g., partial frames 412) that include training information. A duration of the second training frame is the same as a duration of a RS-encoded frame. The PHY processing device 120 is further configured to generate the second training frame by inverting a first bit (e.g., inverted first bit 412-1) in each partial frame (except for at least one partial frame) at 1004a, and including an info field frame (e.g., info field frame 444) in one of the partial frames of the training frame at 1004b. In an embodiment, the first bit of the partial frame that includes the info field frame is not inverted. The info field frame includes the PFC maintained at block 1002.
Then at 1008, the PHY processing device 120 is configured to transmit the second training frame to the master device for training purposes so that a beginning of the info field frame (the second info field frame) of the second training frame is transmitted within a defined time period after the beginning of an info field frame of one of first training frames (the first info field frame) is received. In an embodiment, the first info field frame includes a first PFC count of N, and the second info field frame includes a second PFC count of N. In this embodiment, the beginning of the second info field frame is transmitted within one partial frame duration of the beginning of the first info field frame.
In an embodiment, the first info field frame includes a first PFC count of N, and the second info field frame includes a second PFC count of N+Y, where Y is a suitable positive integer. In this embodiment, the beginning of the second info field frame is transmitted between i) Y partial frame durations and ii) Y+1 partial frame durations after the beginning of the first info field frame.
At 1102, the PHY processing device 120, according to an embodiment, is configured to enter a LPI mode. At 1106, at least a receive portion of the PHY processing device 120 is further configured to exit a low power state during a first plurality of alert windows (e.g., second alert windows 614), where the receive portion of the PHY processing device 120 is configured to be prepared to receive an alert signal during the alert windows in the first plurality of alert windows. In an embodiment, the alert windows in the first plurality of alert windows are spaced apart from one another by a defined number of partial frame durations (e.g., 2*AF partial frame durations). The first plurality of alert windows is offset from a second plurality of alert windows of a second network interface device (e.g., master PHY processing device) by half the defined number of partial frame durations (e.g., AF partial frame durations). At 1108, the PHY processing device 120 is configured to exit the LPI mode only when an alert signal is received within one of the alert windows in the first plurality of alert windows, the alert signal having been generated by the master device.
At least some of the various blocks, operations, and techniques described above may be implemented utilizing hardware, a processor executing firmware instructions, a processor executing software instructions, or any suitable combination thereof. When implemented utilizing a processor executing software or firmware instructions, the software or firmware instructions may be stored in any tangible, non-transitory computer readable medium, or media, such as a magnetic disk, an optical disk, a random access memory (RAM), a read only memory (ROM), a flash memory, a memory of a processor, a tape drive, etc. The software or firmware instructions may include machine readable instructions that, when executed by one or more processors, cause the one or more processors to perform various acts.
When implemented in hardware, the hardware may comprise one or more of discrete components, an integrated circuit, an application-specific integrated circuit (ASIC), a programmable logic device (PLD), etc.
While the present invention has been described with reference to specific examples, which are intended to be illustrative only and not to be limiting of the invention, changes, additions and/or deletions may be made to the disclosed embodiments without departing from the scope of the invention.
Claims
1. A method, comprising:
- receiving, at a first network interface device, a block encoded communication frame from a second network interface device via a single communication channel on a twisted wire pair, wherein the communication frame comprises a plurality of partial frames;
- maintaining, at a first network interface device, a first counter that indicates a count of partial frames corresponding to communication frames exchanged between the first network interface device and the second network interface device via the single communication channel, wherein communication frames respectively include multiple partial frames;
- entering, at the first network interface device, a low power mode of operation;
- while the first network interface device is in the low power mode of operation, using, at the first network interface device, the first counter to determine timing of a window, powering up at least a receive portion of the first network interface device, and determining, with at least the receive portion, during the window, whether the second network interface device transmitted via the single communication channel a signal configured to prompt the first network interface device to exit the low power mode of operation; and
- in response to having determined that the second network interface device transmitted, during the window, the signal configured to prompt the first network interface device to exit the low power mode of operation, exiting, at the first network interface device, the low power mode of operation.
2. The method of claim 1, further comprising, while the first network interface device is in the low power mode of operation and in response to having determined that the second network interface device did not transmit, during the window, the signal configured to prompt the first network interface device to exit the low power mode of operation:
- powering down the at least at the receive portion of the first network interface device.
3. The method of claim 1, further comprising, while the first network interface device is in the low power mode of operation:
- receiving, at the first network interface device, a refresh signal from the second network interface device via the single communication link during the window.
4. The method of claim 1, further comprising:
- synchronizing, at the first network interface device, the first counter with a second counter of the second network interface device.
5. The method of claim 4, further comprising:
- receiving, at the first network interface device, a training frame comprising a plurality of partial frames that include training information, wherein the training frame includes an info field having a partial frame count corresponding to the second counter of the second network interface device; and
- using, at the first network interface device, the training frame to synchronize the first counter of the first network interface device with the second counter of the second network interface device.
6. The method of claim 5, wherein:
- a respective first bit in each of at least some partial frames of the training frame is inverted; and
- determining, at the first network interface device, a number of partial frames in the training frame at least by counting the inverted bits in the training frame with the first counter.
7. The method of claim 6, wherein:
- a last occurring partial frame, among the plurality of partial frames, in the training frame includes the inform field; and
- the first bit in the last occurring partial frame is not inverted.
8. The method of claim 1, wherein:
- the window is a first window; and
- the method further comprises: using, at the first network interface device, the first counter to determine timing of a second window, and transmitting, by the first network interface device and during the second window, a signal configured to prompt the second network interface device to exit a low power mode of operation.
9. The method of claim 8, wherein:
- the second window is offset in time from the first window.
10. The method of claim 1, wherein:
- the window is a first window; and
- the method further comprises, while the first network interface device is in the low power mode of operation: using, at the first network interface device, the first counter to determine timing of a second window, and transmitting, by the first network interface device and during the second window, a refresh signal.
11. A first network interface device, comprising:
- one or more integrated circuits;
- a receive portion implemented on the one or more integrated circuits;
- a transmit portion implemented on the one or more integrated circuits; and
- a first counter implemented on the one or more integrated circuits, the first counter indicating a count of partial frames corresponding to communication frames exchanged between the first network interface device and a second network interface device via a single communication channel on a twisted wire pair;
- wherein the first network interface device includes circuitry implemented on the one or more integrated circuits, wherein the circuitry is configured to: receive a block encoded communication frame from a second network interface device via the single communication channel, maintain the first counter to indicate a count of partial frames corresponding to communication frames exchanged between the first network interface device and the second network interface device via the single communication channel, wherein communication frames respectively include multiple partial frames, enter the first network interface device into a low power mode of operation, while the first network interface device is in the low power mode of operation, use the first counter to determine timing of a window, power up at least the receive portion of the first network interface device, determine, with at least the receive portion, during the window, whether the second network interface device transmitted via the single communication channel a signal configured to prompt the first network interface device to exit the low power mode of operation, and in response to having determined that the second network interface device transmitted, during the window, the signal configured to prompt the first network interface device to exit the low power mode of operation, exiting, at the first network interface device, the low power mode of operation.
12. The first network interface device of claim 11, the circuitry is further configured to, while the first network interface device is in the low power mode of operation and in response to having determined that the second network interface device did not transmit, during the window, the signal configured to prompt the first network interface device to exit the low power mode of operation:
- power down the at least at the receive portion of the first network interface device.
13. The network interface device of claim 11, the circuitry is further configured to, while the first network interface device is in the low power mode of operation:
- receive a refresh signal from the second network interface device via the single communication link during the window.
14. The network interface device of claim 11, wherein the circuitry is further configured to synchronize the first counter with a second counter of the second network interface device.
15. The network interface device of claim 14, wherein the circuitry is further configured to:
- receive a training frame comprising a plurality of partial frames that include training information, wherein the training frame includes an info field having a partial frame count corresponding to the second counter of the second network interface device; and
- use the training frame to synchronize the first counter of the first network interface device with the second counter of the second network interface device.
16. The network interface device of claim 15, wherein:
- a respective first bit in each of at least some partial frames of the training frame is inverted; and
- the circuitry is further configured to determine a number of partial frames in the training frame at least by counting the inverted bits in the training frame with the first counter.
17. The network interface device of claim 16, wherein:
- a last occurring partial frame, among the plurality of partial frames, in the training frame includes the inform field; and
- the first bit in the last occurring partial frame is not inverted.
18. The network interface device of claim 11, wherein:
- the window is a first window; and
- the circuitry is further configured to: use the first counter to determine timing of a second window, and transmit, during the second window, a signal configured to prompt the second network interface device to exit a low power mode of operation.
19. The network interface device of claim 18, wherein:
- the second window is offset in time from the first window.
20. The network interface device of claim 11, wherein:
- the window is a first window; and
- the circuitry is further configured to, while the first network interface device is in the low power mode of operation: use the first counter to determine timing of a second window, and transmit, during the second window, a refresh signal.
6362757 | March 26, 2002 | Lee et al. |
6476737 | November 5, 2002 | Caroselli et al. |
6504493 | January 7, 2003 | Burd |
6813651 | November 2, 2004 | Smith et al. |
7251699 | July 31, 2007 | Lo |
9979507 | May 22, 2018 | Lo |
10256941 | April 9, 2019 | Lo |
20010034729 | October 25, 2001 | Azadet et al. |
20030147654 | August 7, 2003 | Sung et al. |
20030187994 | October 2, 2003 | Jackson et al. |
20090276680 | November 5, 2009 | Chiu |
20100235706 | September 16, 2010 | Eberlein |
- “IEEE Standard for Ethernet, Section Four,” IEEE Std. 802.3-2012, The Institute for Electrical and Electronics Engineers, pp. 1-732 (2012).
- “IEEE Standard for Ethernet ,Amendment 2: Physical Layer Specifications and Management Parameters for 100 Gb/s Operation Over Backplanes and Copper Cables,” IEEE Std. 802.3bj™-2014, The Institute for Electrical and Electronics Engineers, 368 pages (Jun. 12, 2014).
- IEEE Std 802.3-2002, “IEEE Standard for Information technology—Telecommunications and information exchange between systems—Local and metropolitan area networks—Specific requirements, Part 3: Carrier sense multiple access with collision detection (CSMA/CD) access method and physical layer specifications,” The Institute of Electrical and Electronics Engineers, Inc., 379 pages (Mar. 8, 2002).
- IEEE Std. 802.3bp™/D1.5, “Draft Standard for Ethernet Amendment: Physical Layer Specifications and Management Parameters for 1Gb/s Operation over a Single Twisted Pair Copper Cable,” The Institute of Electrical and Electronics Engineers, Inc., 202 pages (Jun. 14, 2015).
Type: Grant
Filed: Mar 22, 2019
Date of Patent: Dec 17, 2019
Assignee: Marvell International Ltd. (Hamilton)
Inventor: William Lo (Cupertino, CA)
Primary Examiner: Gbemileke J Onamuti
Application Number: 16/362,219