Information may be stored on individual memory cells of the memory as a physical signal (e.g., a charge on a capacitive element). The memory may be a volatile memory, and the physical signal may decay over time (which may degrade or destroy the information stored in the memory cells). It may be necessary to periodically refresh the information in the memory cells by, for example, rewriting the information to restore the physical signal to an initial value.
As memory components have decreased in size, the density of memory cells has greatly increased. An auto-refresh operation may be carried out where a sequence of memory cells are periodically refreshed. Repeated access to a particular memory cell or group of memory cells (often referred to as a ‘row hammer’) may cause an increased rate of data degradation in nearby memory cells. It may be desirable to identify and refresh memory cells affected by the row hammer in a targeted refresh operation in addition to the auto-refresh operation. The targeted refresh operations may occur with timing interspersed between the auto-refresh operations.
The following description of certain embodiments is merely exemplary in nature and is in no way intended to limit the scope of the disclosure or its applications or uses. In the following detailed description of embodiments of the present systems and methods, reference is made to the accompanying drawings which form a part hereof, and which are shown by way of illustration specific embodiments in which the described systems and methods may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice presently disclosed systems and methods, and it is to be understood that other embodiments may be utilized and that structural and logical changes may be made without departing from the spirit and scope of the disclosure. Moreover, for the purpose of clarity, detailed descriptions of certain features will not be discussed when they would be apparent to those with skill in the art so as not to obscure the description of embodiments of the disclosure. The following detailed description is therefore not to be taken in a limiting sense, and the scope of the disclosure is defined only by the appended claims.
A memory device may include a plurality of memory cells. The memory cells may store information, and may be organized at the intersection of word lines (rows) and bit lines (columns). The word lines and bit lines may be organized into a memory bank, and the memory device may include a single memory die or a plurality of memory die. Each memory die may include a plurality of memory banks. One or more memory dies may be organized into a memory package, in some examples. In some embodiments, the memory dies of the memory package may be stacked on each other. In some embodiments, a plurality of memory packages or a plurality of single-die memory devices may be organized into a memory module. The memory device may receive one or more command signals which may indicate operations in one or more of the dies of one or more memory packages. The memory dies may be coupled to the command signals in common, may receive commands from a master die and/or interface chip, and/or may individually receive commands. For example, the memory dies of the package may receive a refresh signal, which may control the timing of refresh operations in the memory dies.
Information in the memory cells may decay over time, in some examples. The memory cells may be refreshed on a row-by-row basis. During a refresh operation, the information in one or more rows may be read out and then written back to the respective rows. A refresh command (e.g., an auto-refresh command AREF) may control a timing of the refresh operations. In some embodiments, the memory device may generate one or more “pumps”, which may be activations of an internal refresh signal responsive to receiving an activation of the refresh command. The memory dies may be capable of performing more than one type of refresh operation responsive to the refresh command and/or refresh pumps. For example, the memory dies may be capable of skipping all refresh operations (e.g., performing no refresh operations), performing an auto-refresh operation, or performing a targeted refresh operation. The memory dies may have internal logic configured to determine which type of refresh operation to perform and/or may receive signals (e.g., from an interface and/or controller) that indicates which type of refresh operation should be performed. In some examples, the memory dies may be capable of performing a combination of different operations during one refresh command.
During an auto-refresh operation (e.g., initiated by an activation of the auto-refresh command AREF and/or an activation of a pump), a memory die may refresh a group of rows of the memory array. From one auto-refresh operation to the next, the group of rows to be refreshed may be selected according to a predetermined sequence or pattern. The auto-refresh operation may cycle through and refresh all rows of the memory array of a memory die within a specified time period to prevent data loss (e.g., each row may be refreshed within a specified maximum refresh time period). The specified maximum refresh time period may be based on a normal rate of data degradation in the memory cells.
During a targeted refresh operation, a particular row or rows of memory cells of a memory array may be refreshed in response to detection of an attack on the particular row. Repeated access to a particular row of memory (e.g., an aggressor row) may cause an increased rate of decay in neighboring rows (e.g., victim rows) due, for example, to electromagnetic coupling between the rows. Information in the victim rows may decay at a rate such that data may be lost if they aren't refreshed until the next auto-refresh operation of that row. In order to prevent information from being lost, it may be necessary to identify aggressor rows and then carry out a targeted refresh operation on one or more associated victim rows. In some embodiments, the targeted refresh operation may “steal” a timeslot (e.g., an activation of a pump, an activation of the auto-refresh command AREF) that would have otherwise been used for an auto-refresh operation.
In some examples, auto-refresh commands AREF may be provided to a memory die at a higher frequency than is necessary to reliably maintain information stored in memory cells of a memory die. Thus, in some examples, the charge retention characteristics of the memory cells of a memory die may allow refresh operations to be periodically skipped, which may reduce power consumption during those refresh cycles.
It may be important to control an amount of current drawn by the memory device during refresh operations. Typically, an auto-refresh operation may draw more current than a targeted refresh operation, since more rows may be refreshed during a given auto-refresh operation than are refreshed during a given targeted refresh operation. Thus, if all memory banks of a memory die or all memory die of a group of memory die of a memory package or module contemporaneously perform an auto-refresh operation, current drawn may exceed a defined current limit, in some examples. As previously described, one way to reduce current draw is to periodically skip refreshes when possible. However, if all memory banks of a memory die or all memory die of a group of memory die of a memory package or module contemporaneously skip refresh operation and contemporaneously perform auto-refresh operation, the excessive current draw issue may persist.
The present disclosure is drawn to apparatuses, systems, and methods for staggering timing of different types of refresh operations. Since skipped and targeted refresh operations draw less current than auto-refresh operations, it may be desirable to reduce the number of memory dies (or memory banks of a single memory die) that are contemporaneously performing an auto-refresh operation by having a first subset of the memory dies (or first subset of memory banks) perform the auto-refresh operation while a second subset of the memory dies (or second subset of memory banks) skip a refresh operation, perform a targeted refresh operation, or a combinations thereof. For example, at a moment in time when a maximum number of memory dies (or memory banks) are performing a refresh operation, some of the memory dies (or memory banks) may skip a refresh operation and/or some of the memory dies (or memory banks) may perform a targeted refresh operation rather than performing an auto-refresh operation. In an example implementation, each of the memory dies may skip a refresh operation at a different activation of a refresh timing command (e.g., an auto-refresh command AREF and/or a pump). Thus, a first memory die may skip a refresh operation and a second die may perform an auto-refresh operation responsive to a first activation of a refresh timing signal, and the first memory die may perform an auto-refresh operation and the second die may skip a refresh operation responsive to a second activation of the refresh timing signal.
For brevity and clarity of illustration, only the components of one memory die in the stack 125 are shown in
The semiconductor device 100 includes a memory array 118. The memory array 118 may be positioned in a memory die of the stack 125. The memory array 118 is shown as including a plurality of memory banks BANK0-N, with a total count of memory banks being 2, 4, 8, 16, etc., including any number between those and any number greater than 16. Each of the memory banks BANK0-N may include a plurality of word lines WL, a plurality of bit lines BL and /BL, and a plurality of memory cells MC arranged at intersections of the plurality of word lines WL and the plurality of bit lines BL and /BL. The selection of the word line WL is performed by a row decoder 108 and the selection of the bit lines BL and /BL is performed by a column decoder 110. The row and column decoders 108 and 110 may also be positioned in the memory dies of the stack 125. In the embodiment of
The semiconductor device 100 may employ a plurality of external terminals that include command and address (C/A) terminals coupled to a command and address bus to receive commands and addresses, and a chip select (CS) terminal configured to receive a CS signal, clock terminals to receive clocks CK and /CK, data terminals DQ to provide data, and power supply terminals to receive power supply potentials VDD, VSS, VDDQ, and VSSQ. The external terminals may be positioned on the substrate 123.
The clock terminals are supplied with external clocks CK and /CK that are provided to an input circuit 112. The external clocks may be complementary. The input circuit 112 generates an internal clock ICLK based on the CK and /CK clocks. The ICLK clock is provided to the command decoder 110 and to an internal clock generator 114. The internal clock generator 114 provides various internal clocks LCLK based on the ICLK clock. The LCLK clocks may be used for timing operation of various internal circuits. The internal data clocks LCLK are provided to the input/output circuit 122 to time operation of circuits included in the input/output circuit 122, for example, to data receivers to time the receipt of write data.
The C/A terminals may be supplied with memory addresses. The memory addresses supplied to the C/A terminals are transferred, via a command/address input circuit 102, to an address decoder 104. The address decoder 104 receives the address and supplies a decoded row address XADD to the row decoder 108 and supplies a decoded column address YADD to the column decoder 110. The address decoder 104 may also supply a decoded bank address BADD, which may indicate the bank of the memory array 118 containing the decoded row address XADD and column address YADD. In some embodiments, the address decoder 104 may also indicate a particular memory die of the stack 125 for activation. The C/A terminals may be supplied with commands. Examples of commands include timing commands for controlling the timing of various operations, access commands for accessing the memory, such as read commands for performing read operations and write commands for performing write operations, as well as other commands and operations. The access commands may be associated with one or more row address XADD, column address YADD, and bank address BADD to indicate the memory cell(s) to be accessed.
The commands may be provided as internal command signals to a command decoder 106 via the command/address input circuit 102. The command decoder 106 includes circuits to decode the internal command signals to generate various internal signals and commands for performing operations. For example, the command decoder 106 may provide a row command signal to select a word line and a column command signal to select a bit line.
The semiconductor device 100 may receive an access command which is a read command. When a read command is received, and a bank address, a row address and a column address (and optional die address) are timely supplied with the read command, read data is read from memory cells in the memory array 118 corresponding to the row address and column address. The read command is received by the command decoder 106, which provides internal commands so that read data from the memory array 118 is provided to the read/write amplifiers 120. The read data is output to outside from the data terminals DQ via the input/output circuit 122.
The semiconductor device 100 may receive an access command (e.g., a write command). When the write command is received, and a bank address, a row address and a column address (and optional memory die address) are timely supplied with the write command, write data supplied to the data terminals DQ is written to a memory cells in the memory array 118 corresponding to the row address and column address. The write command is received by the command decoder 106, and in response, the command decoder 106 may provide internal commands to cause the write data is received by data receivers in the input/output circuit 122. Write clocks may also be provided to the external clock terminals for timing the receipt of the write data by the data receivers of the input/output circuit 122. The write data is supplied via the input/output circuit 122 to the read/write amplifiers 120, and by the read/write amplifiers 120 to the memory array 118 to be written into the memory cell MC.
The semiconductor device 100 may also receive commands causing it to carry out refresh operations. The refresh signal AREF may be a pulse signal that is activated when the command decoder 106 receives a refresh command. In some embodiments, the refresh command may be externally issued to the memory device 100. In some embodiments, the refresh command may be periodically generated by a component of the device. In some embodiments, when an external signal indicates a self-refresh entry command, the refresh signal AREF may also be activated. The refresh signal AREF may be activated once immediately after command input, and thereafter may be cyclically activated at desired internal timing period. Thus, refresh operations may automatically continue according to a predefined period. A self-refresh exit command may cause the automatic activation of the refresh signal AREF to stop and return to an IDLE state.
The refresh signal AREF is supplied to the refresh address control circuit 116. In some examples, each memory die of the stack 125 may include an individual refresh address control circuit 116 for each memory bank of the memory banks BANK0-N. In other examples, each memory die may include a single refresh address control circuit 116. In anticipation of a refresh operation, the refresh address control circuit 116 supplies a refresh row address RXADD to the row decoder 108, which may refresh a wordline WL indicated by the refresh row address RXADD. The refresh address control circuit 116 may control a timing of the refresh operation, and may select and provide the refresh address RXADD. The refresh address control circuit 116 may be controlled to change details of the refreshing address RXADD (e.g., how the refresh address is calculated, the timing of the refresh addresses), or may operate based on internal logic.
During a refresh cycle, a memory die may skip a refresh operation, perform an auto-refresh operation, perform a targeted refresh operation, or some combination thereof. Thus, during a skipped refresh operation, the refresh address control circuit 116 may provide no refresh address RXADD. During an auto-refresh operation or a targeted refresh operation, the refresh address control circuit 116 may provide as the refreshing address RXADD either one or more automatic refresh addresses (e.g., an auto-refresh address) or a targeted refresh address (e.g., a victim address), respectively. The automatic refresh addresses may be part of a sequence of addresses that are provided based on activations of the auto-refresh signal AREF. The refresh address control circuit 116 may cycle through the sequence of auto-refresh addresses at a rate determined by an activation rate of the auto-refresh signal AREF. Multiple addresses may be provided as the refreshing address RXADD as part of an auto-refresh operation. In some embodiments, a group or block of addresses may all be indicated by the refresh address RXADD, and the row decoder 108 may refresh the entire group or block of addresses.
The refresh address control circuit 116 may also determine targeted refresh addresses which are addresses that require refreshing (e.g., victim addresses corresponding to victim rows) based on the access pattern of nearby addresses (e.g., aggressor addresses corresponding to aggressor rows) in the memory array 118. The refresh address control circuit 116 may selectively use one or more signals of the device 100 to calculate the targeted refresh address RXADD. For example, the refresh address RXADD may be a calculated based on the row addresses XADD provided by the address decoder. In some embodiments, the refresh address control circuit 116 may sample the current value of the row address XADD provided by the address decoder 104 and determine a targeted refresh address based on one or more of the sampled addresses.
The targeted refresh address may be based on characteristics over time of the row addresses XADD received from the address decoder 104. The refresh address control circuit 116 may sample the current row address XADD to determine its characteristics over time. The sampling may occur intermittently, with each sample acquired based on a random or semi-random timing. The refresh address control circuit 116 may use different methods to calculate a targeted refresh address based on the sampled row address XADD. For example, the refresh address control circuit 116 may determine if a given row is an aggressor address, and then calculate and provide addresses corresponding to victim addresses of the aggressor address as the targeted refresh address. In some embodiments, more than one victim address may correspond to a given aggressor address. In this case the refresh address control circuit may queue up multiple targeted refresh addresses, and provide them sequentially when it determines that a targeted refresh address should be provided. The refresh address control circuit 116 may provide the targeted refresh address right away, or may queue up the targeted refresh address to be provided at a later time (e.g., in the next time slot available for a targeted refresh).
The refresh address RXADD may be provided with a timing based on a timing of the refresh signal AREF. The refresh address control circuit 116 may have time slots corresponding to the timing of the refresh signal AREF, and may provide none, one, or more refresh addresses RXADD during each time slot. In some embodiments, a refresh may be skipped or the targeted refresh address may be issued during (e.g., “steal”) a time slot that would otherwise have been assigned to an auto-refresh address. In some embodiments, multiple refresh operations may be performed in response to an activation of the refresh signal AREF. In this example, certain time slots may be reserved for a particular type of refresh operation according to some predefined pattern. Based on the predefined pattern, the refresh address control circuit 116 may determine whether to provide a targeted refresh address, to provide no refresh address (e.g., a skipped refresh), or provide an auto-refresh address during a particular time slot. In some examples, the refresh address control circuit 116 may be configured to override a pattern, such as in response to a detected row hammer attack.
In some embodiments, the refresh address control circuit 116 may include logic, such as a state machine and/or counter that are used to determine whether to initiate a skipped refresh operation, an auto-refresh operation, or a targeted refresh operation. For example, the refresh address control circuit 116 may count a number of activations of the refresh signal AREF with a counter, and when the counter reaches a maximum value and ‘rolls over’ back to a minimum value, a refresh operation may be skipped. The logic may also be coupled to settings, such as fuse settings, which may be used to alter the operation of the logic in a given memory die. In other embodiments, a refresh operation sequence may occur over many refresh operation cycles.
Since more addresses may be provided as the refresh address RXADD during an auto-refresh operation than during a targeted refresh operation or a skipped refresh operation, an auto-refresh operation may draw more current (e.g., more power) than a targeted refresh operation or a skipped refresh operation. To reduce a peak current drawn by the semiconductor device 100 at any given point in time during a refresh operation, skipped refresh and/or target refresh operations may be staggered in time with auto-refresh operations between different memory dies of the stack 125 (and/or between different memory banks BANK0-N of the memory array 118 of a particular memory die). The different memory dies of the stack 125 may have settings that cause the skipped refresh operations and the auto-refresh operations to occur at different times in the different memory dies (or the different memory banks BANK0-N of a memory die). In one example implementation, the refresh address control circuits 116 of different memory dies in the stack 125 may indicate a skipped refresh operation with a frequency based on the refresh signal (e.g., a skipped refresh operation may be performed responsive to every nth activation of the refresh signal AREF). In another example implementation, the refresh address control circuits 116 of a particular die of the stack 125 may indicate a skipped refresh operation for a corresponding memory bank of the memory banks BANK0-N with a frequency based on the refresh signal (e.g., a skipped refresh operation may be performed responsive to every nth activation of the refresh signal AREF). Each of the memory dies (e.g., or memory banks BANK0-N of a memory die) may perform skipped refresh operations with the same frequency, however settings (e.g., fuse settings) in each of the memory dies (or memory banks BANK0-N) may offset the phase of the skipped refresh operations.
As previously described, the timings of the skipped refresh operations may be staggered in time to reduce a peak power drawn by the memory device 100 during a refresh operation. The settings of the different memory dies of the stack 125 (or different memory banks BANK0-N of a memory die) may be set such that when a maximum number of simultaneous refresh operations would occur across one or more of the memory dies (or one or more of the memory banks BANK0-N), at least one of the memory dies (or at least one of the memory banks BANK0-N) is performing a skipped refresh operation rather than an auto-refresh operation.
The power supply terminals are supplied with power supply potentials VDD and VSS. The power supply potentials VDD and VSS are supplied to an internal voltage generator circuit 124. The internal voltage generator circuit 124 generates various internal potentials VPP, VOD, VARY, VPERI, and the like based on the power supply potentials VDD and VSS supplied to the power supply terminals. The internal potential VPP is mainly used in the row decoder 108, the internal potentials VOD and VARY are mainly used in the sense amplifiers SAMP included in the memory array 118, and the internal potential VPERI is used in many peripheral circuit blocks.
The power supply terminals are also supplied with power supply potentials VDDQ and VSSQ. The power supply potentials VDDQ and VSSQ are supplied to the input/output circuit 122. The power supply potentials VDDQ and VSSQ supplied to the power supply terminals may be the same potentials as the power supply potentials VDD and VSS supplied to the power supply terminals in an embodiment of the disclosure. The power supply potentials VDDQ and VSSQ supplied to the power supply terminals may be different potentials from the power supply potentials VDD and VSS supplied to the power supply terminals in another embodiment of the disclosure. The power supply potentials VDDQ and VSSQ supplied to the power supply terminals are used for the input/output circuit 122 so that power supply noise generated by the input/output circuit 122 does not propagate to the other circuit blocks.
Embodiments which are generally similar to the structure of the memory package 200 may be referred to as 3DS packages, and each of the dies may generally be referred to as a logical rank. The memory package 200 of
Each of the master 228 and slave memory dies 229a-c may include one or more memory arrays (e.g., memory array 118 of
The master die 228 may be coupled to the substrate 227 and to the first slave die 229a. The first slave die 229a is coupled to the master die 228 and also to the next slave die 229b, and so forth. The dies 228 and 229a-c may be coupled to each other (and the substrate 227) with a variety of methods. In some embodiments, the dies may be coupled together with wire bonds. In some embodiments, the dies may be coupled together using through silicon vias (TSVs). In a 3DS package, there may be an additional power constraint based on the peak power (and/or current) which may be pulled through the couplings between the dies (e.g., the wire bonds and/or TSVs).
The substrate 227 may receive a refresh command configured to cause the memory package 200 to be put in a refresh state. In some embodiments, the command may specify which of the memory dies 228 and 229a-c that should be put in the refresh state. While in a refresh state, each of the memory dies 228 and 229a-c may perform refresh operations (e.g., skipped refresh operations, auto-refresh operations, and/or targeted refresh operations). In some embodiments, responsive to a refresh command, the memory package 200 may place only a subset or group of the memory dies 228 and 229a-c (e.g., defined by a logical rank) into a refresh state at the same time. In some examples, after a logical rank begins performing a refresh operation, a minimum amount of time may elapse before a next logical rank can begin performing a refresh operation. Thus, there may be an offset of at least that minimum timing between a first refresh operation of a first logical rank and a first refresh operation of a second logical rank.
While the memory package 200 is in a refresh mode, the substrate 227 may receive a refresh command and provide it to the master die 228. The master die 228 may decode the refresh command and provide the refresh signal AREF to the slave dies 229a-c (as well as to internal components of the master die 228). The refresh signal may be periodically activated (e.g., raised to a high logical level). Each of the logical ranks may receive the refresh signal (e.g., AREF) from the substrate, which may be used to control the timing of the refresh operations in the logical ranks. In some embodiments, the logical ranks (e.g., groups of the memory dies 228 and 229a-c) may perform one or more refresh operations responsive to each activation of the refresh signal. In some embodiments, the logical ranks may begin providing activations of a refresh pump signal responsive to receiving the refresh signal, and may perform refresh operations responsive to the activations of the refresh pump signal.
In some embodiments, each of the logical ranks may have at least one refresh address control circuit (e.g., 116 of
In some embodiments, the master die 228 may determine a timing of skipped refresh, auto-refresh, and targeted refresh operations in the master die 228 and in each of the slave dies 229a-c. For example, the master die 228 may provide a separate skipped refresh signal and a separate targeted refresh signal (e.g., row hammer refresh (RHR)) for each of the slave dies 229a-c. The master die 228 may include internal logic, and may time when it provides each of the separate targeted refresh signals to their respective die. As an example operation, when the master die 228 receives a first activation of the refresh signal, it may send the skipped refresh signal to slave die 229a. When the master die 228 receives a second activation of the refresh signal, it may send the skipped refresh signal to slave die 229b. When the master die 228 receives a third activation of the refresh signal, it may send the skipped refresh signal to the slave die 229c. Upon a subsequent activation of the refresh signal, the master die 228 may repeat the cycle again. Other methods of operation and/or skipped refresh patterns may be used in other example embodiments. In other embodiments, each memory die 228 and 229a-c may include control logic to select groups of memory banks within a memory die (e.g., the master die 228 and the slave dies 229A-C) on which to perform a skipped refresh operation during each cycle.
In some embodiments, the refresh timing settings that control the timing of the skipped refresh, the auto-refresh, and targeted refresh operations may be determined when the memory package 200 is assembled. In some embodiments, the timing settings may be determined based on the placement of the memory dies 228 and 229a-c relative to each other (e.g., the slave dies 229a may take on certain timing settings based on the count of memory dies it is away from the master die 228, etc.). In some other example architectures, memory dies 228 and 229A-C of the memory package 200 may each receive all commands directly from the package substrate 227, rather than via the master die 228. Operation of such a memory package may be similar to the described operation of the memory package 200, with individual memory dies being configured (e.g., programmed) to stagger skipped refresh operations relative to other memory dies or relative to other banks within a memory die. Staggering skipped refresh operations and auto-refresh operations across multiple memory dies or across memory banks within a memory die may reduce peak current draw as compared with performing an auto-refresh operation contemporaneously across all memory dies or across all memory banks within a memory die.
Each of the memory banks 332(0)-(15) includes a number of wordlines and bitlines, with a number of memory cells arranged at the intersections. In some embodiments, there may be further organization of the rows (wordlines) and columns (bitlines) within the memory banks 332(0)-(15). For example, each of the memory banks 332(0)-(15) may include a number of memory mats each containing a number of rows and columns. The memory mats may be organized into memory mat sets. In some embodiments, during an auto-refresh operation, an address may be provided which causes a wordline in a particular memory mat of each of the sets in each of the memory banks 332(0)-(15) to refresh.
In some embodiments, refresh commands may be issued in common to all of the memory banks 332(0)-(15) and all of the memory banks 332(0)-(15) may simultaneously perform refresh operations. In some embodiments, a refresh command may be issued which specifies a subset of the memory banks 332(0)-(15). For example, a particular memory bank group (or groups) 330(0)-(3) of the memory banks 332(0)-(15) may begin refreshing. In another example, a portion of the memory banks 332(0)-(15) in each of the memory bank groups 330(0)-(3) (or a subset of the groups) may begin refreshing (e.g., the first memory bank 332(00), 332(10), 332(20), 332(30) in each of the memory bank groups 330(0)-(3)). Once refresh commands have been issued to one or more of the memory banks 332(0)-(15), each of the indicated memory banks of the memory banks 332(0)-(15) may simultaneously perform one or more refresh operations. The timing of skipped and auto-refresh operations may be staggered in the indicated memory banks of the memory banks 332(0)-(15), such that a portion of the indicated memory banks of the memory banks 332(0)-(15) perform a skipped refresh operation simultaneous with a portion of the indicated banks of the memory banks 332(0)-(15) performing an auto-refresh operation.
The indicated memory banks of the memory banks 332(0)-(15) that are refreshing may have logic and/or programming that configures a first subset of the indicated memory banks to perform auto-refresh operations while a second subset of the memory banks skips refresh operations. In some embodiments, the logic/programming may be inherent to the design of the memory array 300, rather than being based on settings programmed after the memory device is assembled.
Each of the memory banks 332(0)-(15) may be associated with a refresh control circuit (e.g., 116 of
Although the memory module 400 shown in
Similar to spacing out the auto-refresh, targeted refresh, and skipped refresh operations within a memory package 425(0)-(8) as described herein, it may also be desirable to manage refresh timing between memory packages 425(0)-(8) of the module 400. For the sake of brevity, similar components, structures, and/or operations to those previously described are not repeated. For example, one or more of the memory packages 425(0)-(8) may be entered into a refresh mode in which one or more of the respective memory dies performs one of an auto-refresh operation, a targeted refresh operation, or a skipped refresh operation. As well as being staggered between the memory dies of a given the memory package 425(0)-(8) or the memory banks of a die of a given memory package, the targeted refresh operations and the skipped refresh operations may also be staggered between different packages 425(0)-(8) of the memory module 400 to reduce peak current draw.
An interface 531 (e.g., an external memory controller interface or a command decoder interface) may provide one or more signals to an address refresh control circuit 516 and row decoder 508. The refresh address control circuit 516 may include a sample timing generator 538, an address sampler 537, a row hammer refresh (RHR) state controller 536 and a refresh address generator 539. The interface 531 may provide one or more control signals, such as an auto-refresh signal AREF, and a row address XADD. The refresh state control 536 may determine whether a skipped refresh operation, an auto-refresh operation, or a targeted refresh operation should be performed. The refresh state control 536 may indicate different refresh operations in different memory banks or memory dies in order to stagger the skipped, targeted, and auto-refresh operations between the memory banks or memory dies. A refresh stagger circuit 535 may control the refresh state control 536 to stagger the skipped, targeted, and auto-refresh operations.
The refresh address control circuit 516 shows components associated with a particular implementation of detecting aggressor addresses by sampling incoming values of the row address XADD at random or semi-random timing. Other methods of detecting aggressor addresses may be used in other embodiments, and other components may be provided in the refresh address control circuit 516.
The address sampler 537 may sample (e.g., latch) the current row address XADD responsive to an activation of ArmSample. The address sampler 537 may also provide one or more of the latched addresses to the refresh address generator 539 as the matched address HitXADD. The refresh state control 536 may provide the RHR signal to indicate that a row hammer refresh operation (e.g., a refresh of the victim rows corresponding to an identified aggressor row) should occur. The refresh state control 536 may also provide an internal refresh signal IREF to indicate that an auto-refresh operation should occur and no signal (or a skip signal SKIP) when no refresh operation should occur. The refresh state control 536 may be used to control the timings of skipped refresh operations, targeted refresh operations, and auto-refresh operations. The activations of SKIP, IREF, and RHR signals may represent activations of a pump signal. Note that
There may be a refresh state control 536 for each of the different banks. Each refresh state control 536 may include internal logic configured to determine the timing with which it provides signals (e.g., SKIP, IREF, or RHR) to indicate if a skipped, auto, or targeted refresh operation should be performed in the associated memory bank. In some embodiments, each refresh state control 536 may include one or more counters, and may provide the SKIP or the RHR signal based on a number of occurrences of the refresh signal AREF (and/or the number of occurrences of the IREF signal). In examples where the skipped refresh operations or the targeted refresh operations are staggered across memory dies of a memory package or module, each of the different memory banks of a single memory die may initialize to a same value to align the refresh operations on a single memory die, with some memory dies being initialized to different values. Accordingly, each refresh state control 536 may produce the same pattern of skipped, targeted, and auto-refresh operations, however those patterns may be out of phase with each other such that they are staggered in time. In some examples, the refresh state control 536 may be coupled to settings, such as fuse settings (and/or may include settings) that are memory die specific. In some embodiments, the refresh state control 536 may include a counter, and may provide the SKIP signal or the RHR signal based on a number of activations of the refresh signal AREF. In some embodiments, the fuse settings may control an initial value of the counter in the refresh state control 536. In this manner, different patterns of SKIP, RHR, and IREF signals may be generated in different memory dies (and/or different packages of a module) to stagger the timing of targeted refresh operations.
In examples where the skipped refresh operations or the targeted refresh operations are staggered across memory banks of a memory single die, the counter in each refresh state control 536 in each of the different memory banks may initialize to a different value to stagger the refresh operations. Accordingly, each refresh state control 536 may produce the same pattern of targeted and auto-refresh operations, however those patterns may be out of phase with each other such that they are staggered in time. In some embodiments and refresh stagger circuit 535 may provide a signal to the refresh state control circuits 536 to control the staggering. For example, the refresh stagger circuit 535 may provide signals to each of the refresh state control 536 associated with the different memory banks which may indicate when a targeted refresh operation should be performed. In some embodiments, there may be a single refresh stagger circuit 535 that is coupled to all of the refresh address control circuits 516 for the different banks. The refresh stagger circuit 535 may contain internal logic (e.g., counters initialized to different values) that allow it to direct the staggering between the different memory banks.
Responsive to an activation of RHR, the refresh address generator 539 may provide a refresh address RXADD, which may be an auto-refresh address or may be one or more victim addresses corresponding to victim rows of the aggressor row corresponding to the match address HitXADD. The row decoder 508 may perform a refresh operation responsive to the refresh address RXADD and the row hammer refresh RHR signal. The row decoder 508 may perform an auto-refresh operation based on the refresh address RXADD and the internal refresh signal IREF. The row decoder 508 may perform no refresh operations responsive to the SKIP signal (e.g., or responsive to deactivation of both the RHR and IREF signals).
In some embodiments, the refresh address control circuit 516 may determine if no refresh operations (e.g., a skip) are currently needed, or if one or more targeted refresh operations is currently needed. If no refreshes are currently needed, the refresh address control circuit 516 may provide the SKIP signal (e.g., deactivate both of the IREF and the RHR signals). If a targeted refresh operation is currently needed, the refresh address control circuit 516 may provide targeted refresh addresses and activate the RHR signal.
The refresh address control circuits 516 associated with the different banks may each determine a number of targeted refresh operations to perform based on the characteristics of the accesses to the row addresses XADD (e.g., the number, frequency, and/or pattern of accesses). For example, a first refresh address control circuit 516 associated with a first bank containing multiple rows which are hammered may determine that there need to be more targeted refresh operations than a second refresh address control circuit 516 associated with a second bank containing less rows which are hammered. In some embodiments, the refresh operations may occur in cycles (e.g., a certain number of pumps and/or a certain number of AREF occurrences), and the refresh address control circuit 516 may determine a number of skipped refresh operations or a number of targeted refresh operations to perform in each cycle. The remainder of the refresh operations in the cycle may be used for auto-refresh operations. Although different banks may determine different numbers of skipped refresh operations or different numbers of targeted refresh operations to perform, the skipped refresh operations may still be staggered between the different banks and the targeted refresh operations may still be staggered between the different banks, in some examples. In other examples, the skipped and refresh operations may be aligned across all banks of a single die, but may be staggered across different dies.
The interface 531 may represent one or more components configured to provide signals to components of the memory bank (or banks). For example, the interface 531 may represent components such as the command address input circuit 102, the address decoder 105, and/or the command control 106 of
The sample timing generator 538 provides the sampling signal ArmSample. ArmSample may alternate between a low logic level and a high logic level. An activation of ArmSample may be a ‘pulse’, where ArmSample is raised to a high logic level and then returns to a low logic level. The interval between the pulses of ArmSample may be random, pseudo-random, and/or based on one or more signals of the device (e.g., AREF).
The address sampler 537 may receive the row address XADD from the interface 531 and ArmSample from the sample timing generator 538. The row address XADD may change as the interface 531 directs access operations (e.g., read and write operations) to different rows of the memory cell array (e.g., memory cell array 112 of
In some embodiments, responsive to an activation of ArmSample, the address sampler 537 may determine if one or more rows is an aggressor row based on the sampled row address XADD, and may provide identified aggressor rows as the match address HitXADD. As part of this determination, the address sampler 537 may record (e.g., by latching and/or storing in a register) the current value of XADD responsive to the activation of ArmSample. The current value of XADD may be compared to previously recorded addresses in the address sampler 537 (e.g., the addresses stored in the latch/register), to determine access patterns over time of the sampled addresses. If the address sampler 537 determines that the current row address XADD is being repeatedly accessed (e.g., is an aggressor row), the activation of ArmSample may also cause the address sampler 537 to provide the address of the aggressor row as a match address HitXADD. In some embodiments, the match address (e.g., aggressor address) HitXADD may be stored in a latch circuit for later retrieval by the refresh address generator 539. For example, the value of one or more match addresses HitXADD may be stored until the RHR signal indicates a targeted refresh operation.
The refresh state control 536 may receive the auto-refresh signal AREF, and may provide the row hammer refresh RHR signal, the internal refresh signal IREF, or the SKIP signal (e.g., or deactivate both of the RHR and IREF signals). The RHR signal may indicate that a targeted refresh operation should take place (e.g., that one or more victim rows associated with the identified aggressor HitXADD should be refreshed). The IREF signal may indicate that an auto-refresh operation should occur. The SKIP signal (e.g., or deactivation of both the RHR and IREF signals) may indicate a skipped refresh operation should occur. The refresh state control 536 may use internal logic to provide the RHR signal. In some embodiments, the refresh state control 536 may include a counter and may provide the SKIP signal or the RHR signal based on certain number of activations of AREF. In some examples, the SKIP and RHR signals have be associated with different counters. The counter (or counters) may be initialized to a particular value (e.g., when the memory is powered on). The particular value may vary from refresh control circuit to refresh control circuit between banks of a memory die and/or may vary between different memory die of a memory package or memory module.
The refresh state control 536 may provide the IREF signal to control the timing of refresh operations. In some embodiments, the refresh state control 536 may activate the IREF signal multiple times for each activation of the refresh signal AREF. In some embodiments, the IREF signal may be used as a refresh pump signal to control the activations of refresh pumps. In some embodiments, each activation of the AREF signal may be associated with a number of activations of the IREF signal, which may be associated with a number of refresh operations, including a mix of targeted refresh operations, skipped refresh operations, and auto-refresh operations. For example, each activation of the IREF signal may be associated with a refresh operation on the refresh address RXADD, while the state of the RHR signal may determine if the refresh address RXADD is associated with an auto-refresh operation or a targeted refresh operation and the state of the SKIP signal may determine if the refresh address RXADD is associated with an auto-refresh operation or a skipped refresh operation. In some embodiments, the IREF signal may be used to indicate that an auto-refresh operation should occur, the RHR signal is used to indicate that a targeted refresh operation should occur, and the SKIP signal is used to indicate that no refresh operation should occur. For example, the SKIP, RHR, and IREF signals may be generated such that they are not active at the same time (e.g., are not ALL at a high logic level at the same time), and each activation of the SKIP signal may be associated with a skipped refresh operation, each activation of the IREF signal may be associated with an auto-refresh operation, and each activation of the RHR signal may be associated with a targeted refresh operation.
In some embodiments, the refresh state control 536 may count activations of the IREF signal and use the count of activations (e.g., the pumps) of the IREF signal to determine when the SKIP signal or the RHR signal should be provided. The counter may initialize to a different value for different refresh control circuits 516, in some examples. In other examples, the counter may initialize to a same value within a die. In some embodiments, the refresh state control 536 may receive one or more signals from a refresh stagger circuit 535 configured to direct the different refresh state controllers 536 to provide the SKIP signal or the RHR signal. In either of these manners skipped or targeted refresh operations and auto-refresh operations may be staggered between banks of a die, or between die of a memory package.
The refresh address generator 539 may receive the row hammer refresh RHR signal and the match address HitXADD. The match address HitXADD may represent an aggressor row. The refresh address generator 539 may determine the locations of one or more victim rows based on the match address HitXADD and provide them as the refresh address RXADD. In some embodiments, the victim rows may include rows which are physically adjacent to the aggressor row (e.g., HitXADD+1 and HitXADD−1). In some embodiments, the victim rows may also include rows which are physically adjacent to the physically adjacent rows of the aggressor row (e.g., HitXADD+2 and HitXADD−2). Other relationships between victim rows and the identified aggressor rows may be used in other examples.
The refresh address generator 539 may determine the value of the refresh address RXADD based on the RHR signal and, in some examples, the SKIP signal. In some embodiments, when the RHR signal (and the SKIP signal) are not active, the refresh address generator 539 may provide one of a sequence of auto refresh addresses as the refresh address RXADD. When the RHR signal is active (and the SKIP signal is not active), the refresh address generator 539 may provide a targeted refresh address, such as a victim address, as the refresh address RXADD.
The row decoder 508 may perform one or more operations on the memory array (not shown) based on the received signals and addresses. For example, responsive to the activation signal ACT and the row address XADD (and the IREF, SKIP, and/or RHR signals being at a low logic level), the row decoder 508 may direct one or more access operations (for example, a read operation) on the specified row address XADD. Responsive to the RHR signal being active, the row decoder 508 may refresh the refresh address RXADD.
As shown in
The timing diagram 700 shows an example embodiment where four refresh operations are performed responsive to each activation of the refresh signal AREF. In particular, responsive to each activation of AREF, there may be three pumps (e.g., activations of a pump signal in each refresh control circuit), and each of the pumps may be associated with either a skipped refresh operation, an auto-refresh operation, or a targeted refresh operation. The pumps are represented in timing diagram 700 by the vertical lines, with line patterns identifying a type of refresh operation. The pumps are in groups of three to represent the three pumps per AREF activation. Thus, there is an activation of AREF for each group of pumps. The solid lines represent an auto-refresh operation, the medium dashed lines represent a skipped refresh operation, and the longer dashed lines represent a targeted refresh operation. As discussed herein, more wordlines may be simultaneously refreshed in a bank during an auto-refresh operation than during a targeted refresh operation and thus an auto-refresh operation may draw more power than a targeted refresh operation. No wordlines may be refreshed during a skipped refresh operation.
A given bank may perform a refresh operation responsive to each of the pumps. Since the banks produce the pumps responsive to a refresh signal (e.g., AREF) that they receive in common, the pumps may generally be synchronized. Thus, each of the memory banks BANK0-15 may simultaneously perform a first pump, then simultaneously perform a second pump, etc. In response to each of the pumps, each of the banks may generally perform one of a skipped refresh operation, an auto-refresh operations, or targeted refresh operation. In the example depicted in timing diagram 700, two different refresh operation sequences are depicted for an AREF activation. In a first example sequence, an auto-refresh operation is performed responsive to a first pump, a first targeted refresh operation is performed responsive to a second pump, and a second targeted refresh operation is performed responsive to a third pump. In a second example sequence, a skipped refresh operation is performed responsive to a first pump, a first targeted refresh operation is performed responsive to a second pump, and a second targeted refresh operation is performed responsive to a third pump.
In the example timing diagram 700, each of the memory banks BANK0-15 may alternate between the first example sequence and the second example sequence with each AREF activation. However, among the memory banks BANK0-15 during a single AREF activation, the skipped and auto refresh operations may be staggered between the banks such that a first group of memory banks of the memory banks BANK0-15 perform the auto-refresh operation contemporaneous with a second group of memory banks of the memory banks BANK0-15 performing the skipped refresh operation. For example, during the AREF activation received at time T0, the memory banks BANK0-7 may perform the first example sequence (e.g., auto-refresh, first targeted refresh, second targeted refresh), while the memory banks BANK8-15 perform the second example sequence (e.g., skipped refresh, first targeted refresh, second targeted refresh). During the AREF activation received at time T1, the memory banks BANK0-7 may perform the second example sequence (e.g., skipped refresh, first targeted refresh, second targeted refresh), while the memory banks BANK8-15 perform the first example sequence (e.g., auto-refresh, first targeted refresh, second targeted refresh). This two AREF activation cycle or pattern may repeat every two AREF activations (e.g., starting against at time T2, etc.) in the example timing diagram 700. By only performing the auto-refresh on half of the memory banks BANK0-15 at a given time, the peak current draw may be reduced as compared with implementations where all of the memory banks perform the auto-refresh operations contemporaneously.
The memory banks BANK0-15 of
The timing diagram 800 shows an example embodiment where three refresh operations are performed responsive to each activation of the refresh signal AREF. In particular, responsive to each activation of AREF, there may be three pumps (e.g., activations of a pump signal in each refresh control circuit), and each of the pumps may be associated with either a skipped refresh operation, an auto-refresh operation, or a targeted refresh operation. The pumps are represented in timing diagram 800 by the vertical lines, with line patters identifying a type of refresh operation. The pumps are in groups of three to represent the three pumps per AREF activation. Thus, there is an activation of AREF for each group of pumps. The solid lines represent an auto-refresh operation, the medium dashed lines represent a skipped refresh operation, and the longer dashed lines represent a targeted refresh operation. As discussed herein, more wordlines may be simultaneously refreshed in a bank during an auto-refresh operation than during a targeted refresh operation and thus an auto-refresh operation may draw more power than a targeted refresh operation. No wordlines may be refreshed during a skipped refresh operation.
A given memory die of the memory dies DIE0-7 may perform a refresh operation responsive to each of the pumps. Since the memory dies DIE0-7 produce the pumps responsive to a refresh signal (e.g., AREF) that they receive in common, the pumps may generally be synchronized. Thus, each of the memory dies DIE0-7 may simultaneously perform a first pump, then simultaneously perform a second pump, etc. In response to each of the pumps, each of the memory dies DIE0-7 may generally perform one of a skipped refresh operation, an auto-refresh operations, or targeted refresh operation. In the example depicted in timing diagram 800, two different refresh operation sequences are depicted for an AREF activation. In a first example sequence, an auto-refresh operation is performed responsive to a first pump, a first targeted refresh operation is performed responsive to a second pump, and a second targeted refresh operation is performed responsive to a third pump. In a second example sequence, a skipped refresh operation is performed responsive to a first pump, a first targeted refresh operation is performed responsive to a second pump, and a second targeted refresh operation is performed responsive to a third pump.
In the example timing diagram 800, each of the memory dies DIE0-7 may alternate between the first example sequence and the second example sequence with each AREF activation. However, among the memory dies DIE0-7 during a single AREF activation, the skipped and auto refresh operations may be staggered between the memory dies DIE0-7 such that a first group of memory dies of the memory dies DIE0-7 perform the auto-refresh operation contemporaneous with a second group of memory dies of the memory dies DIE0-7 performing the skipped refresh operation. For example, during the AREF activation received at time T0, the memory dies DIE0-3 may perform the first example sequence (e.g., auto-refresh, first targeted refresh, second targeted refresh), while the memory dies DIE4-7 perform the second example sequence (e.g., skipped refresh, first targeted refresh, second targeted refresh). During the AREF activation received at time T1, the memory dies DIE0-3 may perform the second example sequence (e.g., skipped refresh, first targeted refresh, second targeted refresh), while the memory dies DIE4-7 perform the first example sequence (e.g., auto-refresh, first targeted refresh, second targeted refresh). This two AREF activation cycle or pattern may repeat every two AREF activations (e.g., starting against at time T2, etc.) in the example timing diagram 800. By only performing the auto-refresh on a subset of the memory dies DIE0-7 at a given time, the peak current draw may be reduced as compared with implementations where all of the memory banks perform the auto-refresh operations contemporaneously.
The memory dies DIE0-7 of
While this application has described reducing peak current draw during refresh operations within volatile memory architectures, it is appreciated that a similar approach may be implemented in other contexts and in other types of semiconductor devices, including non-volatile memory devices. For example, configuration of other types of periodic maintenance functions within a memory device/package/module may be staggered in a similar fashion to reduce peak power within each device, or device set. Other types of periodic maintenance functions may include error correction code maintenance (e.g., ECC error check and scrub procedures), wear levelling, or other targeted restoring of data within a set of storage array containers after destructive accesses other than row hammer.
The method 900 may include receiving a refresh signal at a first memory die (or bank) and a second memory die (or bank), at 910. In some examples, the first and second memory die include any of the memory die in the stack 125 of
In some examples, the method 900 may include determining, at the first memory die (or the second memory die), whether to perform the auto-refresh operation or to skip the refresh operation in response to an activation of the refresh signal based on an internal setting. The internal setting programmed in a fuse bank, in an example. In some examples, the determination may include determining a pattern of auto-refresh operations and skipped refresh operations based on the internal setting. The determination may be made via a refresh stagger circuit or a refresh address control circuit, such as the refresh stagger circuit 535 and/or the refresh address control circuit 516 of
The method 900 may include, in response to a first activation of the refresh signal, performing an auto-refresh operation at the first memory die (or bank) and skipping an auto-refresh operation at the second memory die (or bank), at 920. In some examples, performing the auto-refresh operation at the first memory die includes performing the auto-refresh operation on a plurality of rows of memory cells.
The method 900 may include, in response to a second activation of the refresh signal, skipping an auto-refresh operation at the first memory die (or bank) and performing an auto-refresh operation at the second memory die (or bank), at 930. In some examples, performing the auto-refresh operation at the second memory die includes performing the auto-refresh operation on a plurality of rows of memory cells. In some examples, the method 900 may further include contemporaneously performing a targeted refresh operation at both of the first memory die and the second memory die in response to a third activation of the refresh signal. The method 900 depicted in
Of course, it is to be appreciated that any one of the examples, embodiments or processes described herein may be combined with one or more other examples, embodiments and/or processes or be separated and/or performed amongst separate devices or device portions in accordance with the present systems, devices and methods.
The foregoing description of certain embodiments is exemplary in nature and is in no way intended to limit the scope of the disclosure or its applications or uses. In the detailed description of embodiments of the present systems and methods, reference is made to the accompanying drawings which form a part hereof, and which are shown by way of illustration specific embodiments in which the described systems and methods may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice presently disclosed systems and methods, and it is to be understood that other embodiments may be utilized and that structural and logical changes may be made without departing from the spirit and scope of the disclosure. Moreover, for the purpose of clarity, detailed descriptions of certain features may not be discussed when they would be apparent to those with skill in the art so as not to obscure the description of embodiments of the disclosure. The foregoing detailed description is therefore not to be taken in a limiting sense, and the scope of the disclosure is defined only by the appended claims.
Finally, the above-discussion is intended to be merely illustrative of the present system and should not be construed as limiting the appended claims to any particular embodiment or group of embodiments. Thus, while the present system has been described in particular detail with reference to exemplary embodiments, it should also be appreciated that numerous modifications and alternative embodiments may be devised by those having ordinary skill in the art without departing from the broader and intended spirit and scope of the present system as set forth in the claims that follow. Accordingly, the specification and drawings are to be regarded in an illustrative manner and are not intended to limit the scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
20140016422 | Kim et al. | Jan 2014 | A1 |
20150134897 | Sriramagiri | May 2015 | A1 |
20180033479 | Lea et al. | Feb 2018 | A1 |
20180061485 | Joo | Mar 2018 | A1 |
20180285007 | Franklin et al. | Oct 2018 | A1 |
20190115069 | Lai | Apr 2019 | A1 |
20190130960 | Kim | May 2019 | A1 |
Entry |
---|
International Search Report and Written Opinion for Application No. PCT/US2020/036133, dated Sep. 11, 2020. |
Number | Date | Country | |
---|---|---|---|
20200388324 A1 | Dec 2020 | US |