Embodiments of the disclosure relate generally to input/output (I/O) drivers, and more particularly, in one or more of the illustrated embodiments, to adding offset delays to signal lines of multi-level communication architectures.
The pursuit of making computing systems more powerful and more power efficient has led to advancement in interface communications to improve throughput without increasing, and ideally reducing, energy consumption. Often, as clock speeds increase, a desire to increase data transition times on interface busses to match the faster clock speeds exists. Some systems have implemented multi-level (e.g., more than two levels) bus architectures to increase throughput over an interface bus. However, an inherent characteristic of multi-level signals is that time shifts (e.g., jitter) may occur between consecutive symbols. That is, the timing between symbol transitions of the output signals determined from the signal line values may vary within a symbol period due to differences in transition magnitudes. For example, an output signal having a constant slew rate will take longer to transition between the max levels (e.g., VH to VL) than between a mid-level and a max level (e.g., VH/2 to VH). The inherent jitter may reduce the available setup and hold times between symbols, sometimes by as much as 20%. As clock speeds increase, the reduction of set-up and hold times can lead to reduced robustness and reliability in reading data on an interface using this type of system.
Certain details are set forth below to provide a sufficient understanding of embodiments of the disclosure. However, it will be clear to one having skill in the art that embodiments of the disclosure may be practiced without these particular details. Moreover, the particular embodiments of the present disclosure described herein are provided by way of example and should not be used to limit the scope of the disclosure to these particular embodiments.
The output drivers 114 may include circuitry that applies a respective delay to offset inherent jitter within a symbol period of an output signal transition from a previous value to a next value. The output signal value may be determined from values on the signal line(s) of a channel, such as by comparison to a reference voltage or differentially by comparison with another signal line of the channel. Similarly, the output drivers 124 may include circuitry that applies a respective delay for each signal line of each channel to offset inherent jitter in the output signal transition from a current value to a next value. Selection of the respective delay by each of the output drivers 114 and the output drivers 124 may be based on a comparison of the current channel state to the next channel state.
For each channel, the receivers 116 may include one or more receivers configured to determine output signal values associated with each channel based on signal line value provided by the output drivers 124. Further, the receivers 126 may include one or more differential receivers configured to determine output signal values associated with each channel based on signal line values provided by the output drivers 114. In some embodiments, the receivers 116 and the receivers 126 may include differential receivers configured to compare a signal line value to a reference value or configured to compare a signal line value of a channel to another signal line value of the channel.
In operation, the first device 110 and the second device 120 may communicate over the I/O bus to transfer information, such as data, addresses, commands, etc. While the I/O bus is shown to be bidirectional, the I/O bus may also be a unidirectional bus. The I/O interface circuit 112 and I/O interface circuit 122 may implement a multi-level communication architecture. In a multi-level communication architecture, a symbol is sent over a channel during a symbol period. A symbol may be a single value on a signal line of a channel, or may be a combination of values provided on a plurality of signal lines of a channel. The symbol may represent a channel state. A receiver may determine an output signal value based on the value transmitted on the signal line(s) of a channel. In a differential architecture, differential output signal values may be determined from the signal line values of a channel. In a single-ended architecture, the signal line value may be compared against one or more reference values to determine the output signal value. A receiver has a time period to determine and latch the output signal value from the time the output signal transitions to the current value to the time the output signal transitions to the next value. The transition time may be determined based on an edge crossing. An edge crossing may include a point through which an output signal must cross when changing from one logical value to another (e.g., from a logical low value to a logical high value, or vice versa). For example, an edge crossing may be an intermediate point between a high voltage level VH and a low voltage level VL. For a signal, a time between edge crossings of consecutive symbol periods may be a setup and hold time period. Ideally, the time period between transition times (e.g., the setup and hold time) is consistent between symbol periods.
However, in a multi-level communication architecture with a fixed slew rate or fixed rise/fall times, inherent time shifts (e.g., jitter) between transition times for an output signal may result from differences in transition magnitudes from a previous value to a next value. For example, a transition from the low voltage level VL to the high voltage level VH may have a transition time within the symbol period that is different than a transition time within the same symbol period of a signal transitioning from a low voltage level VL to a mid-high voltage level VH/2. The time shifts within a symbol period may affect the setup and hold time between symbol periods, sometimes by as much as 20%. In some examples, a count of potential different transition times within a symbol period may be based on a count of possible absolute transition magnitudes in the multi-level communication architecture. For example, when a multi-level communication architecture defines three differential magnitude transitions in an output signal (e.g., |VH-VL|, |VH/2-VL|, and |VH/2-VL/2|), there may be three different inherent transition times. The amount of jitter or time shifting may be based on the slew rate, the rise/fall times, the multi-level magnitudes values, or combinations thereof. In some examples, the transition times may also be affected by process, voltage, and temperature variations. Diagram 810 of
To reduce or eliminate the inherent jitter, the output drivers 114 or the output drivers 124 may include circuitry to introduce respective offset delays to one or more signal lines of a channel. The offset delays may adjust the timing of transitions of a signal line from a current value to a next value as transmitted over the I/O bus. The delay offset for each signal line of a channel is set independent of offset delays for other signals lines of the channel and independent of other signals lines of other channels. That is, a signal line of a channel may have a different offset delay than other signal lines of the channel. Further, the offset delay for a signal line is determined at each symbol period independent of the delay offset from any the previous symbol period. Thus, the delay offset for a signal line may change or stay the same from one symbol period to the next based on the comparison between channel states. The adjusted timing may reduce or eliminate the undesirable time shifting of an output signal value transition within a symbol period (e.g., provide consistent transition times), and make the setup and hold time periods consistent between symbol periods. The offset delays may be based on a comparison of a current channel state to a next channel state. The length of delay offsets that are selectable by the output drivers 114 and 124 may be determined based on the slew rate, the rise/fall times, the multi-level magnitudes values, or combinations thereof. In some examples, the lengths may be adjusted in situ based differences caused by process, voltage, and/or temperature variations.
The receivers 116 or the receivers 126 may receive one or more signals for each channel via the I/O bus. In some examples, the receivers 116 or the receivers 126 may include a respective one or more differential amplifiers for each channel. In some embodiments, during the setup and hold time period the one or more differential amplifiers for a channel may receive the respective signals and provide differential or quasi-differential output signal value(s) for each channel based on comparison of signal line values within a channel. In some embodiments, during the setup and hold time period the one or more differential amplifiers for a channel may receive the respective signals and provide output signal values based on comparison of a signal line value of a channel with one or more reference values. In some examples, the receivers 116 or receivers 126 may latch the output signal value(s) for each channel. The first device 110 or the second device 120, respectively, may determine the next channel state for each channel based on the respective output signal value(s). In some examples, the multi-level communication architecture may include an embedded clock by requiring a channel state change during every symbol period, which may cause the output signal values of the channel to change with every symbol period. Thus, the receivers 116 or receivers 126 may use the transitions to detect a new value, rather than detecting new values responsive to a separate clock signal.
The driver control logic 230 and delay control logic 240 may each receive the next channel state from another circuit, such as another circuit in the first device 110 or the second device 120. In some embodiments, the driver control logic 230 may determine whether the next channel state is a valid state value and/or may determine whether the next channel state following the current channel state is a valid sequence according to a defined specification or standard. The driver control logic 230 may provide control signals to control the drivers 260 to drive the signal lines A-N according to the next channel state. In some embodiments, each control signal may correspond to a respective one of the signal lines A-N.
The delay control logic 240 may compare the next channel state to the current channel state received from the latch 220. The delay control logic 240 may provide a delay control signal for each of the control signals provided by the driver control logic 230 based on the comparison of the next channel state to the current channel state. The delay control signals may be used by the delay lines 250 to select which delay circuit of the delay lines 250 is applied to each respective control signal. The delay circuit selected may be based on a predetermined relationship between the next channel state and the current channel state. In some embodiments, the delay control logic 240 may select the delay control signal value from a lookup table or state machine.
In operation, the output driver circuit 200 may receive the next channel state for a channel at the driver control logic 230 and delay control logic 240 at a start of a symbol period. The driver control logic 230 may determine a value for each of the control signals based on the next channel state to provide to the drivers 260. The drivers 260 may drive the signal lines A-N to values according to the next channel state. The driver control logic 230 may provide the control signals to the delay lines 250.
The delay lines 250 may include a set of selectable delay circuits for each control signal that are controlled by a respective delay control signal from the delay control logic 240. The selectable delay circuits of the delay lines 250 may reduce inherent jitter in output signal values determined from the signal lines A-N at a receiver, such as the receivers 116 or the receivers 126 of
The delay lines 250 may select a respective delay circuit for each of the control signals based on a respective delay control signal. The length of delay of each delay circuit of the delay lines 250 may be determined based on the slew rate, a rise/fall time, and magnitudes of the levels of the multi-level communication architecture. In some examples, the length of delay of each delay circuit of the delay lines 250 may be adjusted in situ based differences caused by process, voltage, and/or temperature variations. The delay lines 250 may provide the delayed control signals to the drivers 260. The drivers 260 may drive the signal lines A-N to values based on the delayed control signals. In some examples, the drivers 260 may include pull-up and pull-down circuits to drive the signals lines A-N.
The count of the delay circuits 0-M 330(0-M) may be based on a count of possible magnitude transitions of an output signal value in the multi-level communication architecture. The delay values of each of the delay circuits 0-M 330(0-M) may be determined based on the slew rate, a rise/fall time, and magnitudes of the levels of the multi-level communication architecture. In some embodiments, the delay line circuit 300 may include two, three, or more than four delay circuits 0-M 330(0-M). In some examples, the length of delay of the delay circuits 0-M 330(0-M) may be adjusted in situ based differences caused by process, voltage, and/or temperature variations.
The block diagram of the delay line circuit 300 is a functional block diagram. It is appreciated that one of skill in the art would recognize the delay line circuit 300 could be implemented in any number of ways, including separate delay circuits, a single delay line that has an adjustable delay (e.g., via an RC circuit, etc.), or other circuits or combinations of circuits configured for generating different selectable delays lengths.
The method 400 may include comparing a current channel state of a channel of a multi-level communication bus with a next channel state of the channel, at 410. Comparison of the current channel state with the next channel state may be performed by the output drivers 114 and/or the output driver 124 of
The method 400 may further include, based on the comparison, applying an offset delay to a control signal configured to control a transition of a signal line of the channel from a value associated with the current channel state to a value associated with the next channel state, at 420. Application of the offset delay may be performed by the output drivers 114 and/or the output driver 124 of
The method 400 may further include, after application of the offset delay, driving the signal line to the value associated with the next channel state responsive to the control signal, at 430. In some embodiments, the method 400 may further include latching the next channel state after driving the signal line to the value associated with the next channel state. Latch of the next channel state may be performed by a receiver, such as the receivers 116 and/or the receivers 126 of
The method 401 may include, during a symbol period, applying an offset delay to a signal line to cause an output signal value determined from the signal line value to transition through an edge crossing at a predetermined transition time within the symbol period, wherein the value of the signal line is based on a next channel state, at 460. Application of the offset delay may be performed by the output drivers 114 or the output drivers 124 of
The method 400 may further include, after application of the offset delay, driving the signal line to the value associated with the next channel state, at 470. In some embodiments, the method 401 may further include determining the output signal value from the value driven on the signal line to determine the next channel state.
The method 400 may further include, after application of the offset delay, driving the signal line to the value associated with the next channel state responsive to the control signal, at 430. The method 400 may further include latching the next channel state after driving the signal line to the value associated with the next channel state. Latch of the next channel state may be performed by a receiver, such as the receivers 116 and/or the receivers 126 of
The methods 400 and 401 may be implemented by a field-programmable gate array (FPGA) device, an application-specific integrated circuit (ASIC), a processing unit such as a central processing unit (CPU), a digital signal processor (DSP), a controller, another hardware device, a firmware device, or any combination thereof. As an example, the methods 400 and 401 may be implemented by a computing apparatus using, for example, one or more processing units that may execute instructions for performing the method that may be encoded on a computer readable medium. The processing units may be implemented using, e.g. processors or other circuitry capable of processing (e.g. one or more controllers or other circuitry). The computer readable medium may be transitory or non-transitory and may be implemented, for example, using any suitable electronic memory, including but not limited to, system memory, flash memory, solid state drives, hard disk drives, etc.
The delay lines 550 may receive six control signals AH, AL, BH, BL, CH, and CL. The delay lines 550 may delay each of the six control signals AH, AL, BH, BL, CH, and CL based on the delay control signals DLY CNTRL. The DLY CNTRL signals may be provided by delay control logic, such as the delay control logic 240 of
The output driver circuit 510 may include a first driver 512 configured to receive delayed AH and AL signals, a second driver 514 configured to receive delayed BH and BL signals, and a third driver 516 configured to receive delayed CH and CL signals. The drivers 512, 514, and 516 may drive the signals lines A-C, respectively, based on the respective control signals AH, AL, BH, BL, CH, and CL.
The receiver circuit 530 may further include a first receiver 532, a second receiver 534, and a third receiver 536. The first receiver 532 may be configured to receive the signal lines A and B, and may be configured to provide an output signal R_AB having a value based on a comparison (e.g., a quasi-differential comparison) of the values of the signal lines A and B. The second receiver 534 may be configured to receive the signal lines B and C, and may be configured to provide an output signal R_BC having a value based on a comparison (e.g., a quasi-differential comparison) of the values of the signal lines B and C. The third receiver 536 may be configured to receive the signal lines C and A, and may be configured to provide an output signal R_CA having a value based on a comparison (e.g., a quasi-differential comparison) of the values of the signal lines C and A.
The MIPI C-PHY standard specifies that one of the signal lines A-C is pulled-up to the high voltage VH, one of the signal lines A-C is pulled down to the low voltage VL, and the remaining signal line is at an intermediate value between the VH and VL (neither pulled up nor pulled down). Thus, the possible differential signal R_AB, R_BC, and R_CA voltage differences may be one of VH (e.g., logical one value), VH/2 (e.g., logical one value), VL (e.g., logical zero value), or VL/2 (e.g., logical zero value).
The apparatus 500 implementing the MIPI C-PHY architecture may result in inherent jitter associated with three different edge crossing times within a symbol period: an early crossing time, a nominal crossing time, and a late crossing time.
In a three phase or more differential architectures, the delay adjustments may be based on voltage change of a differential signal, which may be a combination of two input signals, one or both of which may be used for other differential signals in the system. For example, in the C-PHY system, each of the three differential signals R_AB, R_BC, and RCA are generated from a combination of two of the three input signals A, B, and C. Thus, adjusting timing of one input signal correct an edge crossing timing of a first differential signal may affect an edge crossing timing of a second differential signal. Therefore adjustment of timing of input signals in three phase or more differential architectures may require taking effects of timing changes to input signals on every differential signal generated from the input signal.
To reduce a likelihood of adversely affecting timing of one differential signal to another differential signal in a three-phase system, construction of a lookup table (e.g., table 700) may be determined as follows: 1) Identify the differential transitions having an edge crossing that occurs early or late. 2) For each of the edge crossing transitions that occur early or late, identify which of the two signals that make up the differential signal that swings to or from a mid-level voltage (e.g., to or from the intermediate voltage I from table 600). 3) If the edge crossing is an early crossing, then the max delay may be applied to the signal that is identified to transition to or from the mid-level voltage. Otherwise, if the edge crossing is a late crossing, then the min delay may be applied to the signal that is identified to transition to or from the mid-level voltage. The other signal used to generate the differential signal may be set to the nominal delay.
As an example, for signal R_AB transitioning from the +x state to the +y state, the R_AB signal transitions from a VH-VL differential to a VI-VH differential (determined from table 6), which may result in a late crossing. Because the transition results in a late crossing, the component signals transitions are analyzed. From table 6, the A signal transitions from the high voltage VH to the intermediate voltage VI, and the B signal transitions from the low voltage VL to the high voltage VH. Because the signal A is a partial transition to the mid-level voltage (e.g., the intermediate voltage VI), and the R_AB signal is late, the minimal delay may be applied to the signal A, and a nominal delay may be applied to the signal B.
As previously described,
The row and column addresses are provided by the address latch 910 to a row address decoder 922 and a column address decoder 928, respectively. The column address decoder 928 selects bit lines extending through the array 902 corresponding to respective column addresses. The row address decoder 922 is connected to word line driver 924 that activates respective rows of memory cells in the array 902 corresponding to received row addresses. The selected data line (e.g., a bit line or bit lines) corresponding to a received column address are coupled to a read/write circuitry 930 to provide read data to a data output circuit 934 via an input-output data bus 940. The data output circuit 934 may include drivers with offset delays 935 that are configured to control timing of transitions of signal lines on the output data bus. The drivers with offset delays 935 may include the output drivers 114 and/or the output drivers 124 of
From the foregoing it will be appreciated that, although specific embodiments of the disclosure have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the disclosure. Accordingly, the disclosure is not limited except as by the appended claims.
This application is a continuation of U.S. application Ser. No. 14/531,558, filed Nov. 3, 2014, which claims the filing benefit under 35 U.S.C. 119(e) to U.S. Provisional Application No. 62/067,157, entitled “APPARATUSES AND METHODS FOR ADDING OFFSET DELAYS TO SIGNAL LINES OF MULTI-LEVEL COMMUNICATION ARCHITECTURES” filed Oct. 22, 2014. These applications are incorporated herein by reference in their entirety for any purpose.
Number | Date | Country | |
---|---|---|---|
62067157 | Oct 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14531558 | Nov 2014 | US |
Child | 15994862 | US |