Apparatuses and methods for variable latency memory operations

Information

  • Patent Grant
  • 10740263
  • Patent Number
    10,740,263
  • Date Filed
    Wednesday, August 8, 2018
    6 years ago
  • Date Issued
    Tuesday, August 11, 2020
    4 years ago
Abstract
Apparatuses and methods for variable latency memory operations are disclosed herein. An example apparatus may include a memory configured to provide first information during a variable latency period indicating the memory is not available to perform a command, wherein the first information is indicative of a remaining length of the variable latency period, the remaining length is one of a relatively short, normal, or long period of time, the memory configured to provide second information in response to receiving the command after the latency period.
Description
TECHNICAL FIELD

Embodiments of the present invention relate generally to memories, and more specifically, in one or more described embodiments, to variable latency memory operations.


BACKGROUND

Memories may be provided in a variety of apparatuses, such as computers or other devices, including but not limited to portable memory devices, solid state drives, personal digital assistants, music players, cameras, phones, wireless devices, displays, chip sets, set top boxes, gaming systems, vehicles, and appliances. There are many different types of memory including random-access memory (RAM), read only memory (ROM), dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), flash memory, and resistance variable memory, among others.


Apparatuses, such as resistance variable memory devices, may be used as non-volatile memory for a wide range of electronic devices. Resistance variable memory devices may include, for example, phase change memory (PCM) or resistive memory (RR), among others.


A conventional read operation using PCM is also similar to read operations for RAM. Accordingly, PCM may be used to implement random access memory. Write operations with PCM, however, may be relatively slower than write operations for conventional RAM. For example, PCMs may require additional time to manage and complete write operations, such as preparing data to be written to memory, suspending a write operation in case of a read access request, and monitoring progress of a write operation. Read operations may be slower than for conventional RAM and read operations cannot be performed at a memory location undergoing write operation.


As a result of the limitations of using PCM as RAM replacement, operation of PCMs in memory systems may be restricted. For example, write and read operations may not be performed at any time on any memory location. Status registers used for monitoring the progress of write operations may be regularly queried to determine whether a particular write operation has completed before another write operation is performed. Additionally, in some applications write operations are necessarily suspended for read operations and resumed upon completion of the read operation.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1A is a block diagram of an apparatus according to an embodiment of the present invention.



FIG. 1B is a schematic block diagram of a memory according to an embodiment of the present invention.



FIG. 2A is a timing diagram illustrating various signals of a read operation according to an embodiment of the present invention.



FIG. 2B is a timing diagram illustrating various signals of a write operation according to an embodiment of the present invention.



FIG. 3A is a timing diagram illustrating various signals of a read operation according to an embodiment of the present invention.



FIG. 3B is a timing diagram illustrating various signals of a write operation according to an embodiment of the present invention.



FIG. 4A is a timing diagram illustrating various signals of a read operation according to an embodiment of the present invention.



FIG. 4B is a timing diagram illustrating various signals of a write operation according to an embodiment of the present invention.



FIG. 5 is a schematic state diagram illustrating various states of operation of an apparatus according to an embodiment of the present invention.



FIG. 6 is a table illustrating example latencies according to an embodiment of the present invention.



FIG. 7 is a table illustrating example bit assignments for wait states during memory operations according to an embodiment of the present invention.



FIG. 8 is a table illustrating example bit assignments for acknowledgement events of memory commands according to an embodiment of the present invention.





DETAILED DESCRIPTION

Apparatuses and methods for variable latency memory operations 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 having skill 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.



FIG. 1A is a block diagram of an apparatus 100 according to an embodiment of the present invention. The apparatus may comprise circuitry, one or more semiconductor dice, a packaged semiconductor, a device including such circuitry, die, or package, and/or a system including such a device. The apparatus 100 includes a controller 110 (e.g., memory controller) and a memory 120. The controller 110 and the memory 120 may be coupled by a command and address (CA) bus 130 and a data bus 135. The memory 120 may be configured to receive commands and/or addresses from the controller 110 over the CA bus 130, and the memory may be configured to receive data and/or provide data over the data bus 135.


The memory 120 may be configured to perform memory operations (e.g., read operations or write operations) in response to the received commands and/or addresses that are provided by the controller 110. For example, the memory 120 may provide read data to the controller 110 over the data bus 135 in response to a read command, and may store write data received over the data bus 135 in response to a write command. Additionally, the memory 120 may further provide information to the controller 110 over the data bus 135 in response to particular commands. The information may indicate, for instance, whether the memory 120 is available to perform a memory operation and/or an amount of time before the memory 120 may become available to perform a memory operation.


In at least one embodiment, the apparatus 100 may be configured to operate in accordance with three-phase addressing. Generally, three-phase addressing may include three phases during which the memory 120 receives commands and addresses provided by the memory controller 110, responsive to which memory operations read operations or write operations) are performed. For example, three-phase addressing may include a first phase in which the memory 120 may receive a preactive command from the controller 110 over the CA bus 120. The controller 110 may further provide a first portion of a row address to the memory 120. In response, the memory 120 may store the first portion of a row address received with the preactive command on the CA bus 120. In a second phase, the memory 120 may receive an active command from the controller 110. The controller 110 may further provide a second portion of a row address to the memory 120. In response, the memory 120 may store the second portion of the row address provided with the active command on the CA bus 120. The first portion and second portion of the row address may comprise a full row address, and the memory 120 may access data associated with the row address and store the data in a buffer. During a third phase, the memory 120 may receive a command that is provided by the controller 110. For example, the memory 120 may receive a read command or a write command that is provided by the controller 110. In response to a read command, the buffered data may be provided to the controller 110 over the data bus 135. In response to a write command, write data may be received on the data bus 135, and the memory 120 may store the write data at the row address.


In at least one embodiment, the second phase of a three-phase addressing operation may include a variable latency period tLAT. During the tLAT period, the memory 120 may manage memory operations, for instance, by preparing circuits to perform the command received in the third phase, completing a current memory operation, and/or suspending a current memory operation. Accordingly, because the memory 120 may manage any number of these and/or other memory operations during the tLAT period, the variable latency period tLAT may vary. For example, the tLAT period may vary between relatively short and relatively long durations.


