The pursuit of making computing systems more faster and more power efficient has led to advancement in interface communications to improve throughput without increasing, while 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. Future double data rate (DDR) dynamic random-access memory (DRAM) performance targets will soon exceed DRAM transistor switching capabilities.
Although not observed in the context of memory systems, some computing systems have implemented multi-level (e.g., more than two levels) signaling architectures to increase throughput over an interface bus. However, a challenge with multilevel signaling in high speed, high bandwidth, low power memory systems is non-idealities that negatively affect system performance, for example, with regards to signal voltage levels and signal voltage margins. An example is the inability of signal drivers to fully drive the voltage levels of the multilevel signals to a high supply voltage or to a low supply voltage within a data period due to non-ideal performance of the circuits (e.g., pull-up and pull-down transistors) of the signal drivers. Variations in power, temperature, and fabrication process may further degrade system performance. As a result, the voltage range for the multilevel signals is reduced, which decreases the voltage margins for the different voltage levels. More generally, the signal drivers may be unable to adequately drive the multilevel signals to the correct voltage levels, which may result in data errors.
Certain details are set forth below to provide a sufficient understanding of examples of the disclosure. However, it will be clear to one having skill in the art that examples of the disclosure may be practiced without these particular details. Moreover, the particular examples of the present disclosure described herein should not be construed to limit the scope of the disclosure to these particular examples. In other instances, well-known circuits, control signals, timing protocols, and software operations have not been shown in detail in order to avoid unnecessarily obscuring the disclosure. Additionally, terms such as “couples” and “coupled” mean that two components may be directly or indirectly electrically coupled. Indirectly coupled may imply that two components are coupled through one or more intermediate components.
A bitstream includes a plurality of bits provided serially, wherein each bit of the bitstreams is provided over a period of time, that may be referred to as a data period. For example, a first bit is provided for a first period, and a second bit is provided for a second period following the first period, and a third bit is provided for a third period following the second period, and so on. The successive bits provided in this serial manner represent a stream of bits. The corresponding bits of each bitstream for a data period represents data M bits wide. A multilevel signal may have one of three or more voltage levels (in contrast to binary signals which may have one of two voltage levels to represent a data value), where the voltage level of the multilevel signal represents a data value. The N multilevel signals may be transmitted over the I/O bus. Each multilevel signal is provided over a data period having a voltage corresponding to one of multiple voltage levels (e.g., 2 different voltage levels, 4 different voltage levels, 8 different voltage levels, etc.), where each of the multiple voltage levels represents different data. In one example, 3 bit streams may be converted to 2 tri-level signals. In another example, pulse-amplitude modulation (PAM) may be used to convert 2, 3, or 4 bitstreams into a single multilevel signal having 4, 8, 16, etc., levels.
For example, in a conventional memory device having 8 input/output (I/O) terminals, total of 64 bits of data can be accessed (e.g., read or written) in a column operation. That is, each of 8 I/O terminals may be provided with 8 bits of serialized data, resulting in a total of 64 bits of data (e.g., 8 I/O terminals multiplied by 8 bits (in serial) per I/O terminal). In the conventional memory device, a set of 8 bits of data is converted in series using a first-in, first-out (FIFO) circuit coupled with well-known time multiplexing methods because there are 8 I/O terminals (not 64). In an embodiment of the disclosure, for example, where 2 bits are converted to a multilevel signal (e.g., having one of four different voltage levels to represent the 2 bit value), the 8 serialized data can be converted into 4 serialized data, or 8 I/O terminals can be reduced to 4 I/O terminals (where each of the 4 I/O terminals is provided with 8 bits of serialized data).
In some examples, the first device 110 may include a memory controller or processing system and/or the second device 120 may include a memory, including volatile memory and/or non-volatile memory. In some examples, the second device 120 may include a dynamic random access memory (DRAM), such as a double-data-rate (DDR) DRAM or a low power DDR DRAM. It should be noted, however, that a memory is not a necessary component of the disclosure. Rather, the disclosure may be applied to any two or more devices, on or off-chip, that communicate with one another using multilevel signaling.
The signal driver 114 may include circuitry that applies a bitstream conversion to a set of M bitstreams to generate N multilevel signals and drives the N multilevel signals onto channels of the I/O bus. Similarly, the signal driver 124 may include circuitry that applies a bitstream conversion to a set of M bitstreams to generate N multilevel signals and drives the N multilevel signals onto channels of the I/O bus. In some examples, the signal driver 114 may include modifications to existing DDR drivers to drive the multilevel signals onto the channels of the I/O bus. The M bitstreams may be converted into the N multilevel signals using various techniques now known or later developed. For example, in some embodiments of the disclosure, a PAM4 technique may be used to convert two-bit data into a multilevel signal having one of four different voltage levels. In other embodiments of the disclosure, a PAM8 technique may be used to convert three-bit data into a multilevel signal having one of eight different voltage levels. Other conversion techniques may be used as well without departing from the scope of the disclosure.
For each channel, the receiver and decoder circuit 116 may include decoders configured to recover the set of M bitstreams by decoding the N multilevel signals received via the channels of the I/O bus as provided by the signal driver 124. Further, the receiver and decoder circuit 126 may include decoders configured to recover the set of M bitstreams by decoding the N multilevel signals received via the channels of the I/O bus as provided by the signal driver 114. In some embodiments, the receiver and decoder circuit 116 and the receiver and decoder circuit 126 may include comparators and decoding logic to recover the set of M bitstreams.
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 multilevel communication architecture. In a multilevel communication architecture, data is sent over a channel during a data period. Data may include 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 data 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 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 a clock signal, as well as a setup and hold time based on a transition from one value to another. In a multilevel communication architecture with a fixed slew rate or fixed rise/fall times, inherent jitter may occur due to differing magnitude shifts (e.g., from VH to VL vs. from VMID to VH or VL. The amount of jitter may be based on the slew rate, the rise/fall times, the multilevel magnitudes' values, or combinations thereof. In some examples, the transition times may also be affected by process, voltage, and temperature variations.
In an example, the signal driver 114 may generate data for a channel by converting a bit from each of the M bitstreams during a data period into N multilevel signals. The data may be transmitted to the receiver and decoder circuit 126 via N signal lines of the I/O bus. The receiver and decoder circuit 126 may detect levels on the N signal lines and decode the levels to retrieve the bit from each of the M streams. By using multilevel signal lines, more data can be transmitted during a data period as compared with using binary signal line levels. In an example, M is 3 and N is 2, and the signal lines of the I/O bus are capable of being driven to three independent voltage levels. In another example, M is 2 and N is 1, and the signal lines of the I/O bus are capable of being driven to four independent voltage levels (e.g., in a PAM implementation). Communication protocol between the signal driver 124 and the receiver and decoder circuit 116 may be similar to the communication protocol between the encoder and signal driver 114 and the receiver and decoder circuit 126. The signal driver 114 may include a DRAM driver that has been segmented to drive multiple (e.g., more than 2) voltage levels on a signal line.
The signal driver 214 may include a driver circuit 240. The driver circuit 240 may receive bitstreams IN<1> and IN<0> and drive an output signal OUT in response. The IN<1> and IN<0> bitstreams may represent a stream of two-bit data. The output signal OUT driven by the driver circuit 240 is based on the IN<1> and IN<0> bitstreams. For example, the OUT signal may be a multilevel signal representing data of the IN<0> and IN<1> bitstreams. A PAM4 technique may be used in some embodiments of the disclosure to convert the two-bit data of the IN<1> and IN<0> bitstreams into a multilevel signal having one of four different voltage levels. In some embodiments of the disclosure, the driver circuit 240 may include one or more signal line drivers having a pull-up (e.g., p-type) transistor coupled in series with a pull-down (e.g., n-type) transistor. A source of the pull-up transistor is coupled to a high supply voltage and the source of the pull-down transistor is coupled to a low supply voltage. In some embodiments of the disclosure, the high supply voltage is 1.2 V and the low supply voltage is ground. The output signal OUT is provided at a common node to which the pull-up and pull-down transistors are coupled. Gates of the pull-up and pull-down transistors of the driver circuit 240 are provided with the IN<1> and IN<0> bitstreams. Where a PAM4 conversion is used, the IN<1> bitstream may be provided to a signal line driver having a drive strength that is twice the drive strength of a signal line driver to which the IN<0> bitstream is provided. In such an embodiment, the impedance of the signal line driver to which the IN<1> bitstream is provided is half of the impedance of the signal line driver to which the IN<0> bitstream is provided. In other embodiments of the disclosure, the driver circuit 240 may be implemented using other configurations.
The signal driver 214 further includes a boost control circuit 244 and a boost circuit 246. The boost control circuit 244 provides control signals to control the boost circuit 246 according to the IN<0> and IN<1> bitstreams. The boost circuit 244 may be controlled to provide increased pull-up capability and/or increased pull-down capability for the driver circuit 240 based on current data of the IN<0> and IN<1> bitstreams.
The receiver 226 may include a comparator block 250 coupled to a decoder 260. The comparator 250 may be configured to receive the signal from the I/O bus and provide Z0-Zn signals (n is a whole number) to the decoder 260. The comparator block 250 may include circuits (not shown in
In operation, the IN<0> and IN<1> may be bitstreams to be transmitted over the I/O bus. Rather than send each bitstream on a separate signal line, the signal driver 214 may provide a signal based on the IN<0> and IN<1> bitstreams to be transmitted over a signal line using a multilevel signal. For example, the signal driver 214 may receive the IN<0> and IN<1> bitstreams, and during each data period, the driver circuit 240 may drive the signal line of the I/O bus with a voltage that will be used by the receiver 226 to provide the RX<0> and RX<1> bitstreams. The multilevel signal may be used to represent data of the IN<0> and IN<1> bitstreams using fewer signal lines than one signal line per bitstream. For example, as in the embodiment of
Although
The signal driver 300 includes a driver circuit including six signal line drivers coupled to a common node that is an output. The output may represent an output terminal. Each of the signal line drivers are coupled to a high supply voltage (e.g., VDDQ) and to a low supply voltage (e.g., VSSQ). The driver circuit may be a driver in a DRAM, such as a double data rate (DDR) DRAM driver. In some embodiments of the disclosure, each of the signal line drivers has an impedance of 240 ohms. However, in other embodiments of the disclosure, each of the signal line drivers may have an impedance other than 240 ohms. The signal line drivers are not limited to having the same impedance, and may also have different impedances in embodiments of the disclosure.
The driver circuit may include a first driver section 320 and a second driver section 330 configured to drive an output signal OUT to a common node to which the first and second driver sections 320 and 330 are coupled. A signal line may be coupled to the common node. The output signal OUT driven by the first and second driver sections 320 and 330 may be based on IN<1> and IN<0> bitstreams, which may be provided to the signal line drivers of the driver circuit. The output signal OUT may be a multilevel signal representing data of the IN<1> and IN<0> bitstreams that drives the I/O bus. In some embodiments of the disclosure, “1” data is represented by the IN<1> signal or IN<0> signal having a voltage of 1.2 V, and “0” data is represented by the IN<1> signal or IN<0> signal having a voltage of 0 V. However, other voltage levels may be used to represent the “1” and “0” data in other embodiments of the disclosure.
The first driver section 320 may include four signal line drivers coupled to the common node, each controlled responsive to the IN<1> bitstream. Each signal line driver may include a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor. The complement of the IN<1> bitstream is provided to the gates of the pull-up and pull-down transistors by an inverter circuit that receives the IN<1> bitstream. The second driver section 330 may include two signal line drivers coupled to the common node, each controlled responsive to the IN<0> bitstream, and each signal line driver may include a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor. The complement of the IN<0> bitstream is provided to the gates of the pull-up and pull-down transistors by an inverter circuit that receives the IN<0> bitstream. In an embodiment of the disclosure where each signal line driver has an impedance of 240 ohms, the first driver section 320 has an effective impedance of 60 ohms, the second driver section 330 has an effective impedance of 120 ohms. With each of the signal line drivers having the same impedance, the signal line drivers have the same drive strength.
The signal driver 300 further includes a boost circuit 346 that receives control signals BoostHi and BoostLo from boost control circuit 344. The boost control circuit 344 includes logic circuits and provides control signals BoostHi and BoostLo to the boost circuit 346 based on the IN<0> and IN<1> bitstreams. In some embodiments of the disclosure, a BoostHi signal or BoostLo signal having the high logic level is represented by a signal of 1.2 V, and a BoostHi signal or BoostLo signal having the low logic level is represented by a signal of 0 V. However, other voltage levels may be used to represent the “1” and “0” data in other embodiments of the disclosure.
The boost circuit 346 is coupled to the common node and includes a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor, which are controlled by the BoostHi and BoostLo signals, respectively. The boost circuit 346 may also be referred to as another driver section of the driver circuit. The complement of the BoostHi signal is provided to the gate of the pull-up transistor by an inverter circuit that receives the BoostHi signal. In the embodiment of
As previously described, embodiments of the disclosure are not limited to each of the driver circuits having an impedance of 240 ohms or having each of the drivers circuits having the same impedance. In some embodiments of the disclosure, the boost circuit may have an impedance that is less than the impedance of the other driver circuits. The boost circuit may also be tunable in some embodiments of the disclosure, such as having an impedance that may be adjusted to provide a desired impedance.
As will be described in more detail below, the pull-up transistor of the boost circuit 346 may be activated when the IN<1> and IN<0> bitstreams represent data corresponding to a voltage level of a high supply voltage (e.g., representing data “11”), and the pull-down transistor may be activated when the IN<1> and IN<0> bitstreams represent data corresponding to a voltage level of a low supply voltage (e.g., representing data “00”). While
In operation, the signal driver 300 may drive the OUT signal responsive to the IN<1> and IN<0> bitstreams. The IN<1> and IN<0> bitstreams are provided to the signal line drivers of the driver sections 320 and 330 to provide an output signal OUT having an appropriate voltage for the multilevel signal, for example, using PAM to convert a plurality of bitstreams into a multilevel signal.
In some embodiments of the disclosure, PAM4 is used to convert two bitstreams (e.g., the IN<1> and IN<0> bitstreams) into an OUT signal having one of four different voltage levels. The IN<1> bitstream may be provided to the signal line drivers of the first driver section 320 and the IN<0> bitstream may be provided to the signal line drivers of the second driver section 330. The resulting output signal will have one of four different voltages corresponding to the data of the IN<1> and IN<0> bitstreams. For example, where a current data of the IN<1> and IN<0> bitstreams is a “00”, the pull-down transistors of both the driver sections 320 and 330 are activated to drive (e.g., pull down) the common node to the low supply voltage to provide an output signal OUT having the voltage of the low supply voltage. Additionally, as previously described, a current data of “00” also causes the pull-down transistor of the boost circuit 346 to provide additional drive to pull down the common node to the low supply voltage. Where a current data of the IN<1> and IN<0> bitstream is a “11”, the pull-up transistors of both the driver sections 320 and 330 are activated to drive (e.g., pull up) the common node to the high supply voltage to provide an output signal OUT having the voltage of the high supply voltage. Additionally, as previously described, a current data of “11” also causes the pull-up transistor of the boost circuit 346 to provide additional drive to pull up the common node to the high supply voltage. As illustrated by the example, the pull-up transistor of the boost circuit 346 is activated to drive the common node to the high supply voltage when the first and second driver sections 320 and 330 drive the common node to the high supply voltage. Similarly, the pull-down transistor of the boost circuit 346 is activated to drive the common node to the low supply voltage when the first and second driver sections 320 and 330 drive the common node to the low supply voltage.
Where current data of the IN<1> and IN<0> bitstream is a “01”, the pull-down transistors of the driver section 320 are activated and the pull-up transistors of the driver section 330 are activated to provide a voltage to the common node that results in an output signal OUT having an intermediate-low voltage. Lastly, for current data of the IN<1> and IN<0> bitstream is a “10”, the pull-up transistors of the driver section 320 are activated and the pull-down transistors of the driver section 330 are activated to provide a voltage to the common node that results in an output signal OUT having an intermediate-high voltage. For a current data of “01” or “10”, that is, where the first and second driver sections 320 and 330 are driving the common node to different supply voltages, neither the pull-up nor pull-down transistors of the boost circuit 346 are activated to provide any additional drive to change the voltage of the common node. With both the pull-up and pull-down transistors of the boost circuit 346 deactivated, the boost circuit 346 is in a high-impedance state.
The first driver section 320, the second driver section 330, and the boost circuit 346 are shown in
In operation, the boost control circuit 410 provides an active BoostHi signal (e.g., active when a high logic level) when the current data represented by the IN<1> and IN<0> bitstreams is “11”, which causes the signal driver 300 to provide the output signal OUT having the voltage of the high supply voltage (e.g., current data of the IN<1> and IN<0> bitstreams is “11”). That is, with the IN<1> a “1” and the IN<0> a “1”, the high logic level of the IN<1> bitstream is provided to the line drivers of the first driver section 320 to cause the pull-up transistors to be activated and the high logic level of the IN<0> bitstream is provided to the line drivers of the second driver section 330 to cause the pull-up transistors to be activated. As a result, the common node to which the first and second driver sections 320 and 330 are coupled is pulled up to the voltage of the high supply voltage. Additionally, the high logic levels of the IN<1> and IN<0> bitstreams are provided to the AND logic circuit of the boost control circuit 410 and a logical AND operation is performed to provide an active (e.g., a high logic level) BoostHi signal. The pull-up transistor of the boost circuit 346 is activated by the active BoostHi signal to provide additional drive to further pull up the common node to the voltage of the high supply voltage. Thus, as illustrated by the example operation, the pull-up transistor of the boost circuit 346 is activated to assist in pulling up the common node when the output signal OUT is to be provided having the voltage near or equal to the high supply voltage.
In operation, the boost control circuit 420 provides an active BoostLo signal (e.g., active when a high logic level) when the current data represented by the IN<1> and IN<0> bitstreams is a “00”, which causes the signal driver 300 to provide the output signal OUT having the voltage of the low supply voltage (e.g., current data of the IN<1> and IN<0> bitstreams is “00”). That is, with the IN<1> a “0” and the IN<0> a “0”, the low logic level of the IN<1> bitstream is provided to the line drivers of the first driver section 320 to cause the pull-down transistors to be activated and the low logic level of the IN<0> bitstream is provided to the line drivers of the second driver section 330 to cause the pull-down transistors to be activated. As a result, the common node to which the first and second driver sections 320 and 330 are coupled is pulled up to the voltage of the low supply voltage. Additionally, the low logic levels of the IN<1> and IN<0> bitstreams are provided to the XOR logic circuit 430 of the boost control circuit 420 and the IN<0> bitstream is provided to the inverter circuit 440. The outputs of the XOR logic circuit 430 and the inverter circuit 440 are provided to the AND logic circuit 450, and a logical NAND operation is performed to provide an active (e.g., a high logic level) BoostLo signal. The pull-down transistor of the boost circuit 346 is activated by the active BoostLo signal to provide additional drive to further pull down the common node to the voltage of the low supply voltage. Thus, as illustrated by the example operation, the pull-down transistor of the boost circuit 346 is activated to assist in pulling down the common node when the output signal OUT is to be provided having the voltage near or equal to the low supply voltage.
As shown in
As shown in
As shown in
In some embodiments of the disclosure, the boost circuit 346 may provide additional drive for data corresponding to just one of the supply voltages. For example, in some embodiments of the disclosure, data corresponding to the low supply voltage is boosted, but data corresponding to the high supply voltage is not. The pull-up transistor of the boost circuit 346 may be disabled, circuits for providing signals to activate a pull-up transistor of the boost circuit 346 may not be included in the boost control circuit, circuits for providing signals to activate a pull-up transistor of the boost circuit 346 may not be enabled, or other approaches may be used to not provide boost for data corresponding to the high supply voltage. In other embodiments of the disclosure, the pull-down transistor of the boost circuit 346 may be disabled, so that data corresponding to the high supply voltage is boosted, but data corresponding to the low supply voltage is not. The pull-down transistor of the boost circuit 346 may be disabled, circuits for providing signals to activate a pull-down transistor of the boost circuit 346 may not be included in the boost control circuit, circuits for providing signals to activate a pull-down transistor of the boost circuit 346 may not be enabled, or other approaches may be used to not provide boost for data corresponding to the low supply voltage. In some embodiments of the disclosure, the boost circuit 346 is activated to provide additional drive for data corresponding to both the high supply voltage and the low supply voltage. In such embodiments, the boost control circuit 410 and the boost control circuit 420 may be included together.
The signal driver 215 may be implemented in the signal driver 114 and/or the signal driver 124 of
In operation, the signal driver 215 may receive the IN<0> and IN<1> bitstreams, and during each data period, the driver circuit 240 may drive the signal line of the I/O bus with a voltage that will be used by the receiver 226 to provide the RX<0> and RX<1> bitstreams. The multilevel signal may be used to represent data of the IN<0> and IN<1> bitstreams using fewer signal lines than one signal line per bitstream. Although
For heavily loaded output signals the transitions to extreme low and extreme high levels take more time than transitions between intermediate levels. In operation, the circuit in
In operation, the logic circuit 700 provides an active PREPU signal (e.g., active high logic level) when the data of the IN<1> and IN<0> bitstreams changes from a previous value to a current data of “11”. That is, where the previous data represented by the IN<1> and IN<0> bitstreams is “00”, “01”, or “10”, and the data changes to a current data of “11”, the logic circuit 700 provides an active PREPU signal. The logic circuit 700 provides and inactive PREPU signal for other changes from a previous data to a current data represented by the IN<1> and IN<0> bitstreams. That is, the logic circuit 700 provides an inactive PREPU signal for the IN<1> and IN<0> bitstreams changing from a previous data to current data of “00”, “01”, or “10”. The active PREPU signal provided by the logic circuit 700 may be used to activate a boost circuit, for example, the boost circuit 346 of the signal driver 300, to provide additional drive to assist driving the common node to the high supply voltage to provide an OUT signal having a voltage of the high supply voltage. As will be described in more detail below, the PREPU signal is active for a portion of the data period of the OUT signal. For example, in some embodiments of the disclosure, the PREPU signal is limited to being active to assist the driving of the common node to the high supply voltage.
The NAND logic circuit 710 provides a low logic level IN_11F signal when D<1> and D<0> are both a high logic level (i.e., resulting from the IN<1> and IN<0> bitstreams representing a current data of “11”). The inverter circuit 730 coupled to the NAND logic circuit 720 to receive the IND_11F signal provides a low logic level IND_11 when IND<1> and IND<0> are both a high logic level (i.e., resulting from D<1> and D<0> both a high logic level). Recall that the IND<I> and IND<0> are delayed relative to D<1> and D<0>, for example, by one-half a clock period of the CLK signal. The NOR logic gate provides an active PREPU signal (e.g. active high logic level) when the IN_11F and IND_11 signals have low logic levels. As a result, the PREPU signal is active when D<1> and D<0> are both at a high logic level, and for one-half a clock cycle of the CLK signal following a rising edge of the CLK signal. The PREPU signal is active for one-half a clock cycle of the CLK signal because the one-half clock cycle delay of the IND<I> and IND<O> relative to D<1> and D<0> will result in the IND_11 signal being at a low logic level while the IN_11F signal is at a low logic level (from D<1> and D<0> both being a high logic level), but for one-half a clock cycle of the CLK signal before both IND<1> and IND<0> also become a high logic level (resulting from the D<1> and D<0> both being at the high logic level). As a result, the PREPU signal is active for one-half a clock cycle of the CLK signal.
In operation, the logic circuit 750 provides an active PREPD signal (e.g., active high logic level) when the data of the IN<1> and IN<0> bitstreams changes from a previous value to a current data of “00”. That is, where the previous data represented by the IN<1> and IN<0> bitstreams is “01”, “10”, or “11”, and the data changes to a current data of “00”, the logic circuit 750 provides an active PREPD signal. The logic circuit 750 provides and inactive PREPD signal for other changes from a previous data to a current data represented by the IN<1> and IN<0> bitstreams. That is, the logic circuit 750 provides an inactive PREPD signal for the IN<1> and IN<0> bitstreams changing from a previous data to current data of “01”, “10”, or “11”. The active PREPD signal provided by the logic circuit 750 may be used to activate a boost circuit, for example, the boost circuit 346 of the signal driver 300, to provide additional drive to assist driving the common node to the low supply voltage to provide an OUT signal having a voltage of the low supply voltage. As will be described in more detail below, the PREPD signal is active for a portion of the data period of the OUT signal. For example, in some embodiments of the disclosure, the PREPD signal is limited to being active to assist the driving of the common node to the low supply voltage.
The inverter circuit 780 coupled to the NOR logic circuit 760 provides a low logic level IN_00F signal when D<1> and D<0> are both a low logic level. (i.e., resulting from the IN<1> and IN<0> bitstreams representing a current data of “00”). The NOR logic circuit 770 provides a high logic level IND_00 signal when IND<1> and IND<0> are both a low logic level (i.e., resulting from D<1> and D<0> both a low logic level). Recall that the IND<1> and IND<0> are delayed relative to D<1> and D<0>, for example, by one-half a clock period of the CLK signal. The NOR logic gate 790 provides an active PREPD signal (e.g. active high logic level) when the IN_00F and IND_00 signals have low logic levels. As a result, the PREPD signal is active when D<1> and D<0> are both at a low logic level, and for one-half a clock cycle of the CLK signal following a rising edge of the CLK signal. The PREPD signal is active for one-half a clock cycle of the CLK signal because the one-half clock cycle delay of the IND<1> and IND<0> relative to D<1> and D<0> will result in the IND_00 signal being at a low logic level while the IN_00F signal is at a low logic level (from D<1> and D<0> both being a low logic level), but for one-half a clock cycle of the CLK signal before both IND<1> and IND<0> also become a low logic level (resulting from the D<1> and D<0> both being at the low logic level) and the NOR logic circuit 770 provides a high logic level IND_00. As a result, the PREPD signal is active for one-half a clock cycle of the CLK signal.
In some embodiments of the disclosure, the boost circuit 346 of the signal driver 300 is temporarily activated to provide additional drive for long data transitions towards both the highest output level and the lowest output level. In such embodiments, the boost control circuit 700 and 750 may be used together to control the boost circuit 346.
Prior to time T(−2) the D<1> and D<0> signals are “00,” as reflected by an OUT signal provided having a voltage of the low supply voltage. At time T(−2) the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal (shown in
At time T0 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. In the present example, the data at time T0 is “10”. The D flip-flop 610 provides a high logic level D<1> signal and the D flip-flop 640 provides a low logic level D<0> signal (not shown in
At time T2 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. The data at time T2 is “11”. The D flip-flop 610 maintains a high logic level D<1> signal and the D flip-flop 640 provides a high logic level D<0> signal (not shown in
At time T3, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The high logic level of the D<1> signal is latched by the D flip-flop 620 to maintain a high logic level IND<1> signal and the high logic level of the D<0> signal is latched by the D flip-flop 660 to provide a high logic level IND<0> signal (not shown in
After the IND<1> and IND<0> signals propagate through the NAND logic circuit 720 and the inverter circuit 730 of the pull-up logic circuit 700, the IND_11 signal switches to a high logic level, which causes the XOR logic circuit 740 to provide an inactive PREPU signal. The change of the PREPU signal to inactive deactivates the pull-up transistor of the boost circuit 346. Thus, when the present data represented by the IN<1> and IN<0> bitstreams is “11”, the boost circuit 346 provides additional drive to pull up the common node to the high supply voltage for a portion of the data period of the OUT signal, for example, during the transition of the OUT signal to the high supply voltage. The voltage of the OUT signal changes during the transition from one voltage level to another.
At time T4 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. The data at time T4 is “00”. The D flip-flop 610 provides a low logic level D<1> signal and the D flip-flop 640 provides a low logic level D<0> signal (not shown in
At time T5, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The low logic level of the D<1> signal is latched by the D flip-flop 620 to provide a low logic level IND<1> signal and the low logic level of the D<0> signal is latched by the D flip-flop 660 to provide a low logic level IND<0> signal (not shown in
After the IND<1> and IND<0> signals propagate through the NOR logic circuit 770 of the pull-down logic circuit 750, the IND_00 signal switches to a high logic level, which causes the XOR logic circuit 790 to provide an inactive PREPD signal. The change of the PREPD signal to inactive deactivates the pull-down transistor of the boost circuit 346. Thus, when the present data represented by the IN<1> and IN<0> bitstreams is “00”, the boost circuit 346 provides additional drive to pull down the common node to the low supply voltage for a portion of the data period of the OUT signal, for example, during the transition of the OUT signal to the low supply voltage. As previously described, the voltage of the OUT signal changes during the transition from one voltage level to another.
At time T6 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. The data at time T6 is “11”. The D flip-flop 610 provides a high logic level D<1> signal and the D flip-flop 640 provides a high logic level D<0> signal (not shown in
At time T7, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The high logic level of the D<1> signal is latched by the D flip-flop 620 to provide a high logic level IND<1> signal and the high logic level of the D<0> signal is latched by the D flip-flop 660 to provide a high logic level IND<0> signal (not shown in
At time T8 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. The data at time T0 is “01”. The D flip-flop 610 provides a low logic level D<1> signal and the D flip-flop 640 provides a high logic level D<0> signal (not shown in
In summary:
As illustrated by the previous example of
In operation, the pull-up logic circuit 900 provides an active PREPU signal (e.g., active high logic level) when the data of the IN<1> and IN<0> bitstreams changes from a previous data to a current data that is represented by a higher voltage than the previous data. That is, where the previous data represented by the IN<1> and IN<0> bitstreams is “00”, the pull-up logic circuit 900 provides an active PREPU signal for a current data of “01”, “10”, and “11”; where the previous data represented by the IN<1> and IN<0> bitstreams is “01”, the pull-up logic circuit 900 provides an active PREPU signal for a current data of “10” and “11”; and where the previous data represented by the IN<1> and IN<0> bitstreams is “10”, the pull-up logic circuit 900 provides an active PREPU signal for a current data of “11”. The active PREPU signal provided by the logic circuit 900 may be used to activate a boost circuit, for example, the boost circuit 346 of the signal driver 300, to provide additional drive to assist driving the common node to a higher voltage to provide an OUT signal. As will be described in more detail below, the PREPU signal is active for a portion of the data period of the OUT signal. For example, in some embodiments of the disclosure, the PREPU signal is limited to being active to assist the driving of the common node during a transition to a higher voltage when changing to current data that is represented by a higher voltage than the previous data. That is, the voltage of the OUT signal changes during the transition from one voltage level to another.
In operation, the pull-down logic circuit 950 provides an active PREPD signal (e.g., active high logic level) when the data of the IN<1> and IN<0> bitstreams changes from a previous data to a current data that is represented by a lower voltage than the previous data. That is, where the previous data represented by the IN<1> and IN<0> bitstreams is “11”, the pull-down logic circuit 950 provides an active PREPD signal for a current data of “00”, “01”, and “10”; where the previous data represented by the IN<1> and IN<0> bitstreams is “10”, the pull-down logic circuit 950 provides an active PREPD signal for a current data of “01” and “00”; and where the previous data represented by the IN<1> and IN<0> bitstreams is “01”, the pull-up logic circuit 950 provides an active PREPD signal for a current data of “00”. The active PREPD signal provided by the logic circuit 950 may be used to activate a boost circuit, for example, the boost circuit 346 of the signal driver 300, to provide additional drive to assist driving the common node to a lower voltage to provide an OUT signal. As will be described in more detail below, the PREPD signal is active for a portion of the data period of the OUT signal. For example, in some embodiments of the disclosure, the PREPD signal is limited to being active to assist the driving of the common node during a transition to a lower voltage when changing to current data that is represented by a lower voltage than the previous data. That is, the voltage of the OUT signal changes during the transition from one voltage level to another.
At time T0 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal (shown in
At time T1, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal (corresponding to a falling edge of the CLK signal). The high logic level of the D<1> signal is latched by the D flip-flop 620 to provide a high logic level IND<1> signal (also resulting in a low logic level INDF<1> signal) and the low logic level of the D<0> signal is latched by the D flip-flop 660 to provide a low logic level IND<0> signal (not shown in
At time T2 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. In the present example, the previous data prior to time T2 is “10” and the current data at time T2 is “11”. Latching of the current data “11” results in the D flip-flop 610 providing a high logic level D<1> signal and the D flip-flop 640 providing a high logic level D<0> signal (not shown in
At time T3, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The high logic level of the D<1> signal is latched by the D flip-flop 620 to provide a high logic level IND<1> signal (also resulting in a low logic level INDF<1> signal) and the high logic level of the D<0> signal is latched by the D flip-flop 660 to provide a high logic level IND<0> signal (not shown in
At time T4 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. In the present example, the previous data prior to time T4 is “11” and the current data at time T4 is “00”. Latching of the current data “00” results in the D flip-flop 610 providing a low logic level D<c> signal and the D flip-flop 640 providing a low logic level D<0> signal (not shown in
At time T5, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The low logic level of the D<1> signal is latched by the D flip-flop 620 to provide a low logic level IND<1> signal and the low logic level of the D<0> signal is latched by the D flip-flop 660 to provide a low logic level IND<0> signal (not shown in
At time T6 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. In the present example, the previous data prior to time T6 is “11” and the current data at time T6 is “10”. Latching of the current data “10” results in the D flip-flop 610 providing a high logic level D<1> signal and the D flip-flop 640 providing a low logic level D<0> signal (not shown in
At time T7, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The high logic level of the D<1> signal is latched by the D flip-flop 620 to provide a high logic level IND<1> signal and the low logic level of the D<0> signal is latched by the D flip-flop 660 to provide a low logic level IND<0> signal (not shown in
At time T8 the D flip-flops 610 and 640 of the input circuit 600 are clocked by a rising edge of the CLK signal and the data of the IN<1> and IN<0> bitstreams is latched to provide the D<1> and D<0> signals. In the present example, the previous data prior to time T8 is “10” and the current data at time T8 is “00”. Latching of the current data “00” results in the D flip-flop 610 providing a low logic level D<1> signal and the D flip-flop 640 providing a low logic level D<0> signal (not shown in
At time T9, the D flip-flops 620 and 660 of the input circuit 600 are clocked by a rising edge of the CLKF signal. The low logic level of the D<1> signal is latched by the D flip-flop 620 to provide a low logic level IND<I> signal and the low level of the D<0> signal is latched by the D flip-flop 660 to provide a low logic level IND<0> signal (not shown in
In summary:
As illustrated by the previous example of
In some embodiments of the disclosure, PAM8 is used to convert three bitstreams (e.g., IN<2>, IN<1>, and IN<0> bitstreams) into an OUT output signal having one of eight different voltage levels.
The driver circuit 1100 may include a first driver section 1120, a second driver section 1130, and a third driver section 1140 configured to drive an output signal OUT to a common node to which the first, second, and third driver sections 1120, 1130, and 1140 are coupled. A signal line may be coupled to the common node. The output signal OUT may be driven by the first, second, and third driver sections 1120, 1130, and 1140 based on IN<2>, IN<1>, and IN<0> bitstreams. As will be described in more detail below, signals DD<2>, DD<1>, and DD<0>, which are based on the IN<2>, IN<1>, and IN<0> bitstreams, respectively, may be provided to the signal line drivers of the driver circuit 1100. The output signal OUT may be a multilevel signal representing data of the IN<2>, IN<1>, and IN<0> bitstreams that drives the I/O bus. In some embodiments of the disclosure, “1” data is represented by the IN<2> signal, IN<1> signal, or IN<0> signal having a voltage of 1.2 V, and “0” data is represented by the IN<2>, IN<1> signal, or IN<0> signal having a voltage of 0 V. However, other voltage levels may be used to represent the “1” and “0” data in other embodiments of the disclosure.
The first driver section 1120 may include four signal line drivers coupled to the common node, each controlled responsive to the DD<2> signal. Each signal line driver may include a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor. The second driver section 1130 may include two signal line drivers coupled to the common node, each controlled responsive to the DD<1> signal, and each signal line driver may include a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor. The third driver section 1130 may include one signal line driver coupled to the common node and controlled responsive to the DD<0> signal. The signal line driver of the third driver section 1130 may include a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor. In an embodiment of the disclosure, where each signal line driver has an impedance of 240 ohms, the first driver section 1120 has an effective impedance of 60 ohms, the second driver section 1130 has an effective impedance of 120 ohms, and the third driver section 1140 has an effective impedance of 240 ohms.
The signal driver 1100 further includes a boost circuit 346 that receives control signals PREPU and PREPD from boost control circuit 1144. The boost control circuit 1144 includes logic circuits and provides control signals PREPU and PREPD to the signal driver 1100 based on the IN<2>, IN<I>, and IN<0> bitstreams. The boost circuit 1146 is coupled to the common node and includes a pull-up (e.g., p-type) transistor and a pull-down (e.g., n-type) transistor, which are controlled by the PREPU and PREPD signals, respectively. In the embodiment of
As will be described in more detail below, the pull-up transistor of the boost circuit 346 may be activated when the IN<2>, IN<1>, and IN<0> bitstreams represent data corresponding to a voltage level of a high supply voltage (e.g., representing data “111”), and the pull-down transistor may be activated when the IN<2>, IN<1>, and IN<0> bitstreams represent data corresponding to a voltage level of a low supply voltage (e.g., representing data “000”). While
In operation, the signal driver 1100 may drive the OUT signal responsive to the IN<2>, IN<1>, and IN<0> bitstreams. The DD<2>, DD<1>, DD<0> signals, which are based on the IN<2>, IN<1>, and IN<0> bitstreams, are provided to the signal line drivers of the driver sections 1120, 1130, and 1140 to provide an output signal OUT having appropriate voltage for the multilevel signal, for example, using PAM to convert a plurality of bitstreams into a multilevel signal.
In some embodiments of the disclosure, PAM8 is used to convert three bitstreams (e.g., the IN<2>, IN<1>, and IN<0> bitstreams) into an OUT signal having one of eight different voltage levels. By way of the DD<2> signal, the IN<2> bitstream may be provided to the signal line drivers of the first driver section 1120; by way of the DD<1> signal, the IN<1> bitstream may be provided to the signal line drivers of the second driver section 1130; and by way of the DD<2> signal, the IN<0> bitstream may be provided to the signal line drivers of the third driver section 1140. The resulting output signal will have one of eight different voltages corresponding to the data of the IN<2>, IN<1>, and IN<0> bitstreams.
For example, where a current data of the IN<2>, IN<1>, and IN<0> bitstreams is a “000”, the pull-down transistors of the driver sections 1120, 1130, and 1140 are activated to pull down the common node to the low supply voltage to provide an output signal OUT having the voltage of the low supply voltage. Where a current data of the IN<2>, IN<1>, and IN<0> bitstream is a “111”, the pull-up transistors of the driver sections 1120, 1130, and 1140 are activated to pull up the common node to the high supply voltage to provide an output signal OUT having the voltage of the high supply voltage. The six other data represented by the three bits may have intermediate voltages between the high and low supply voltages.
The first driver section 1120, the second driver section 1130, the third driver section 1140, and the boost circuit 1146 are shown in
In operation, the D flip-flop circuit 1210 latches a current logic level of the IN<2> bitstream responsive to a rising edge of the CLK signal and provides an output signal D<2> having the same logic level as the latched logic level. The D flip-flop circuit 1220 latches the logic level of the D<2> signal responsive to a rising edge of the CLKF signal and provides an output signal DD<2> having the same logic level as the latched logic level. The D flip-flop circuit 1230 latches a current logic level of the IN<1> bitstream responsive to a rising edge of the CLK signal and provides an output signal D<1> having the same logic level as the latched logic level. The D flip-flop circuit 1240 latches the logic level of the D<1> signal responsive to a rising edge of the CLKF signal and provides an output signal DD<1> having the same logic level as the latched logic level. Likewise, the D flip-flop circuit 1250 latches a current logic level of the IN<0> bitstream responsive to a rising edge of the CLK signal and provides an output signal D<0> having the same logic level as the latched logic level. The D flip-flop circuit 1260 latches the logic level of the D<0> signal responsive to a rising edge of the CLKF signal and provides an output signal DD<0> having the same logic level as the latched logic level. As previously described, the DD<2>, DD<1>, and DD<0> signals, which are based on the IN<2>, IN<1>, and IN<0> bitstreams, are provided to the driver sections 1120, 1130, and 1140, all respectively, of the signal driver 1100.
With reference to the CLK signal, the IN<2>, IN<1>, and IN<0> bitstreams are latched and the D<2>, D<1>, and D<0> signals provided responsive to a rising edge of the CLK signal, and the D<2>, D<1>, and D<0> signals are latched and the DD<2>, DD<1>, and DD<0> signals are provided responsive to a falling edge of the CLK signal (i.e., the rising edge of the CLKF signal). Thus, the DD<2>, DD<1>, and DD<0> signals have the logic levels of the D<2>, D<c>, and D<0> signals delayed by one-half a clock period of the CLK signal.
In operation, the logic circuit 1300 provides an active PREPU signal (e.g., active high logic level) when the data of the IN<2>, IN<1>, and IN<0> bitstreams changes from a previous value to a current data of “111”. That is, where the previous data represented by the IN<2>, IN<1>, and IN<0> bitstreams is “000”, “001”, “010”, “011”, “100”, “101”, or “110”, and the data changes to a current data of “111”, the logic circuit 1300 provides an active PREPU signal. The logic circuit 1300 provides an inactive PREPU signal for other changes from a previous data to a current data represented by the IN<2>, IN<1>, and IN<0> bitstreams. That is, the logic circuit 1300 provides an inactive PREPU signal for the IN<2>, IN<1>, and IN<0> bitstreams changing from a previous data to current data of “000”, “001”, “010”, “011”, “100”, “101”, or “110”. The active PREPU signal provided by the logic circuit 1300 may be used to activate a boost circuit, for example, the boost circuit 1146 of the signal driver 1100, to provide additional drive to assist driving the common node to the high supply voltage to provide an OUT signal having a voltage of the high supply voltage. The PREPU signal is active for a portion of the data period of the OUT signal. For example, in some embodiments of the disclosure, the PREPU signal is limited to being active to assist the driving of the common node to the high supply voltage.
The NAND logic circuit 1310 provides a low logic level D_111F signal when D<2>, D<1>, and D<0> are all a high logic level (i.e., resulting from the IN<2>, IN<1>, and IN<0> bitstreams representing a current data of “111”). The inverter circuit 1330 coupled to the NAND logic circuit 1320 provides a low logic level DD_111 when DD<2>, DD<1>, and DD<0> signals are all a high logic level (i.e., resulting from D<2>, D<1>, and D<0> all a high logic level). Recall that the DD<2>, DD<1>, and DD<0> signals are delayed relative to the D<2>, D<1>, and D<0> signals, for example, by one-half a clock period of the CLK signal. The NOR logic gate 1340 provides an active PREPU signal (e.g. active high logic level) when the D_111F and DD_111 signals have low logic levels. As a result, the PREPU signal is active when the D<2>, D<1>, and D<0> signals are at a high logic level, and for one-half a clock cycle of the CLK signal following a rising edge of the CLK signal. The PREPU signal is active for one-half a clock cycle of the CLK signal because the one-half clock cycle delay of the DD<2>, DD<1>, and DD<0> signals relative to the D<2>, D<1>, and D<0> signals will result in the DD_111 signal being at a low logic level while the D_111F signal is at a low logic level (from D<2>, D<1>, and D<0> being a high logic level), but for one-half a clock cycle of the CLK signal before DD<2>, DD<1>, and DD<0> also become a high logic level (resulting from the D<2>, D<1>, and D<0> signals being at the high logic level). As a result, the PREPU signal is active for one-half a clock cycle of the CLK signal.
In operation, the logic circuit 1350 provides an active PREPD signal (e.g., active high logic level) when the data of the IN<2>, IN<1>, and IN<0> bitstreams changes from a previous value to a current data of “000”. That is, where the previous data represented by the IN<2>, IN<1>, and IN<0> bitstreams is “001”, “010”, “011”, “100”, “101”, “110”, or “111”, and the data changes to a current data of “000”, the logic circuit 1350 provides an active PREPD signal. The logic circuit 1350 provides an inactive PREPD signal for other changes from a previous data to a current data represented by the IN<2>. IN<1>, and IN<0> bitstreams. That is, the logic circuit 1350 provides an inactive PREPD signal for the IN<2>, IN<1>, and IN<0> bitstreams changing from a previous data to current data of “001”, “010”, “011”, “100”, “101”, “110”, or “111”. The active PREPD signal provided by the logic circuit 1350 may be used to activate a boost circuit, for example, the boost circuit 1146 of the signal driver 1100, to provide additional drive to assist driving the common node to the low supply voltage to provide an OUT signal having a voltage of the low supply voltage. As will be described in more detail below, the PREPD signal is active for a portion of the data period of the OUT signal. For example, in some embodiments of the disclosure, the PREPD signal is limited to being active to assist the driving of the common node to the low supply voltage.
The inverter circuit 1380 coupled to the NOR logic circuit 1360 provides a low logic level D_000F signal when D<2>, D<1>, and D<0> are all a low logic level (i.e., resulting from the IN<2>, IN<1>, and IN<0> bitstreams representing a current data of “000”). The NOR logic circuit 1370 provides a high logic level DD_000 signal when DD<2>, DD<1>, and DD<0> are all a low logic level (i.e., resulting from D<2>, D<1>, and D<0> all a low logic level). Recall that the DD<2>, DD<1>, and DD<0> signals are delayed relative to the D<2>, D<1>, and D<0> signals, for example, by one-half a clock period of the CLK signal. The NOR logic gate 1390 provides an active PREPD signal (e.g. active high logic level) when the D_000F and DD_000 signals have low logic levels. As a result, the PREPD signal is active when D<2>, D<1>, and D<0> are at a low logic level, and for one-half a clock cycle of the CLK signal following a rising edge of the CLK signal. The PREPD signal is active for one-half a clock cycle of the CLK signal because the one-half clock cycle delay of the DD<2>, DD<c>, and DD<0> relative to D<2>, D<1>, and D<0> will result in the DD_000 signal being at a low logic level while the D_000F signal is at a low logic level (from D<2>, D<1>, and D<0> being a low logic level), but for one-half a clock cycle of the CLK signal before the DD<2>, DD<I>, and DD<0> signals also become a low logic level (resulting from the D<2>, D<1>, and D<0> signals being at the low logic level) and the NOR logic circuit 1370 provides a high logic level DD_000. As a result, the PREPD signal is active for one-half a clock cycle of the CLK signal.
The memory 1400 further includes an address latch 1410 that receives memory addresses through an address bus 1420, for example, row and column addresses. The address latch 1410 then outputs separate column addresses and separate row addresses. The row and column addresses are provided by the address latch 1410 to a row address decoder 1422 and a column address decoder 1428, respectively. The column address decoder 1428 selects bit lines extending through the array 1402 corresponding to respective column addresses. The row address decoder 1422 is connected to word line driver 1424 that activates respective rows of memory cells in the array 1402 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 1430 to provide read data to a data output circuit 1434 via an input-output data bus 1440. The data output circuit 1434 may include multilevel signal drivers 1435 that are configured to drive multilevel voltages on signal lines of an output data bus. The multilevel signal drivers 1435 may include signal drivers according to embodiments of the disclosure, including for example, the signal drivers and circuits previously shown and described, or combinations thereof. Write data to be written to the array 1402 are received by the data input circuit 1444 and provided over the input-output data bus 1440 to the read/write circuitry 1430. The data is then written to the array 1402 in the memory cells corresponding to the row and column addresses of the write command.
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 scope disclosure should not be limited any of the specific embodiments described herein.
This application is a divisional of U.S. application Ser. No. 15/783,688 filed Oct. 13, 2017, issued as U.S. Pat. No. 10,283,187 on May 7, 2019, which claims the filing benefit of U.S. Provisional Application No. 62/534,436, filed Jul. 19, 2017. These applications and patent are incorporated by reference herein in their entirety and for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5166956 | Baltus et al. | Nov 1992 | A |
5446697 | Yoo et al. | Aug 1995 | A |
5770967 | Alzati et al. | Jun 1998 | A |
5917340 | Manohar et al. | Jun 1999 | A |
6078627 | Crayford | Jun 2000 | A |
6199182 | Whetsel | Mar 2001 | B1 |
6208575 | Proebsting | Mar 2001 | B1 |
6745316 | Yang | Jun 2004 | B1 |
6772351 | Werner et al. | Aug 2004 | B1 |
7224737 | Voutilainen | May 2007 | B2 |
8026740 | Hollis | Sep 2011 | B2 |
8363707 | Hollis | Jan 2013 | B2 |
8436653 | Hollis | May 2013 | B2 |
8594262 | Slezak et al. | Nov 2013 | B2 |
8737456 | Hollis | May 2014 | B2 |
8760225 | Wilson | Jun 2014 | B1 |
8781022 | Chang et al. | Jul 2014 | B1 |
8854236 | Hollis | Oct 2014 | B2 |
9112550 | Ulrich | Aug 2015 | B1 |
9116828 | Hollis | Aug 2015 | B2 |
9263107 | Wayland et al. | Feb 2016 | B1 |
9464918 | Klode et al. | Oct 2016 | B2 |
9479369 | Shokrollahi | Oct 2016 | B1 |
9917711 | Ulrich | Mar 2018 | B2 |
9979354 | Høyerby | May 2018 | B2 |
10283187 | Hollis | May 2019 | B2 |
10403337 | Butterfield | Sep 2019 | B2 |
10425260 | Hollis et al. | Sep 2019 | B2 |
20020084833 | Kim et al. | Jul 2002 | A1 |
20020196510 | Hietala et al. | Dec 2002 | A1 |
20030156101 | Lechevalier | Aug 2003 | A1 |
20030169195 | Hietala et al. | Sep 2003 | A1 |
20030205974 | Kuehner et al. | Nov 2003 | A1 |
20030214347 | Nuzzarello et al. | Nov 2003 | A1 |
20040066225 | Seo | Apr 2004 | A1 |
20040207329 | Kudo et al. | Oct 2004 | A1 |
20050078712 | Voutilainen | Apr 2005 | A1 |
20050147178 | Kikuchi | Jul 2005 | A1 |
20050220232 | Kunnari et al. | Oct 2005 | A1 |
20060197550 | Mauthe | Sep 2006 | A1 |
20070171998 | Hietala et al. | Jul 2007 | A1 |
20070183205 | Lee | Aug 2007 | A1 |
20080068070 | Lee et al. | Mar 2008 | A1 |
20080150620 | Lesso | Jun 2008 | A1 |
20080297199 | Grunzke | Dec 2008 | A1 |
20080304335 | Shin et al. | Dec 2008 | A1 |
20090059712 | Lee et al. | Mar 2009 | A1 |
20090122593 | Cho et al. | May 2009 | A1 |
20090153176 | Inaba | Jun 2009 | A1 |
20090167344 | Lee | Jul 2009 | A1 |
20090167425 | Park | Jul 2009 | A1 |
20090184239 | Jeong et al. | Jul 2009 | A1 |
20090238300 | Hollis | Sep 2009 | A1 |
20090241006 | Liikanen | Sep 2009 | A1 |
20090243655 | Nascimento | Oct 2009 | A1 |
20090267654 | Hinz | Oct 2009 | A1 |
20090273362 | Fairbanks | Nov 2009 | A1 |
20090298457 | Jakobs | Dec 2009 | A1 |
20090313521 | Hollis | Dec 2009 | A1 |
20100026533 | Hollis | Feb 2010 | A1 |
20100220514 | Vigoda | Sep 2010 | A1 |
20100289556 | Byeon | Nov 2010 | A1 |
20110001534 | Chuang et al. | Jan 2011 | A1 |
20110012521 | Byun et al. | Jan 2011 | A1 |
20110012671 | Chuang et al. | Jan 2011 | A1 |
20110102208 | Terashima | May 2011 | A1 |
20110316618 | Bergler et al. | Dec 2011 | A1 |
20120056624 | Stirk | Mar 2012 | A1 |
20120249636 | Kitabayashi | Oct 2012 | A1 |
20130043900 | Hollis | Feb 2013 | A1 |
20130076395 | Kim | Mar 2013 | A1 |
20130195155 | Pan et al. | Aug 2013 | A1 |
20130207689 | Bansal | Aug 2013 | A1 |
20130278296 | Amirkhany et al. | Oct 2013 | A1 |
20130301750 | Chang et al. | Nov 2013 | A1 |
20140016404 | Kim | Jan 2014 | A1 |
20140043069 | Oh | Feb 2014 | A1 |
20140185388 | Vaysman | Jul 2014 | A1 |
20140210545 | Leibowitz | Jul 2014 | A1 |
20140266319 | Bodem | Sep 2014 | A1 |
20140269975 | Chong | Sep 2014 | A1 |
20140297986 | Lee | Oct 2014 | A1 |
20140313836 | Pan et al. | Oct 2014 | A1 |
20150002408 | Mozak et al. | Jan 2015 | A1 |
20150015329 | Wilson | Jan 2015 | A1 |
20150022383 | Hollis | Jan 2015 | A1 |
20150061738 | Kwon et al. | Mar 2015 | A1 |
20150097598 | Cronin | Apr 2015 | A1 |
20150171836 | Lee | Jun 2015 | A1 |
20150187441 | Hollis | Jul 2015 | A1 |
20150345993 | Klode et al. | Dec 2015 | A1 |
20160065211 | Hsu | Mar 2016 | A1 |
20160087633 | Zhang et al. | Mar 2016 | A1 |
20160094202 | Hollis | Mar 2016 | A1 |
20160094224 | Tamura | Mar 2016 | A1 |
20160149656 | Levin | May 2016 | A1 |
20160282918 | Low | Sep 2016 | A1 |
20160363461 | Klode et al. | Dec 2016 | A1 |
20170039981 | Hwang et al. | Feb 2017 | A1 |
20170131327 | Ullmann et al. | May 2017 | A1 |
20170154007 | Sreerama et al. | Jun 2017 | A1 |
20170212695 | Hollis et al. | Jul 2017 | A1 |
20170287556 | Sandhu | Oct 2017 | A1 |
20170365331 | Chanana et al. | Dec 2017 | A1 |
20180006643 | Schulmeyer et al. | Jan 2018 | A1 |
20180053558 | Tanzawa | Feb 2018 | A1 |
20180123451 | Larsen et al. | May 2018 | A1 |
20180145681 | Foley et al. | May 2018 | A1 |
20190027205 | Hollis et al. | Jan 2019 | A1 |
20190043543 | Butterfield | Feb 2019 | A1 |
20190044764 | Hollis et al. | Feb 2019 | A1 |
20190121381 | Jankowski | Apr 2019 | A1 |
20190287584 | Hollis | Sep 2019 | A1 |
20190316973 | Ippolito | Oct 2019 | A1 |
20190332279 | Hollis et al. | Oct 2019 | A1 |
20190347074 | Choi | Nov 2019 | A1 |
20200081473 | Jankowski | Mar 2020 | A1 |
Number | Date | Country |
---|---|---|
105247791 | Jan 2016 | CN |
I343058 | Jun 2011 | TW |
201411636 | Mar 2014 | TW |
2017127222 | Jul 2017 | WO |
Entry |
---|
U.S. Appl. No. 16/507,292 titled “Apparatuses and Methods for Encoding and Decoding of Signal Lines for Multi-Level Communication Architectures” filed Jul. 10, 2019. |
International Search Report and Written Opinion dated Oct. 29, 2018 for PCT Application No. PCT/US2018/042698, 16 pages. |
Avci, et al., “A Novel Compact Circuit for 4-PAM Energy-Efficient High Speed Interconnect Data Transmission and Reception”, Microelectron Journal, vol. 36, No. 1, pp. 67-75, Jan. 2005. |
Farzan, et al., “A Low-Complexity Power-Efficient Signaling Scheme for Chip-To-Chip Communication”, IEEE, May 2003. |
Koob, et al., “Design and Characterization of a Multilevel DRAM”, IEEE Transactions on Very Large Scale Integration (VLSI) Systems, vol. 19, No. 9, Sep. 2011. |
Liu, et al., “A Multi-Level DRAM with Fast Read and Low Power Consumption”, IEEE, Apr. 2005. |
Rokhani, et al., “Low-Power Bus Transform Coding for Multilevel Signals”, IEEE, Dec. 2006. |
Svensson, et al., “A 3-Level Asynchronous Protocol for a Differential Two-Wire Communication Link”, IEEE Journal of Solid-State Circuits. vol. 29. No. 9, Sep. 1994. |
Number | Date | Country | |
---|---|---|---|
20190237125 A1 | Aug 2019 | US |
Number | Date | Country | |
---|---|---|---|
62534436 | Jul 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15783688 | Oct 2017 | US |
Child | 16375770 | US |