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 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 (e.g., as one or more bits), and may be organized at the intersection of word lines (rows) and bit lines (columns). Each word line of the memory device may be associated with a row address. When a given word line is accessed, a row address may be provided which specifies which row is being accessed.
Information in the memory cells may decay over time. The memory cells may be refreshed on a row-by-row basis to preserve information in the memory cells. During a refresh operation, the information in one or more rows may be rewritten back to the respective rows to restore an initial value of the information. Repeated accesses to a given row (e.g., an aggressor row) may cause an increased rate of information decay in nearby rows (e.g., victim rows). Victim rows may be refreshed as part of a targeted refresh operation. It may be important to track accesses to word lines of the memory in order to perform targeted refresh operations before information is lost in the victim rows. Tracking accesses as a binary number (e.g., with a counter) may require a relatively large amount of space on a chip. It may be desirable to track accesses in a manner which requires a minimal amount of space and power.
The present disclosure is drawn to apparatuses, systems, and methods for analog row access rate determination. When a row is accessed, its row address may be compared the row addresses stored in the files (e.g., registers) of a stack (e.g., register stack, data storage unit). If there is a match, a match signal may be provided to an accumulator circuit associated with that file. The accumulator circuit includes a capacitor, and responsive to the match signal an amount of charge is added to the capacitor. The accumulator circuit may also allow the charge to drain out of the capacitor over time. The accumulator circuit may provide a voltage based on the current charge on the capacitor. Accordingly, the voltage may represent a rate at which the row stored in the associated file is accessed. Each file may also be associated with a voltage to time (VtoT) circuit, which may use the voltage provided by the associated accumulator circuit to determine which of the files includes an address with a fastest access rate and/or a slowest access rate.
The semiconductor device 100 includes a memory array 112. In some embodiments, the memory array 112 may include of a plurality of memory banks. Each memory bank includes 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 control 108 and the selection of the bit lines BL and /BL is performed by a column control 110. In some embodiments, there may be a row control 108 and column control 110 for each of the memory banks.
The bit lines BL and /BL are coupled to a respective sense amplifier (SAMP) 117. Read data from the bit line BL or BL is amplified by the sense amplifier SAMP 117, and transferred to read/write amplifiers 120 over complementary local data lines (LIOT/B), transfer gate (TG) 118, and complementary main data lines (MIO). Conversely, write data outputted from the read/write amplifiers 120 is transferred to the sense amplifier 117 over the complementary main data lines MIO, the transfer gate 118, and the complementary local data lines LIOT/B, and written in the memory cell MC coupled to the bit line BL or BL.
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, 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 clock terminals are supplied with external clocks CK and /CK that are provided to a clock input circuit 122. The external clocks may be complementary. The clock input circuit 122 generates an internal clock ICLK based on the CK and /CK clocks. The ICLK clock is provided to the command control 106 and to an internal clock generator 124. The internal clock generator 124 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 126 to time operation of circuits included in the input/output circuit 126, 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 control 108 and supplies a decoded column address YADD to the column control 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. 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 control 106 via the command/address input circuit 102. The command control 106 includes circuits to decode the internal command signals to generate various internal signals and commands for performing operations. For example, the command control 106 may provide a row command signal to select a word line and a column command signal to select a bit line.
The device 100 may receive an access command which is a row activation command ACT. When the row activation command ACT is received, a bank address BADD and a row address XADD are timely supplied with the row activation command ACT.
The device 100 may receive an access command which is a read command. When a read command is received, a bank address and a column address are timely supplied with the read command, read data is read from memory cells in the memory array 112 corresponding to the row address and column address. The read command is received by the command control 106, which provides internal commands so that read data from the memory array 112 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 126.
The device 100 may receive an access command which is a write command. When the write command is received, a bank address and a column 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 112 corresponding to the row address and column address. The write command is received by the command control 106, which provides internal commands so that the write data is received by data receivers in the input/output circuit 126. 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 126. The write data is supplied via the input/output circuit 126 to the read/write amplifiers 120, and by the read/write amplifiers 120 to the memory array 112 to be written into the memory cell MC.
The device 100 may also receive commands causing it to carry out refresh operations. A refresh signal AREF may be a pulse signal which is activated when the command control 106 receives a signal which indicates 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. Thus, refresh operations may continue automatically. 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 control circuit 116. There may be a refresh control circuit 116 associated with each bank. The refresh control circuits 116 may receive the refresh signal AREF in common, and may generate and provide one or more refresh row address(es) RXADD in order to perform one or more refresh operations in the associated memory bank. In some embodiments, a subset of the memory banks may be given refresh commands. For example, one or more additional signals may indicate which of the refresh control circuits 116 should provide refresh address(es) responsive to AREF. In another example, AREF may only be provided to refresh control circuits 116 which are associated with the subset of memory banks which are refreshing.
Focusing on the operation of a given refresh control circuit, the refresh control circuit 116 supplies a refresh row address RXADD to the row control 108, which may refresh one or more wordlines WL indicated by the refresh row address RXADD. The refresh control circuit 116 may control a timing of the refresh operation based on the refresh signal AREF. In some embodiments, responsive to an activation of AREF, the refresh control circuit 116 may generate one or more activations of a pump signal, and may generate and provide a refresh address RXADD for each activation of the pump signal (e.g., each pump).
Since the various refresh control circuits are coupled in common to AREF, multiple memory banks of the device 100 may simultaneously perform refresh operations. Each refresh 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. The refresh control circuit 116 may direct the associated memory bank to perform different types of refresh operation based on the provided refresh address RXADD.
One type of refresh operation may be an auto-refresh operation. Responsive to an auto-refresh operation the memory bank may refresh a group of rows of the memory, and then may refresh a next group of rows of the memory bank responsive to a next auto-refresh operation. The refresh control circuit 116 may provide a refresh address RXADD which indicates a group of wordlines in the memory bank. The refresh control circuit 116 may generate a sequence of refresh addresses RXADD such that over time the auto-refresh operation may cycle through all the wordlines WL of the memory bank. The timing of refresh operations may be such that each wordline is refreshed with a frequency based on a normal rate of data degradation in the memory cells.
Another type of refresh operation may be a targeted refresh operation. 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. In some embodiments, the victim rows may include rows which are physically adjacent to the aggressor row. In some embodiments, the victim rows may include rows further away from the aggressor row. Information in the victim rows may decay at a rate such that data may be lost if they aren't refreshed before 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 where a refresh address RXADD associated with one or more associated victim rows is refreshed.
The refresh control circuit 116 may track accesses to various wordlines of the memory. The refresh control circuit 116 may receive the row address RXADD and may compare it to previously received addresses. The refresh control circuit 116 includes a stack which includes a number of slices. Each slice includes a file configured to store a row address, an accumulator circuit which provides a voltage proportional to a rate at which the address in the file has been received, and a voltage to time (VtoT) circuit which may be used to determine which of the accumulator circuits in the stack is providing the highest voltage. The row address associated with the highest voltage (e.g., the fastest rate of accesses) may have its victims refreshed as part of a targeted refresh operation.
In some embodiments, the refresh control circuits 116 may perform multiple refresh operations responsive to each occurrence of AREF. Each refresh control circuit 116 may generate a number of ‘pumps’ (e.g., activations of a pump signal) responsive to receiving an activation of AREF. Each pump, in turn, may cause the refresh control circuit 116 to provide a refresh address RXADD, and trigger a refresh operation as indicated by the refresh address RXADD. A given refresh control circuit 116 may provide auto-refresh addresses responsive to some of the pumps and targeted refresh addresses responsive to some of the pumps generated from a given activation of AREF. In some embodiments, the refresh control circuit 116 may perform auto-refresh operations for a certain number of pumps, and then may perform targeted refresh operations for a certain number of pumps. In some embodiments, auto-refresh operations and targeted refresh operations may be dynamically assigned to the pumps. For example, if there are no rows waiting to be refreshed as part of a targeted refresh operation, pumps which would have been used for a targeted refresh operation may be used for an auto-refresh operation instead.
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 128. The internal voltage generator circuit 128 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 control 108, the internal potentials VOD and VARY are mainly used in the sense amplifiers SAMP included in the memory array 112, 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 126. 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 126 so that power supply noise generated by the input/output circuit 126 does not propagate to the other circuit blocks.
An interface 231 may provide one or more signals to an address refresh control circuit 216 and row decoder 208. The refresh address control circuit 216 may include a sample timing generator 238, an aggressor detector circuit 237, a row hammer refresh (RHR) state controller 236 and a refresh address generator 239. The interface 231 may provide one or more control signals, such as an auto-refresh signal AREF, and a row address XADD. The RHR state control 236 may determine if an auto-refresh or a targeted refresh operation should be performed. The RHR state control circuit 236 may indicate different refresh operations in different banks in order to stagger the targeted and auto-refresh operations between the banks.
The example refresh control circuit 216 of
In the embodiment, shown in
There may be an RHR state controller 236 for each of the different banks. Each RHR state controller 236 may include internal logic which determines the timing with which it provides signals (e.g., RHR) to indicate if a targeted refresh or auto-refresh operation should be performed in the associated bank. In some embodiments, each RHR state controller 236 may include a counter, and may provide the signal RHR based on a number of occurrences of the refresh signal AREF (and/or the number of occurrences of IREF). For example, the RHR state controller 236 may provide the signal IREF m times, then may provide the signal RHR n times, then provide the signal IREF m times, etc.
Responsive to an activation of RHR and/or IREF, the refresh address generator 239 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 208 may perform a refresh operation responsive to the refresh address RXADD and the row hammer refresh signal RHR. The row decoder 208 may perform an auto-refresh operation based on the refresh address RXADD and the internal refresh signal IREF.
The interface 231 may represent one or more components which provides signals to components of the bank. For example, the interface 231 may represent components such as the command address input circuit 102, the address decoder 104, and/or the command control 106 of
The sample timing generator 238 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 aggressor detector circuit 237 may receive the row address XADD from the interface 231 and ArmSample from the sample timing generator 238. The row address XADD may change as the interface 231 directs access operations (e.g., read and write operations) to different rows of the memory cell array (e.g., memory cell array 112 of FIG. 1). Each time the aggressor detector circuit 237 receives an activation (e.g., a pulse) of ArmSample, the aggressor detector circuit 237 may sample the current value of XADD.
Responsive to an activation of ArmSample, the aggressor detector circuit 237 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 aggressor detector circuit 237 may store (e.g., by latching and/or storing the address in a stack) the current value of XADD responsive to the activation of ArmSample if the current value of XADD was not already stored. The current value of XADD may be compared to previously stored addresses in the aggressor detector circuit 237 (e.g., the addresses stored in the stack), to determine access patterns over time of the sampled addresses. If the sampled row address XADD matches one of the previously stored addresses, an amount of charge may be added to a capacitor associated with the stored address. The charge on the capacitor may leak out over time, and thus the charge on the capacitor may be proportional to the frequency at which the stored address is received as the sampled address XADD.
The aggressor detector circuit 237 may use the charge on the different capacitors to identify a row address associated with a highest charge (e.g., a fastest access rate) and with a lowest charge (e.g., a slowest access rate). For example, each capacitor may provide a voltage based on the charge on the capacitor and a highest and lowest voltage may be identified. The address associated with the highest charge may be provided as the match address HitXADD. After being provided as HitXADD, the charge on the capacitor may be reset to an initial value (e.g., a minimum value such as 0). If the sampled address XADD does not match a stored address, it may be stored in one of the files of the stack. If the stack is full (e.g., all of the files are busy) then the address associated with the lowest charge may be replaced with the new address, and the charge may be reset.
The RHR state controller 236 may receive the auto-refresh signal AREF and provide the row hammer refresh signal RHR and the internal refresh signal IREF. The signal RHR 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 signal IREF may indicate that an auto-refresh operation should occur. The RHR state controller 236 may use internal logic to provide the RHR signal. In some embodiments, the RHR state controller 236 may include a counter and may provide the RHR signal based on certain number of activations of AREF (e.g., every 4th activation of AREF). The counter 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.
The RHR state controller 236 may also provide an internal refresh signal IREF, which may control the timing of refresh operations. In some embodiments, there may be multiple activations of IREF for each activation of the refresh signal AREF. In some embodiments, the internal refresh signal IREF may be used as a refresh pump signal to control the activations of refresh pumps. In some embodiments, each activation of AREF may be associated with a number of activations of IREF, which may be associated with a number of refresh operations, which may be a mix of targeted refresh operations and auto-refresh operations. For example, each activation of IREF may be associated with a refresh operation on the refresh address RXADD, while the state of RHR may determine if the refresh address RXADD is associated with an auto-refresh operation or a targeted refresh operation. In some embodiments, the signal IREF may be used to indicate that an auto-refresh operation should occur, while the signal RHR is used to indicate that a targeted refresh operation should occur. For example, the signals RHR and IREF may be generated such that they are not active at the same time (e.g., are not both at a high logic level at the same time) and each activation of IREF may be associated with an auto-refresh operation, while each activation of RHR may be associated with a targeted refresh operation.
In some embodiments, the RHR state controller 236 may count activations of IREF and use the count of IREF (e.g., the pumps) to determine when the signal RHR should be provided. Similar to previously described, the counter may initialize to a different value for different refresh control circuits. In some embodiments, the RHR state controller 236 may receive one or more signals from an RHR bank stagger circuit, which may direct the different RHR state controllers 236 to provide the signal RHR. In either of these manner targeted and auto-refresh operations may be staggered between banks.
The refresh address generator 239 may receive the row hammer refresh signal RHR and the match address HitXADD. The match address HitXADD may represent an aggressor row. The refresh address generator 239 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 239 may determine the value of the refresh address RXADD based on the row hammer refresh signal RHR. In some embodiments, when the signal RHR is not active, the refresh address generator 239 may provide one of a sequence of auto refresh addresses as the refresh address RXADD. When the signal RHR is active, the refresh address generator 239 may provide a targeted refresh address, such as a victim address, as the refresh address RXADD.
The row decoder 208 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 IREF and RHR being at a low logic level), the row decoder 208 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 208 may refresh the refresh address RXADD.
The stack 340 may be used to store received addresses (e.g., row address XADD of
Each slice 341 includes a file 342 which stores a row address. The file includes a number of CAM cells 344, each of which stores one of the bits of the row address. Each CAM cell 344 includes a latch portion which stores the bit of the address and a comparator portion. The comparator portions of the CAM cells 344 in a slice 341 may work together to determine if a received address AddressIn is an exact match for the row address stored in the file 342 when the control signal Activate is active. In some embodiments, the control signal Activate may be based on an access signal of the memory device, such as ACT/Pre of
The file 342 may include a number of CAM cells 344 based on the number of bits of information stored in the file 342. The number of CAM cells 344 in a given file 342 may generally be referred to as a ‘width’ of the file 342. In some embodiments, the file 342 may have a width which is the number of bits of a row address (e.g., XADD). In some embodiments, the file 342 may include additional width, which may be used to store one or more other pieces of information associated with the slice 341. For example, additional CAM cells 344 may be included in the file 342 to store a busy signal Busy, which may be used to indicate if the slice 341 is storing an unrefreshed row address or not.
The file 342 may also receive control signals such as the write signal Store, which may cause the file 342 to write the value of the received address AddressIn to the CAM cells 344, storing the received address AddressIn in the file 342. The file 342 may also receive the signal Reset which, in some embodiments, may cause the file 342 to reset the address stored in the file 342 (e.g., by setting the bits stored in the CAM cells all to the same value). The file 342 also provides a signal Busy, which indicates if the file 342 is currently storing an address or not. Accordingly, before being reset, the file 342 may provide the signal Busy at a first state (e.g., a high logical level), and may provide the signal Busy at a second state (e.g., a low logical level) after being reset. In some embodiments, one or more CAM cells 344 may be used to store the state of the Busy signal. An example CAM cell 344 and its operation is discussed in more detail in
Each slice 341 also includes an accumulator circuit 346 which tracks accesses to the row address stored in the file 342. Each time the accumulator circuit 346 receives the signal Match, it may update a physical signal stored in the accumulator circuit 346. For example, the accumulator circuit 346 may include a capacitor, and each time the signal Match is received from the file 342, an amount of charge may be added to the capacitor. The accumulator circuit may provide a voltage HammerFreq which is based on the amount of charge on the capacitor. Accordingly each time Match is received, the voltage HammerFreq may be increased. The capacitor in the accumulator circuit 346 may also slowly discharge over time, which may cause the voltage HammerFreq to decrease at a certain rate. Responsive to the signal reset, the voltage HammerFreq may be reset to an initial value (e.g., by discharging the capacitor). An example accumulator circuit and its operation are discussed in more detail in
The voltage to time (VtoT) circuit 348 may be used to determine which of the different voltages HammerFreq in the stack 340 is the highest and the lowest. Since the voltage HammerFreq may be proportional to the rate at which the row address stored in the file 342 is received, the VtoT circuit 348 may be used to indicate which of the row addresses in the stack 340 is the most and least frequently accessed.
Each VtoT circuit 348 may include a high VtoT circuit and a low VtoT circuit, which may provide the signals High and Low respectively with timing based on the voltage HammerFreq received from the accumulator circuit 346. The VtoT circuit 348 may provide the signals High and Low responsive to the signal SampleVtoT. Once the signal SampleVtoT is provided, the higher the voltage HammerFreq, the faster the signal High is provided by the VtoT circuit 348 and the lower the voltage HammerFreq the faster the signal Low is provided by the VtoT circuit 348. The stack logic circuit 343 may keep track of which of the slices 341 provides the signals High and Low first each time the signal SampleVtoT is provided. An example VtoT circuit and its operation are discussed in more detail in
Referring back to
The stack logic circuit 343 may examine the match signals provided by each file 342 of the stack 340 to determine if there were any matches between the address XADD and the stored addresses. If there is a match, then the signal Match is provided by the file 342 containing the matched address (e.g., the file 342 provides the signal Match at a high logical level) which in turn updates the voltage HammerFreq provided by the accumulator circuit 346. If there is not a match (e.g., the signal Match is provided at a low logical level), then the address XADD may be stored in the stack 340 (e.g., by providing it as the address AddressIn along with the write signal Store to a particular file 342).
After providing a received address XADD for comparison, the stack logic circuit 343 may provide the signal SampleVtoT (e.g., provide SampleVtoT at a high logical level) in order to determine which of the files 342 contains a row address which is accessed the most (e.g., has the highest voltage HammerFreq) and least (e.g., has the lowest voltage HammerFreq). Responsive to the signal SampleVtoT each of the VtoT circuits 348 may provide the signals High and Low. The signal High is provided faster the higher the voltage HammerFreq is, and the signal Low is provided faster the lower the voltage HammerFreq is. The stack logic circuit 343 includes a high latch 345 which latches the first signal High to be provided and a low latch 347 which latches the first signal Low to be provided. In this manner, the signals stored in the high latch 345 and low latch 347 may represent the row addresses of the stack 340 which are most and least frequently accessed respectively.
In some embodiments, each slice 341 may include a high latch 345 and a low latch 347. Each of the high and low latches in the slices 341 may record the value of the signals High and Low, respectively when they are provided (e.g., when they switch from a low logical level to a high logical level). The first high latch 345 and the first low latch 347 to store their respective signal at a high logical level may be maintained, while all of the other high and low latches are cleared (e.g., reset to a low logical level). In this manner, only the first high latch 345 and the first low latch 347 to store a high logical level remain holding a high logical level, which may be used to identify the slices 341 which contain the highest and lowest voltages HammerFreq, respectively, at the most recent time the signal SampleVtoT was provided.
When the stack logic circuit 343 is storing a new address XADD in the stack 340 (e.g., because address XADD did not match any addresses stored in the stack 340), the stack logic circuit 343 may determine if there are any available slices 341. For example the stack logic circuit 343 may check the status of the busy signals Busy provided by the files 342 to determine if any of the signals Busy indicate that at least one row is not busy. If any files 342 are not busy (e.g., the signal Busy is at a second state/low logical level), the new address XADD may be stored in one of the non-busy files 342 (e.g., by providing XADD as AddressIn along with the write signal Store to that file 342). If all of the files 342 are busy, the stack logic circuit 343 may reset the slice 341 indicated by the low latch 347 and may then store the received address XADD in that reset slice 341.
When the stack logic circuit 343 receives a signal (such as the signal RHR) which indicates that a targeted refresh should be performed, the stack logic circuit 343 may provide the address in the slice 341 indicated by the high latch 345. The stack logic circuit 343 may provide the signal Refresh to the stack, which in turn may cause the stack 340 to provide the address from the file 342 associated with the highest access rate (e.g., as indicated by the high latch 345) as the address AddressOut. The address provided as AddressOut may be provided as the match address HitXADD of
The CAM cell 400 includes a latch portion 456 and a comparator portion 458. The latch portion stores a bit with a state represented by stored signal Q and inverse stored signal QF. The stored signals Q and QF may be complementary to each other. Thus, if the signal Q is at a high logical level, the signal QF may be at a low logical level, and vice versa. The latch portion 456 includes a pair of cross coupled inverters, a first inverter 452, and a second inverter 453 which may be used to store the values of the signals Q and QF (and thus the value of the stored bit).
The first inverter 452 has an input terminal coupled to a node which carries the signal Q, and an output terminal coupled to a node which carries the signal QF. The second inverter 452 has an input terminal which is coupled to a node which carries the signal QF and an output terminal which is coupled to the node which carries the signal Q. In this manner, the first inverter 452 provides the signal QF at a level complementary to the signal Q, and the second inverter 453 provides the signal Q at a level complementary to the signal QF.
An external bit may be received along with a write signals Store, which may cause the external bit to overwrite the value of the stored bit. The external bit may be provided as the signals AddressIn and AddressInF, which are complementary to each other. The external bit may be a bit of a received address (e.g., XADD of
In an example write operation, the latch portion 456 may receive the write signal Store at a high level (e.g., a system voltage such as VPERI) and an external bit represented by signals AdressIn and AdressInF. The write signal Store may activate both the first and the second transistors 450, 451, which may couple the signal AdressIn to the signal Q, and the signal AdressInF to the signal QF. The value of the signals AdressIn and AddressInF may overwrite the values The write signal Write may also inactivate one (or more) of the inverters, 452, 453. In the example CAM cell 400 of
The inverter portion 458 includes a first multiplexer 454 and a second multiplexer 455. During a comparison operation, an external bit may be compared to the stored bit, by providing the comparison bit as represented by the signals AddressIn and AdressInF when the write signal Store is at a low level. The multiplexers 454, 455 may work together so that if the external bit matches a state (e.g., a logical level) of the stored bit, the signal BitMatch is provided at a high level, and if they bits do not match, then the signal BitMatch is provided at a low level. The state of the overall match signal Match may be based on the states of the bit match signals BitMatch from each of the CAM cells 400 in a file.
The first multiplexer 454 has an input terminal coupled to the external signal AddressIn, a command terminal coupled to the signal Q, and an inverse command terminal coupled to the signal QF. The output of the first multiplexer is coupled to the signal Match. When the stored signal Q is at a high level (and the signal QF is at a low level) the first multiplexer 454 may couple the signal AdressIn to the signals BitMatch. Accordingly, only if the external signal AdressIn is high and the stored signal Q is high is a high signal coupled to the signal BitMatch through the first multiplexer 454.
The second multiplexer 455 has an input terminal coupled to AdressInF, a command terminal coupled to the signal QF, and an inverse command terminal coupled to the signal Q. The output of the second multiplexer 455 is coupled to the signal BitMatch. When the signal QF is at a high level (and thus the signal Q is at a low level) the second multiplexer 455 may couple the signal AdressInF to the signal BitMatch. Accordingly, only if the external signal AddressInF is high (indicating that the external bit is a low logical level) and the stored signal QF is high (indicating that the stored signal is at a low logical level) is a high signal coupled to the signal BitMatch through the second multiplexer 455.
In some embodiments, multiple CAM cells 400 may be grouped together to store multiple bits of information. For example, multiple CAM cells 400 may be grouped together to form a file which stores a row address, such as the file 342 of
The accumulator circuit 500 includes a first transistor 561, a second transistor 562, and a third transistor 564. The first transistor has a gate coupled to a bias voltage PBias, a source coupled to a system voltage (e.g., VPERI) and a drain coupled to a source of the second transistor 562. The first transistor 561 may be a p-type transistor. The voltage PBias may generally keep the first transistor 561 in an active state.
The second transistor 562 has a source coupled to the drain of the first transistor 561 and a drain coupled to a node carrying the voltage HammerFreq. The signal match may be provided to an inverter 560, which provides a signal MatchF to the gate of the second transistor 562. The second transistor 562 may be a p-type transistor. Accordingly, when the signal Match is high, the signal MatchF is low, which may activate the second transistor, coupling the system voltage (e.g., VPERI) through the first and second transistors, 561, 562 to the voltage HammerFreq.
The third transistor 564 has a drain coupled to the voltage HammerFreq and a source coupled to a ground voltage (e.g., VSS). The gate of the third transistor 564 is coupled to a bias voltage NBias, which may generally keep the third transistor 564 in an active state. The third transistor 564 may be an n-type transistor.
The voltage HammerFreq is coupled to ground via a capacitor 565. Accordingly, each time the signal Match is provided, the second transistor 562 may activate and the capacitor 565 may be coupled to the system voltage VPERI through the first and second transistors 561, 562. This may add an amount of charge to the capacitor 565 which may increase the voltage HammerFreq. In some embodiments, the amount of charge added for each activation of Match may be adjusted by varying one or more of the length of time Match is active, the characteristics of the transistor 561, and/or the voltage PBias. In some embodiments, the amount that the voltage HammerFreq changes with each activation of Match may also be adjusted by adjusting the capacitance of the capacitor 565.
The capacitor 565 may also be constantly discharging through the third transistor 564, which may be activated by NBias to allow the voltage HammerFreq to leak by permitting a leak current to flow through the third transistor 564 to a ground voltage (e.g., VSS). This may cause the voltage HammerFreq to decrease over time. In some embodiments, the rate at which the capacitor 565 discharges (and HammerFreq decreases over time) may be adjusted by adjusting one or more of the capacitance of the capacitor 565, the characteristics of the third transistor 564, and/or the bias voltage NBias.
In this manner, the voltage HammerFreq may be increased each time an activation of the signal Match is received and may otherwise decrease steadily over time. Thus, the more rapidly that activations of the signal Match are received, the higher the voltage HammerFreq may become. Since the voltage HammerFreq may saturate as the capacitor 565 reaches a maximum amount of charge, it may be important to adjust parameters to prevent saturation for expected rates of Match activation (e.g., expected rates at which a given row may be accessed before it is refreshed). Parameter such as the capacitor 565, the first and third transistors 561, and 564, and the voltages PBias and NBias may be adjusted to reduce the likelihood of saturation conditions form occurring.
A fourth transistor 563 may act as a switch which resets the voltage HammerFreq by discharging the capacitor 565. The fourth transistor has a drain coupled to the voltage HammerFreq and a source coupled to a ground voltage (e.g., VSS). The gate of the fourth transistors 563 is coupled to the signal Reset. The fourth transistor 563 may be an n-type transistor. When the signal Reset is provided at a high level, the fourth transistor 563 may be active, and may couple the voltage HammerFreq to the ground voltage, which may discharge the capacitor 565. The signal Reset may generally be provided at a low level during normal operations to keep the fourth transistor 563 inactive so that the voltage HammerFreq may increase responsive to the signal Match.
The VtoT circuit 600 includes a low VtoT circuit 601 and a high VtoT circuit 602. The low VtoT circuit 601 provides the signal Low, and the high VtoT circuit 602 provides the signal High. The VtoT circuit 600 receives a sampling signal SampleVtoT which causes the low and high VtoT circuits 601, 602 to begin the process of providing the signals Low and High. The signal SampleVtoT is provided to an inverter, which provides the signal SampleVtoTF, which is complementary to the signal SampleVtoT.
The low VtoT circuit 601 includes a first transistor 671, a second transistor 672, and a third transistor 673. The first transistor 617 has a source coupled to a system voltage (e.g., VPERI) and a drain coupled to a source of the second transistor 672. The gate of the first transistor 671 is coupled to the signal SampleVtoTF. The second transistor 672 has a source coupled to the drain of the first transistor 671 and a drain coupled to a node 681. The gate of the second transistor 672 is coupled to the voltage HammerFreq. The first and second transistors 671, 672 may be p-type transistors. The third transistor 673 has a drain coupled to the node 681 and a source coupled to a ground voltage (e.g., VSS). The gate of the third transistor 673 is coupled to the signals SampleVtoTF. The third transistor 673 may be an n-type transistor. The node 681 is coupled to a ground voltage (e.g., VSS) via a capacitor 674. The voltage on the node 681 is provided as an input to a pair of inverters 675 coupled in series, the second of which provides the signal Low.
When the low VtoT circuit 601 is not in operation, the signal SampleVtoT may be provided at a low level, which in turn may cause the signal SampleVtoTF to be provided at a high level. This may inactivate the first transistor 671 and activate the third transistor 673. Accordingly, the node 681 may be coupled to the ground voltage via the third transistor 673, and the capacitor 674 may be discharged. Since the node 681 is grounded (e.g., a low level), the pair of inverters 675 may provide the signal Low at a low level.
When the stack (e.g., stack 340 of
Once the voltage of the node 681 increases above a threshold voltage of the pair of inverters 675, the inverters change the state of the signal Low to a high level. Since the speed at which the voltage of the node 681 increases is dependent on the voltage of HammerFreq, the time between when SampleVtoT is provided at a high level and when the signal Low switches from a low level to a high level may also be dependent on the voltage HammerFreq, with lower voltages leading to shorter times.
The high VtoT circuit 602 operates on a similar principle to the low VtoT circuit 601, except that the signal High is provided at a high level with a faster timer the higher that the voltage HammerFreq is. The high VtoT circuit 602 includes a first transistor 676 with a source coupled to a system voltage (e.g., VPERI) and a drain coupled to a node 682. A second transistor 677 has a drain coupled to the node 682 and a source coupled to a drain of a third transistor 678. The source of the third transistor 678 is coupled to a ground voltage (e.g., VSS). The gates of the first transistor 676 and the third transistor 678 are coupled to the signal SampleVtoT. The gate of the second transistor 677 is coupled to the voltage HammerFreq. The first transistor 676 may be a p-type transistor. The second transistor 677 and the third transistor 678 may be n-type transistors. The node 682 is coupled to ground through a capacitor 679. An inverter 680 provides the signal High with a level based on the voltage on the node 682.
When the VtoT circuit 600 is not in operation, the signal SampleVtoT may be provided at a low level. This may inactivate the third transistor 678 and activate the first transistor 676. Accordingly the node 682 may be coupled to the system voltage (e.g., VPERI) through the first transistors 676. This may charge the capacitor 679 to a saturation level, which may raise the voltage on the node 682 to a maximum level (e.g., VPERI). This may cause the inverter 680 to provide the voltage High at a low level.
When the VtoT circuit 600 is polled, the signal SampleVtoT is switched from a low level to a high level. This may inactivate the first transistor 676 and activate the third transistor 678. A current may flow from the node 682 through the second transistor 677 and third transistor 678 to the ground voltage (e.g., VSS). The amount of current may be proportional to the voltage HammerFreq applied to the gate of the second transistor 677. The higher the voltage HammerFreq, the higher the current. The current may allow the capacitor 679 to discharge to ground, which may decrease the voltage on the node 682. Accordingly, the higher the voltage HammerFreq, the faster the voltage on the node 682 decreases. When the voltage on the node 682 falls below a threshold of the inverter 680, the inverter may switch to providing the signal High at a high level. The time between when the signal SampleVtoT is switched from a low level to a high level to when the signal High switches from a low level to a high level may be proportional to the voltage HammerFreq, with higher voltages leading to shorter times.
The two capacitors 674 and 679 may be adjustable in some embodiments. Adjusting the capacitor 674 may adjust the rate at which the voltage on the node 681 increases when the signal SampleVtoT is provided at a high level. Adjusting the capacitor 679 may adjust the rate at which the voltage on the node 682 decreases when the signal SampleVtoT is provided at a low level.
The method 700 may generally begin with block 705, which describes a beginning of the method. For example, the method 700 may begin when the device (e.g., device 100 of
Block 710 may generally be followed by block 715 which describes determining if an access operation or a refresh operation is being performed. For example, the stack logic circuit may receive a row address (e.g., XADD) which indicates an access operation. In some embodiments, the stack logic circuit may receive additional signals such as ACT/Pre, which may be used instead of or in addition to the row address XADD to indicate that an access operation is occurring. In some embodiments, the row addresses may be ignored until a row address is received along with a sampling signal (e.g., ArmSample of
If a targeted refresh operation is being performed, (e.g., the signal RHR is received from RHR state control circuit 236 of
If a row address XADD is received (e.g., as part of an access operation), block 715 may generally be followed by block 735, which describes placing the row address on the AddressIn bus and pulsing the signal Activate. The received address XADD may be provided as the signal AddressIn to each of the files (e.g., files 342 of
Block 735 may generally be followed by block 740, which describes determining if the signal Match fires (e.g., is provided at a high level) by any of the slices of the stack. Each bit of the received row address XADD may be compared to the corresponding CAM cell in each of the slices (e.g., in the file in each of the slices). The match signals from each individual CAM cell in a file may be coupled to an AND gate, which provides an overall signal Match which is at a high level only if each bit of XADD matches all of the bits stored in the CAM cells of the file. In block 740 the states of the signals Match from each of the files may be examined to determine if any are at a high level after the comparison operation described in block 735.
If any of the signals Match are at a high level, block 740 may generally be followed by block 745 which describes incrementing the analog accumulator. The accumulator circuits in each slice may receive the signal Match from the files in that slice. If the signal Match is at a high level, it may cause a preset amount of charge to be added to a capacitor (e.g., capacitor 565 of
Block 745 may generally be followed by block 770, which describes polling the VtoT circuits (e.g., VtoT circuits 348 of
Returning to block 740, if the signal Match was not provided by any slice, then block 740 may generally be followed by block 750. Block 750 describes determining if all of the slices are busy. Each slice may provide a signal Busy with a level which indicates if the slice is currently storing an unrefreshed row or not. In some embodiments, block 750 may involve checking to see if all of the Busy signals are at a high logical level or not.
If not all the slices are busy (e.g., if at least one Busy signal is at a low logical level) then block 750 may generally be followed by block 755. Block 755 describes choosing a slice which is not busy to store the row address (e.g., XADD) which was received as part of the activate command during block 715. In some embodiments, if more than one slice has the signal Busy at a low logical level, then one of the slices with Busy at a low logical level may be selected. For example, a slice with a lowest index may be chosen. Block 755 may generally be followed by block 765 as described herein.
If all the slices are busy, then block 750 may be followed by block 760, which describes storing the received row address in the slice with the Low signal at a high logic level. As described in block 770, the slice which has the lowest voltage HammerFreq (which is proportional to the rate at which the row address stored in that slice is accessed) has the signal Low saved at a high level in a low latch. During block 760, that slice may be reset (e.g., in a manner similar to block 710, except only for a specific slice), by providing the signal Reset at a high level to the slice with the signal Low at a high level. The signal Reset may cause the accumulator circuit to reset to a minimum value of HammerFreq (e.g., by discharging the capacitor to a ground voltage). Block 760 may generally be followed by block 765.
Blocks 755 and block 765 may generally be followed by block 765 which describes storing the received row address in the selected slice. The process described in block 765 may be the same whether the slice was selected by the process described in block 755 (e.g., the slice is not busy) or the process described in block 760 (e.g., the slice is associated with the signal Low). During the process described in the block 765 the each bit of the received address XADD may be provided as the external signal AddressIn to a corresponding CAM cell of the selected slice. In some embodiments the signals AddressIn may be provided in common to all of the slices. In some embodiments, the signals AddressIn may still be being provided as they were during block 735. The stack control logic may provide the write signal Store at an active level to the selected slice. This may cause the file in the selected slice to store the values of the bits of the received address XADD in the file, overwriting the previous stored row address (if any). If the signal Busy was not previously set to a high level, it may be set to a high level after the row address is stored. Block 765 may generally be followed by block 770, which proceeds as previously described.
Returning to block 715, if a refresh command (e.g., the signal RHR) is received, then block 715 may generally be followed by block 720. Block 720 describes providing the row address from the slice with the signal High at a high logical level. As described in block 770, the slices may be polled and the signal High may be saved at a high logical level for one of the slices. In block 720, the signal Refresh may be provided at a high level to the slice which has the signal High at a high level. This may cause the row address stored in the file of that slice to be provided on the AddressOut bus.
Block 720 may generally be described by block 725, which describes refreshing victim addresses associated with the address provided on AddressOut. The address provided on the AddressOut bus may be latched by the stack control circuit and provided as the match address HitXADD. A refresh address generator (e.g., 239 of
Block 725 may generally be followed by block 730, which describes resetting the accumulator circuit associated with the row address that was provided as the match address HitXADD. The stack control circuit may provide the signal Reset to the slice associated with the signal High at a high logical level. The signal Reset may cause the accumulator circuit to reset the voltage HammerFreq to a minimum level (e.g., a ground voltage such as VSS). The signal Reset may also clear the contents of the file (e.g., by resetting the CAM cells and/or by changing the Busy signal to a low level). Block 730 may generally be followed with block 770 as previously described.
In some embodiments, determining the highest and lowest voltages (e.g., as described in block 770) may only be triggered when a slice which has the highest or lowest voltage needs to be identified, rather than being performed each time an RHR or access command is received as shown in the example embodiment of
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.
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 |
---|---|---|---|
5299159 | Balistreri et al. | Mar 1994 | A |
5422850 | Sukegawa et al. | Jun 1995 | A |
5699297 | Yamazaki et al. | Dec 1997 | A |
5768196 | Bloker et al. | Jun 1998 | A |
5933377 | Hidaka | Aug 1999 | A |
5943283 | Wong et al. | Aug 1999 | A |
5970507 | Kato et al. | Oct 1999 | A |
6011734 | Pappert | Jan 2000 | A |
6061290 | Shirley | May 2000 | A |
6212118 | Fujita | Apr 2001 | B1 |
6310806 | Higashi et al. | Oct 2001 | B1 |
6317381 | Gans et al. | Nov 2001 | B1 |
6373738 | Towler et al. | Apr 2002 | B1 |
6424582 | Ooishi | Jul 2002 | B1 |
6434064 | Nagai | Aug 2002 | B2 |
6452868 | Fister | Sep 2002 | B1 |
6480931 | Buti et al. | Nov 2002 | B1 |
6567340 | Nataraj et al. | May 2003 | B1 |
6950364 | Kim | Sep 2005 | B2 |
7027343 | Sinha et al. | Apr 2006 | B2 |
7057960 | Fiscus et al. | Jun 2006 | B1 |
7187607 | Koshikawa et al. | Mar 2007 | B2 |
7203115 | Eto et al. | Apr 2007 | B2 |
7209402 | Shinozaki et al. | Apr 2007 | B2 |
7215588 | Lee | May 2007 | B2 |
7444577 | Best et al. | Oct 2008 | B2 |
7551502 | Dono et al. | Jun 2009 | B2 |
7830742 | Han | Nov 2010 | B2 |
8451677 | Okahiro et al. | May 2013 | B2 |
8625360 | Iwamoto et al. | Jan 2014 | B2 |
8681578 | Narui | Mar 2014 | B2 |
8811100 | Ku | Aug 2014 | B2 |
8862973 | Zimmerman et al. | Oct 2014 | B2 |
8938573 | Greenfield et al. | Jan 2015 | B2 |
9032141 | Bains et al. | May 2015 | B2 |
9047978 | Bell et al. | Jun 2015 | B2 |
9058900 | Kang | Jun 2015 | B2 |
9087602 | Youn et al. | Jul 2015 | B2 |
9117544 | Bains et al. | Aug 2015 | B2 |
9123447 | Lee et al. | Sep 2015 | B2 |
9153294 | Kang | Oct 2015 | B2 |
9190139 | Jung et al. | Nov 2015 | B2 |
9286964 | Halbert et al. | Mar 2016 | B2 |
9299457 | Chun et al. | Mar 2016 | B2 |
9311985 | Lee et al. | Apr 2016 | B2 |
9324398 | Jones et al. | Apr 2016 | B2 |
9384821 | Bains et al. | Jul 2016 | B2 |
9412432 | Narui et al. | Aug 2016 | B2 |
9424907 | Fujishiro | Aug 2016 | B2 |
9484079 | Lee | Nov 2016 | B2 |
9514850 | Kim | Dec 2016 | B2 |
9570143 | Lim et al. | Feb 2017 | B2 |
9646672 | Kim et al. | May 2017 | B1 |
9672889 | Lee et al. | Jun 2017 | B2 |
9685240 | Park | Jun 2017 | B1 |
9691466 | Kim | Jun 2017 | B1 |
9697913 | Mariani et al. | Jul 2017 | B1 |
9741409 | Jones et al. | Aug 2017 | B2 |
9741447 | Akamatsu | Aug 2017 | B2 |
9747971 | Bains et al. | Aug 2017 | B2 |
9786351 | Lee et al. | Oct 2017 | B2 |
9799391 | Wei | Oct 2017 | B1 |
9805782 | Liou | Oct 2017 | B1 |
9805783 | Ito et al. | Oct 2017 | B2 |
9818469 | Kim et al. | Nov 2017 | B1 |
9865326 | Bains et al. | Jan 2018 | B2 |
9922694 | Akamatsu | Mar 2018 | B2 |
9934143 | Bains et al. | Apr 2018 | B2 |
9953696 | Kim | Apr 2018 | B2 |
10032501 | Ito et al. | Jul 2018 | B2 |
10083737 | Bains et al. | Sep 2018 | B2 |
10134461 | Bell et al. | Nov 2018 | B2 |
10147472 | Jones et al. | Dec 2018 | B2 |
10153031 | Akamatsu | Dec 2018 | B2 |
10170174 | Ito | Jan 2019 | B1 |
10176860 | Mylavarapu | Jan 2019 | B1 |
10210925 | Bains et al. | Feb 2019 | B2 |
10297305 | Moon et al. | May 2019 | B1 |
10339994 | Ito et al. | Jul 2019 | B2 |
10387276 | Ryu et al. | Aug 2019 | B2 |
10600462 | Augustine et al. | Mar 2020 | B2 |
10600491 | Chou et al. | Mar 2020 | B2 |
10607686 | Akamatsu | Mar 2020 | B2 |
10629286 | Lee et al. | Apr 2020 | B2 |
10679710 | Hirashima et al. | Jun 2020 | B2 |
10770127 | Shore et al. | Sep 2020 | B2 |
20010008498 | Ooishi | Jul 2001 | A1 |
20020181301 | Takahashi et al. | Dec 2002 | A1 |
20030063512 | Takahashi et al. | Apr 2003 | A1 |
20030067825 | Shimano et al. | Apr 2003 | A1 |
20030090400 | Barker | May 2003 | A1 |
20030123301 | Jang et al. | Jul 2003 | A1 |
20030193829 | Morgan et al. | Oct 2003 | A1 |
20040008544 | Shinozaki et al. | Jan 2004 | A1 |
20040022093 | Lee | Feb 2004 | A1 |
20040114446 | Takahashi et al. | Jun 2004 | A1 |
20040130959 | Kawaguchi | Jul 2004 | A1 |
20040174757 | Garverick et al. | Sep 2004 | A1 |
20040184323 | Mori et al. | Sep 2004 | A1 |
20040218431 | Chung et al. | Nov 2004 | A1 |
20050105315 | Shin et al. | May 2005 | A1 |
20050243629 | Lee | Nov 2005 | A1 |
20050265104 | Remaklus et al. | Dec 2005 | A1 |
20060083099 | Bae et al. | Apr 2006 | A1 |
20060087903 | Riho et al. | Apr 2006 | A1 |
20060176744 | Stave | Aug 2006 | A1 |
20060262616 | Chen | Nov 2006 | A1 |
20070008799 | Dono et al. | Jan 2007 | A1 |
20070014174 | Ohsawa | Jan 2007 | A1 |
20070030746 | Best et al. | Feb 2007 | A1 |
20070133330 | Ohsawa | Jun 2007 | A1 |
20070297252 | Singh | Dec 2007 | A1 |
20080028260 | Oyagi et al. | Jan 2008 | A1 |
20080031068 | Yoo et al. | Feb 2008 | A1 |
20080126893 | Harrand et al. | May 2008 | A1 |
20080130394 | Dono et al. | Jun 2008 | A1 |
20080181048 | Han | Jul 2008 | A1 |
20080253212 | Iida et al. | Oct 2008 | A1 |
20080266990 | Loeffler | Oct 2008 | A1 |
20080288720 | Atwal et al. | Nov 2008 | A1 |
20080316845 | Wang et al. | Dec 2008 | A1 |
20090077571 | Gara et al. | Mar 2009 | A1 |
20090161457 | Wakimoto | Jun 2009 | A1 |
20090185440 | Lee | Jul 2009 | A1 |
20090201752 | Riho et al. | Aug 2009 | A1 |
20090296510 | Lee et al. | Dec 2009 | A1 |
20100054011 | Kim | Mar 2010 | A1 |
20100074042 | Fukuda et al. | Mar 2010 | A1 |
20100080074 | Ohmaru et al. | Apr 2010 | A1 |
20100110809 | Kobayashi et al. | May 2010 | A1 |
20100110810 | Kobayashi | May 2010 | A1 |
20100131812 | Mohammad | May 2010 | A1 |
20100157693 | Iwai et al. | Jun 2010 | A1 |
20100329069 | Ito et al. | Dec 2010 | A1 |
20110026290 | Noda et al. | Feb 2011 | A1 |
20110069572 | Lee et al. | Mar 2011 | A1 |
20110216614 | Hosoe | Sep 2011 | A1 |
20110286271 | Chen | Nov 2011 | A1 |
20110310648 | Iwamoto et al. | Dec 2011 | A1 |
20120014199 | Narui | Jan 2012 | A1 |
20120059984 | Kang et al. | Mar 2012 | A1 |
20120151131 | Kilmer et al. | Jun 2012 | A1 |
20120213021 | Riho et al. | Aug 2012 | A1 |
20130003467 | Klein | Jan 2013 | A1 |
20130003477 | Park et al. | Jan 2013 | A1 |
20130304982 | Jung et al. | Nov 2013 | A1 |
20140006703 | Bains et al. | Jan 2014 | A1 |
20140006704 | Greenfield et al. | Jan 2014 | A1 |
20140050004 | Mochida | Feb 2014 | A1 |
20140078841 | Chopra | Mar 2014 | A1 |
20140078842 | Oh et al. | Mar 2014 | A1 |
20140089576 | Bains et al. | Mar 2014 | A1 |
20140095780 | Bains et al. | Apr 2014 | A1 |
20140095786 | Moon et al. | Apr 2014 | A1 |
20140136763 | Li et al. | May 2014 | A1 |
20140177370 | Halbert et al. | Jun 2014 | A1 |
20140189228 | Greenfield et al. | Jul 2014 | A1 |
20140219043 | Jones et al. | Aug 2014 | A1 |
20140237307 | Kobla et al. | Aug 2014 | A1 |
20140241099 | Seo et al. | Aug 2014 | A1 |
20140254298 | Dally | Sep 2014 | A1 |
20140269021 | Yang et al. | Sep 2014 | A1 |
20140281206 | Crawford et al. | Sep 2014 | A1 |
20140281207 | Mandava et al. | Sep 2014 | A1 |
20140292375 | Angelini | Oct 2014 | A1 |
20140355332 | Youn et al. | Dec 2014 | A1 |
20150049567 | Chi | Feb 2015 | A1 |
20150055420 | Bell et al. | Feb 2015 | A1 |
20150089326 | Joo et al. | Mar 2015 | A1 |
20150155027 | Abe | Jun 2015 | A1 |
20150170728 | Jung et al. | Jun 2015 | A1 |
20150206572 | Lim et al. | Jul 2015 | A1 |
20150213872 | Mazumder et al. | Jul 2015 | A1 |
20150213877 | Darel | Jul 2015 | A1 |
20150228341 | Watanabe et al. | Aug 2015 | A1 |
20150243339 | Bell et al. | Aug 2015 | A1 |
20150255140 | Song | Sep 2015 | A1 |
20150262652 | Igarashi | Sep 2015 | A1 |
20150279441 | Greenberg et al. | Oct 2015 | A1 |
20150279442 | Hwang | Oct 2015 | A1 |
20150294711 | Gaither et al. | Oct 2015 | A1 |
20150340077 | Akamatsu | Nov 2015 | A1 |
20160019940 | Jang et al. | Jan 2016 | A1 |
20160027531 | Jones et al. | Jan 2016 | A1 |
20160027532 | Kim | Jan 2016 | A1 |
20160042782 | Narui et al. | Feb 2016 | A1 |
20160078911 | Fujiwara et al. | Mar 2016 | A1 |
20160086649 | Hong et al. | Mar 2016 | A1 |
20160093402 | Kitagawa et al. | Mar 2016 | A1 |
20160125931 | Doo et al. | May 2016 | A1 |
20160133314 | Hwang et al. | May 2016 | A1 |
20160140243 | Adams et al. | May 2016 | A1 |
20160172056 | Huh | Jun 2016 | A1 |
20160180917 | Chishti et al. | Jun 2016 | A1 |
20160196863 | Shin et al. | Jul 2016 | A1 |
20160202926 | Benedict | Jul 2016 | A1 |
20160225461 | Tuers et al. | Aug 2016 | A1 |
20170076779 | Bains et al. | Mar 2017 | A1 |
20170092350 | Halbert et al. | Mar 2017 | A1 |
20170117030 | Fisch et al. | Apr 2017 | A1 |
20170140811 | Joo | May 2017 | A1 |
20170213586 | Kang et al. | Jul 2017 | A1 |
20170263305 | Cho | Sep 2017 | A1 |
20170287547 | Ito | Oct 2017 | A1 |
20170323675 | Jones et al. | Nov 2017 | A1 |
20170352399 | Yokoyama et al. | Dec 2017 | A1 |
20170371742 | Shim et al. | Dec 2017 | A1 |
20170372767 | Kang et al. | Dec 2017 | A1 |
20180005690 | Morgan et al. | Jan 2018 | A1 |
20180025770 | Ito et al. | Jan 2018 | A1 |
20180060194 | Ryu et al. | Mar 2018 | A1 |
20180090199 | Kim et al. | Mar 2018 | A1 |
20180114561 | Fisch et al. | Apr 2018 | A1 |
20180158504 | Akamatsu | Jun 2018 | A1 |
20180182445 | Lee et al. | Jun 2018 | A1 |
20180203621 | Ahn et al. | Jul 2018 | A1 |
20180218767 | Wolff | Aug 2018 | A1 |
20180261268 | Hyun et al. | Sep 2018 | A1 |
20180294028 | Lee et al. | Oct 2018 | A1 |
20180308539 | Ito et al. | Oct 2018 | A1 |
20190013059 | Akamatsu | Jan 2019 | A1 |
20190051344 | Bell et al. | Feb 2019 | A1 |
20190066759 | Nale | Feb 2019 | A1 |
20190103147 | Jones et al. | Apr 2019 | A1 |
20190130961 | Bell et al. | May 2019 | A1 |
20190139599 | Ito et al. | May 2019 | A1 |
20190198090 | Lee | Jun 2019 | A1 |
20190198099 | Mirichigni et al. | Jun 2019 | A1 |
20190207736 | Ben-tovim et al. | Jul 2019 | A1 |
20190228810 | Jones et al. | Jul 2019 | A1 |
20190228813 | Nale et al. | Jul 2019 | A1 |
20190228815 | Morohashi et al. | Jul 2019 | A1 |
20190237132 | Morohashi | Aug 2019 | A1 |
20190243708 | Cha et al. | Aug 2019 | A1 |
20190267077 | Ito et al. | Aug 2019 | A1 |
20190333573 | Shin et al. | Oct 2019 | A1 |
20190348100 | Smith et al. | Nov 2019 | A1 |
20190348107 | Shin et al. | Nov 2019 | A1 |
20190349545 | Koh et al. | Nov 2019 | A1 |
20190362774 | Kuramori et al. | Nov 2019 | A1 |
20190385667 | Morohashi et al. | Dec 2019 | A1 |
20200075106 | Tokutomi et al. | Mar 2020 | A1 |
20200090760 | Purahmad et al. | Mar 2020 | A1 |
20200194050 | Akamatsu | Jun 2020 | A1 |
20200201380 | Murali et al. | Jun 2020 | A1 |
20200211633 | Okuma | Jul 2020 | A1 |
20200251158 | Shore et al. | Aug 2020 | A1 |
20200302994 | Enomoto et al. | Sep 2020 | A1 |
Number | Date | Country |
---|---|---|
1195173 | Oct 1998 | CN |
101038785 | Sep 2007 | CN |
101067972 | Nov 2007 | CN |
101331554 | Dec 2008 | CN |
101458658 | Jun 2009 | CN |
101622607 | Jan 2010 | CN |
102113058 | Jun 2011 | CN |
102483952 | May 2012 | CN |
2005-216429 | Aug 2005 | JP |
2011-258259 | Dec 2011 | JP |
2013-004158 | Jan 2013 | JP |
1020180064940 | Jun 2018 | KR |
1020180085184 | Jul 2018 | KR |
2014120477 | Aug 2014 | WO |
2015030991 | Mar 2015 | WO |
2017171927 | Oct 2017 | WO |
2020191222 | Sep 2020 | WO |
Entry |
---|
Thomas et al. (“Voltage Source Based Voltage-to-Time Converter”, IEEE, 2020) (Year: 2020). |
U.S. Appl. No. 16/546,152 titled “Apparatuses and Methods for Analog Row Access Tracking” filed Aug. 20, 2019. |
U.S. Appl. No. 16/549,942 titled “Apparatuses and Methods for Lossy Row Access Counting” filed Aug. 23, 2019. |
U.S Appl. No. 16/425,525 titled “Apparatuses And Methods For Tracking All Row Accesses” filed May 29, 2019. |
U.S. Appl. No. 16/427,105 titled “Apparatuses And Methods For Priority Targeted Refresh Operations” filed May 30, 2019. |
U.S. Appl. No. 16/427,140 titled “Apparatuses And Methods For Tracking Access Counts Between Multiple Register Stacks” filed May 30, 2019. |
U.S. Appl. No. 16/437,811 titled “Apparatuses, Systems, and Methods For Determining Extremum Numerical Values” filed Jun. 11, 2019. |
U.S. Appl. No. 16/012,679, titled “Apparatuses and Methods for Multiple Row Hammer Refresh Address Sequences”, filed Jun. 19, 2018. |
U.S. Appl. No. 16/176,932, titled “Apparatuses and Methods for Access Based Refresh Timing”, filed Oct. 31, 2018. |
U.S. Appl. No. 16/268,818, titled “Apparatuses and Methods for Managing Row Access Counts”, filed Feb. 6, 2019. |
U.S. Appl. No. 16/358,587, titled “Semiconductor Device Having Cam That Stores Address Signals”, dated Mar. 19, 2019. |
U.S. Appl. No. 16/411,573 titled “Apparatuses, Systems, and Methods for a Content Addressable Memory Cell” filed May 14, 2019. |
U.S. Appl. No. 16/427,330 titled “Apparatuses and Methods for Storing Victim Row Data” filed May 30, 2019. |
U.S. Appl. No. 16/428,625 titled “Apparatuses and Methods for Tracking Victim Rows” filed May 31, 2019. |
U.S. Appl. No. 16/459,520 titled “Apparatuses and Methods for Monitoring Word Line Accesses”, filed Jul. 1, 2019, pp. all. |
Kim, et al., “Flipping Bits in MemoryWithout Accessing Them: An Experimental Study of DRAM Disturbance Errors”, IEEE, Jun. 2014, 12 pgs. |
U.S. Appl. No. 16/797,658, titles “Apparatuses and Methods for Controlling Refresh Operations”, filed Feb. 21, 2020. |
U.S. Appl. No. 15/881,256 entitled ‘Apparatuses and Methods for Detecting a Row Hammer Attack with a Bandpass Filter’ filed Jan. 26, 2018. |
U.S. Appl. No. 16/513,400 titled “Apparatuses and Methods for Tracking Row Accesses” filed Jul. 16, 2019. |
U.S. Appl. No. 15/789,897, entitled “Apparatus and Methods for Refreshing Memory”, filed Oct. 20, 2017; pp. all. |
U.S. Appl. No. 15/796,340, entitled: “Apparatus and Methods for Refreshing Memory” filed Oct. 27, 2017; pp. all. |
U.S. Appl. No. 16/237,291, titled “Apparatus and Methods for Refreshing Memory”, filed Dec. 31, 2018,. |
U.S. Appl. No. 16/805,197, titled “Apparatuses and Methods for Calculating Row Hammer Refresh Addresses in a Semiconductor Device”, dated Feb. 28, 2020. |
U.S. Appl. No. 15/884,192 entitled ‘Semiconductor Device Performing Row Hammer Refresh Operation’ filed Jan. 30, 2018. |
U.S. Appl. No. 16/936,297 titled “Apparatuses and Methods for Managing Access Counts” filed Jul. 22, 2020. |
U.S. Appl. No. 17/102,266, titled “Apparatuses and Methods for Tracking Word Line Accesses”, dated Nov. 23, 2020. |
Number | Date | Country | |
---|---|---|---|
20210057012 A1 | Feb 2021 | US |