In some embodiments, the memory 120 may be configured such that the tLAT period is guaranteed to elapse within one or more particular amounts of time. For example, in at least one embodiment, when the command of the third phase comprises a read command, the memory 120 may be configured to complete the second phase at least within a time tMAXLATR. That is, the tLAT period will elapse within tMAXLATR. When the command provided in the third phase comprises a write command, the memory 120 may be configured to complete the second phase at least within a time tMAXLATW. That is, the tLAT period will elapse within tMAXLATW. Values for both tMAXLATR and tMAXLATW may be stored as parameters in a register (not shown in FIG. 1). The values for tMAXLATR and tMAXLATW, in some instances, may be predetermined and/or equal or unequal. The values for tMAXLATR and tMAXLATW may be adjusted in real-time, for instance, based on priority of commands. By way of example, tMAXLATW may be increased when read commands are prioritized over write commands.


Accordingly, because a maximum duration of the tLAT period may depend on the type of command provided in a subsequent phase, in some embodiments, activate commands may indicate the type of command provided in the third phase. For example, in at least one embodiment, an activate command may comprise an activate read command or an activate write command. In this manner, the variable latency period tLAT may be based, at least in part, on whether an activate command comprises an activate read command or an activate write command. In some instances, activate read commands and activate write commands may be distinguished based on a bit value, for example, as represented by a signal. By way of example, one or more bits of a buffer address BA may be used to distinguish activate read and activate write commands. In another example, particular combination of bits received on the CA bus 130 may indicate that an activate command comprises an activate read command or comprises an activate write command.


In some instances, the controller 110 may be configured to provide a read or write command a particular amount of time after providing an activate command, and as previously described, the tLAT period may vary based, at least in part, on the number and type of operations the memory 120 may perform during the second phase of a three-phase addressing procedure. As a result, a read or write command may be provided by the controller 110 before the tLAT period elapses, that is, prior to a time at which the memory 120 is available to perform the respective command. As will be explained in further detail below, when a command is provided prior to the tLAT period elapsing, the memory 120 may provide information indicating that the memory 120 is not available to perform a command. In some embodiments, data not valid (DNV) information is provided on the data bus 135 to indicate that the memory 120 is not available to perform a command. If a command is provided after the tLAT period elapses, the memory 120 may provide information indicating that the memory 120 is available to perform a command. In some embodiments, data valid (DV) information indicating that the memory 120 is available to perform a command and/or read data is provided on the data bus 135. In at least one embodiment, the data bus 135 may include one or more data mask signal lines that may be used for providing respective DNV and DV information.



FIG. 1B is a schematic block diagram of a memory 150 according to an embodiment of the present invention. The memory 150 may be used to implement, at least in part, the memory 120 of FIG. 1A. The memory 150 may include an address buffer 160 and a data buffer 170. The memory 150 includes elements that have been previously described with respect to the apparatus 100 of FIG. 1A. Those elements have been identified in FIG. 1B using the same reference numbers used in FIG. 1A and operation of the common elements is as previously described. Consequently, a detailed description of the operation of these elements will not be repeated in the interest of brevity.


The address buffer 160 may include a multiplexer 154 that may be configured to receive a first portion (e.g., higher portion) of an N-bit address (e.g., row address) from the CA bus 130 and further configured to provide the first portion of the row address to one of a plurality of row address buffers 166. The address buffer 160 may include any number of row address buffers 166, such as four row address buffers 166 as illustrated in FIG. 1B.


The multiplexer 154 may be configured to provide the first portion of the row address to a row address buffer 166 based, at least in part, on a buffer address BA. By way of example, the buffer address BA may be used to determine which row address buffer 166 receives the first portion of the row address. In embodiments having 4 row address buffers 166, for instance, 2 bits of the buffer address BA may be used to determine the row address buffer 166 that receives the first portion of the row address.


Each of the row address buffers 166 may be coupled to a multiplexer 168. The multiplexer 168 may be configured to receive the first portion of the row address and provide it to a row address register 190 based, at least in part, on the buffer address BA. The row address register 190 may receive the first portion of the row address from the multiplexer 168 and further may receive a second portion e.g., lower portion) of the row address from the CA bus 130. Accordingly, the row address register 190 may store an entire address. As previously described, the address may comprise N bits, and any number of bits may be allocated between the first and second portions of the row address. A row decoder 192 may be configured to receive the row address for accessing memory of array 194 associated with the address for read and/or write operations.


In an example read operation, read data may be provided from the array 194 to the multiplexer 172 via the I/O circuitry 196. The I/O circuitry 196 may include, for instance, a plurality of sense amplifiers configured to sense and/or amplify respective data such that the data may be provided to or received from the array 194. Based, at least in part, on the buffer address the multiplexer 172 may provide the read data to one of a plurality of row data buffers 174 of the data buffer 170. The data buffer 170 may include any number of row data buffers 174 and in at least one embodiment, the address buffer 160 and data buffer 170 may include a same number of row address buffers 166 and row data buffers 174, respectively. In some embodiments, the number of row data buffers 174 and row address buffers 166 may be different. The read data may be provided from the row data buffer 174 to a multiplexer 176 based, at least on part, on the buffer address BA, and thereafter provided to a state machine 178. The state machine 178 may provide the read data to the data bus 135 based, at least in part, on a control signal CTL.


In an example write operation, write data (e.g., associated with a write command received on the CA bus) may be provided from the data bus 135 to the state machine 178. Based, at least in part, on the control signal CTL, the state machine 178 may provide the write data to the multiplexer 176, which may in turn provide the write data to one of the plurality of row data buffers 174 based, at least in part, on the buffer address BA. The selected row data buffer 174 may provide the write data to the multiplexer 172, which may in turn provide the write data to the I/O circuitry 196 for storing in the array 194. The write data may be stored in memory cells of the array 194 associated with the row address provided by the row decoder 192.


