The present disclosure includes methods and devices for logical unit operation. One device embodiment includes a number of logical units, wherein each of the number of logical units has a unique address. The device includes control circuitry coupled to the number of logical units and configured optionally to control more than one of the number of logical units with one of a number of commands and one address.
|
14. A method for operating a memory device, comprising:
receiving a command and an address corresponding only to one logical unit; and
issuing the command to the one logical unit and at least one additional logical unit to move data from the one logical unit and the at least one additional logical unit simultaneously according to the address when an operating parameter is set to a particular value.
19. A method for operating a memory device, comprising:
masking at least a portion of an address when an operating parameter is set to a particular value, wherein the address is associated with a command and corresponds to only one logical unit; and
issuing the command to two or more logical units to move data from the two or more logical units simultaneously, wherein the two or more logical units correspond to the masked address.
1. A memory device, comprising:
a number of logical units, wherein each of the number of logical units has a unique address; and
control circuitry coupled to the number of logical units, wherein the control circuitry, in response to an operating parameter being set to a particular value and until the operating parameter changes to a different value, issues one command to move data simultaneously from more than one of the number of logical units, wherein address information associated with the one command corresponds to only one of the more than one of the number of logical units.
11. A memory device, comprising:
a number of logical units, wherein at least two of the number of logical units share one or more control inputs;
control circuitry coupled to the one or more control inputs, wherein the control circuitry, in response to an operating parameter being set to a particular value and until the operating parameter changes to a different value, sends one command to the at least two of the number of logical units without regard to at least a portion of an address associated with the one command that corresponds to only one of the at least two of the number of logical units; and
wherein the one command simultaneously moves data from the at least two of the number of logical units.
7. A memory device, comprising:
a number of logical units, wherein at least two of the number of logical units share one or more control inputs;
control circuitry coupled to the one or more control inputs and, wherein the control circuitry, in response to an operating parameter being set to a particular value and until the operating parameter changes to a different value, masks at least a portion of an address associated with one command such that the one command is issued to two or more of the number of logical units to move data from the two or more of the number of logical units simultaneously, wherein the address, prior to being masked, identifies only one of the two or more of the number of logical units.
24. A method for operating a memory device, comprising:
setting an operating parameter to a first value;
receiving a first command and a first address corresponding only to a first logical unit;
issuing the first command to the first logical unit and at least one other logical unit to move data from the first logical unit and the at least one other logical unit simultaneously according to the first address;
setting the operating parameter to a second value subsequent to setting the operating parameter to the first value;
receiving a second command and the first address corresponding only to the first logical unit; and
issuing the second command only to the first logical unit according to the first address.
2. The device of
the device includes input/output (I/O) circuitry coupled to the number of logical units and to the control circuitry; and
the control circuitry transfers the one command across the I/O circuitry only once to the more than one of the number of logical units.
3. The device of
4. The device of
5. The device of
6. The device of
8. The device of
10. The device of
12. The device of
13. The device of
15. The method of
16. The method of
17. The method of
18. The method of
20. The method of
21. The method of
a bitwise AND operation; and
a bitwise OR operation.
22. The method of
23. The method of
25. The method of
26. The method of
|
This application is a continuation of U.S. application Ser. No. 12/259,380, filed Oct. 28, 2008, which is incorporated by reference.
The present disclosure relates generally to semiconductor memory devices, methods, and systems, and more particularly, to logical unit operation.
Memory devices are typically provided as internal, semiconductor, integrated circuits 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), phase change random access memory (PCRAM), and flash memory, among others.
Solid state memory devices are utilized as volatile and non-volatile memory for a wide range of electronic applications. Flash memory, which is just one type of solid state memory, typically uses a one-transistor memory cell that allows for high memory densities, high reliability, and low power consumption.
Solid state memory devices, including flash devices, can be combined together to form a solid state drive. A solid state drive can be used to replace hard disk drives as the main storage device for a computer, as the solid state drives can have advantages over hard drives in terms of performance, size, weight, ruggedness, operating temperature range, and power consumption. For example, flash solid state drives can have superior performance when compared to magnetic disk drives due to their lack of moving parts, which may ameliorate seek time, latency, and other electro-mechanical delays associated with magnetic disk drives.
A solid state drive is a data storage device that uses solid state memory to store persistent data. A solid state drive may include NAND flash non-volatile memory and/or DRAM volatile memory. Solid state drive manufacturers can use nonvolatile flash memory to create a drive that does not use an internal battery supply thus allowing the drive to be more versatile and compact. Solid state drives using flash memory, also known as flash drives, can use standard disk drive form factors (e.g., 1.8-inch, 2.5-inch, and 3.5-inch, among others).
For some storage applications, hard drives may be arranged in a redundant array, such as a redundant array of inexpensive disks, also referred to as a redundant array of independent disks (RAID). A RAID can refer to data storage systems that can divide and replicate data among multiple hard disk drives. Such arrangements, e.g., in servers, may be intended to prevent data loss in case a particular drive fails. However, this practice may involve a substantial investment in extra capacity that is not realized in system storage capacity. For example, in some storage applications, as little as 5-30% of a hard disk capacity is used for storage in order to increase performance by reducing seek times associated with the hard disk(s). Furthermore, hard drive failure rates may tend to increase as the drive ages. Solid state devices, conversely, may tend to fail early in life, if at all, and then operate correctly through the end of their expected service life.
The present disclosure includes methods and devices for logical unit operation. One device embodiment includes a number of logical units, wherein each of the number of logical units has a unique address. The device includes control circuitry coupled to the number of logical units and configured optionally to control more than one of the number of logical units with one of a number of commands and one address.
In the following detailed description of the present disclosure, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration how one or more embodiments of the disclosure may be practiced. These embodiments are described in sufficient detail to enable those of ordinary skill in the art to practice the embodiments of this disclosure, and it is to be understood that other embodiments may be utilized and that process, electrical, and/or structural changes may be made without departing from the scope of the present disclosure. As used herein, the designators “N,” “P,” “L,” and “B,” particularly with respect to reference numerals in the drawings, indicates that a number of the particular feature so designated can be included with one or more embodiments of the present disclosure.
The figures herein follow a numbering convention in which the first digit or digits correspond to the drawing figure number and the remaining digits identify an element or component in the drawing. Similar elements or components between different figures may be identified by the use of similar digits. For example, 110 may reference element “10” in
The memory device 120 includes an array of non-volatile memory cells 130, which can be floating gate flash memory cells with a NAND architecture. The control gates of memory cells of a “row” are coupled with a word line, while the drain regions of the memory cells of a “column” are coupled to bit lines. The source regions of the memory cells are coupled to source lines. As will be appreciated by those of ordinary skill in the art, the manner of connection of the memory cells to the bit lines and source lines depends on whether the array is a NAND architecture, a NOR architecture, an AND architecture, or some other memory array architecture.
The embodiment of
The memory device 120 senses data in the memory array 130 by sensing voltage and/or current changes in the memory array columns using sense/buffer circuitry that in this embodiment can be read/latch circuitry 150. The read/latch circuitry 150 can read and latch a page, e.g., a row, of data from the memory array 130. I/O circuitry 160 is included for bi-directional data communication over the I/O connections 162 with the processor 110. Write circuitry 155 is included to write data to the memory array 130.
Control circuitry 170 decodes signals provided by control connections 172 from the processor 110. These signals can include chip signals, write enable signals, and address latch signals that are used to control the operations on the memory array 130, including data sensing, data write, and data erase operations, as described herein. In one or more embodiments, the control circuitry 170 is responsible for executing instructions from the processor 110 to perform the operations according to embodiments of the present disclosure. The control circuitry 170 can be a state machine, a sequencer, or some other type of controller. It will be appreciated by those skilled in the art that additional circuitry and control signals can be provided, and that the memory device detail of
The embodiment illustrated in
In one or more embodiments of the present disclosure, control circuitry 202 can be configured to control more than one logical unit with one command, e.g., a single command. For example, control circuitry 202 can control logical units 270-A and 270-B with one command issued across control inputs 241-1. As another example, control circuitry 202 can control logical units 270-C, 270-D, 270-E, and 270-F with one command issued across control inputs 241-2. In one or more embodiments, control circuitry 202 can issue a command across control inputs 241-2 such that it controls any one, two, three, or all four logical units 270-C, 270-D, 270-E, and 270-F. Details of such commands and controls are described in more detail herein.
Each page of memory cells can include a number of memory cells, e.g., non-volatile memory cells. As used herein, a page of memory cells means a number of memory cells which can store an amount of data programmable at one time. As an example, the amount of data programmable at one time can be referred to as a page of data, and the memory cells which store the page of data can be referred to as a page of memory cells. In one or more embodiments, a page of memory cells can include memory cells coupled to a particular access line, e.g., word line. In one or more embodiments, memory cells coupled to a particular word line can be divided into more than one page, e.g., into an “even” page and an “odd” page of data. In one or more embodiments, a page of memory cells can include memory cells coupled to more than one word line. As used herein, a block of memory cells means a number of memory cells which can store an amount of data erasable at one time. For example, the amount of data erasable at one time can be referred to as a block of data, and the memory cells which store the block of data can be referred to as a block of memory cells.
The CLE signal can be used to load a command from a bus into a command register. The CE# signal and can enable or disable a logical unit, e.g., a die, of memory. The WE# signal can transfer commands, addresses, and serial data from a memory access device (e.g., processor, memory controller, control circuitry, host system, etc.), to the memory. For example, the WE# signal can be used to provide a timing reference to a memory device. Timing chains that are activated by the control signals (e.g., ALE and CLE) can be used to control the timing of communications transfers. The memory access device can use control signals to indicate to the memory device when requests for data transactions are sent. The ALE signal can be used to load an address from a bus into an address register. The RE# signal can transfer serial data from the memory to a host system.
Various control signals coordinate communication of a command, address and other information, and data across a memory interface. According to the previous approach illustrated in
According to the previous approach illustrated in
As described above, timing diagram 380 includes signals associated with programming data redundantly to two logical units. Accordingly, after data is programmed to the first logical unit during time 385-1, a second serial data input command 381-2 can be issued, accompanied by address information 382-2, which identifies the second logical unit, and the redundant copy of data 383-2. Data 383-2 can be followed by programming command 384-2 to program the redundant copy of data to the second logical unit during programming time 385-2. As illustrated in timing diagram 380, some prior art approaches to programming data redundantly to two logical units involve issuing two data input commands and two sets of address information (for the two logical units), clocking data across an I/O bus twice, issuing two programming commands, and programming the data to two different logical units at separate times.
According to one or more embodiments of the present disclosure, more than one logical unit can be controlled with one of a number of commands, e.g., a single programming command. Thus, in the embodiment illustrated in
Address information 482 can identify a location in memory, e.g., a logical unit. An example of information included with address information 482 is illustrated in
In one or more embodiments, more than one logical unit can be controlled by one or more commands associated with the address information 482 when control circuitry is configured to mask at least a portion of the address 482. In one or more embodiments, more than one logical unit can be controlled without regard to at least the portion of the address 482. The portion of the address can be a portion of the address that identifies the logical unit. As described below in connection with
In one or more embodiments, the ability of a memory device to control more than one logical unit with one or more commands can be optionally enabled. An operating parameter can be set, e.g., programmed, in the memory device, e.g., during initialization of the device. For example, a “set features” command can be used to alter default power-on behavior of the memory device. The set features command can be used to program an operating parameter into a location in memory that is reserved for such information. In one or more embodiments, such operating parameters can be stored in the device until it is powered down. Setting the operating parameter can be similar to programming data, e.g., as illustrated by timing diagram 480. That is a set features command can issue, followed by address information, which can identify a portion of the memory device for which a particular operating parameter is being set. The address information can be followed by data, e.g., values representing a particular setting for the operating parameter. Such information can be clocked in through the I/O and programmed into an appropriate memory location. Once programmed, the operating parameter can be read by the device to determine operating behavior.
Embodiments are not limited to programming an operating parameter during device initialization, and such an operating parameter can be changed without powering down the device, e.g., a different operating parameter can be programmed to change the behavior of the device. For example, it may be beneficial to enable a memory device to operate more than one logical unit as controlled by a single command so that data can be programmed redundantly until a threshold of used space is met, then disable such redundant programming thereafter. Such uses of this feature are described in more detail in commonly assigned U.S. patent application Ser. No. 12/259,363, now U.S. Pat. No. 8,291,181, entitled “Temporary Mirroring, Logical Segregation, and Redundant Programming or Addressing for Solid State Drive Operation” including at least one common inventor, Troy Manning, filed on the same date herewith. Such embodiments can include setting the operating parameter to a first value and operating more than one logical unit for certain commands. Subsequently, the operating parameter can be set to a second value and the device can be operated such that there only one logical unit is controlled by each command.
In one or more embodiments, when the particular operating parameter is set such that one or more commands can control more than one logical unit, certain commands may continue to control only one logical unit. For example, programming commands, erasing commands, data move commands, cached commands, and multiple plane commands can control more than one logical unit. However, reading commands, status commands, get feature commands, and set feature commands may control only one logical unit, per their associated address information associated with such commands. Such embodiments can be useful in allowing data to be programmed to, moved from, or erased from more than one logical unit for redundancy, among other purposes. Such embodiments can also be useful in allowing one copy of the data to be read during a sensing operation to reduce the operating overhead that would be associated with sensing more than one copy of the same data.
The row labeled “CYCLE” includes headers for each of the 8 I/O bits for each address cycle. The designator “CA” indicates a column address, “PA” indicates a plane address, and “BA” indicates a block address. The data arrangement shown in table 590 includes a number of unused bits (shown set LOW in
In one or more embodiments, control circuitry that is coupled to control inputs shared by a number of logical units can be configured to mask at least a portion of an address associated with one or more commands such that the one or more commands control two or more of the number of logical units. For example, two logical units (a first logical unit and a second logical unit) could have addresses differing only by one bit, e.g., a die select bit 591 or logical unit ID bit. In such an instance, the bit 591 can be masked such that a command addressed to either the first or the second logical unit would control both the first and the second logical units.
For example, consider a first logical unit having “0011” as a portion of a logical unit address and a second logical unit having “1011” as a portion of a logical unit address. The first bit could be masked by a number of different masking operations, e.g., logical operations. For instance, the portion of the address could be operated on logically by applying a bitwise AND with “0111” such that the first bit would return a “0” for any entry in that field, e.g., bit 591. In this example, the result of the AND operation would be “0011” for either the portion of the first logical unit address or the portion of the second logical unit address. Another example can include a bitwise OR operation with “1000” such that the bit 591 would be a “1”. Such an operation would yield “1011” for both the portion of the first logical unit address and the portion of the second logical unit address. The masked portion of the address can at least partially identify at least one of the number of logical units that are to be controlled by the masked address. In this example, either the first “0” or “1” is masked. That “0” or “1” can at least partially identify the first or second logical unit. That is, the bit to be masked can represent the only difference between the addresses of the first and second logical units.
Control circuitry can include additional gating, e.g., one or more AND gates, OR gates, or combinations of various logical gates to perform such masking operations. Additional gating can be located in control circuitry including command decoders, address registers, command registers, or other locations in the memory device depending on the particular implementation. Other masking operations are possible, as will be understood by one of ordinary skill in the art having read and understood the present disclosure. Additionally, the address can be modified, e.g., by adding or subtracting a value therefrom such that it corresponds to two or more logical units. As described above, such a masking operation can be optionally enabled based on, for example, an operating parameter being set to a particular value. In one or more embodiments, only one bit of one or more addresses is masked. Regardless of how many bits are used to identify a particular logical unit, masking only one bit can provide control over two logical units. For embodiments where simultaneous control is desired over more than two logical units, more than one bit can be masked.
In one or more embodiments, control circuitry that is coupled to control inputs shared by a number of logical units can be configured to send one or more commands to two or more logical units without regard to at least a portion of an address associated with one or more commands such that the one or more commands control the two or more logical units. For example, two logical units (a first logical unit and a second logical unit) could have addresses differing only by one bit, e.g., a die select bit 591 or logical unit ID bit. In such an instance, control circuitry can send a command to both the first and the second logical units regardless of the status of a portion of the address, e.g., whether bit 591 is a 0 or a 1. That is, the control circuitry can “ignore” at least a portion of the address, e.g., bit 591.
In one or more embodiments, the number of logical units controlled by one or more commands can share a remainder of an address identifying each logical unit, other than the portion of the address that is masked, e.g., ignored. Thus, the portion of the address that is masked and the remainder of the address can identify one of the logical units controlled by the one or more commands. That is, the logical units that are controlled by the one or more commands can share a substantial portion of the address corresponding to each logical unit. For example, in table 590, 25 bits are used, e.g., not LOW, for the address. If two logical units are controlled by masking bit 591, then the two logical units share 24 out of the 25 bits that are included in their addresses. Embodiments are not limited to memory device operations that mask only one bit of an address corresponding to a logical unit.
The interface 603 can be used to communicate information between the solid state drive 620 and another device such as a computing device. For example, when the solid state drive 620 is used for data storage in a computing device, as illustrated in
The controller 601 can communicate with the solid state memory arrays 630-1, . . . , 630-N to sense, program, and erase data, among other operations, on the solid state memory arrays 630-1, . . . , 630-N. Controller 601 can have circuitry that may be one or more integrated circuits and/or discrete components. For one or more embodiments, the circuitry in controller 601 may include control circuitry for controlling access across a number of memory arrays and/or for providing a translation layer between an external host and the solid state drive 620. Thus, a memory controller could selectively couple an I/O connection (not shown in
The circuitry of controller 601 may further include functionality unrelated to control of a memory array, e.g., array 630-1, such as logic functions as might be performed by an ASIC. Also, the circuitry of controller 601 may include circuitry to restrict sensing or programming access to the solid state drive 620, such as password protection, biometrics or the like. The circuitry of controller 601 may include circuitry to indicate a status of the solid state drive 620. For example, the circuitry of controller 601 may include functionality to determine whether power is being supplied to the solid state drive 620 and whether the solid state drive 620 is currently being accessed, and to display an indication of its status, such as a solid light while powered and a flashing light while being accessed. The circuitry of controller 601 may further include passive devices, such as decoupling capacitors to help regulate power requirements within the solid state drive 620.
Embodiments of the present disclosure can include a number of solid state memory arrays 630-1, . . . , 630-N. The solid state memory arrays 630-1, . . . , 630-N can be various types of volatile and/or non-volatile memory arrays (e.g., Flash or DRAM arrays, among others). Memory arrays 630-1, . . . 630-N can include a number of memory cells that can be grouped in logical units such as a number of individual or stacked dice.
In one or more embodiments, the solid state drive can implement wear leveling to control the wear rate on the memory arrays 630-1, . . . , 630-N. As one of ordinary skill in the art will appreciate, wear leveling can increase the life of a solid state memory array since a solid state memory array can experience failure after a number of program and/or erase cycles.
In various embodiments, wear leveling can include dynamic wear leveling to minimize the amount of valid blocks moved to reclaim a block. Dynamic wear leveling can include a technique called garbage collection in which blocks with a number of invalid pages (i.e., pages with data that has been re-written to a different page and/or is no longer needed on the invalid pages) are reclaimed by erasing the block. Static wear leveling includes writing static data to blocks that have high erase counts to prolong the life of the block.
In some embodiments, a number of blocks can be designated as spare blocks to reduce the amount of write amplification associated with writing data in the memory array. A spare block can be a block in a memory array that can be designated as a block where data can not be written. Write amplification is a process that occurs when writing data to solid state memory arrays. When randomly writing data in a memory array, the memory array scans for free space in the array. Free space in a memory array can be individual cells, pages, and/or blocks of memory cells that are not programmed. If there is enough free space to write the data, then the data is written to the free space in the memory array. If there is not enough free space in one location, the data in the memory array is rearranged by erasing, moving, and rewriting the data that is already present in the memory array to a new location leaving free space for the new data that is to be written in the memory array. The rearranging of old data in the memory array is called write amplification because the amount of writing the memory arrays has to do in order to write new data is amplified based upon the amount of free space in the memory array and the size of the new data that is to be written on the memory array. Write amplification can be reduced by increasing the amount of space on a memory array that is designated as free space (i.e., where static data will not be written), thus allowing for less amplification of the amount of data that has to be written because less data will have to be rearranged.
In various embodiments, host and/or user traffic and/or program/erase cycles performed by the solid state drive can be monitored, in addition to wear leveling in the solid state drive, to improve performance of the solid state drive. Host and/or user traffic requests can be made by the processor through the controller to read data and/or erase/write data on the solid state drive. Program and/or erase cycles can be monitored to determine the wear rate and life expectancy of the blocks and/or pages in the solid state memory arrays, as a solid state memory arrays can only be erased and written to a finite number of time. Host and/or user traffic trends can be monitored and altered to allow the drive to perform for a desired operational life (e.g., a time period such as hours, days, weeks, years, etc). The solid state drive can monitor and limit the number of program and/or erase cycles performed by the solid state drive, such as to ensure a desired operational life of the drive. The solid state drive can also monitor the number of program and/or erase cycles performed over a particular time period to determine how to calculate the allowable program and/or erase cycle rate for the drive given the a number of space blocks and the desired operational life of the drive.
In addition, in some embodiments, the number of spare blocks in the solid state memory arrays of the solid state drive can be controlled to ensure operability over a desired operational life for a desired number of write IOPs per unit time. The percentage of spare blocks can be optimized for the type of data that is being programmed on the solid state drive. A solid state drive that has static data (i.e., data that is stored on the drive for long periods of time without be erased and/or rewritten) can have a lower percentage of spare blocks because there is less need to reclaim blocks in the drive due to the static nature of the data having fewer program and/or erase cycles. In a solid state drive that has dynamic data (i.e., data that is programmed and/or erased more frequently) a higher percentage of spare blocks can be used to reduce the write amplification associated with having to reclaim blocks to perform program and/or erase cycles in the memory array.
In one or more embodiments, memory module 793 will include a housing 794 (as depicted) to enclose one or more memory devices 720, though such a housing is not essential to all devices or device applications. At least one memory device 720 includes an array of non-volatile multilevel memory cells. Where present, the housing 794 includes one or more contacts 796 for communication with a host device. Examples of host devices include digital cameras, digital recording and playback devices, PDAs, personal computers, memory card readers, interface hubs and the like. For one or more embodiments, the contacts 796 are in the form of a standardized interface. For example, with a USB flash drive, the contacts 796 might be in the form of a USB Type-A male connector. For one or more embodiments, the contacts 796 are in the form of a semi-proprietary interface, such as might be found on CompactFlash™ memory cards licensed by SanDisk Corporation, Memory Stick™ memory cards licensed by Sony Corporation, SD Secure Digital™ memory cards licensed by Toshiba Corporation and the like. In general, however, contacts 796 provide an interface for passing control, address and/or data signals between the memory module 793 and a host having compatible receptors for the contacts 796.
The memory module 793 may optionally include additional circuitry 797, which may be one or more integrated circuits and/or discrete components. For one or more embodiments, the additional circuitry 797 may include control circuitry, such as a memory controller, for controlling access across multiple memory devices 720 and/or for providing a translation layer between an external host and a memory device 720. For example, there may not be a one-to-one correspondence between the number of contacts 796 and a number of connections to the one or more memory devices 720. Thus, a memory controller could selectively couple an I/O connection (not shown in
The additional circuitry 797 may further include functionality unrelated to control of a memory device 720 such as logic functions as might be performed by an ASIC. Also, the additional circuitry 797 may include circuitry to restrict read or write access to the memory module 793, such as password protection, biometrics or the like. The additional circuitry 797 may include circuitry to indicate a status of the memory module 793. For example, the additional circuitry 797 may include functionality to determine whether power is being supplied to the memory module 793 and whether the memory module 793 is currently being accessed, and to display an indication of its status, such as a solid light while powered and a flashing light while being accessed. The additional circuitry 797 may further include passive devices, such as decoupling capacitors to help regulate power requirements within the memory module 793.
The present disclosure includes methods and devices for logical unit operation. One device embodiment includes a number of logical units, wherein each of the number of logical units has a unique address. The device includes control circuitry coupled to the number of logical units and configured optionally to control more than one of the number of logical units with one of a number of commands and one address.
Although specific embodiments have been illustrated and described herein, those of ordinary skill in the art will appreciate that an arrangement calculated to achieve the same results can be substituted for the specific embodiments shown. This disclosure is intended to cover adaptations or variations of one or more embodiments of the present disclosure. It is to be understood that the above description has been made in an illustrative fashion, and not a restrictive one. Combination of the above embodiments, and other embodiments not specifically described herein will be apparent to those of skill in the art upon reviewing the above description. The scope of the one or more embodiments of the present disclosure includes other applications in which the above structures and methods are used. Therefore, the scope of one or more embodiments of the present disclosure should be determined with reference to the appended claims, along with the full range of equivalents to which such claims are entitled.
In the foregoing Detailed Description, some features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the disclosed embodiments of the present disclosure have to use more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment.
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
4342079, | May 15 1979 | Nortel Networks Limited | Duplicated memory system having status indication |
4965717, | Dec 13 1988 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Multiple processor system having shared memory with private-write capability |
5134584, | Jul 22 1988 | CYPRESS SEMICONDUCTOR MINNESOTA INC | Reconfigurable memory |
5887270, | Nov 21 1995 | EMC Corporation | Fault tolerant controller system and method |
6256702, | Sep 18 1997 | TESSERA ADVANCED TECHNOLOGIES, INC | Nonvolatile memory device with extended storage and high reliability through writing the same data into two memory cells |
6266273, | Aug 21 2000 | SanDisk Technologies LLC | Method and structure for reliable data copy operation for non-volatile memories |
6748482, | Sep 27 2000 | BEIJING XIAOMI MOBILE SOFTWARE CO , LTD | Multiple non-contiguous block erase in flash memory |
6813212, | Dec 11 2000 | Renesas Electronics Corporation | Semiconductor memory device and refresh control circuit |
6877076, | Sep 20 2000 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Memory controller with programmable configuration |
20030012055, | |||
20030086295, | |||
20040095838, | |||
20050010725, | |||
20050144357, | |||
20050289313, | |||
20070168624, | |||
20070279988, | |||
20070283079, | |||
20080082741, | |||
20080113525, | |||
20080189478, | |||
20080320214, | |||
20090037652, | |||
20090089492, | |||
20090307389, | |||
20100030946, | |||
CN101067969, | |||
JP20030140963, | |||
JP57152600, | |||
JP6175929, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Feb 28 2014 | Micron Technology, Inc. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Date | Maintenance Schedule |
Jun 09 2018 | 4 years fee payment window open |
Dec 09 2018 | 6 months grace period start (w surcharge) |
Jun 09 2019 | patent expiry (for year 4) |
Jun 09 2021 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jun 09 2022 | 8 years fee payment window open |
Dec 09 2022 | 6 months grace period start (w surcharge) |
Jun 09 2023 | patent expiry (for year 8) |
Jun 09 2025 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jun 09 2026 | 12 years fee payment window open |
Dec 09 2026 | 6 months grace period start (w surcharge) |
Jun 09 2027 | patent expiry (for year 12) |
Jun 09 2029 | 2 years to revive unintentionally abandoned end. (for year 12) |