Embodiments of the present invention relate generally to semiconductor memory, and more specifically, in one or more described embodiments, to the timing of internal clock, data, and command signals for capturing data in a memory.
In semiconductor memory, proper operation of the memory is based on the correct timing of various internal command and clock signals. For example, in writing data to memory internal clock signals that clock data path circuitry to capture write data may need to be provided with specific timing relationships with internal write command signals to properly enable the data path circuitry to provide the captured write data for writing to memory. Inaccurate timing of the internal command and clock signals could result in the write command being inadvertently ignored or incorrect write data being provided to the memory may (e.g., the write data is associated with another write command). Likewise, in reading data from the memory, internal clock signals that clock data block circuitry to provide the read data may need to be provided substantially concurrently with internal read command signals to properly enable the data block circuitry to output the read data. If the timing of the internal read command signal is not such that the data block circuitry is enabled at the time the internal clock signal clocks the data block circuitry to output the read data at an expected time, the read command may be inadvertently ignored or the read data provided by the memory may not be correct (i.e., the data associated with another read command).
Complicating the generation of correctly timed internal clock and command signals is the relatively high frequency of memory clock signals. For example, memory clock signals can exceed 1 GHz. Further complicating the matter is that multi-data rate memories may provide and receive data at a rate higher than the memory clock signal, which may represent the rate at which commands may be executed. As a result, the timing domains of command and clock signals may need to be crossed in order to maintain proper timing.
Apparatuses and methods for capturing data in a memory are disclosed herein. Certain details are set forth below to provide a sufficient understanding of embodiments of the invention. However, it will be clear to one skilled in the art that embodiments of the invention may be practiced without these particular details. Moreover, the particular embodiments of the present invention described herein are provided by way of example and should not be used to limit the scope of the invention to these particular embodiments. 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 invention.
The adjustable delay circuit 120 may be configured to receive the buffered CMD and CLK signals from the input buffers 102, 104. The adjustable delay circuit 120 may be configured to delay the buffered command signal CMD to provide a command signal DLLCMD and to delay the buffered clock signal CLK to provide a clock signal DLLCLK. Both the command signal CMD and clock signal CLK may be delayed, for instance, by an amount suitable to substantially synchronize an operation to the clock signal CLK. In one embodiment, for example, this delay may be an amount to account for the propagation delay of a forward clock path, that is, the propagation delay incurred between the adjustable delay circuit 120 and a DQ pad 130 of the apparatus 100 (e.g., propagation delay of the clock path 124, a data multiplexer out 142, and a data output driver 108). In at least one embodiment, the adjustable delay circuit 120 may delay the CMD and CLK signals to provide signals DLLCMD and DLLCLK using a delay-locked loop (DLL), although it will be appreciated by those having ordinary skill in the art that other circuits may be used as well.
The shifter 114 may be coupled to the adjustable delay circuit 120 and configured to receive the command signal DLLCMD and the clock signal DLLCLK therefrom. The shifter 114 may be configured to delay DLLCMD based, at least in part, on DLLCLK and in at least one embodiment, may delay DLLCMD based on a number of clock cycles of DLLCLK needed to satisfy a programmable latency, for example, CAS latency and CAS write latency. By way of example, the shifter 114 may delay the command signal DLLCMD by a number of cycles of the clock signal DLLCLK best matching the programmable latency. The number of cycles to delay DLLCMD may be stored in the shifter 114, or may be provided to the shifter 114 as an N-count control signal (not shown), for instance, by a memory controller or the adjustable delay circuit 120. In this manner, the shifter 114 may be configured to statically or dynamically delay the command signal DLLCMD.
The shifted command signal DLLCMD may be received by the command path 122 from the shifter 114 and delayed to provide a command signal WR_START. The delay of the command path 122 may model both a propagation delay of a DQS input path and the propagation delay of the forward clock path. The propagation delay of the DQS input path may, for example, be the propagation delay of providing a signal, such as a data strobe signal DQS, from the DQS pad 132 to the data capture logic 140 (e.g., propagation delay of the DQS input buffer 110 and the DQS input distribution tree 126). The command path 122 may include a signal distribution tree (not shown) to distribute WR_START to one or more circuits that may rely on WR_START to operate. The clock signal DLLCLK may be received by the clock path 124. The clock path 124 may include a signal distribution tree (not shown) to distribute the clock signal DLLCLK as a clock signal DLLCLK_T to one or more circuits that may rely on DLLCLK_T to operate, such as the data out multiplexer 142 and a DQS output driver 112.
The apparatus 100 may further include a data input buffer 106, a data output driver 108, a DQS input driver 110, a DQS output driver 112, a DQS input distribution tree 126, a data capture logic 140, and a data out multiplexer 142. The input buffers 106, 108 and the output drivers 110, 112 may be any input buffers and output drivers known in the art, now or in the future, and will not be discussed further in the interest of brevity. The data input buffer 106 may be coupled to the DQ pad 130 and the data capture logic 140 and may be configured to provide data, such as write data, from the DQ pad 130 to the data capture logic 140. Data may be provided to the DQ pad 130 according to a strobe signal DQS. The data output driver 108 may be coupled to the data out multiplexer 142 and the DQ pad 130, and may be configured to provide (e.g., output, drive, generate, apply, etc.) data received from the data out multiplexer 142 to the DQ pad 130. The data out multiplexer 142 may be configured to provide data to the output driver 108 according to the clock signal DLLCLK_T provided by the clock path 124.
The DQS input buffer 110 may be coupled to the DQS input distribution tree 126 and the DQS pad 132 and may be configured to provide the data strobe signal DQS from the DQS pad 132 to the DQS input distribution tree 126. The DQS input distribution tree 126 may be used to distribute the data strobe signal DQS as a data strobe signal DQS_T, to one or more circuits that rely on DQS to operate, such as the data capture logic 140. The DQS output driver 112 may be configured to receive the clock signal DLLCLK_T from the clock path 124 and provide DLLCLK_T to the DQS pad 132.
While the described operation of components of
The data capture logic 140 may comprise one or more logic circuits, control logic, logic gates, and/or any combination or sub-combination of the same. As described, the data capture logic 140 may receive signals WR_START and DQS_T from the command path 122 and the DQS input distribution tree 126, respectively. As will be explained in more detail below, based, at least in part, on the WR_START and DQS_T signals, the data capture logic 140 may capture (e.g., latch) data, such as write data, from the data input buffer 106. The captured data may subsequently be provided to a memory array (not shown).
In an example operation of the apparatus 100, the command signal CMD and clock signal CLK may be provided to the input buffers 102, 104, respectively. The adjustable delay circuit 120 may delay the CMD and CLK signals to provide signals DLLCMD and DLLCLK. Signals CMD and CLK may be delayed, for instance, based on the propagation delay of the forward clock path. As previously explained, this delay may account for the propagation delays of the clock path 124, the data out multiplexer 142, the data output driver 108, or any combination thereof. The shifter 114 may receive the DLLCMD and DLLCLK signals and may delay DLLCMD by a number of cycles of DLLCLK that may, for instance, correspond to a programmable latency. The command path 122 may receive and delay the shifted DLLCMD to provide a command signal WR_START. The command path 122 may include model delays which model the propagation delays of the forward clock path and the DQS input path.
In providing the DQS strobe signal to the DQS distribution tree, the DQS strobe signal may be provided to one or more circuits that rely on the DQS strobe signal to operate, including the data capture logic 140. Moreover, the data capture logic 140 may receive the command signal WR_START from the command path 122. Based, at least in part, on the DQS_T and WR_START signals, the data capture logic 140 may capture data provided by the data input buffer 106. As will be explained in more detail below, the command signal WR_START may identify a first valid edge of the DQS_T signal, and in response, the data capture logic 140 may capture data on each edge of the strobe signal DQS_T. The data captured may, for instance, correspond to the command signal CMD provided to the input buffer 102. By delaying the command signal CMD to provide the command signal WR_START, the command signal CMD may be provided to the apparatus 100 before corresponding data is applied to the DQ pad 130 and captured by the data capture logic 140. In this manner, data corresponding to a particular command signal may be properly captured by the data capture logic 140 despite that the data and command signal are not received by the apparatus 100 simultaneously.
In some embodiments, the data capture logic 140 may capture data until a complete write burst has been captured. In other embodiments, a WR_LAST control signal (not shown) may be generated to identify the last valid edge of the DQS_T signal, and the data capture logic 140 may stop capturing data responsive to the WR_LAST control signal. The WR_LAST control signal may be generated by the data capture logic 140 or may be provided by another device, such as a memory controller (not shown). Accordingly, in some embodiments the WR_START and WR_LAST signals may be used to control the manner in which the data capture logic 140 captures data. As described, captured data may be provided from the data capture logic 140 to a memory array.
The distribution tree 202 may be coupled to the DQ model 204 and may be configured to receive the command signal DLLCMD, for instance, from the shifter 114 of
The DQS input buffer model 206 may delay the command signal WR_START_XCLK to provide a command signal WR_START_IB to the DQS input distribution tree model 208. The delay of the DQS input buffer model 206 may model a propagation delay of a DQS input buffer, such as the DQS input buffer 110 of
Although the elements of the command path 200 are described as having a particular order, in other embodiments, the elements of the command path 200 may be arranged in any different order. For example, in one embodiment, the DQS input buffer model 206 may be coupled between the distribution tree 202 and the DQ model 204. The delays provided by one or more of the elements of the command path 200 may model any combination of propagation delays of elements of the apparatus 100 and/or the command path 200. Moreover, respective delays provided by elements of the command path 200 may be adjustable based on one or more respective control signals and/or process, voltage, and/or temperature (PVT) characteristics of the command path 200 and/or the apparatus 100.
The delay line 302 may be coupled to the delay controller 306 and may be configured to receive a buffered command signal CMD, for instance, from the input buffer 102 of
The delay line 304 may provide the clock signal DLLCLK to the model delay 308. The model delay 308 may be configured to provide a delay that models a portion (or all) of one or more propagation delays described herein. In one embodiment, for instance, the model delay may provide a delay that models a portion (or all) of a propagation delay of an input buffer, such as the input buffer 104 of
At a time T0, a clock cycle 0 of the clock signal CLK may be received by the apparatus 100, and in particular, by the input buffer 104. In addition, a command signal CMD may be received by the input buffer 102. The clock signal CLK and the command signal CMD may be provided to the adjustable delay circuit 120. At a time T1, a delayed clock cycle 0 of the clock signal CLK, or clock cycle 0 of the clock signal DLLCLK, may be provided from the adjustable delay circuit 120 to the shifter 114 and the clock path 124. In addition, the command signal CMD may be provided from the adjustable delay circuit 120 to the shifter 114. As previously described, the adjustable delay circuit 120 may be configured to delay the command signal CMD and the clock signal CLK, for instance, by a delay 410 based on the propagation delay of the forward clock path.
At a time T2, the delayed command signal CMD may be provided to the DQ model 204 as the command signal WR_START_PDQ. The DQ model 204 may delay the command signal WRSTART_PDQ by a delay 420 to provide a command signal WR_START_XCLK. At a time T3, WR_START_XCLK may be delayed by a delay 430 to provide a command signal WR_START at a time T4. The delay 430 may for instance, include delays modeled by both the DQS input buffer model 206 and the DQS input distribution tree model 208.
As discussed above, the data capture logic 140 may be configured to receive both the WR_START and DQS_T signals, and the WR_START signal may identify a first valid edge of the DQS_T signal. Thus, the WR_START signal may be provided to the data capture logic 140 at the time T4, and in response, the data capture logic 140 may recognize the next edge of the signal DQS_T, an edge 440, as a first valid edge at which to capture data provided by the data input buffer 106. In one embodiment, the WR_START signal may be received at a falling edge of the signal DQS_T, however, it will be appreciated that the signal WR_START may be received at any point relative to the DQS_T, such that the next edge may properly be identified as a next valid edge. Accordingly, at a time T5, the edge 440 of the DQS_T signal may be received by the data capture logic 140, and the data capture logic 140 may capture data in response. As described, data may be captured at each edge of the signal DQS_T until a WR_LAST (not shown) signal is generated by, or provided to, the data capture logic 140, or until a full burst has been captured by the data capture logic 140.
As explained, the timing diagram 400 is directed to an example operation having a delay of 5 clock cycles of the clock signal DLLCLK. Thus, as illustrated, the command signal WR_START may be received by the data capture logic 140 at a time T4 during the 5th cycle (clock cycle 4) of the clock signal CLK, and in response, the data capture logic 140 may begin capturing data during the 6th cycle (clock cycle 5) of the clock signal CLK. The 5 clock cycle delay between the time at which the command signal CMD is provided to the apparatus 100 and the time at which the data capture logic 140 begins capturing data may be based, at least in part, on the delay provided by the shifter 114.
Accordingly, various embodiments of the invention may delay the command signal WR_START such that it is properly aligned with DQS_T signal. In this manner, the data capture logic 140 may receive the aligned WR_START and DQS_T signals and determine the edges of the DQS_T signal at which data of a write burst should be captured and provided to an array thereafter, as described above.
The row and column addresses may be provided by the address latch 510 to a row address decoder 522 and a column address decoder 528, respectively. The column address decoder 528 may select bit lines extending through the array 502 corresponding to respective column addresses. The row address decoder 522 may be connected to word line driver 524 that activates respective rows of memory cells in the array 502 corresponding to received row addresses. The selected data line (e.g., a bit line or bit lines) corresponding to a received column address may be coupled to a read/write circuitry 530 to provide read data to an input/output data block 502 through the I/O data block 534 and the memory array read/write circuitry 530. The I/O data block 534 may include clocked circuitry that operates responsive to an internal clock signal DLLCLK_T and an internal command signal WR_START, for example.
The memory 500 further includes adjustable delay circuit 514, command path 515, and a clock path 516. The adjustable delay circuit 514 may receive the signals CLK and CMD and provide the signals DLLCLK and DLLCMD in accordance with embodiments of the invention described herein. The command path 515 may receive the signal DLLCMD and provide a command signal WR_START based, at least in part, on the signal DLLCMD. The clock path 516 may receive the signal DLLCLK and provide a DLLCLK_T signal based, at least in part, on the DLLCLK signal.
While the adjustable delay circuit 514 is shown in
From the foregoing it will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.