As previously described, the memory 150 may be configured to operate in accordance with three-phase addressing. Accordingly, during the first phase, a preactive command may cause a first portion of a row address to be provided to the multiplexer 154 over the CA bus 130. The first portion of the row address may be stored in a row address buffer 166.


In the second phase, an activate command may be provided and cause the first portion of the row address to be provided from the row address buffer 166 to the row address register 190. Moreover, a second portion of the row address may be provided to the row address register 190 over the CA bus 130. The row address may be used to access data of the array 194 such that data may be provided from the array 194 to a row data buffer 174. The particular row address buffer 166 and row data buffer 174 receive the first portion of the row address and the data from the array 194, respectively, may be based, at least in part, on a buffer address BA.


During the third phase, a read operation or a write operation may be performed in response to a read command or a write command, respectively. As previously described, commands provided in this manner may be provided after a tLAT period. In a read operation, the data stored in the row data buffer 174 may be provided to the data bus 135 as read data using the output state machine 178. In a write operation, write data may be received on the data bus 135 by the state machine 178 and provided to the row data buffer 174. The write data may then be stored in the array 194 at the row address.



FIG. 2A is a timing diagram 200 illustrating various signals of a read operation according to an embodiment of the present invention. The timing diagram 200 may include signals provided on the CA bus 130 and the data bus 135 of FIG. 1A.


At time T0, the controller 110 may provide a preactive command 202 on the CA bus 130, and at time T1, may further provide an activate read command 204. As previously described, the activate read command 204 may indicate an upcoming read operation. The activate read command 204 may be deasserted at time T2, and after a delay tRCD, at time T3, the controller 110 may provide a read command 206. The delay tRCD may, for instance, comprise a RAS to CAS delay that defines the minimum time between a time when an activate command is provided and a time when a subsequent read command or write command is provided. The time tRCD may be predetermined and/or specified in accordance with one or more standards, such as the JEDEC LPDDR2 standard.


At time T4, in response to the read command 206 and after a time RL has elapsed, the memory 120 may provide data not valid (DNV) information on the data bus 135. The time RL may comprise an amount of time for the memory 120 to provide a response (e.g., DNV or DV information) to the read command 206 and may comprise, for instance, a number of clock cycles (e.g., 3 clock cycles) of a system clock signal. In at least one embodiment, the DNV information 210 may be provided on data mask signal lines of the data bus 135 and further may be provided with a burst length having, for instance, a length of 8 bits. As previously described, the DNV information 210 may indicate that the memory 120 is not available to perform a read command. For example, the DNV information 210 may indicate that the tLAT period has not yet elapsed. The DNV information 210 may further include information indicating an amount of time until the apparatus 100 will be available to perform a read command, or the amount of time before the tLAT period elapses.


After time T5 at which the tLAT period elapses, the controller 110 may provide a read command 208 to the CA bus 130 at time T6. In response, at time T7, the memory 120 may provide DV information 212 on the data bus 135 indicating that the memory is available for the operation. As previously described, because the command is provided after the tLAT period has elapsed, the command may be performed. In at least one embodiment, the DV information 212 may be provided on the data mask signal lines of the data bus and the data associated with the read command 208 may be provided on the data bus at time T7 as well.


While the timing diagram 200 has been described with respect to read commands 206, 208, other read commands may be provided as well. For example, multiple read commands may be provided to cause the memory 120 to provide DNV information before the tLAT period has elapsed. Because each of these commands are provided before the apparatus 100 is available to perform a command, DNV information may be provided on the data bus 135 in response to each of these read commands, as previously described.



FIG. 2B is a timing diagram 250 illustrating various signals of a write operation according to an embodiment of the present invention. The timing diagram 250 may include signals provided on the CA bus 130 and the data bus 135 of FIG. 1A.


At time T0, a preactive command 252 may be provided on the CA bus 130. At time T1, the controller 110 may provide an activate write command 254, and at time T2 may no longer provide the write command 254. As previously described, the activate write command 254 may indicate an upcoming write operation. After a time tRCD, at time T3, a read command 256 may be provided.


At time T4, after RL has elapsed, the memory 120 may provide DNV information 270 on the data bus 135 in response to the read command 256. The read command 256, for example, may be used to cause the memory 120 to provide DNV or DV information. The DNV information 270 may be provided on data mask signal lines of the data bus 135 and may be provided with a burst length, for instance, of 8 bits. As previously described, the DNV information 270 may indicate that the memory 120 is not yet available to perform a write command. The DNV information 270 may further include information indicating an amount of time until the memory 120 will be available to perform a command.


After time T5 at which the tLAT period elapses, the controller 110 may provide a read command 258 on the CA bus 130 at time T6. In response, at time T7, the memory 120 may provide DV information 272 on the data bus, e.g., data mask signal lines, indicating that the memory is available for the operation. Because the command is provided at a time after the tLAT period has elapsed, a write command may be performed. In response to the DV information 272 being provided on the data bus 135, the controller may provide a write command 260 on the CA bus 130 at a time T8. Write data 274 associated with the write command 260 is provided to the memory 120 on the data bus 135 at time T9.


While the timing diagram 200 of FIG. 2A and the timing diagram 250 of FIG. 2B have been described with respect to read commands 206, 208, and 256, 258, respectively, other read commands may be provided as well. For example, in some embodiments, an external device may be configured to periodically provide read commands to cause the memory 120 to provide DNV/DV information until DV information is provided, e.g., multiple read commands may be provided before the tLAT period has elapsed. In other embodiments, the external device may be configured to provide one or more read commands based, at least in part, on information included in the DNV information. By way of example, DNV information may indicate that the tLAT period may elapse in 50 microseconds, and the controller 110 may wait 50 or more microseconds before providing another read command.


Moreover, in both the timing diagram 200 of FIG. 2A and the timing diagram 250 of FIG. 2B, a respective read command is provided a time tRCD after an activate command is provided. In this manner, it may be determined whether the memory 120 is available to perform a read command or a write command. As previously described, read commands may be provided periodically and/or based, at least in part, on information included with DNV information. Accordingly, in at least one embodiment, for read operations, read commands may be provided until DV information and associated read data is provided to the data bus 135. For write operations, read commands may be provided until DV information is provided, and in response, a write command may be provided causing the memory 120 to store write data provided from the data bus 135.



