Gap detection for consecutive write operations of a memory device
Method and devices include a shifter that is configured to receive a write command for a memory device and is configured to produce multiple shifted write commands from the write command. Multiple flip-flops that are configured to receive a subset of the multiple shifted write commands from the shifter. The multiple flip-flops also are configured to output an indicator of whether subsequent write commands of the subset of write commands is asserted when the write command has completed shifting through the shifter as a write start signal.
Latest Micron Technology, Inc. Patents:
- Integrated circuitry comprising a memory array comprising strings of memory cells and method used in forming a memory array comprising strings of memory cells
- Read window management in a memory system
- Memory device sideband systems and methods
- Memory device having memory cell strings and separate read and write control gates
- Metadata storage at a memory device
This application claims priority to U.S. Provisional Patent Application 62/631,760, entitled “DDR5 Memory Device,” and filed on Feb. 17, 2018, which this application incorporates entirely for all purposes.
BACKGROUND Field of the Present DisclosureEmbodiments of the present disclosure relate generally to the field of gap detection between consecutive writes for memory devices. More specifically, embodiments of the present disclosure relate to outputting an indicator of a gap between consecutive write operations for memory devices.
Description of Related ArtSemiconductor devices (e.g., memory devices) utilize timing with phase shifts of data signals, data strobes, and/or other signals to perform operations (e.g., write operations). A decision feedback equalizer (DFE) may be used to maintain a buffer of a number (e.g., 4) of preceding data bits to improve accuracy in interpreting whether a current bit is high or low. For example, if the DFE has 4 previous low data bits stored, then a data line (DQ) will be at a lower voltage level, and the current data bit is to be interpreted as a logical high or a low relative to that level. However, contents of the DFE at the beginning (e.g., a first bit) of write operations may vary according to how closely spaced the write operations occur on the DQ.
Embodiments of the present disclosure may be directed to one or more of the problems set forth above.
One or more specific embodiments will be described below. In an effort to provide a concise description of these embodiments, not all features of an actual implementation are described in the specification. It should be appreciated that in the development of any such actual implementation, as in any engineering or design project, numerous implementation-specific decisions must be made to achieve the developers' specific goals, such as compliance with system-related and business-related constraints, which may vary from one implementation to another. Moreover, it should be appreciated that such a development effort might be complex and time consuming, but would nevertheless be a routine undertaking of design, fabrication, and manufacture for those of ordinary skill having the benefit of this disclosure.
A decision feedback equalizer (DFE) may utilize a DFE buffer to track previous data levels to interpret incoming data levels. Between write operations, this DFE buffer may be reset to an initial state (e.g., all high or low values) in the DFE buffer. However, some write operations may be closely spaced which may prevent complete resetting of the DFE buffer between write operations. Accordingly, a memory device incorporating the DFE may utilize reset circuitry to reset the DFE buffer unless suppression circuitry suppresses the reset for specific conditions. To implement resets/suppressions, generation circuitry may be used to detect a gap between consecutive write operations and generate an appropriate signal that controls whether the DFE buffer is reset or whether the reset is suppressed.
Turning now to the figures,
The memory device 10, may include a number of memory banks 12. The memory banks 12 may be DDR5 SDRAM memory banks, for instance. The memory banks 12 may be provided on one or more chips (e.g., SDRAM chips) that are arranged on dual inline memory modules (DIMMS). Each DIMM may include a number of SDRAM memory chips (e.g., x8 or x16 memory chips), as will be appreciated. Each SDRAM memory chip may include one or more memory banks 12. The memory device 10 represents a portion of a single memory chip (e.g., SDRAM chip) having a number of memory banks 12. For DDR5, the memory banks 12 may be further arranged to form bank groups. For instance, for an 8 gigabyte (Gb) DDR5 SDRAM, the memory chip may include 16 memory banks 12, arranged into 8 bank groups, each bank group including 2 memory banks. For a 16 Gb DDR5 SDRAM, the memory chip may include 32 memory banks 12, arranged into 8 bank groups, each bank group including 4 memory banks, for instance. Various other configurations, organization and sizes of the memory banks 12 on the memory device 10 may be utilized depending on the application and design of the overall system.
The memory device 10 may include a command interface 14 and an input/output (I/O) interface 16. The command interface 14 is configured to provide a number of signals (e.g., signals 15) from an external device, such as a processor or controller 17. The processor or controller 17 may provide various signals 15 (including the DQ signals) to the memory device 10 to facilitate the transmission and receipt of data to be written to or read from the memory device 10.
As will be appreciated, the command interface 14 may include a number of circuits, such as a clock input circuit 19 and a command address input circuit 20, for instance, to ensure proper handling of the signals 15. The command interface 14 may receive one or more clock signals from an external device. Generally, double data rate (DDR) memory utilizes a differential pair of system clock signals, referred to herein as the true clock signal (Clk_t) and the bar clock signal (Clk_c). The positive clock edge for DDR refers to the point where the rising true clock signal Clk_t crosses the falling bar clock signal Clk_c, while the negative clock edge indicates that transition of the falling true clock signal Clk_t and the rising of the bar clock signal Clk_c. Commands (e.g., read command, write command, etc.) are typically entered on the positive edges of the clock signal and data is transmitted or received on both the positive and negative clock edges.
The clock input circuit 19 receives the true clock signal (Clk_t) and the bar clock signal (Clk_c) and generates an internal clock signal CLK. The internal clock signal CLK is supplied to an internal clock generator, such as a delay locked loop (DLL) circuit 30. The DLL circuit 30 generates a phase controlled internal clock signal LCLK based on the received internal clock signal CLK. The phase controlled internal clock signal LCLK is supplied to the I/O interface 16, for instance, and is used as a timing signal for determining an output timing of read data.
The internal clock signal(s)/phases CLK may also be provided to various other components within the memory device 10 and may be used to generate various additional internal clock signals. For instance, the internal clock signal CLK may be provided to a command decoder 32. The command decoder 32 may receive command signals from the command bus 34 and may decode the command signals to provide various internal commands. For instance, the command decoder 32 may provide command signals to the DLL circuit 30 over the bus 36 to coordinate generation of the phase controlled internal clock signal LCLK. The phase controlled internal clock signal LCLK may be used to clock data through the IO interface 16, for instance.
Further, the command decoder 32 may decode commands, such as read commands, write commands, mode-register set commands, activate commands, etc., and provide access to a particular memory bank 12 corresponding to the command, via the bus path 40. As will be appreciated, the memory device 10 may include various other decoders, such as row decoders and column decoders, to facilitate access to the memory banks 12. In one embodiment, each memory bank 12 includes a bank control block 22 which provides the necessary decoding (e.g., row decoder and column decoder), as well as other features, such as timing control and data control, to facilitate the execution of commands to and from the memory banks 12.
The memory device 10 executes operations, such as read commands and write commands, based on the command/address signals received from an external device, such as a processor. In one embodiment, the command/address bus may be a 14-bit bus to accommodate the command/address signals (CA<13:0>). The command/address signals are clocked to the command interface 14 using the clock signals (Clk_t and Clk_c). The command interface may include a command address input circuit 20 which is configured to receive and transmit the commands to provide access to the memory banks 12, through the command decoder 32, for instance. In addition, the command interface 14 may receive a chip select signal (CS_n). The CS_n signal enables the memory device 10 to process commands on the incoming CA<13:0> bus. Access to specific banks 12 within the memory device 10 is encoded on the CA<13:0> bus with the commands.
In addition, the command interface 14 may be configured to receive a number of other command signals. For instance, a command/address on die termination (CA_ODT) signal may be provided to facilitate proper impedance matching within the memory device 10. A reset command (RESET_n) may be used to reset the command interface 14, status registers, state machines and the like, during power-up for instance. The command interface 14 may also receive a command/address invert (CAI) signal which may be provided to invert the state of command/address signals CA<13:0> on the command/address bus, for instance, depending on the command/address routing for the particular memory device 10. A mirror (MIR) signal may also be provided to facilitate a mirror function. The MIR signal may be used to multiplex signals so that they can be swapped for enabling certain routing of signals to the memory device 10, based on the configuration of multiple memory devices in a particular application. Various signals to facilitate testing of the memory device 10, such as the test enable (TEN) signal, may be provided, as well. For instance, the TEN signal may be used to place the memory device 10 into a test mode for connectivity testing.
The command interface 14 may also be used to provide an alert signal (ALERT_n) to the system processor or controller for certain errors that may be detected. For instance, an alert signal (ALERT_n) may be transmitted from the memory device 10 if a cyclic redundancy check (CRC) error is detected. Other alert signals may also be generated. Further, the bus and pin for transmitting the alert signal (ALERT_n) from the memory device 10 may be used as an input pin during certain operations, such as the connectivity test mode executed using the TEN signal, as described above.
Data may be sent to and from the memory device 10, utilizing the command and clocking signals discussed above, by transmitting and receiving data signals 44 through the IO interface 16. More specifically, the data may be sent to or retrieved from the memory banks 12 over the datapath 46, which includes multiple bi-directional data buses. Data IO signals, generally referred to as DQ signals, are generally transmitted and received in one or more bi-directional data busses. The datapath 46 may convert the DQ signals from a serial bus 48 to a parallel bus 49. For example, the datapath 46 may include a parallelizer 50 to translate the serial bus 48 to the parallel bus 49. The parallelizer 50 (and/or the IO interface 16) includes decision feedback engine (DFE) circuitry 52 that includes a buffer of a number (e.g., 4) of previous bits (e.g., high or low) that may be used to interpret incoming data bits in data IO signals, generally referred to as DQ signals. The DFE circuitry 52 uses the previous levels in the DQ signals to increase accuracy of interpreting incoming bits in the DQ signals.
For certain memory devices, such as a DDR5 SDRAM memory device, the IO signals may be divided into upper and lower bytes. For instance, for a x16 memory device, the IO signals may be divided into upper and lower IO signals (e.g., DQ<15:8> and DQ<7:0>) corresponding to upper and lower bytes of the data signals, for instance.
To allow for higher data rates within the memory device 10, certain memory devices, such as DDR memory devices may utilize data strobe signals, generally referred to as DQS signals. The DQS signals are driven by the external processor or controller sending the data (e.g., for a write command) or by the memory device 10 (e.g., for a read command). For read commands, the DQS signals are effectively additional data output (DQ) signals with a predetermined pattern. For write commands, the DQS signals are used as clock signals to capture the corresponding input data. As with the clock signals (Clk_t and Clk_c), the DQS signals may be provided as a differential pair of data strobe signals (DQS_t and DQS_c) to provide differential pair signaling during reads and writes. For certain memory devices, such as a DDR5 SDRAM memory device, the differential pairs of DQS signals may be divided into upper and lower data strobe signals (e.g., UDQS_t and UDQS_c; LDQS_t and LDQS_c) corresponding to upper and lower bytes of data sent to and from the memory device 10, for instance.
The DQS signals are driven by the controller 17 to the memory device 10 to strobe in write data. When the write operation is complete, the controller 17 will stop driving the DQS and allow it to float to an indeterminate tri-state condition. When the DQS signal is no longer driven by the controller 17, the external DQS signal from the controller 17 to the memory device 10 will be at an unknown/indeterminate state. This state can cause undesirable behavior inside the memory device 10 because an internal DQS signal inside the memory device 10 may be at an intermediate level and/or may oscillate. In some embodiments, even the external DQS signal may ring at the I/O interface 16 when the controller 17 stops driving the external DQS signal.
The DDR5 specification may include a short postamble period where the external DQS signal is still driven by the controller 17 after the last write data bit to allow time for disabling of write circuitry to propagate before the controller 17 ceases to drive the external DQS signal. The DDR5 specification may define a short (e.g., 0.5 tCK) postamble period and a long (e.g., 1.5 tCK) postamble period that may be selected using a mode register. However, the short postamble period may provide a short period of time to reset a DFE buffer.
Returning to
In addition, a loopback signal (LOOPBACK) may be provided to the memory device 10 through the IO interface 16. The loopback signal may be used during a test or debugging phase to set the memory device 10 into a mode wherein signals are looped back through the memory device 10 through the same pin. For instance, the loopback signal may be used to set the memory device 10 to test the data output of the memory device 10. Loopback may include both a data and a strobe or possibly just a data pin. This is generally intended to be used to monitor the data captured by the memory device 10 at the IO interface 16.
As will be appreciated, various other components such as power supply circuits (for receiving external VDD and VSS signals), mode registers (to define various modes of programmable operations and configurations), read/write amplifiers (to amplify signals during read/write operations), temperature sensors (for sensing temperatures of the memory device 10), etc., may also be incorporated into the memory device 10. Accordingly, it should be understood that the block diagram of
For DDR5, the DFE circuitry 52 for data input receivers of the DQ signals is specified to maintain a “history” buffer of a preceding number (e.g., 4) of data bits to interpret whether the current bit is interpreted as a high or a low. For example, if the preceding data bits were all low, the system data channel (DQ) data line will be at a lower voltage level and the current data bit is to be interpreted as a logical high or a low relative to that level.
However, some new writes may have no preceding data. For any new write where there is no preceding data, the DFE circuitry 52 is expected to have been placed into a reset condition such that the “history” buffer of bits is at a pre-arranged level (e.g., high or low). The host sets the system data channel (DQ) line to be at the proper voltage level, such as high at the positive rail, in order to correspond to the pre-arranged buffer condition.
DDR5 allows write operations to be performed consecutively such that data entry is gapless between two consecutive writes. In this case, the normal postamble for the first write operation and/or the normal preamble for the second write operation may be completely eliminated. For some consecutive write operations, there may be cycle gaps having a certain gap (e.g., 1, 2, 3, or more cycles) between the data burst of the first write operation and the data burst of the second write operation. For these cases, there may be a specified partial postamble and/or partial preamble to support these operations.
In some consecutive write operations, the spacing between the first write operation and the second write operation is such that the entire first postamble and second preamble is met and there may even be additional clock cycles in between the two write operations. When there are additional clock cycles in between the first postamble and second preamble, the DQS strobe may be disabled (float) or driven depending on the specification. Thus, the DFE circuitry 52 may reset the DFE buffer at the end of a write burst using reset circuitry when sufficient time to reset occurs between write operations, but the reset may be at least partially suppressed when there is insufficient time (e.g., less than 2 DQS cycles) between write operations. As noted below, when the DFE reset is suppressed at the end of a write burst, the DFE buffer may instead be populated using data strobed in using the available DQS cycles. For example, in a suppression of a reset of a 4-bit DFE buffer when 2 DQS cycles occur between write operations, 4 bits (on rising and falling edges of the DQS cycles) of “not live” data existing on the data line may be written into the DFE buffer. Moreover, in a suppression of a reset of a 4-bit DFE buffer when only a single cycle occurs between write operations, 2 bits (on rising and falling edges of the DQS cycle) may be written into the DFE buffer even though the buffer may only be halfway overwritten with “not live” data.
Example Timing Diagrams Implemented in the Memory Device
Specification of Write Postambles of 0.5 nCK DQS and Write Preambles of 1 nCK DQS
Returning to
Furthermore, as illustrated in the timing diagram 90, a 0.5 nCK postamble 98 of the first write operation 94 occurs after the last bit capture 100 of the first write operation 94. Moreover, as illustrated, the preamble 102 has a 1 nCK duration for the second write operation 96. The reset period 92 occurs during a 2 nCK (or greater) gap between the last bit capture 100 and the first bit capture 104. During this period, the DFE buffer 76 may be reset completely using the reset circuitry 78 during the reset period 92. For example, the DFE buffer 76 may be initialized to all high (or all low) values during the reset period 92. Since reset period 92 occurs between the postamble 98 and the preamble 102, in some embodiments, the DQS signal may float to an indeterminate state.
Write Postambles of 0.5 nCK DQS and Write Preambles of 2 nCK DQS
When no cycles exist between the last bit capture 100 and the first bit capture 104, the preamble 102 may be completely omitted while the 0.5 nCK postamble is included. Thus, in such a situation, the memory device 10 may utilize the timing diagram 120 of
Write Postambles of 0.5 nCK DQS and Write Preambles of 3 nCK DQS
If no cycles exist between the last bit capture 100 and the first bit capture 104 when a 3 nCK preamble is specified, the preamble 102 may be completely omitted resulting in the memory device 10 using the timing diagram 120 of
Write Postambles of 1.5 nCK DQS and Write Preambles of 1 nCK DQS
Write Postambles of 1.5 nCK DQS and Write Preambles of 2 nCK DQS
If no cycles exist between the last bit capture 100 and the first bit capture 104 when a 2 nCK preamble is specified with a 1.5 nCK postamble, the preamble 102 and the postamble 98 may be completely omitted resulting in the memory device 10 using the timing diagram 200 of
Write Postambles of 1.5 nCK DQS and Write Preambles of 3 nCK DQS
If only a single cycle exists between the last bit capture 100 and the first bit capture 104 when a 3 nCK preamble is specified with a 1.5 nCK postamble, the preamble 102 may be completely omitted resulting in the memory device 10 using the timing diagram 230 of
If no cycles exist between the last bit capture 100 and the first bit capture 104 when a 3 nCK preamble is specified with a 1.5 nCK postamble, the preamble 102 and the postamble 98 may both be completely omitted resulting in the memory device 10 using the timing diagram 200 of
The foregoing timing diagrams of
Reset Circuitry
Firing of the a_Rst signal 311, as previously discussed, may be suppressed when a DFErstMaskF signal 314 is asserted (e.g. transitions low). In some embodiments, the DFErstMaskF signal 314 may pass through a flip-flop 316 that may be optionally placed in a flow-through configuration using a switch 318. An inverter 320 may be included to ensure that differential clocking may be used by the flip-flop 316. In some embodiments, the flip-flop 316 may be omitted.
A cyclic redundancy check (CRC) flip-flop 322 may be included to provide an extra shift from the a_Rst signal 311 to an output a_CRCRst signal 324 for the instances where CRC is enabled. When CRC is enabled, one more DQS cycle occur before the end of the write burst. As discussed in relation to
In some embodiments, the DQS signal may be divided into a number (e.g., 4) separate phases. For example, each phase corresponds to every other rising edge or every other falling edge of the DQS. For such 4-phase DQS implementations, the CRC shift may be applied only to the leading phase. To ensure that only the leading phase has the CRC shift added, a ThisPhLeadF signal 326 is used to indicate whether the phase is a leading phase (e.g., the first rising or the first falling edge) of a writing operation. ThisPhLeadF signal 326 and an mrWrCRCEnF signal 328 are submitted to a NOR gate 329 to generate a CRCrstEn signal 330. The mrWrCRCEnF signal 328 is used to indicate whether CRC is enabled for the write operation, and the CRCrstEn signal 330 indicates whether CRC is enabled for the corresponding phase. In other words, for a 4-phase implementation, the reset circuitry 78 (or at least first portion 300 and second portion 340) may be reproduced for each phase of a same type (e.g., rising or falling edge).
In some embodiments, the reset of the DFE buffer 76 may be forced independent of whether a write operation. For instance, a DIBWrEn signal 331 may be provided to force a reset of the DFE buffer 76 when no write operation is in progress or pending.
The first portion 300 may utilize an RstRstF signal 332 to reset the first portion 300. For example, the RstRstF signal 332 may be used to reset the clock-gating circuitry 304, the flip-flop 310, and/or the flip-flop 322 after a width of the pulse from the flip-flop 310 and/or the flip-flop 322 has been passed. To ensure the timing back to the clock-gating circuitry 304, a delay 334 may be used to delay resetting the clock-gating circuitry 304 for some time after the flip-flops 310, 322 are reset.
The a_Rst signal 311, the a_CRCRst signal 324, the CRCrstEn signal 330, and the DIBWrEn signal 331 are passed to a second portion 340 of the reset circuitry 78 as illustrated in
A feedback path 354 may be used to feedback the RstRstF signal 332. The feedback includes inverters and/or delays and sets the width of the pulse of the FastDFErstPhF signal 344 by delaying the leading edge and feeding it back to the first portion 300 to cause a reset of the FastDFErstPhF signal 344. In other words, the FastDFErstPhF signal 344 is a self-timed pulse that has a duration set by the feedback path 354.
As appreciated, for write operations where the input buffer reset is not suppressed, the DFE buffer 76 is to be reset very quickly after the capture of the last bit of a write burst. If the reset is not suppressed, the reset may have as few as 1.5 cycles to receive the first “conditioning” bit captured by a 2nd rising edge of the DQS after a write operation's last captured using a falling edge. In this timing scenario, 2 conditioning bits may be captured from the data line. To ensure timeliness of the reset or suppression, the reset circuitry 78 passes such signals using the first and second portions 300, 340.
The GaplessWrites signal 400 and the OneGapWrites signal 402 are submitted to a NOR gate 408. Similarly, the TwoGapWrites signal 404 and the WPst15 signal 406 are submitted to a NAND gate 410. The output of the NOR gate 408 and the NAND gate 410 are passed to a NAND gate 412 along with optional override signals that may be used to force the output of the NAND gate 412 to a specific value regardless of the values of the GaplessWrites signal 400, the OneGapWrites signal 402, the TwoGapWrites signal 404, and the WPst15 signal 406.
In addition to these signals, the suppression circuitry 80 receives a Bst8En signal 416. The Bst8En signal 416 indicates whether the write data burst length for a write operation has been truncated. For example, if asserted, the Bst8En signal 416 may indicate that only 8 bits are being transmitted instead of a possible 16 bits. Thus, when the Bst8En signal 416 is asserted, the write operation always has enough space to complete the reset. Accordingly, the Bst8En signal 416 may be used to force a condition that DFE buffer 76 resets are never suppressed by the suppression circuitry via the DFErstMaskF signal 314 via the NAND gate 418 and the inverter 420.
The generation circuitry 82 includes a cas (column access strobe) write latency (CWL) shifter 500. The CWL shifter 500 includes serially-connected flip-flops 502, 504, 506, 508, 510, 512, 514, 516, 518, 520, 522, 524, and 526, collectively referred to as flip-flops 502-526. The CWL shifter 500 may also include one or more other flip-flops to delay received signals (e.g., write commands) by an amount of CWL for the memory device 10. The CWL shifter 500 uses the flip-flops 502-526 to receive a write command as WrCmd13 signal 528. The WrCmd13 signal 528 is a write command passed through the CWL shifter as a received write command delayed by the CWL minus a number of cycles equal to a number of flip-flops included for use in the generation circuitry 82. In the illustrated embodiment, since the illustrated portion of the CWL shifter 500 includes thirteen flip-flops 502-526, the WrCmd13 signal 528 is the delay of an incoming write command delayed by the CWL minus thirteen cycles. After WrCmd13 signal 528 has shifted through the flip-flops 502-528, it is output as a WrStart signal 530. The WrStart signal 530 begins the internal DRAM write operation for the memory device 10.
To determine whether a subsequent write command is shifting through the CWL shifter 500 behind a previous write command, a SloGaplessWrites signal 532 from the CWL shifter 500 that is a number (e.g., 8) stages prior to the WrStart signal 530 in the CWL shifter 500. In some embodiments, the number may be any number that includes a length of the write operation. For instance, for a double-data rate using a pre-fetch (e.g., 16 bits), the number of cycles may be half of the number of bits in the pre-fetch. As illustrated, the SloGaplessWrites signal 532 is captured between flip-flops 510 and 512. When the write commands have no gaps between consecutive write commands, the previous write command has completed shifting through the CWL shifter 500 and has asserted the WrStart signal 530. When no gap occurs between the write operations, the WrStart signal 530 causes a flip-flop 534 to capture the subsequent write command that is the number of stages prior to the WrStart signal 530 in the CWL shifter 500. Capture of the SloGaplessWrites signal 532 causes the flip-flop 534 to assert a GaplessWrites signal 400 absent assertion of a cyclic redundancy check (CRC) discussed below.
Similarly, if the write operations occur with a one-cycle gap between the write operations, a SloOneGapWrites signal 538 between flip-flops 508 and 510 is captured by a flip-flop 540 upon assertion of the WrStart signal 530. Absent CRC assertion, the flip-flop 540 asserts a OneGapWrites signal 402.
Moreover, if the write operations occur with a two-cycle gap between the write operations, a SloTwoGapWrites signal 544 is captured between flip-flops 506 and 508 and captured by a flip-flop 546 upon assertion of the WrStart signal 530. Absent CRC assertion, the flip-flop 546 asserts a TwoGapWrites signal 404. Furthermore, if the write operations occur with a three-cycle gap between the write operations, a SloThreeGapWrites signal 550 between flip-flops 504 and 506 is captured by a flip-flop 552 upon assertion of the WrStart signal 530. Absent CRC assertion, the flip-flop 552 asserts a ThreeGapWrites signal 554.
If four cycles occur between the write operations, a SloFourGapWrites signal 556 from between flip-flops 502 and 504 is captured at a flip-flop 558 based on the WrStart signal 530. This captured value is used when CRC is enabled using a mrWrCRCEn signal 560 used to indicate whether CRC is used for the write operations. Since CRC adds an additional cycle to the write operation (e.g., 18 bits instead of 16 bits), multiplexers 562, 564, 566, and 568 may be used to select between signals based on whether mrWrCRCEn signal 560 indicates that CRC is enabled. In other words, when CRC is included, the multiplexers 562, 564, 566, and 568 cause the assertion of a signal corresponding to a smaller number of writes than captured to account for the additional CRC bit. Thus, the multiplexer 562 outputs the GaplessWrites signal 400 when the SloOneGapWrites signal 538 is captured by the flip-flop 540 and the mrWrCRCEn signal 560 is asserted. Similarly, the multiplexers 564, 566, and 568 shift outputs when the mrWrCRCEn signal 560 is asserted.
In some cases, the write command pulse width at WrCmd13 signal 528 may be more than one cycle wide. This may cause two consecutive stages in the CWL shifter 500 to both be captured by WrStart signal 530. To compensate for this case, NAND gates 570, 572, 574, and 576 may be included to ensure that only a leading stage that is nearest to the WrStart signal 530 is captured while the earlier stage is ignored. The NAND gates 570, 572, 574, and 576 capture only a first cycle of the write operation to avoid incorrectly asserting two outputs at the same time.
The generation circuitry 82 also receives a set signal 578 that sets the flip-flops 534, 540, 546, 552, and 558 in preparation for capturing write operations. The generation circuitry 82 may also include various inverters 580 that are used to amplify signals and/or invert signals for use by logic of the generation circuitry 82. The generation circuitry 82 may also include various other non-illustrated circuitry, such as delay circuitry, that enables proper timing for generation of the GaplessWrites signal 400, OneGapWrites signal 402, TwoGapWrites signal 404, and ThreeGapWrites signal 554.
Suppression of the reset of the DFE buffer 76 is to occur quickly to cut off reset of the DFE buffer 76 quickly after write operation before a next write operation. For example, gapless write operations may have as little as 0.5 cycles to suppress a reset of the DFE buffer 76. To increase the propagation of the GaplessWrites signal 400, OneGapWrites signal 402, TwoGapWrites signal 404, and ThreeGapWrites signal 554, the generation circuitry 82 may utilize a “walkback.” As used herein, walkback refers to progressively timed clocks where each clock is a portion of a cycle of the DQS faster than a previous clock.
Furthermore, to ensure that the write gap signals are properly latched using a walkback configuration, the walkback delays for the walkback clock circuitry 602 is replicated by the walkback WrStart circuitry 604 to walkback the WrStart signal 530 to latch the selected CWL stage outputs as previously described.
In some implementations, a signal that occurs before the WrStart signal 530 may be used for latching. For example, a signal occurring a number (e.g., 1) of cycles before the WrStart signal 530 may be used for latching instead of using the WrStart signal 530. Indeed, any stage may be used to provide a final latching, as long as the relative number of preceding stages is maintained to provide correct spacing to detect gapless writes (e.g., 8 stages) and one-gap writes (e.g., 9 stages) and the other gap writes previously discussed. By using an earlier stage than the final (e.g., WrStart signal 530) the gap write signals are asserted earlier relative to the WrStart signal 530 to allow more time for them to propagate to their destinations before the WrStart signal 530 begins the internal DRAM write operation.
Although the foregoing discusses various logic-low and/or logic-high assertion polarities, at least some of these polarities may be inverted in some embodiments. Furthermore, in some embodiments, logic gates as discussed herein may be replaced with similar logical functions, such as an inverter replaced with a single NAND gate or other similar changes.
While the present disclosure may be susceptible to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and have been described in detail herein. However, it should be understood that the present disclosure is not intended to be limited to the particular forms disclosed. Rather, the present disclosure is intended to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present disclosure as defined by the following appended claims.
The techniques presented and claimed herein are referenced and applied to material objects and concrete examples of a practical nature that demonstrably improve the present technical field and, as such, are not abstract, intangible or purely theoretical. Further, if any claims appended to the end of this specification contain one or more elements designated as “means for [perform]ing [a function] . . . ” or “step for [perform]ing [a function] . . . ”, it is intended that such elements are to be interpreted under 35 U.S.C. 112(f). However, for any claims containing elements designated in any other manner, it is intended that such elements are not to be interpreted under 35 U.S.C. 112(f).
Claims
1. A memory device comprising:
- a shifter that is configured to receive a write command and is configured to produce a plurality of shifted write commands from the write command; and
- a plurality of flip-flops that is configured to receive a subset of the plurality of shifted write commands from the shifter and to output an indication of whether subsequent write commands subsequent to the write command are asserted when the write command has shifted through an entire length of the shifter and is output from the shifter as a write start signal.
2. The memory device of claim 1, wherein the shifter comprises a plurality of shifter flip-flops connected in series, and each of the plurality of shifter flip-flops is configured to produce a respective one of the plurality of shifted write commands.
3. The memory device of claim 2, wherein each of the plurality of shifter flip-flops is coupled to a common clock.
4. The memory device of claim 2, wherein the plurality of shifter flip-flops is coupled to a plurality of clocks.
5. The memory device of claim 4, comprising walkback circuitry, wherein each of the clocks of the plurality of clocks is generated using the walkback circuitry, and the plurality of clocks are progressively faster relative to a data strobe (DQS) through the shifter.
6. The memory device of claim 5, wherein the walkback circuitry comprises a series of latches.
7. The memory device of claim 6, wherein each of the latches in the series of latches produces a clock of the plurality of clocks and an inverse clock that is logically inverse to a respective clock of the plurality of clocks.
8. The memory device of claim 6, comprising walkback write start circuitry, wherein the walkback write start circuitry comprises an additional series of latches to delay the write start signal from causing the plurality of flip-flops to output the indication.
9. The memory device of claim 8, wherein latches in the additional series of latches each has a similar delay to a respective latch of the series of latches.
10. The memory device of claim 1, wherein the indication comprises a plurality of signals each indicating whether the write start signal and an asserted subsequent write command of the subsequent write commands has a particular duration between the write start signal and an asserted subsequent write command.
11. The memory device of claim 10, wherein the particular duration for a respective signal of the plurality of signals comprises:
- a gap duration between a first write operation corresponding to the write start signal and a second write operation corresponding to the asserted subsequent write command; and
- a write duration comprising a number of cycles for which data for the write operation is transferred.
12. The memory device of claim 1, comprising a cas write latency shifter that comprises the shifter.
13. A method comprising:
- receiving a write command signal configured to indicate whether a write is active for a memory device;
- shifting the write command signal through a series shifter to generate a plurality of write command signals;
- upon completion of an asserted write command shifting through the series shifter, detecting whether a subsequent asserted write command is currently in the series shifter using a plurality of flip-flops configured to receive a subset of the write command signals from the shifter; and
- upon detection of the subsequent asserted write command as currently in the series shifter, outputting a respective indication of a gap between a first write operation corresponding to the asserted write command and a second write operation corresponding to the subsequent asserted write command.
14. The method of claim 13, wherein the gap corresponds to a number of flip-flops in the series shifter between the asserted write command and the subsequent asserted write command minus a length of a write burst for the first write operation.
15. The method of claim 13, comprising receiving a cyclic redundancy check (CRC) signal indicative of whether CRC is active for the first write operation.
16. The method of claim 15, wherein the respective indication of the gap is based at least in part on the CRC signal.
17. A memory device comprising:
- a first plurality of flip-flops that is configured to receive a write command signal and is configured to produce a plurality of shifted write command signals from the write command signal;
- a second plurality of flip-flops that is configured to receive a subset of the plurality of shifted write command signals from the first plurality of flip-flops and to output an indication of whether subsequent write commands subsequent to the subset of the write command signal are asserted when an asserted write command signal has shifted through an entire length of the first plurality of flip-flops and is output from the first plurality of flip-flops as a write start signal; and
- a plurality of multiplexers each coupled to outputs of a pair of adjacent flip-flops of the second plurality of flip-flops, wherein each multiplexer of the plurality of multiplexers is configured to select one of the outputs of the pair of adjacent flip-flops based at least in part on a cyclic redundancy check (CRC) signal.
18. The memory device of claim 17, comprising a plurality of NAND gates configured to ensure that only one of the flip-flops of the second plurality of flip-flops is configured to output an asserted indication in response to the write start signal.
19. The memory device of claim 17, comprising write start signal walkback circuitry comprising a first plurality of latches connected in series to provide a plurality of delayed versions of the write start signal to the second plurality of flip-flops.
20. The memory device of claim 19, comprising walkback circuitry comprising a second plurality of latches connected in series to provide a plurality of clocks to the first plurality of flip-flops, wherein each latch in the second plurality of latches has a same delay as a corresponding latch in the first plurality of latches.
6202119 | March 13, 2001 | Manning |
6400625 | June 4, 2002 | Arimoto |
6634002 | October 14, 2003 | Furubeppu |
8406079 | March 26, 2013 | Kim |
8737159 | May 27, 2014 | Song |
9230621 | January 5, 2016 | Shim |
9865317 | January 9, 2018 | Ishibashi |
9892770 | February 13, 2018 | Bell |
9997220 | June 12, 2018 | Miyano |
10068626 | September 4, 2018 | Eaton |
10148269 | December 4, 2018 | Mazumder |
10153014 | December 11, 2018 | Mazumder |
10360951 | July 23, 2019 | Penney |
10431294 | October 1, 2019 | Penney |
10452319 | October 22, 2019 | Penney |
10490241 | November 26, 2019 | Penney |
10510398 | December 17, 2019 | Penney |
20020078294 | June 20, 2002 | Tsuchida |
20030002378 | January 2, 2003 | Uchida |
20050128828 | June 16, 2005 | Lee |
20050254307 | November 17, 2005 | Dietrich |
20060104150 | May 18, 2006 | Yoshida |
20110242911 | October 6, 2011 | Ko |
20110271133 | November 3, 2011 | Kim |
20120113728 | May 10, 2012 | Kwon |
20130083617 | April 4, 2013 | Song |
20140198591 | July 17, 2014 | Morgan et al. |
20140258607 | September 11, 2014 | Shim |
20140340969 | November 20, 2014 | Jung |
20140355361 | December 4, 2014 | Bell et al. |
20160314823 | October 27, 2016 | Bell |
20170076761 | March 16, 2017 | Shimizu |
20180122440 | May 3, 2018 | Manning |
20180158509 | June 7, 2018 | Kim |
20190333552 | October 31, 2019 | Hong |
- PCT International Search Report & Written Opinion for PCT Application No. PCT/US2018/055276 dated Jan. 31, 2019; 11 Pages.
Type: Grant
Filed: Jul 31, 2018
Date of Patent: Jun 2, 2020
Patent Publication Number: 20190259433
Assignee: Micron Technology, Inc. (Boise, ID)
Inventors: Daniel B. Penney (Wylie, TX), Liang Chen (Allen, TX), David R. Brown (Lucas, TX)
Primary Examiner: Viet Q Nguyen
Application Number: 16/051,202
International Classification: G11C 7/00 (20060101); G11C 7/22 (20060101); G11C 7/10 (20060101); G11C 11/4076 (20060101); G11C 11/4093 (20060101); G11C 8/18 (20060101); G11C 8/10 (20060101); G11C 11/4096 (20060101); H04L 25/03 (20060101); G06F 13/18 (20060101); G11C 11/4074 (20060101);