(1) Technical Field
The present invention relates to computer storage systems, such as data storage devices that use data recovery.
(2) Description of Related Art
Typically, a storage system experiencing power failure at the middle of a process either acquires corrupted data or loses the data in a worst case scenario. The usual technique of easy data recovery is that upon data modification, the controls and directories associated to the data are also updated. This type of technique consumes relatively larger time and bandwidth. Consequently, there is a need for efficient power cycle sequences capable of data recovery.
The directory structure of a hybrid storage system is very hierarchical. This structure includes controls and directories arranged in a linked list manner. Constant updates of these directories are not only very time and bandwidth consuming but moreover, update synchronization is difficult considering the different directory levels that are contained in different memory blocks. Consequently, there is a need for sequences that are sufficiently adaptive to determine when these directories need to be updated and when the directories require no updates, thereby minimizing directory updates.
Normally, the control information is contained in the control blocks alone. Putting the controls in one block allows rebuilding of all directory structures, and this rebuilding even includes the rebuilding of unrelated information. This results in the wasting of time and bandwidth during the rebuilding process. Consequently, there is a need to achieve an improved and more efficient rebuilding of control data that has been corrupted.
The present invention relates to an apparatus, method, and/or sequence that adaptively provide the recovery of data after a power cycle sequence, wherein only minimal updates are provided for control blocks associated with the data.
A power outage without notification can cause data corruption and/or data loss in storage systems. An example of such causes of data corruption is when at the middle of a system update process, an unexpected power failure occurs.
Embodiments of the invention further provide an apparatus, methods, and/or sequences which minimize data corruption and/or loss, and can recover the aforementioned corrupted and/or lost data by utilizing (i) data relocation, (ii) preventive safe sequence of data updates, and (iii) power cycle recovery sequence.
An embodiment of the invention advantageously separates some of the necessary information and places these necessary information in the data sections, so that only the corrupted control blocks related to the corrupted data are re-built.
In one embodiment of the invention, a method for data relocation includes: providing a free section in a free list block; obtaining an old physical block address (PBA) of an associated LBA of a used section that is currently storing old data; setting the old PBA of the used section equal to a displaced PBA of the free section; writing new data for the used section into the free section; and erasing the used section and changing the used section into a new free section. Another embodiment of the invention also provides an apparatus that can be configured to perform at least some of the above functionalities.
In another embodiment of the invention, a method for a power cycle recovery sequence, includes: providing, in a cache, a free list block comprising free list entries pointing to sections in a memory in a system; scanning the free list block to determine if each used free section is dirty, wherein a used free section that is dirty will require an update of a directory (DirBlk) and information directory block (BlkInfoDirBlk) that are associated with the used free section, and wherein each used free section stores user data; if a used free section is dirty, then performing a power cycle recovery sequence of the information directory block (BlkInfoDirBlk) and performing a power cycle recovery sequence of the directory (DirBlk); scanning each free section that is pointed by each free list entry; and if a free section is free, then performing a power cycle recovery sequence for the information directory block (BlkInfoDirBlk), and if the free section is not free, then erasing the free section. Another embodiment of the invention also provides an apparatus that can be configured to perform at least some of the above functionalities.
In another embodiment of the invention, a method of data relocation, includes: writing a new data to a free section, wherein the new data is for replacing old data in a current used section and wherein the new data includes a physical block address of the used section; determining if the new data in the free section is valid; if the new data is valid, converting the free section into the next used section with the physical block address of the current used section; and erasing the old data and converting the current used section into another free section. Another embodiment of the invention also provides an apparatus that can be configured to perform at least some of the above functionalities.
In another embodiment of the invention, a method for data recovery includes: in a power cycle recovery sequence, providing a minimal update for control blocks associated with data to be recovered. Another embodiment of the invention also provides an apparatus that can be configured to perform at least some of the above functionalities.
The above and additional advantages of the present invention will become apparent to those skilled in the art from a reading of the following detailed description when taken in conjunction with the accompanying drawings.
In the following detailed description, for purposes of explanation, numerous specific details are set forth to provide a thorough understanding of the various embodiments of the present invention. Those of ordinary skill in the art will realize that these various embodiments of the present invention are illustrative only and are not intended to be limiting in any way. Other embodiments of the present invention will readily suggest themselves to such skilled persons having the benefit of this disclosure.
In addition, for clarity purposes, not all of the routine features of the embodiments described herein are shown or described. One of ordinary skill in the art would readily appreciate that in the development of any such actual implementation, numerous implementation-specific decisions may be required to achieve specific design objectives. These design objectives will vary from one implementation to another and from one developer to another. Moreover, it will be appreciated that such a development effort might be complex and time-consuming but would nevertheless be a routine engineering undertaking for those of ordinary skill in the art having the benefit of this disclosure.
A power outage without notification can cause data corruption and/or data loss in storage systems. Usually this problem is solved by an immediate update of control blocks associated with the modified data. However, this solution is time and bandwidth consuming especially in cases when the data is frequently overwritten. As will be discussed below, embodiments of the invention provide adaptive sequences or methods capable of data recovery after a power cycle sequence and involving only minimal updates of control blocks associated to the modified data.
For small end storage system, the directory structure is less complex compared to that in the hybrid storage system.
In comparison with that of the directory structure in
The free list block physical block address (FreeLstBlkOPBA) 203 holds the physical block address (PBA) of the free list block 0 (FreeLstBlk0) 204 which is the first memory block in the chain holding the list of all non-volatile memory blocks with free sections in the system. In
The details of the FreeLstBlk structure (e.g., FreeLstBlk0204) are also shown in
The DirBlk 202 structure holds the array of directory entries 210 for a plurality of used data sections 211. In the example of
The control block 201 also contains a pointer that point to an information directory block (BlkInfoDirBlk) 216. This information directory block (BlkInfoDirBlk) 216 holds the array of information entries (BlkInfoDirEntry) 217 for all the non-volatile memory blocks present in the whole system. Each entry (BlkInfoDirEntry) holds an invalid bit map (InvalidBitMap) 218 that flags whether a data section is invalid or not. A data section is in its invalid state if it is not associated to any LBA but has to be erased first before the data section can be associated with an LBA. The DataSections can be in a single non-volatile memory Blk 220 (as shown in
The importance of separating the information describing the status of the DirBlk (i.e., the presence of BlkInfoDirBlk) allows the separation of updates for each block. This separation advantageously minimizes the unwanted updates for unnecessary data, as will be discussed below, in accordance with one or more embodiments of the invention.
For the directory structure of
Reference is now made to
Each FreeLstBlk contains an index (I) 501 (
The system further verifies if the particular used free section (associated with one of the used free list entries 0 through 11) is actually free (pre-erased or clean) in task 402. If the particular used free section is dirty (not clean or not pre-erased) in task 403, this means that the BlkInfoDirBlk (information directory block) and the DirBlk (directory block) saved in the non-volatile memory associated to that particular used free section (also in the non-volatile memory) needs to be updated because that particular used section is dirty (i.e., contains user data). This update is performed in Task 404 and Task 405. Task 404 illustrates the power cycle recovery sequence for updating the BlkInfoDirBlk and is shown in additional details in
Task 414 checks for the next free list entry among the candidates for removal, and the tasks 401 through 405 are repeated in loop 412 for the next free list entry among the candidates for removal until the last free list entry that is a candidate for removal has been processed by the tasks that start at task 401.
After the last free list entry that is a candidate for removal (from free list block 500) has been processed by the tasks that starts at task 401 (or if a particular used free section is clean in task 403), then the sequence proceeds to the tasks in
As mentioned above, the Tasks 401 to 405 in
Reference is now again made to
In task 407, the system verifies if an aforementioned free section 504 is indeed clean (erased). In task 408, if the aforementioned free section 504 is clean, the system again executes the power cycle recovery sequence for the BlkInfoDirBlk (of
If, in task 408, the aforementioned free section 504 is not clean (i.e., is dirty), then the system erases the aforementioned free section 504 in task 409 so that the free section 504 is clean in non-volatile memory.
Reference is now made to both
As stated above, if the used free section is dirty Task 403, then the information directory block (BlkInfoDirBlk) saved in non-volatile memory associated with that used free section is updated or is verified as updated with the Task 410 shown in
The InvalidBitMap flag 603 is associated with the aforementioned used free section 604 and is in the BlkInfoDirEntry. The system then checks, in task 602, if the InvalidBitMap flag 603 is not set because the aforementioned used free section 604 is in its used state. If the InvalidBitMap flag 603 is not in same state with that of the aforementioned used free section 604, the InvalidBitMap flag 603 is set (updated) to “0” in task 605, so that the flag 603 is updated to the current state which is the used state. The system then exits this process and returns to the main program of
Then in task 704, the system checks if the User Data 705 (of the used free section 604) is error free (valid). If the user data 705 turns out to be invalid, the system exits this process and returns to the main program in
An invalid user data 705 indicates that the writing of the user data (into the used free section 604) was not yet finished when system power interruption occurred, and as a result the DirBlk associated with the used free section 604 is not updated. Otherwise, the system makes available the DirBlk associated to the aforementioned used free section 604 in cache, as shown in task 706.
In task 707, the system looks (searches) for the DirEntry 708 which is associated with the used free section 604. The system then reads the Pba 709 of the DirEntry 708. In task 710, the system checks whether the Pba 709 is matched with the associated Pba of the Lba 701 of the used free section 604. If the above physical block addresses (Pbas) are matched, this means that the DirBlk (associated with the used free section 604) in the non-volatile memory is already updated and the system exits this process and returns to the main program in
Referring now to
The second case (case2) 903 is another possible case during the system's traversing of the sections as indicated in reference block 911. In the second case (Case2) 903, the section pointed to by the FreeLstEntry 905 is not equal to the section pointed to by the DirEntry 904 and is newer than the section pointed to by the DirEntry 904. For this case 903, the DirBlk requires an update.
The third case (case3) 906 is another possible case during the system's traversing of the sections as indicated in reference block 912. In the third case (Case3) 906, the section pointed to by the FreeLstEntry 907 is invalid (i.e., the section S1 pointed to by the DirEntry 908 is newer than the section S2 pointed to by the FreeLstEntry 907). For this case 906, the BlkInfoDirBlk needs an update. For example, the section S1's InvalidBitMap 218 (
Reference is now made to both
In task 805, the system evaluates if this DisplacedPba (which the system had obtained via traversal to the previous section in non-volatile memory and had saved in CurrDisplacedPba) is equal to the Pba in the DirEntry. If in task 805, the CurrDisplacedPba is equal to the PBA from the DirEntry, then the DirBlk 904 needs to be updated in accordance with case2903 (
When the free list 902 (
When the free list 905 (
When the free list 907 (
The system loops back from task 808 to task 804 if, in task 808, the compare LBA is equal to the LBA from the section pointed by the CurrDisplacedPba. The system performs this loop until the criteria in task 805 or task 808 is satisfied.
After the system performs the above tasks 713 and 714, the system then exits this process in
After the process illustrated in
Typically, every time the control blocks in cache become dirty, the control blocks stored in non-volatile memory are also updated. However, for very hierarchical directory structures, constant updates are inefficient as discussed above. Consequently, an embodiment of the present invention implements the following thresholds and background tasks that allow the sequences to be sufficiently adaptive to determine when these directories need to be updated, thereby minimizing directory updates. Background tasks preferably occur when the system is, for example, idle.
In the discussion below and in other parts of this disclosure, the term “cache” can also mean other suitable types of volatile memory. Table 1 illustrates an example threshold for the FreeLstBlk update. The FreeLstBlk 500 (
Similarly, if the BlkInfoDirBlk is fully cached, condition [2] of Table 2 is not performed; otherwise, an update of BlkInfoDirBlk in non-volatile is performed. Otherwise stated, in condition [2], the BlkInfoDirBlk saved in the non-volatile memory is updated when there is a lack of free BlkInfoDirBlk in the cache. A cache coherency algorithm program, as known to those skilled in the art, can be used to perform the functions as stated in condition [2].
The BlkInfoDirBlk in cache is also updated in the non-volatile memory when the FreeLstBlk is updated of which the BlkInfoDirBlk is dependent as stated in condition [1].
The BlkInfoDirBlk is also updated in the non-volatile memory when condition [3] is satisfied, where a threshold value (e.g., approximate 75%) of the BlkInfoDirBlk in the cache is dirty. This update of the BlkInfoDirBlk in the non-volatile memory is preferably only performed in, e.g., the background task.
Similarly, if the DirBlk is fully cached, condition [2] of Table 2 is not performed; otherwise, an update of DirBlk in non-volatile memory is performed. The DirBlk in cache is updated in non-volatile memory when the FreeLstBlk is updated of which the DirBlk is dependent as stated in condition [1]. The DirBlk is also updated when condition [3] is satisfied.
Reference is now made to both
Additionally, in Task 1000, the BlkInfoDirBlk and the DirBlk can be recovered during initialization of system in
Reference is now made to
In task 1302, the system then obtains the old PBA of the associated LBA of the previous section 1201 (shown as user section 1201 in
Note further that tasks 1300, 1301, 1302, 1303, and 1304 use information in the control blocks of the old data 1201 in order to perform the operations associated with these tasks. The information needed in old data 1201 is the Lba and the DisplacedPba.
In process 1215, after assuring that all new data 1202 has been written to free section 1200, the old used section 1201 can now be erased and marked as a new free section 1203 and now ready to carry new data (i.e., the system modifies the PBA of the DirEntry to the new given free section's PBA in task 1305; and in task 1306, the system also sets the InvaldiBitMap of the BlkInfoDirBlk of the old section to invalid). As long as a section has never been marked as free in the event of power failure, this old data will still be valid. The conversion of old sections to free sections is performed in one action so that when power fails, all sections are synchronized as either old or new. In the event of power failure occurring during this data relocation process, the redundant data recovery method is executed. Data recovery is performed during start-up in which the system will first read the content of the free sections one by one to determine whether it contains a valid data. If a free section contains a valid data it will be marked as a used section 1204.
Note that in task 1305, the DirBlk (in cache) will be recovered during the system initialization and the free list detects the free section as not actually free as shown in
In task 1306, the BlkInfoDirBlk (in cache) will be recovered during the system initialization and the free list detects the free section as not actually free and contains a displaced Pba as shown in
Typically, the storage device 1400 is coupled to a host 1402 through a peripheral interface 1404, such as SCSI, Fibre Channel, ATA, IDE, and/or the like, permitting the host 1402 to perform storage operations on the storage device 1400, such as write and read operations. The storage device 1400 is shown having a Memory A 1406, a Memory B 1408, a system bus, a memory bus, a local processor 1418 and associated circuitry. In addition, a Processor Circuit 1424, a Local Processor Memory 1422, a ROM 1420, and their general interaction with the storage device 1400 appear in the block diagram but are not described to avoid overcomplicating the herein disclosure. Additionally, some of the elements or components in the storage device 1400 can be varied or substituted in a manner that would achieve the functions or operations described herein.
In one embodiment, the Memory A 1406 typically includes at least one bank of NAND Flash memory 1410 and a flash memory buffer circuit 1412, which is coupled to a memory controller 1414, such as, for example, a DMA controller. The Memory A 1406 is intended for use as the primary storage memory of the device 1400 and more than one set may be used to increase capacity and/or performance. In the previous discussion above, the memory 1410 is referred to as a non-volatile memory. As one example, this non-volatile memory that forms the memory 1410 is a flashchip, although this non-volatile memory may be other suitable types of memory devices. In one embodiment, one DMA controller is used for every set implemented.
The Memory B 1408 typically includes a DRAM (or its equivalents, such as SDRAM, RDRAM, etc.) and is used as a read/write (“storage”) cache to Memory A 1406. In the previous discussion above, the Memory B 1408 is a volatile memory such as, for example, a cache as also referred to in the previous discussion above. The Memory B 1408 can also be other suitable types of volatile memory. The Memory B 1408 is controlled by at least one DMA memory controller (not shown) although more than one controller may be used to increase performance. Two DMA controllers (not shown) are used and provided using the local processor, which is, for example, a RISC processor having two embedded DMA controllers or other suitable processors.
The conduit between the peripheral interface 1404 is a simplified representation of a peripheral bus 1430 and may include switches, routers, and network devices but are not shown to avoid complicating the herein disclosure. For example, if the peripheral interface 1430 is implemented using a fibre channel interface, then at least one port provided by a switch would be part of the conduit between the peripheral interface and the host.
It is also within the scope of the present invention to implement a program or code that can be stored in a machine-readable or computer-readable medium to permit a computer to perform any of the inventive techniques described above, or a program or code that can be stored in an article of manufacture that includes a computer readable medium on which computer-readable instructions for carrying out embodiments of the inventive techniques are stored. Other variations and modifications of the above-described embodiments and methods are possible in light of the teaching discussed herein.
The above description of illustrated embodiments of the invention, including what is described in the Abstract, is not intended to be exhaustive or to limit the invention to the precise forms disclosed. While specific embodiments of, and examples for, the invention are described herein for illustrative purposes, various equivalent modifications are possible within the scope of the invention, as those skilled in the relevant art will recognize.
These modifications can be made to the invention in light of the above detailed description. The terms used in the following claims should not be construed to limit the invention to the specific embodiments disclosed in the specification and the claims. Rather, the scope of the invention is to be determined entirely by the following claims, which are to be construed in accordance with established doctrines of claim interpretation.
Number | Name | Date | Kind |
---|---|---|---|
4752871 | Sparks | Jun 1988 | A |
5111058 | Martin | May 1992 | A |
RE34100 | Hartness | Oct 1992 | E |
5222046 | Kreifels et al. | Jun 1993 | A |
5297148 | Harari et al. | Mar 1994 | A |
5341339 | Wells | Aug 1994 | A |
5371709 | Fisher et al. | Dec 1994 | A |
5379401 | Robinson et al. | Jan 1995 | A |
5388083 | Assar et al. | Feb 1995 | A |
5396468 | Harari et al. | Mar 1995 | A |
5406529 | Asano | Apr 1995 | A |
5432748 | Hsu et al. | Jul 1995 | A |
5448577 | Wells et al. | Sep 1995 | A |
5459850 | Clay et al. | Oct 1995 | A |
5479638 | Assar et al. | Dec 1995 | A |
5485595 | Assar et al. | Jan 1996 | A |
5488711 | Hewitt et al. | Jan 1996 | A |
5500826 | Hsu et al. | Mar 1996 | A |
5509134 | Fandrich et al. | Apr 1996 | A |
5513138 | Manabe et al. | Apr 1996 | A |
5524231 | Brown | Jun 1996 | A |
5530828 | Kaki et al. | Jun 1996 | A |
5535328 | Harari et al. | Jul 1996 | A |
5535356 | Kim et al. | Jul 1996 | A |
5542042 | Manson | Jul 1996 | A |
5542082 | Solhjell | Jul 1996 | A |
5548741 | Watanabe | Aug 1996 | A |
5559956 | Sukegawa | Sep 1996 | A |
5568423 | Jou et al. | Oct 1996 | A |
5568439 | Harari | Oct 1996 | A |
5572466 | Sukegawa | Nov 1996 | A |
5594883 | Pricer | Jan 1997 | A |
5602987 | Harari et al. | Feb 1997 | A |
5603001 | Sukegawa et al. | Feb 1997 | A |
5606529 | Honma et al. | Feb 1997 | A |
5606532 | Lambrache et al. | Feb 1997 | A |
5619470 | Fukumoto | Apr 1997 | A |
5627783 | Miyauchi | May 1997 | A |
5640349 | Kakinuma et al. | Jun 1997 | A |
5644784 | Peek | Jul 1997 | A |
5682509 | Kabenjian | Oct 1997 | A |
5737742 | Achiwa et al. | Apr 1998 | A |
5787466 | Berliner | Jul 1998 | A |
5796182 | Martin | Aug 1998 | A |
5799200 | Brant et al. | Aug 1998 | A |
5802554 | Caceres et al. | Sep 1998 | A |
5819307 | Iwamoto et al. | Oct 1998 | A |
5822251 | Bruce et al. | Oct 1998 | A |
5875351 | Riley | Feb 1999 | A |
5881264 | Kurosawa | Mar 1999 | A |
5913215 | Rubinstein et al. | Jun 1999 | A |
5918033 | Heeb et al. | Jun 1999 | A |
5943421 | Grabon | Aug 1999 | A |
5956743 | Bruce et al. | Sep 1999 | A |
6000006 | Bruce et al. | Dec 1999 | A |
6014709 | Gulick et al. | Jan 2000 | A |
6076137 | Asnaashari | Jun 2000 | A |
6098119 | Surugucchi et al. | Aug 2000 | A |
6128303 | Bergantino | Oct 2000 | A |
6215875 | Nohda | Apr 2001 | B1 |
6230269 | Spies et al. | May 2001 | B1 |
6298071 | Taylor et al. | Oct 2001 | B1 |
6363441 | Bentz et al. | Mar 2002 | B1 |
6363444 | Platko et al. | Mar 2002 | B1 |
6397267 | Chong, Jr. | May 2002 | B1 |
6404772 | Beach et al. | Jun 2002 | B1 |
6496939 | Portman et al. | Dec 2002 | B2 |
6526506 | Lewis | Feb 2003 | B1 |
6529416 | Bruce et al. | Mar 2003 | B2 |
6557095 | Henstrom | Apr 2003 | B1 |
6678754 | Soulier | Jan 2004 | B1 |
6744635 | Portman et al. | Jun 2004 | B2 |
6757845 | Bruce | Jun 2004 | B2 |
6857076 | Klein | Feb 2005 | B1 |
6901499 | Aasheim et al. | May 2005 | B2 |
6922391 | King et al. | Jul 2005 | B1 |
6961805 | Lakhani et al. | Nov 2005 | B2 |
6970446 | Krischer et al. | Nov 2005 | B2 |
6970890 | Bruce et al. | Nov 2005 | B1 |
6980795 | Hermann et al. | Dec 2005 | B1 |
7103684 | Chen et al. | Sep 2006 | B2 |
7174438 | Homma et al. | Feb 2007 | B2 |
7194766 | Noehring et al. | Mar 2007 | B2 |
7263006 | Aritome | Aug 2007 | B2 |
7283629 | Kaler et al. | Oct 2007 | B2 |
7305548 | Pierce et al. | Dec 2007 | B2 |
7330954 | Nangle | Feb 2008 | B2 |
7372962 | Fujimoto et al. | May 2008 | B2 |
7386662 | Kekre et al. | Jun 2008 | B1 |
7415549 | Vemula et al. | Aug 2008 | B2 |
7424553 | Borrelli et al. | Sep 2008 | B1 |
7430650 | Ross | Sep 2008 | B1 |
7490177 | Kao | Feb 2009 | B2 |
7500063 | Zohar et al. | Mar 2009 | B2 |
7506098 | Arcedera et al. | Mar 2009 | B2 |
7613876 | Bruce et al. | Nov 2009 | B2 |
7620748 | Bruce et al. | Nov 2009 | B1 |
7624239 | Bennett et al. | Nov 2009 | B2 |
7636801 | Kekre et al. | Dec 2009 | B1 |
7660941 | Lee et al. | Feb 2010 | B2 |
7676640 | Chow | Mar 2010 | B2 |
7681188 | Tirumalai et al. | Mar 2010 | B1 |
7716389 | Bruce et al. | May 2010 | B1 |
7729370 | Orcine et al. | Jun 2010 | B1 |
7743202 | Tsai et al. | Jun 2010 | B2 |
7765359 | Kang et al. | Jul 2010 | B2 |
7877639 | Hoang | Jan 2011 | B2 |
7913073 | Choi | Mar 2011 | B2 |
7921237 | Holland et al. | Apr 2011 | B1 |
7934052 | Prins et al. | Apr 2011 | B2 |
8010740 | Arcedera et al. | Aug 2011 | B2 |
8032700 | Bruce et al. | Oct 2011 | B2 |
8156320 | Borras | Apr 2012 | B2 |
8161223 | Chamseddine et al. | Apr 2012 | B1 |
8165301 | Bruce et al. | Apr 2012 | B1 |
8200879 | Falik et al. | Jun 2012 | B1 |
8341311 | Szewerenko et al. | Dec 2012 | B1 |
8375257 | Hong et al. | Feb 2013 | B2 |
8447908 | Bruce et al. | May 2013 | B2 |
8510631 | Wu et al. | Aug 2013 | B2 |
8560804 | Bruce et al. | Oct 2013 | B2 |
8707134 | Takahashi et al. | Apr 2014 | B2 |
8713417 | Jo | Apr 2014 | B2 |
8788725 | Bruce et al. | Jul 2014 | B2 |
8959307 | Bruce et al. | Feb 2015 | B1 |
9043669 | Bruce et al. | May 2015 | B1 |
9099187 | Bruce et al. | Aug 2015 | B2 |
9135190 | Bruce et al. | Sep 2015 | B1 |
9147500 | Kim et al. | Sep 2015 | B2 |
20010010066 | Chin et al. | Jul 2001 | A1 |
20020044486 | Chan et al. | Apr 2002 | A1 |
20020073324 | Hsu et al. | Jun 2002 | A1 |
20020083262 | Fukuzumi | Jun 2002 | A1 |
20020083264 | Coulson | Jun 2002 | A1 |
20020141244 | Bruce et al. | Oct 2002 | A1 |
20030023817 | Rowlands et al. | Jan 2003 | A1 |
20030065836 | Pecone | Apr 2003 | A1 |
20030120864 | Lee et al. | Jun 2003 | A1 |
20030131201 | Khare et al. | Jul 2003 | A1 |
20030163624 | Matsui et al. | Aug 2003 | A1 |
20030163647 | Cameron et al. | Aug 2003 | A1 |
20030163649 | Kapur et al. | Aug 2003 | A1 |
20030182576 | Morlang et al. | Sep 2003 | A1 |
20030204675 | Dover et al. | Oct 2003 | A1 |
20030223585 | Tardo et al. | Dec 2003 | A1 |
20040073721 | Goff et al. | Apr 2004 | A1 |
20040128553 | Buer et al. | Jul 2004 | A1 |
20050050245 | Miller et al. | Mar 2005 | A1 |
20050120146 | Chen et al. | Jun 2005 | A1 |
20050210149 | Kimball | Sep 2005 | A1 |
20050243610 | Guha et al. | Nov 2005 | A1 |
20050289361 | Sutardja | Dec 2005 | A1 |
20060004957 | Hand, III et al. | Jan 2006 | A1 |
20060031450 | Unrau et al. | Feb 2006 | A1 |
20060095709 | Achiwa | May 2006 | A1 |
20060112251 | Karr et al. | May 2006 | A1 |
20060184723 | Sinclair et al. | Aug 2006 | A1 |
20070019573 | Nishimura | Jan 2007 | A1 |
20070028040 | Sinclair | Feb 2007 | A1 |
20070058478 | Murayama | Mar 2007 | A1 |
20070073922 | Go et al. | Mar 2007 | A1 |
20070083680 | King et al. | Apr 2007 | A1 |
20070088864 | Foster | Apr 2007 | A1 |
20070094450 | VanderWiel | Apr 2007 | A1 |
20070096785 | Maeda | May 2007 | A1 |
20070121499 | Pal et al. | May 2007 | A1 |
20070130439 | Andersson et al. | Jun 2007 | A1 |
20070159885 | Gorobets | Jul 2007 | A1 |
20070168754 | Zohar et al. | Jul 2007 | A1 |
20070174493 | Irish et al. | Jul 2007 | A1 |
20070174506 | Tsuruta | Jul 2007 | A1 |
20070195957 | Arulambalam et al. | Aug 2007 | A1 |
20070288686 | Arcedera et al. | Dec 2007 | A1 |
20070288692 | Bruce et al. | Dec 2007 | A1 |
20080052456 | Ash et al. | Feb 2008 | A1 |
20080072031 | Choi | Mar 2008 | A1 |
20080147963 | Tsai et al. | Jun 2008 | A1 |
20080189466 | Hemmi | Aug 2008 | A1 |
20080218230 | Shim | Sep 2008 | A1 |
20080228959 | Wang | Sep 2008 | A1 |
20090055573 | Ito | Feb 2009 | A1 |
20090077306 | Arcedera et al. | Mar 2009 | A1 |
20090083022 | Bin Mohd Nordin et al. | Mar 2009 | A1 |
20090094411 | Que | Apr 2009 | A1 |
20090158085 | Kern et al. | Jun 2009 | A1 |
20090172250 | Allen et al. | Jul 2009 | A1 |
20090172466 | Royer et al. | Jul 2009 | A1 |
20090240873 | Yu et al. | Sep 2009 | A1 |
20100058045 | Borras et al. | Mar 2010 | A1 |
20100095053 | Bruce et al. | Apr 2010 | A1 |
20100125695 | Wu et al. | May 2010 | A1 |
20100250806 | Devilla et al. | Sep 2010 | A1 |
20110022778 | Schibilla et al. | Jan 2011 | A1 |
20110022801 | Flynn | Jan 2011 | A1 |
20110087833 | Jones | Apr 2011 | A1 |
20110093648 | Belluomini et al. | Apr 2011 | A1 |
20110113186 | Bruce et al. | May 2011 | A1 |
20110145479 | Talagala et al. | Jun 2011 | A1 |
20110161568 | Bruce et al. | Jun 2011 | A1 |
20110167204 | Estakhri et al. | Jul 2011 | A1 |
20110197011 | Suzuki et al. | Aug 2011 | A1 |
20110202709 | Rychlik | Aug 2011 | A1 |
20110258405 | Asaki et al. | Oct 2011 | A1 |
20110264884 | Kim | Oct 2011 | A1 |
20110264949 | Ikeuchi et al. | Oct 2011 | A1 |
20110270979 | Schlansker et al. | Nov 2011 | A1 |
20120005405 | Wu et al. | Jan 2012 | A1 |
20120005410 | Ikeuchi | Jan 2012 | A1 |
20120017037 | Riddle et al. | Jan 2012 | A1 |
20120102263 | Aswadhati | Apr 2012 | A1 |
20120102268 | Smith et al. | Apr 2012 | A1 |
20120137050 | Wang et al. | May 2012 | A1 |
20120271967 | Hirschman | Oct 2012 | A1 |
20120311197 | Larson et al. | Dec 2012 | A1 |
20130094312 | Jang et al. | Apr 2013 | A1 |
20130099838 | Kim et al. | Apr 2013 | A1 |
20130111135 | Bell, Jr. et al. | May 2013 | A1 |
20130208546 | Kim et al. | Aug 2013 | A1 |
20130212337 | Maruyama | Aug 2013 | A1 |
20130212349 | Maruyama | Aug 2013 | A1 |
20130246694 | Bruce et al. | Sep 2013 | A1 |
20130262750 | Yamasaki et al. | Oct 2013 | A1 |
20130304775 | Davis et al. | Nov 2013 | A1 |
20130339578 | Ohya et al. | Dec 2013 | A1 |
20130339582 | Olbrich et al. | Dec 2013 | A1 |
20130346672 | Sengupta et al. | Dec 2013 | A1 |
20140095803 | Kim et al. | Apr 2014 | A1 |
20140104949 | Bruce et al. | Apr 2014 | A1 |
20140108869 | Brewerton et al. | Apr 2014 | A1 |
20140189203 | Suzuki et al. | Jul 2014 | A1 |
20140258788 | Maruyama | Sep 2014 | A1 |
20140285211 | Raffinan | Sep 2014 | A1 |
20140331034 | Ponce et al. | Nov 2014 | A1 |
20150006766 | Ponce et al. | Jan 2015 | A1 |
20150012690 | Bruce et al. | Jan 2015 | A1 |
20150032937 | Salessi | Jan 2015 | A1 |
20150032938 | Salessi | Jan 2015 | A1 |
20150067243 | Salessi et al. | Mar 2015 | A1 |
20150149697 | Salessi et al. | May 2015 | A1 |
20150149706 | Salessi et al. | May 2015 | A1 |
20150153962 | Salessi et al. | Jun 2015 | A1 |
20150169021 | Salessi et al. | Jun 2015 | A1 |
20150261456 | Alcantara et al. | Sep 2015 | A1 |
20150261475 | Alcantara et al. | Sep 2015 | A1 |
20150261797 | Alcantara et al. | Sep 2015 | A1 |
20150370670 | Lu | Dec 2015 | A1 |
20150371684 | Mataya | Dec 2015 | A1 |
20150378932 | Souri et al. | Dec 2015 | A1 |
20160026402 | Alcantara et al. | Jan 2016 | A1 |
20160027521 | Lu | Jan 2016 | A1 |
20160041596 | Alcantara et al. | Feb 2016 | A1 |
Number | Date | Country |
---|---|---|
2005142859 | Jun 2005 | JP |
2005-309847 | Nov 2005 | JP |
489308 | Jun 2002 | TW |
200428219 | Dec 2004 | TW |
436689 | Dec 2005 | TW |
WO 9406210 | Mar 1994 | WO |
WO 9838568 | Sep 1998 | WO |
Entry |
---|
Office Action for U.S. Appl. No. 13/475,878, mailed on Jun. 23, 2014. |
Office Action for U.S. Appl. No. 12/876,113 mailed on Jul. 11, 2014. |
Office Action for U.S. Appl. No. 13/475,878 mailed on Dec. 4, 2014. |
Office Action for U.S. Appl. No. 12/876,113 mailed on Dec. 5, 2014. |
Notice of Allowability for U.S. Appl. No. 14/038,684 mailed on Dec. 5, 2014. |
Notice of Allowability for U.S. Appl. No. 12/270,626 mailed on Oct. 3, 2014. |
Office Action for U.S. Appl. No. 13/475,878 mailed on Jun. 23, 2014. |
Office Action for U.S. Appl. No. 12/876,113 mailed on Oct. 16, 2014. |
Notice of Allowance for U.S. Appl. No. 12/270,626 mailed Oct. 3, 2014. |
Office Action for U.S. Appl. No. 12/270,626 mailed on May 23, 2014. |
Office Action for U.S. Appl. No. 12/270,626 mailed on Apr. 4, 2011. |
Office Action for U.S. Appl. No. 12/270,626 mailed on Dec. 18, 2013. |
Office Action for U.S. Appl. No. 12/270,626 mailed on Mar. 15, 2013. |
Office Action for U.S. Appl. No. 12/270,626 mailed on Aug. 23, 2012. |
Office Action for U.S. Appl. No. 12/270,626 mailed on Feb. 3, 2012. |
Office Action for U.S. Appl. No. 12/876,113 mailed on Mar. 13, 2014. |
Advisory Action for U.S. Appl. No. 12/876,113 mailed on Sep. 6, 2013. |
Office Action for U.S. Appl. No. 12/876,113 mailed on May 14, 2013. |
Office Action for U.S. Appl. No. 12/876,113 mailed on Dec. 21, 2012. |
Security Comes to SNMP: The New SNMPv3 Proposed Internet Standard, The Internet Protocol Journal, vol. 1, No. 3, Dec. 1998. |
Notice of Allowability for U.S. Appl. No. 12/882,059 mailed on May 30, 2013. |
Notice of Allowability for U.S. Appl. No. 12/882,059 mailed on Feb. 14, 2013. |
Office Action for U.S. Appl. No. 12/882,059 mailed on May 11, 2012. |
Notice of Allowability for U.S. Appl. No. 14/038,684 mailed on Aug. 1, 2014. |
Office Action for U.S. Appl. No. 14/038,684 mailed on Mar. 17, 2014. |
Notice of Allowance/Allowability for U.S. Appl. No. 12/270,626 mailed on Oct. 3, 2014. |
Advisory Action for U.S. Appl. No. 12/876,113 mailed on Oct. 16, 2014. |
Notice of Allowability for U.S. Appl. No. 13/890,229 mailed on Feb. 20, 2014. |
Office Action for U.S. Appl. No. 13/890,229 mailed on Oct. 8, 2013. |
USPTO Notice of Allowability & attachment(s) mailed Jan. 7, 2013 for U.S. Appl. No. 12/876,247. |
Office Action mailed Sep. 14, 2012 for U.S. Appl. No. 12/876,247. |
Office Action mailed Feb. 1, 2012 for U.S. Appl. No. 12/876,247. |
Notice of Allowance/Allowability mailed Mar. 31, 2015 for U.S. Appl. No. 13/475,878. |
Office Action mailed Jul. 17, 2015 for U.S. Appl. No. 14/297,628. |
Notice of Allowance/Allowabilty for U.S. Appl. No. 12/876,113 mailed on Jun. 22, 2015. |
Office Action for U.S. Appl. No. 14/616,700 mailed on Apr. 30, 2015. |
Office Action for U.S. Appl. No. 14/215,414 mailed on Jun. 4, 2015. |
Office Action for U.S. Appl. No. 14/217,467 mailed on Apr. 27, 2015. |
Office Action for U.S. Appl. No. 14/217,436 mailed on Sep. 11, 2015. |
Office Action mailed Sep. 11, 2015 for U.S. Appl. No. 14/217,436. |
Office Action mailed Sep. 24, 2015 for U.S. Appl. No. 14/217,334. |
Office Action dated Sep. 18, 2015 for Taiwanese Patent Application No. 102144165. |
Office Action mailed Sep. 29, 2015 for U.S. Appl. No. 14/217,316. |
Office Action mailed Sep. 28, 2015 for U.S. Appl. No. 14/689,045. |
Office Action mailed Jun. 4, 2015 for U.S. Appl. No. 14/215,414. |
Office Action mailed Oct. 8, 2015 for U.S. Appl. No. 14/217,291. |
Final Office Action mailed Nov. 19, 2015 for U.S. Appl. No. 14/217,249. |
Final Office Action mailed Nov. 18, 2015 for U.S. Appl. No. 14/217,467. |
Office Action mailed Nov. 25, 2015 for U.S. Appl. No. 14/217,041. |
Office Action mailed Oct. 5, 2015 for Taiwanese Application No. 103105076. |
Office Action mailed Nov. 19, 2015 for U.S. Appl. No. 14/217,249. |
Office Action mailed Nov. 18, 2015 for U.S. Appl. No. 14/217,467. |
Office Action mailed Dec. 4, 2015 for U.S. Appl. No. 14/616,700. |
National Science Fountation, Award Abstract #1548968, SBIR Phase I: SSD In-Situ Processing, http://www.nsf.gov/awardsearch/showAward?AWD—ID=1548968 printed on Feb. 13, 2016. |
Design-Reuse, NxGn Data Emerges from Stealth Mode to provide a paradigm shift in enterprise storage solution, http://www.design-reuse.com/news/35111/nxgn-data-intelligent-solutions.html, printed on Feb. 13, 2016. |
Office Action mailed Dec. 17, 2015 for U.S. Appl. No. 14/214,216. |
Office Action mailed Dec. 17, 2015 for U.S. Appl. No. 14/215,414. |
Office Action mailed Dec. 17, 2015 for U.S. Appl. No. 14/803,107. |
Office Action mailed Jan. 15, 2016 for U.S. Appl. No. 14/866,946. |
Office Action mailed Jan. 11, 2016 for U.S. Appl. No. 14/217,399. |
Office Action mailed Jan. 15, 2016 for U.S. Appl. No. 14/216,937. |
Notice of Allowance and Examiner-Initiated Interview Summary, mailed Jan. 29, 2016 for U.S. Appl. No. 14/297,628. |
Office Action for U.S. Appl. No. 14/217,365 dated Feb. 18, 2016. |
Office Action for U.S. Appl. No. 14/217,365 dated Mar. 2, 2016. |
Office Action for U.S. Appl. No. 14/690,305 dated Feb. 25, 2016. |
Office Action for U.S. Appl. No. 14/217,436 dated Feb. 25, 2016. |
Office Action for U.S. Appl. No. 14/217,316 dated Feb. 26, 2016. |
Office Action for U.S. Appl. No. 14/215,414 dated Mar. 1, 2016. |
Office Action for U.S. Appl. No. 14/616,700 dated Mar. 8, 2016. |