FIG. 3A is a timing diagram 300 illustrating various signals of a read operation according to an embodiment of the present invention. The timing diagram 300 may include signals provided on the CA bus 130 and the data bus 135 of FIG. 1A.


At time T0, the controller 110 may provide a preactive command 302 on the CA bus 130, and at time T1, may further provide an activate read command 304. The activate read command 304 may be deasserted at time T2, and after a time tRCD, at time T3, the controller 110 may provide a read check command 306. The read check command 306 may comprise a “dummy” command that may cause the memory 120 to indicate whether it is available to perform a command (e.g., provide DNV information or DV information), that is, whether the tLAT period has elapsed. In at least one embodiment, providing the read check command 306 may comprise providing a read command and asserting one or more particular bits of the buffer address BA (e.g., bit 2 of the buffer address BA). In other embodiments, particular signal combinations on the CA bus 130 may be used to provide a read check command.


In response to the read check command 306, the memory 120 may provide DNV information 320 on the data bus 135 at time T4. The DNV information 320 may indicate that the tLAT period has not yet elapsed, and may further may include information indicating an amount of time until the tLAT period will elapse.


After time T5 at which the tLAT period elapses, the controller 110 may provide a read check command 308 on the CA bus 130 at time T6. In response, at time T7, the memory 120 may provide DV information 322 on the data bus 135 indicating that the memory 120 is available for a read operation. Accordingly, the controller 110 may provide a read command 310 at a time T8, and at time T9, the memory 120 may provide read data 324 associated with the read command 310 to the data bus 135.



FIG. 3B is a timing diagram 350 illustrating various signals of a write operation according to an embodiment of the present invention. The timing diagram 350 may include signals provided on the CA bus 130 and the data bus 135 of FIG. 1A.


At time T0, the controller 110 may provide a preactive command 352 on the CA bus 130, and at time T1, and further may provide an activate write command 354. The activate write command 354 may be deasserted at time T2, and after a time tRCD, at time T3, the controller 110 may provide a read check command 356. As previously described, the read check command 356 may comprise a “dummy” command that may cause the memory 120 to indicate whether it is available to perform a command (e.g., provide DNV information or DV information). Because the activate command 354 is an activate write command, the read check command 356 may cause the memory 120 to indicate whether it is available to perform a write command. The read check command may be provided by asserting a read command and one or more particular bits of the buffer address BA (e.g., bit 2 of the buffer address BA), or by asserting particular signal combinations on the CA bus 130.


In response to the read check command 356, the memory 120 may provide DNV information 370 on the data bus 135 at time T4, indicating to the controller 110 that the tLAT period has not elapsed since an activate command was provided. The DNV information 370 may further may include information indicating an amount of time until the tLAT period will elapse.


After time T5 at which the tLAT period elapses, the controller 110 may provide a read check command 358 on the CA bus 130 at time T6. In response, at time T7, the memory 120 may provide DV information 372 on the data bus 135 indicating that the memory is available for a write operation. The controller 110 may provide a write command 360 at time T8, and at time T9, the controller 110 may further provide write data 374 to the data bus 135 for storing in the memory 120.


Timing diagram 300 of FIG. 3A and timing diagram 350 of FIG. 3B have been described with reference to a read check command. In at least one embodiment, the read check command may differ from a read command in that the apparatus 100 may provide indication of its status without providing any data to the data bus 135.



FIG. 4A is a timing diagram 400 illustrating various signals of a read operation according to an embodiment of the present invention. The timing diagram 400 may include signals provided on the CA bus 130 and the data bus 135 of FIG. 1A.


At time T0, the controller 110 may provide a preactive command 402 on the CA bus 130, and at time T1, may further provide an activate read command 404. In response to the activate read command 404, the memory 120 may provide DNV information 420 to the data bus 135, and in at least one embodiment, the DNV information 420 may be provided on the data bus 135 until time T4 at which the tLAT period elapses. Moreover, the memory 120 may provide DV information 422 on the data bus 135 at time T4. In response to the DV information 422 being provided, the controller 110 may provide a read command 406 at time T5, thereby causing the memory 120 to provide read data 424 on the data bus 135 at time T6.



FIG. 4B is a timing diagram 450 illustrating various signals of a write operation according to an embodiment of the present invention. The timing diagram 450 may include signals provided on the CA bus 130 and the data bus 135 of FIG. 1A.


At time T0, the controller 110 may provide a preactive command 452 on the CA bus 130, and at time T1, may further provide an activate write command 454. In response to the activate write command 454, the memory 120 may provide DNV information 470 on the data bus 135, and in at least one embodiment, the DNV information 470 may be provided until time T3 at which the tLAT period elapses. Moreover, the memory 120 may provide DV information 472 at time T3. In response to the DV information 472 being provided, the controller 110 may provide a write command 456 at time T4. The controller 110 may further provide write data 474 to the data bus 135 at time T5 for storing in the memory 120.



FIG. 5 is a schematic state diagram 500 illustrating various states of operation of an apparatus according to an embodiment of the present invention. The state diagram 500 may include an idle state 502, an active state 504, a read state 506, and a write state 508, and a preactive state 510 and may be used, for instance, in operation of an apparatus, such as the apparatus 100 of FIG. 1A. The state diagram 500 may be used to implement, modify, or replace, wholly or in part, any state diagram in accordance with one or more standards, such as the JEDEC LPDDR2 standard. In at least one embodiment, the state diagram 500 may comprise a simplified version of a state diagram and accordingly may omit one or more known states to avoid unnecessarily obscuring the invention.


In an example operation, after initialization, the apparatus 100 may enter the idle state 502. In the idle state 502, the apparatus 100 may not be operating in any of the phases of three-phase addressing described herein. In response to a preactive command, the apparatus 100 may enter the preactive state 510 and operate in a first phase of three-phase addressing. Once the first phase has completed, the apparatus 100 may reenter the idle state 502.


