SYSTEMS AND METHODS INVOLVING HARDWARE-BASED RESET OF UNRESPONSIVE MEMORY DEVICES
Systems and methods of memory operation that provide a hardware-based reset of an unresponsive memory device are disclosed. In one embodiment, an exemplary system may comprise a semiconductor memory device having a memory array, a controller that may include a firmware component for controlling memory operations, and a reset circuit including power-up circuitry and timeout circuitry. The reset circuit may be configured to detect when the memory device is in a non-responsive state and reset the memory device without using any internal controller components potentially impacted/affected by the non-responsive state.
The present disclosure relates generally to semiconductor memory, and more particularly, to systems and methods for implementing a hardware-based reset of memory devices that have become unresponsive.
BACKGROUNDIntegrated circuit devices traverse a broad range of electronic devices including memory devices, which are often referred to simply as memory. Memory devices are typically provided as internal, semiconductor, integrated circuit devices in computers or other electronic devices. There are many different types of memory including random-access memory (RAM), read only memory (ROM), dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), and flash memory.
Flash memory has developed into a popular source of non-volatile memory for a wide range of electronic applications. Flash memory typically use a one-transistor memory cell that allows for high memory densities, high reliability, and low power consumption. Changes in threshold voltage (Vt) of the memory cells, through programming (which is often referred to as writing) of charge storage structures (e.g., floating gates or charge traps) or other physical phenomena (e.g., phase change or polarization), determine the data state (e.g., data value) of each memory cell. Common uses for flash memory and other non-volatile memory include personal computers, personal digital assistants (PDAs), digital cameras, digital media players, digital recorders, games, appliances, vehicles, wireless devices, mobile telephones, and removable memory modules, and the uses for non-volatile memory continue to expand.
NAND flash memory is a common type of flash memory, so called for the logical form in which the basic memory cell configuration is arranged. Typically, the array of memory cells for NAND flash memory is arranged such that the control gate of each memory cell of a row of the array is connected together to form an access line, such as a word line. Columns of the array include strings (often termed NAND strings) of memory cells connected together in series between a pair of select gates, e.g., a source select transistor and a drain select transistor.
Further, current NAND memory devices provide various methods to reset the memory if it becomes unresponsive. Certain commands may be used to reset an entire memory device, for example, but such commands are often processed via memory control circuitry and/or firmware controllers that are also used in the memory operations. Other techniques are provided to reset erase or program operations, as opposed to the overall memory device, yet such techniques also typically require internal control circuitry and/or firmware. These techniques are not useful if the control circuitry and/or firmware controllers that process the reset instructions also become unresponsive, which can occur with brownout, illegal sequences, etc. As such, users may have no recourse when memory devices become unresponsive in this manner, as powering-down in not an option in actual systems and operation. Updating memory design to avoid such drawbacks is also a challenge, as the addition of another, dedicated pin to perform such reset independent of the control circuitry and firmware is also not viable, due to the cost and complexity of adding an extra pin to the package.
The disclosed embodiments provide improved technical solutions regarding the above-noted drawbacks and/or otherwise remedy or overcome the above and other deficiencies of existing semiconductor memories.
The foregoing and other objects, features, and advantages of the disclosure will be apparent from the following description of embodiments as illustrated in the accompanying drawings, in which reference characters refer to the same parts throughout the various views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating principles of the disclosure.
In the following detailed description, reference is made to the accompanying drawings that form a part hereof, and in which is shown, by way of illustration, specific embodiments. In the drawings, like reference numerals describe substantially similar components throughout the several views. Other embodiments may be utilized and structural, logical and electrical changes may be made without departing from the scope of the present disclosure. The following detailed description is, therefore, not to be taken in a limiting sense.
The term “semiconductor” used herein can refer to, for example, a layer of material, a wafer, or a substrate, and includes any base semiconductor structure. “Semiconductor” is to be understood as including silicon-on-sapphire (SOS) technology, silicon-on-insulator (SOI) technology, thin film transistor (TFT) technology, doped and undoped semiconductors, epitaxial layers of a silicon supported by a base semiconductor structure, as well as other semiconductor structures well known to one skilled in the art. Furthermore, when reference is made to a semiconductor in the following description, previous process steps may have been utilized to form regions/junctions in the base semiconductor structure, and the term semiconductor can include the underlying layers containing such regions/junctions.
The term “conductive” as used herein, as well as its various related forms, e.g., conduct, conductively, conducting, conduction, conductivity, etc., refers to electrically conductive unless otherwise apparent from the context. Similarly, the term “connecting” as used herein, as well as its various related forms, e.g., connect, connected, connection, etc., refers to electrically connecting unless otherwise apparent from the context.
Various embodiments will be discussed using the example of a NAND memory device. However, it should be understood that the concepts disclosed herein may also be applied to other forms of semiconductor memory.
As explained in more detail, below, systems and methods of memory operation that provide a hardware-based reset of an unresponsive memory device are provided. In one embodiment, an exemplary system may comprise a semiconductor memory device having a memory array, a controller that may include a firmware component for controlling memory operations, as well as reset circuitry including a special timeout circuit. The reset circuitry may be configured to detect when the memory device is in a non-responsive state and reset the memory device without using any internal controller components potentially impacted/affected by the non-responsive state. The timeout circuit may be configured with a timeout delay value based on parameters and conditions of the particular memory device. Once enabled, the timeout circuit can reset an entire memory device without requiring any of the internal memory control circuitry or firmware controllers of the memory, i.e., the components that may be or could become unresponsive, to process the relevant reset instructions.
Memory device 100 includes an array of memory cells 104 logically arranged in rows and columns. Memory cells of a logical row are typically connected to the same access line (commonly referred to as a word line) while memory cells of a logical column are typically selectively connected to the same data line (commonly referred to as a bit line). A single access line may be associated with more than one logical row of memory cells and a single data line may be associated with more than one logical column. Memory cells (not shown in
A row decode circuitry 108 and a column decode circuitry 110 are provided to decode address signals. Address signals are received and decoded to access the array of memory cells 104. Memory device 100 also includes input/output (I/O) control circuitry 112 to manage input of commands, addresses and data to the memory device 100 as well as output of data and status information from the memory device 100. An address register 114 is in communication with I/O control circuitry 112 and row decode circuitry 108 and column decode circuitry 110 to latch the address signals prior to decoding. A command register 124 is in communication with I/O control circuitry 112 and control logic 116 to latch incoming commands. A count register 126 may be in communication with the control logic 116 to store count data, such as data representative of respective numbers of read cycles for different portions of the array of memory cells 104. Although depicted as a separate storage register, count register 126 may represent a portion of the array of memory cells 104.
A controller (e.g., the control logic 116 internal to the memory device 100) controls access to the array of memory cells 104 in response to the commands and generates status information for the external processor 130, i.e., control logic 116 is configured to perform access operations (e.g., read operations, program operations and/or erase operations) in accordance with embodiments described herein. The control logic 116 is in communication with row decode circuitry 108 and column decode circuitry 110 to control the row decode circuitry 108 and column decode circuitry 110 in response to the addresses.
Control logic 116 is also in communication with a cache register 118. Cache register 118 latches data, either incoming or outgoing, as directed by control logic 116 to temporarily store data while the array of memory cells 104 is busy writing or reading, respectively, other data. During a program operation (e.g., write operation), data is passed from the cache register 118 to data register 120 for transfer to the array of memory cells 104; then new data is latched in the cache register 118 from the I/O control circuitry 112. During a read operation, data is passed from the cache register 118 to the I/O control circuitry 112 for output to the external processor 130; then new data is passed from the data register 120 to the cache register 118. A status register 122 is in communication with I/O control circuitry 112 and control logic 116 to latch the status information for output to the processor 130.
Memory device 100 receives control signals at control logic 116 from processor 130 over a control link 132. The control signals might include a chip enable CE#, a command latch enable CLE, an address latch enable ALE, a write enable WE#, a read enable RE#, and a write protect WP#133. Memory device 100 may also generate output signals, such as ready/busy R/B# 135. Control signals and output signals may be applied to or present on specified pins of the memory package, as shown further in connection with
For example, the commands are received over input/output (I/O) pins [7:0] of I/O bus 134 at I/O control circuitry 112 and are written into command register 124. The addresses are received over input/output (I/O) pins [7:0] of I/O bus 134 at 10 control circuitry 112 and are written into address register 114. The data are received over input/output (I/O) pins [7:0] for an 8-bit device or input/output (I/O) pins [15:0] for a 16-bit device at I/O control circuitry 112 and are written into cache register 118. The data are subsequently written into data register 120 for programming the array of memory cells 104. For another embodiment, cache register 118 may be omitted, and the data are written directly into data register 120. Data are also output over input/output (I/O) pins [7:0] for an 8-bit device or input/output (I/O) pins [15:0] for a 16-bit device.
It will be appreciated by those skilled in the art that additional circuitry and signals can be provided, and that the memory device 100 of
Additionally, while specific I/O pins are described in accordance with popular conventions for receipt and output of the various signals, it is noted that other combinations, numbers and/or specific ones of I/O pins may be used in the various embodiments.
Referring to the example embodiment shown in
In some embodiments, the timeout delay value may be calculated based on the greater of (i) the necessary time that the write protect signal is held low to reset erase/program operations, i.e., when the memory becomes unresponsive during erase or program, (ii) the worst-case time that is desired for the busy signal to be high, i.e., the worst-case time for the memory device to be busy, indicating it is in an unresponsive state. With regard to the first time, (i), implementations herein may determine, for the memory device, this first time that a write protect signal is held low during an erase operation or a program operation to perform this reset. The time needed to perform such reset operation (often referred to as tRST) may be provided in the datasheet for a given memory device, e.g., as the tRST spec. Here, for example, if the memory device were to become unresponsive during erase or program, reset is performed by keeping the write protect signal active (e.g., low) for greater than this reset time, tRST, to see if the memory device's busy signal transitions from the busy or unresponsive state to the ready state. With regard to the second time, (ii), implementations herein may also set the timeout delay value equal to, or just above, a second time that the busy signal is held high, if such second time is greater than the first time, (i). Here, for example, this second time may be established by determining the worst-case busy high time for any memory operation of the memory device. Further, the reset circuitry may factor-in this second time with some margin added. As such, by comparing these two times and using the greater of the two, the timeout circuit is not triggered until after such worst-case time period has elapsed. Accordingly, then, if the write protect signal is held low for this entire, worst-case time delay value, the reset circuitry is configured to provide a reset signal to transition the control circuitry and/or memory device out of an unresponsive state. Operation involving such timeout delay value or fixed delay is shown and described further, below, in connection with
Furthermore, the subject matter disclosed above may be embodied in a variety of different forms and, therefore, covered or claimed subject matter is intended to be construed as not being limited to any example embodiments set forth herein; example embodiments are provided merely to be illustrative. Likewise, a reasonably broad scope for claimed or covered subject matter is intended. Among other things, for example, subject matter may be embodied as methods, devices, components, or systems. Accordingly, embodiments may, for example, take the form of hardware, software, firmware or any combination thereof (other than software per se). The following detailed description is, therefore, not intended to be taken in a limiting sense.
Throughout the specification and claims, terms may have nuanced meanings suggested or implied in context beyond an explicitly stated meaning. Likewise, the phrase “in one embodiment” as used herein does not necessarily refer to the same embodiment and the phrase “in another embodiment” as used herein does not necessarily refer to a different embodiment. It is intended, for example, that claimed subject matter include combinations of example embodiments in whole or in part.
In general, terminology may be understood at least in part from usage in context. For example, terms, such as “and”, “or”, or “and/or,” as used herein may include a variety of meanings that may depend at least in part upon the context in which such terms are used. Typically, “or” if used to associate a list, such as A, B or C, is intended to mean A, B, and C, here used in the inclusive sense, as well as A, B or C, here used in the exclusive sense. In addition, the term “one or more” as used herein, depending at least in part upon context, may be used to describe any feature, structure, or characteristic in a singular sense or may be used to describe combinations of features, structures or characteristics in a plural sense. Similarly, terms, such as “a,” “an,” or “the,” again, may be understood to convey a singular usage or to convey a plural usage, depending at least in part upon context. In addition, the term “based on” may be understood as not necessarily intended to convey an exclusive set of factors and may, instead, allow for existence of additional factors not necessarily expressly described, again, depending at least in part on context.
Those skilled in the art will recognize that the methods and devices of the present disclosure may be implemented in many manners and as such are not to be limited by the foregoing exemplary embodiments and examples. In other words, aspects/elements can be performed by single or multiple components, in various combinations and/or sub-combinations, and individual aspects, may be distributed among components and/or subcomponents. In this regard, any number of the features of the different embodiments described herein may be combined into single or multiple embodiments, and alternate embodiments having fewer than, or more than, all the features described herein are possible.
While various embodiments have been described for purposes of this disclosure, such embodiments should not be deemed to limit the teaching of this disclosure to those embodiments. Various changes and modifications may be made to the elements and features described above to obtain a result that remains within the scope of the systems and processes described in this disclosure.
Claims
1. A memory device comprising:
- at least one memory array;
- input/output circuitry coupled to the at least one memory array and configured to read from and write to the at least one memory array;
- control circuitry coupled to the at least one memory array and the input/output circuitry and configured to control operation of the memory device, the control circuitry comprising: an output providing a busy signal indicating that the memory device is busy; memory control components including nodes having electrical connections that render the nodes inoperative when the memory device is busy;
- reset circuitry coupled to the control circuitry and configured to reset the memory device, the reset circuitry comprising timeout circuitry and logic, wherein the reset circuitry is configured to generate a global reset signal in response to a determination that the timeout circuit has been activated for longer than a predetermined period, wherein the predetermined period is set as being greater than the longer of: a first time that the write protect signal is maintained active to perform the reset of the erase or program operation; and a second time, determined for the memory device, that the busy signal is allowed to be active indicating a busy state before the memory device requires reset;
- wherein the timeout circuitry is configured to activate in response to a write protect signal and in response to the busy signal, the write protect signal configured to reset an erase or program operation of the memory device; and
- wherein the global reset signal is configured to power-down and power up the control circuitry to reset the memory device.
2. The device of claim 1 wherein the reset circuitry consists of logic that is electrically separate from the memory control components.
3. The device of claim 1 wherein the at least one memory array, the input/output circuitry, the control circuitry and the reset circuitry are contained within a semiconductor memory package, the package comprising a first pin that provides the write protect signal and a second pin that receives the busy signal.
4. The device of claim 3 wherein the second pin is a ready/busy pin that is dedicated to providing the busy signal, and wherein the device status circuitry is configured to indicate via the busy signal when the memory device is: (i) processing a program operation, (ii) processing an erase operation, or (iii) transferring data to a data register during a read operation.
5. The device of claim 1 wherein the control circuitry further comprises write protect circuitry coupled to the first pin and device status circuitry coupled to the second pin.
6. The device of claim 5 wherein the first pin is a write protect pin that is dedicated to receiving a write protect signal, and wherein the write protect circuitry is configured to disable all program and erase operations when the write protect signal is active.
7. The device of claim 1 wherein the control circuitry further comprises one or more firmware controllers that are part of the memory control components that are electrically separate from the reset circuitry.
8. The device of claim 1 wherein the busy signal, which indicates when the memory device is busy or unresponsive, is provided as input to the reset circuitry.
9. The device of claim 1 wherein the timeout circuit is configured to operate as a function of the write protect signal and the busy signal, wherein the timeout circuit output is triggered when the busy signal indicates that the memory device is busy or unresponsive and when the write protect signal is maintained.
10. A memory device comprising:
- at least one memory array;
- input/output circuitry coupled to the at least one memory array and configured to read from and write to the at least one memory array;
- control circuitry coupled to the at least one memory array and the input/output circuitry and configured to control operation of the memory device, the control circuitry comprising: an output providing a busy signal indicating that the memory device is busy; memory control components including nodes having electrical connections that render the nodes inoperative when the memory device is busy; and
- reset circuitry coupled to the control circuitry and configured to reset the memory device, the reset circuitry comprising timeout circuitry and logic, wherein the reset circuitry is configured to generate a global reset signal in response to a determination that the timeout circuit has been activated for longer than a predetermined period;
- wherein the timeout circuitry is configured to activate in response to a write protect signal and the busy signal, the write protect signal used to reset an erase or program operation of the memory device;
- wherein the global reset signal is configured to power-down and power up the control circuitry to reset the memory device; and
- wherein the reset circuitry comprises a first logic circuit that couples the write protect signal with the busy signal to generate a control input to the timeout circuit, wherein the control input triggers the timeout circuit when the busy signal indicates that the memory device is busy and when the write protect signal is maintained.
11. The device of claim 1 further comprising power-up circuitry associated with powering-up the memory device, wherein the reset circuitry is configured to process a signal provided by the power-up circuitry, power-down and power up the control circuitry, and thereby reset the memory device out of the busy state.
12. A memory device comprising:
- at least one memory array;
- input/output circuitry coupled to the at least one memory array and configured to read from and write to the at least one memory array;
- control circuitry coupled to the at least one memory array and the input/output circuitry and configured to control operation of the memory device, the control circuitry comprising: an output providing a busy signal indicating that the memory device is busy; memory control components including nodes having electrical connections that render the nodes inoperative when the memory device is busy;
- reset circuitry comprising timeout circuitry and logic, coupled to the control circuitry and configured to reset the memory device, wherein the reset circuitry is configured to generate a global reset signal in response to a determination that the timeout circuit has been activated for longer than a predetermined period; and
- power-up circuitry associated with powering-up the memory device, the power-up circuitry providing a signal to the reset circuitry;
- wherein the timeout circuitry is configured to activate in response to a write protect signal and in response to the busy signal, the write protect signal configured to reset an erase or program operation of the memory device; and
- wherein the reset circuitry comprises a second logic circuit that couples an output of the power-up circuitry with the output of the timeout circuitry, and wherein the second logic circuit is configured to switch the global reset signal provided as output of the second logic circuit between high and low, to yield the power-down and the power-up of the control circuitry, based on the output of the timeout circuit.
13. The device of claim 12 wherein the control circuitry is configured, upon receipt of a low output on the global reset signal, to reset the memory device.
14. (canceled)
15. A method comprising:
- receiving, in a memory device, a write protect signal configured to reset an erase or program operation of the memory device;
- activating, in response to the write protect signal and in response to a busy signal from a controller of the memory device, a timeout circuit, the timeout circuit being part of reset circuitry configured to reset the memory device;
- determining that the timeout circuit has been activated, via the write protect signal and the busy signal, for longer than a predetermined period, wherein the predetermined period is set as being greater than the longer of: a first time that the write protect signal is maintained active to perform the reset of the erase or program operation; and a second time, determined for the memory device, that the busy signal is allowed to be active indicating a busy state before the memory device requires reset
- generating, by the timeout circuit, a global reset signal in response to a determination that the timeout circuit has been activated for longer than the predetermined period; and
- powering-down and powering up the controller of the memory device, by the reset circuitry, in response to the global reset signal.
16. The method of claim 15 further comprising:
- enabling the timeout circuit when the write protect signal is maintained in a logic state beyond a period of time established for resetting the erase operation or the program operation.
17. The method of claim 15 further comprising:
- providing, via device status circuitry, the busy signal as output on a ready/busy pin to indicate when the memory device is: (i) processing a program operation, (ii) processing an erase operation, or (iii) transferring data to a data register during a read operation, wherein the second pin is a ready/busy pin dedicated to providing the ready/busy signal.
18. The method of claim 15 further comprising:
- generating, by the control circuitry, the busy signal to indicate when the memory device is busy or unresponsive; and
- providing the busy signal as an input to the timeout circuit.
19. The method of claim 18 further comprising:
- operating the timeout circuit as a function of the write protect signal and the busy signal; and
- triggering output of the timeout circuit when the busy signal indicates that the memory device is busy or unresponsive and when the write protect signal is maintained.
20. The method of claim 19 further comprising:
- coupling, via a first logic circuit provided as input to the timeout circuit, the write protect signal with the busy signal to generate a control input to the timeout circuit;
- providing the control input as an input signal to the timeout circuit; and
- triggering the timeout circuit when the busy signal indicates that the memory device is busy or unresponsive and when the write protect signal is maintained.
21. The method of claim 15 further comprising:
- controlling a signal, provided to the memory device by power-up circuitry, to power-down and power-up the control circuitry and thereby reset the memory device from the busy or unresponsive state.
22. The method of claim 21 further comprising:
- coupling, by a second logic circuit, an output of the power-up circuitry with the output signal of the timeout circuitry;
- switching a global reset signal provided as output from the second logic circuit between high and low when the output signal of the timeout circuit is triggered active;
- switching the global reset between low and high when the output signal of the timeout circuit is triggered inactive; and
- resetting the memory device via transitioning the global reset signal between high and low.
23-24. (canceled)
25. The device of claim 10 wherein the reset circuitry consists of logic that is electrically separate from the memory control components.
26. The device of claim 10 wherein the at least one memory array, the input/output circuitry, the control circuitry and the reset circuitry are contained within a semiconductor memory package, the package comprising a first pin that provides the write protect signal and a second pin that receives the busy signal.
27. The device of claim 10 wherein the busy signal, which indicates when the memory device is busy or unresponsive, is provided as input to the reset circuitry.
Type: Application
Filed: Aug 16, 2019
Publication Date: Feb 18, 2021
Inventors: Vipul Patel (Santa Clara, CA), Theodore Pekny (San Jose, CA)
Application Number: 16/543,271