In response to an activate command (e.g., activate read or activate write), the apparatus 100 may enter the active state 504. When in the active state 504, the apparatus 100 may operate in a second phase of three-phase addressing. As previously described, the controller 110 may provide an activate read command or an activate write command, and the memory 120 may manage any operations during a tLAT period. As previously described, in at least one embodiment, the memory 120 may be configured to complete the second phase of three-phase addressing within tMAXLATR in response to an activate read command and within tMAXLATW in response to an activate write command.


In accordance with at least one embodiment of the invention, once in an active state 504, the controller 110 may provide a command to the memory 120, for example, as previously described with reference to FIGS. 2A and 2B. As previously described, in some instances, the controller 110 may provide a read command, for instance, before the tLAT period elapses. Accordingly, the apparatus 100 may enter the read state 506, provide DNV information, and return to the active state 504. If a read command is received at a time at which the apparatus 100 is available to perform a read command, for instance the tLAT period has elapsed, the apparatus 100 may enter the read state 506, provide DV information, and return to the active state 504. If the activate command was an activate read command, the memory 100 may further provide read data with the DV information. If the activate command was an activate write command, the apparatus 100 may return to the active state 504. Subsequently, the apparatus 100 may enter the write state 508, and the controller 110 may provide a write command and associated write data to the memory 120. The memory 120 may store write data associated with the write command and the apparatus 100 may return to the active state 504.


In other embodiments, once in an active state, the controller 110 may provide a read check command to the memory 120 for example, as previously described with reference to FIGS. 3A and 3B. In response, the memory 120 may provide DNV information if the read check command is received before the tLAT period elapses. If the read check command is received after the tLAT period has elapsed, the memory 120 may provide DV information if the read check command and the apparatus 100 may return to the active state 504 once the DV information is provided. A read or write command may subsequently be performed by entering the read state 506 or the write state 508, respectively. Once the command has been performed, the apparatus 100 may return to the active state 504.


In yet other embodiments, once in the active state 504, the memory 120 may provide DNV information to the controller 110 until the memory 120 is available to perform a command, for instance, after the tLAT period has elapsed, for example, as previously described with reference to FIGS. 4A and 4B. Once the memory 120 is available to perform a command, the memory 120 may provide DV information. A read or write command may subsequently be performed by entering the read state 506 or the write state 508, respectively. Once the command has been performed, the apparatus 100 may return to the active state 504.


In each case, after performing a read command or a write command, the apparatus 100 may return to the active state 504. During a subsequent three-phase addressing process, another preactive command may be provided. The apparatus 100 may enter the preactive state 510 and transition to the idle state 502 before receiving an active command, as previously described.



FIG. 6 is a table 600 illustrating example latencies according to an embodiment of the present invention. As previously described, tMAXLATR and tMAXLATW may comprise maximum times for the tLAT period for read and write operations, respectively. The table 600 illustrates example latencies for both tMAXLATR and tMAXLATW that may be used in accordance with described examples. Values for tMAXLATR and tMAXLATW may be stored in one or more registers, such as a transparent operations register (TOR). Registers storing tMAXLATR and tMAXLATW may, in some embodiments, may be read-only, or may be writeable such that a user may specify values for tMAXLATR and/or tMAXLATW.



FIG. 7 is a table 700 illustrating example bit assignments for wait states during memory operations according to an embodiment of the present invention. As previously described. DNV information, such as the DNV information 210 of FIG. 2, may include information indicating the remaining duration before the tLAT period elapses. As illustrated in FIG. 7, in at least one embodiment, DNV information may indicate whether relatively short, normal, or long periods of time remain. In this manner, a controller, such as the controller 110 of FIG. 1A, may determine whether to hold the CA bus 130 and/or the data bus 135 in a wait state, or to abort (e.g., terminate) a pending command such that another command, for instance, having higher priority, may be performed. In at least one embodiment, information included in the DNV information may be provided in parallel and/or in serial using one or more data mask signal lines of the data bus 135.



FIG. 8 is a table 800 illustrating example bit assignments for acknowledgement events of memory commands according to an embodiment of the present invention. As previously described, DV information may be used to indicate that the apparatus 100 is available to perform a read command or a write command, respectively. In some embodiments, and as illustrated in FIG. 8, the DV information may further include information, for instance, indicating whether an error has occurred and/or whether a particular action (e.g., check status register) is suggested as a result. In at least one embodiment, each of the bit state assignments may be provided in parallel and/or in serial using one or more data mask signal lines of the data bus 135.


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.

Claims
  • 1. An apparatus, comprising: a memory configured to receive at least one of an activate read command or an activate write command during a first addressing phase and at least one of a read command or a write command during a second addressing phase, the activate read command indicative of the memory operable to receive the read command during the second addressing phase, and the activate write command indicative of the memory operable to receive the write command during the second addressing phase, the memory further configured to:provide information indicative of the memory being unavailable to perform the command received during the second addressing phase responsive to receiving the read command or the write command during a variable latency period, wherein the information is further indicative of a remaining duration of the variable latency period, the remaining duration comprising one of a relatively short, normal, or long period of time, andprovide information indicative of the memory being available to perform the command received during the second addressing phase responsive to receiving the read command or the write command after the variable latency period.
  • 2. The apparatus of claim 1, wherein the variable latency is based on a number of operations the memory performs during the second addressing phase.
  • 3. The apparatus of claim 1, wherein the variable latency period is measured relative to the activate read command or the activate write command.
  • 4. The apparatus of claim 1, wherein a maximum duration of the variable latency period is based on whether the command received during the first addressing phase comprises the activate read command or the activate write command.
  • 5. The apparatus of claim 1, wherein the information indicating that the memory is unavailable to perform the command received during the second addressing phase comprises data not valid information.
  • 6. The apparatus of claim 5, wherein the data not valid information comprises the remaining duration of the variable latency period.
  • 7. The apparatus of claim 1, further comprising: a controller coupled to the memory and configured to provide at least one of the activate read command or the activate write command.
  • 8. The apparatus of claim 1, wherein the memory is configured to transmit or receive data associated with the command in response to the memory receiving at least one of the read command or write command after the variable latency period.
  • 9. An apparatus, comprising a controller configured to provide to a memory at least one of an activate read command or an activate write command during a first addressing phase and provide at least one of a read command or a write command during a second addressing phase, wherein the activate read command is indicative of the controller operable to provide the read command during the second addressing phase, and the activate write command is indicative of the controller operable to provide the write command during the second addressing phase,wherein the controller is further configured to receive information indicative of the memory being available or unavailable to perform the command provided during the second addressing phase, wherein the memory is unavailable to perform the command received during the second addressing phase responsive to receiving the read command or the write command during a variable latency period, wherein the information is further indicative of a remaining duration of the variable latency period, the remaining duration comprising one of a relatively short, normal, or long period of time, and the memory is available to perform the command received during the second addressing phase responsive to receiving the read command or the write command after the variable latency period.
  • 10. The apparatus of claim 9, wherein the controller is configured to provide the command provided during the second addressing phase a second time responsive to receipt of information indicating the memory is unavailable to perform the read command or the write command provided during the second addressing phase.
  • 11. The apparatus of claim 9, wherein the controller is configured to receive read data responsive to receipt of data valid information and the command provided during the first addressing phase comprising an activate read command and to provide a write command responsive to receipt of data valid information and the command provided during the first addressing phase comprising an activate write command.
  • 12. The apparatus of claim 9, wherein the controller is configured to provide the read command or the write command after a delay.
  • 13. The apparatus of claim 9, wherein the controller is configured to receive the information indicative of the memory being available or unavailable to perform the command provided during the second addressing phase on one or more data mask signal lines of a data bus.
  • 14. The apparatus of claim 9, wherein the variable latency period is based on a number of operations the memory performs during the second addressing phase.
  • 15. A method, comprising: receiving, via a memory, an activate read command or an activate write command during a first addressing phase, the activate read command indicative of the memory operable to receive a read command during a second addressing phase, and the activate write command indicative of the memory operable to receive a write command during the second addressing phase;receiving the read command or the write command during the second addressing phase;responsive to receiving the read command or the write command during the second addressing phase within a variable latency period, providing information indicating the memory is unavailable to perform the read command or the write command received during the second addressing phase, wherein the information is further indicative of a remaining duration of the variable latency period, the remaining duration comprising one of a relatively short, normal, or long period of time; andresponsive to receiving the read command or the write command during the second addressing phase after the variable latency period, providing information indicating the memory is available to perform the read command or write command received during the second addressing phase.
  • 16. The method of claim 15, wherein the variable latency period has a first maximum duration responsive to receiving the activate read command during the first addressing phase.
  • 17. The method of claim 16, wherein the variable latency period has a second maximum duration responsive to receiving the activate write command during the first addressing phase.
  • 18. The method of claim 15, wherein providing information indicating the memory is unavailable to perform the read command or the write command received during the second addressing phase comprises providing data not valid information, wherein the data not valid information comprises the remaining duration of the variable latency period.
  • 19. The method of claim 15, wherein providing information indicating the memory is available to perform the read command or the write command received during the second addressing phase comprises providing data valid information indicating an error.
CROSS-REFERENCED TO RELATED APPLICATION(S)

This application is a continuation of U.S. patent application Ser. No. 15/667,358, filed Aug. 2, 2017, and issued as U.S. Pat. No. 10,067,890 on Sep. 4, 2018, which is a continuation of U.S. patent application Ser. No. 13/838,296, filed Mar. 15, 2013, and issued as U.S. Pat. No. 9,734,097 on Aug. 15, 2017. The aforementioned applications and patents are incorporated by reference herein, in their entirety, and for all purposes.

US Referenced Citations (224)
Number Name Date Kind
4833642 Ooi May 1989 A
5287469 Tsuboi Feb 1994 A
5369616 Wells et al. Nov 1994 A
5546344 Fawcett Aug 1996 A
5668972 Liu et al. Sep 1997 A
5778432 Rubin et al. Jul 1998 A
5822244 Hansen et al. Oct 1998 A
5892961 Trimberger Apr 1999 A
5893149 Hagersten et al. Apr 1999 A
5953522 Fox et al. Sep 1999 A
6026034 Suzuki et al. Feb 2000 A
6201739 Brown et al. Mar 2001 B1
6219384 Kliza et al. Apr 2001 B1
6260128 Ohshima et al. Jul 2001 B1
6275077 Tobin et al. Aug 2001 B1
6412045 DeKoning et al. Jun 2002 B1
6438055 Taguchi et al. Aug 2002 B1
6459313 Godbee et al. Oct 2002 B1
6510095 Matsuzaki et al. Jan 2003 B1
6546462 Palanca et al. Apr 2003 B1
6552956 Shibata Apr 2003 B2
6629224 Suzuki et al. Sep 2003 B1
6687185 Keeth et al. Feb 2004 B1
6710726 Kim et al. Mar 2004 B2
6744285 Mangum et al. Jun 2004 B2
6861901 Prexl et al. Mar 2005 B2
6879540 Maruyama et al. Apr 2005 B2
6973008 Krause Dec 2005 B2
6980479 Park Dec 2005 B2
6988218 Drexler Jan 2006 B2
6996016 Oh Feb 2006 B2
7042799 Cho May 2006 B2
7058799 Johnson Jun 2006 B2
7111185 Gomm et al. Sep 2006 B2
7139673 Vashi et al. Nov 2006 B1
7170819 Szczypinski Jan 2007 B2
7173863 Conley et al. Feb 2007 B2
7187599 Schnell et al. Mar 2007 B2
7209396 Schnell Apr 2007 B2
7219251 Adkisson May 2007 B2
7268605 Fang et al. Sep 2007 B2
7269754 Ramaswamy et al. Sep 2007 B2
7280430 Lee Oct 2007 B2
7340632 Park Mar 2008 B2
7363540 Patel et al. Apr 2008 B2
7375560 Lee et al. May 2008 B2
7411852 Nishioka et al. Aug 2008 B2
7443216 Gomm et al. Oct 2008 B2
7451338 Lemos Nov 2008 B2
7463534 Ku et al. Dec 2008 B2
7509517 Matsumoto et al. Mar 2009 B2
7579683 Falik et al. Aug 2009 B1
7590013 Yu et al. Sep 2009 B2
7593273 Chu et al. Sep 2009 B2
7609584 Kim et al. Oct 2009 B2
7616040 Motomura Nov 2009 B2
7624209 Ansari et al. Nov 2009 B1
7631248 Zakharchenko et al. Dec 2009 B2
7643334 Lee et al. Jan 2010 B1
7656745 Kwak Feb 2010 B2
7660187 Johnson et al. Feb 2010 B2
7663946 Kim Feb 2010 B2
7671648 Kwak Mar 2010 B2
7715260 Kuo et al. May 2010 B1
7716510 Kwak May 2010 B2
7751261 Cho Jul 2010 B2
7773435 Cho Aug 2010 B2
7802039 Morita Sep 2010 B2
7826305 Fujisawa Nov 2010 B2
7826583 Jeong et al. Nov 2010 B2
7865658 Lasser et al. Jan 2011 B2
7872924 Ma Jan 2011 B2
7885365 Hagleitner et al. Feb 2011 B2
7913103 Gold et al. Mar 2011 B2
7945800 Gomm et al. May 2011 B2
7948817 Coteus et al. May 2011 B2
7969813 Bringivijayaraghavan et al. Jun 2011 B2
7983094 Roge et al. Jul 2011 B1
8004884 Franceschini et al. Aug 2011 B2
8030981 Kim Oct 2011 B2
8195891 Trika Jun 2012 B2
8358546 Kim et al. Jan 2013 B2
8441888 Bringivijayaraghavan et al. May 2013 B2
8489820 Ellard Jul 2013 B1
8509011 Bringivijayaraghavan Aug 2013 B2
8539129 Wang Sep 2013 B2
8582356 Abdulla Nov 2013 B2
8595441 Nakibly et al. Nov 2013 B1
8902684 Kwean Dec 2014 B2
9042156 Nakura et al. May 2015 B2
9268651 Salyers et al. Feb 2016 B1
9563565 Bernardi et al. Feb 2017 B2
9710192 Mirichigni et al. Jul 2017 B2
9727493 Mirichigni et al. Aug 2017 B2
9734097 Mirichigni et al. Aug 2017 B2
9740485 Mirichigni et al. Aug 2017 B2
9754648 Mirichigni et al. Sep 2017 B2
9928171 Mirichigni et al. Mar 2018 B2
10067764 Mirichigni et al. Sep 2018 B2
10067890 Mirichigni et al. Sep 2018 B2
10163472 Mirichigni et al. Dec 2018 B2
10223263 Mirichigni et al. Mar 2019 B2
20010015924 Arimoto et al. Aug 2001 A1
20020006074 Roohparvar Jan 2002 A1
20020168816 Shibata Nov 2002 A1
20030117864 Hampel et al. Jun 2003 A1
20030212865 Hicken et al. Nov 2003 A1
20040098549 Dorst May 2004 A1
20050024107 Takai et al. Feb 2005 A1
20050068812 Oh Mar 2005 A1
20060028883 Shimoyama Feb 2006 A1
20060069812 Osborne Mar 2006 A1
20060155948 Ruckerbauer Jul 2006 A1
20060268619 Chen Nov 2006 A1
20060282717 Suda Dec 2006 A1
20070005829 Fujimoto Jan 2007 A1
20070005922 Swaminathan et al. Jan 2007 A1
20070033427 Correale, Jr. et al. Feb 2007 A1
20070088903 Choi Apr 2007 A1
20070145151 Nakamura et al. Jun 2007 A1
20070150688 Osborne et al. Jun 2007 A1
20070156991 Gould et al. Jul 2007 A1
20070192651 Schoch Aug 2007 A1
20070208904 Hsieh et al. Sep 2007 A1
20070217253 Kim et al. Sep 2007 A1
20080080267 Lee Apr 2008 A1
20080080271 Kim Apr 2008 A1
20080082707 Gupta et al. Apr 2008 A1
20080082769 Bouchou et al. Apr 2008 A1
20080117682 Byeon May 2008 A1
20080155301 Ahvenainen et al. Jun 2008 A1
20080209109 Lasser Aug 2008 A1
20080270811 Chow et al. Oct 2008 A1
20080304351 Lim et al. Dec 2008 A1
20080307165 Kazuhiro Dec 2008 A1
20080320214 Ma et al. Dec 2008 A1
20090024778 Morita Jan 2009 A1
20090044190 Tringali et al. Feb 2009 A1
20090157974 Lasser Jun 2009 A1
20090232250 Yamada et al. Sep 2009 A1
20090235025 Kondo Sep 2009 A1
20090265514 Biles et al. Oct 2009 A1
20090315600 Becker et al. Dec 2009 A1
20100001762 Kim Jan 2010 A1
20100013675 Bennett Jan 2010 A1
20100023675 Chen et al. Jan 2010 A1
20100124090 Arai May 2010 A1
20100124102 Lee et al. May 2010 A1
20100161880 You Jun 2010 A1
20100161932 Stern et al. Jun 2010 A1
20100165769 Kuroki Jul 2010 A1
20100165780 Bains et al. Jul 2010 A1
20100172179 Gorobets et al. Jul 2010 A1
20100174955 Carnevale et al. Jul 2010 A1
20100195429 Sonoda Aug 2010 A1
20100254198 Bringivijayaraghavan et al. Oct 2010 A1
20100269118 Arimilli et al. Oct 2010 A1
20100293343 Perego Nov 2010 A1
20110035536 Shim et al. Feb 2011 A1
20110047319 Jeon et al. Feb 2011 A1
20110055453 Bennett Mar 2011 A1
20110055671 Kim et al. Mar 2011 A1
20110072190 Borracini et al. Mar 2011 A1
20110153900 Zitlaw Jun 2011 A1
20110170354 DeCaro et al. Jul 2011 A1
20110197014 Yeh Aug 2011 A1
20110228625 Bringivijayaraghavan et al. Sep 2011 A1
20110238866 Zitlaw Sep 2011 A1
20110238941 Xu et al. Sep 2011 A1
20110289255 Wang et al. Nov 2011 A1
20110314324 Ozdemir Dec 2011 A1
20120017053 Yang et al. Jan 2012 A1
20120054419 Chen et al. Mar 2012 A1
20120066434 Zitlaw Mar 2012 A1
20120079138 Obkircher Mar 2012 A1
20120117303 Carannante et al. May 2012 A1
20120124317 Mirichigni et al. May 2012 A1
20120131263 Yeh May 2012 A1
20120131304 Franceschini et al. May 2012 A1
20120173809 Ko et al. Jul 2012 A1
20120179860 Falanga et al. Jul 2012 A1
20120216085 Weingarten et al. Aug 2012 A1
20120254873 Bringivijayaraghavan Oct 2012 A1
20120265922 Post et al. Oct 2012 A1
20120269015 Bringivijayaraghavan Oct 2012 A1
20120324141 Seong et al. Dec 2012 A1
20120331207 Lassa et al. Dec 2012 A1
20130036253 Baltar Feb 2013 A1
20130058175 Lin et al. Mar 2013 A1
20130159766 D'Abreu et al. Jun 2013 A1
20130191601 Peterson et al. Jul 2013 A1
20130191704 Eleftheriou et al. Jul 2013 A1
20130194013 Kwak Aug 2013 A1
20130250701 Bringivijayaraghavan et al. Sep 2013 A1
20130262746 Srinivasan Oct 2013 A1
20130282967 Ramanujan Oct 2013 A1
20130321052 Huber et al. Dec 2013 A1
20130329503 Bringivijayaraghavan Dec 2013 A1
20130342254 Mazumder et al. Dec 2013 A1
20140010025 Bringivijayaraghavan Jan 2014 A1
20140013028 Rametta Jan 2014 A1
20140035640 Kwak et al. Feb 2014 A1
20140055184 Vankayala Feb 2014 A1
20140082259 Yeh Mar 2014 A1
20140089562 Deguchi et al. Mar 2014 A1
20140122814 Mirichigni et al. May 2014 A1
20140122822 Mirichigni et al. May 2014 A1
20140136771 Cornwell et al. May 2014 A1
20140215129 Kuzmin et al. Jul 2014 A1
20140281182 Mirichigni et al. Sep 2014 A1
20150052288 Mirichigni et al. Feb 2015 A1
20150052299 Mirichigni et al. Feb 2015 A1
20150095551 Confalonieri et al. Apr 2015 A1
20150100744 Mirichigni Apr 2015 A1
20150347038 Monteleone et al. Dec 2015 A1
20170083263 Mirichigni et al. Mar 2017 A1
20170147234 Frans et al. May 2017 A1
20170300413 Mirichigni et al. Oct 2017 A1
20170308382 Mirichigni et al. Oct 2017 A1
20170309318 Mirichigni et al. Oct 2017 A1
20170329534 Mirichigni et al. Nov 2017 A1
20180121356 Mirichigni et al. May 2018 A1
20190012173 Mirichigni et al. Jan 2019 A1
20190080733 Mirichigni et al. Mar 2019 A1
Foreign Referenced Citations (11)
Number Date Country
1497604 May 2004 CN
1860460 Nov 2006 CN
101030166 Sep 2007 CN
101256539 Sep 2008 CN
101752009 Jun 2010 CN
101820450 Sep 2010 CN
102789423 Nov 2012 CN
2005108395 Apr 2005 JP
20090094333 Sep 2009 KR
20110014923 Feb 2011 KR
201303735 Jan 2013 TW
Non-Patent Literature Citations (15)
Entry
U.S. Appl. No. 16/272,945 titled “Apparatuses and Methods for Providing Data to a Configurable Storage Area”, filed Feb. 11, 2019, pp. all.
U.S. Appl. No. 16/189,865 titled “Apparatuses and Methods for Memory Operations Having Variable Latencies” filed Nov. 13, 2018, pp. all.
U.S. Appl. No. 16/105,846 titled “Apparatuses and Methods for Memory Operations Having Variable Latencies” filed Aug. 20, 2018, pp. all.
English Translation of Third Office Action for CN Application No. 201480008522.4, dated Sep. 26, 2018; pp. all.
Examination Report dated Jan. 3, 2018 for European Application No. 14770419.1.
International Search Report and Written Opinion for PCT/US2014/021118 dated Jun. 27, 2014.
Translated Second Office Action dated Jan. 26, 2018 for Chinese Application No. 201480008522.4.
“Available”—Definition from Wiktionary, the free dictionary—Archived revision by Tuvalkin (talk | contribs) as of 21:49, Jan. 5, 2012. https://en.wiktionary.org/w/index/php?title=available&oldid=15765189 Downloaded Jan. 13, 2016, Jan. 5, 2012.
“Interfacing DDR SDRAM with Stratix II Devices”, Version 3.2, Altera Corp, Sep. 2008.
“JEDEC—Low Power Double Data Rate 2 (LPDDR2)”, Feb. 2010.
“Received EP Search Report dated Nov. 3, 2016 for EP application No. 14770419.1”.
Handy, J. “The Cache Memory Book Second Edition”, Academic Press Prof., Inc., San Diego, CA, Jan. 1993, p. 67.
Lee, “How to Implement DDR SGRAM in Graphic System”, Samsung Electric, 4Q1998 (Oct.-Dec. 1998).
Qureshi, et al., “Enhancing Lifetime and Security of PCM-Based Main Memory with Start-Gap Wearing Leveling”, Microarchitecture, 2009 42nd Annual IEEE/ACM International Symposium, Dec. 12-16, 2009, 14-23.
U.S. Appl. No. 16/523,860 titled Apparatuses and Methods for Performing Wear Leveling Operations filed Jul. 26, 2019.
Related Publications (1)
Number Date Country
20180349302 A1 Dec 2018 US
Continuations (2)
Number Date Country
Parent 15667358 Aug 2017 US
Child 16058793 US
Parent 13838296 Mar 2013 US
Child 15667358 US