The present invention is directed to data storage management. In particular, the present invention is directed to methods and apparatuses for managing snapshot data.
The need to store digital files, documents, pictures, images and other data continues to increase rapidly. In connection with the electronic storage of data, various data storage systems have been devised for the rapid and secure storage of large amounts of data. Such systems may include one or a plurality of storage devices that are used in a coordinated fashion. Systems in which data can be distributed across multiple storage devices such that data will not be irretrievably lost if one of the storage devices (or in some cases, more than one storage device) fails are also available. Systems that coordinate operation of a number of individual storage devices can also provide improved data access and/or storage times. Examples of systems that can provide such advantages can be found in the various RAID (redundant array of independent disks) levels that have been developed. Whether implemented using one or a plurality of storage devices, the storage provided by a data storage system can be treated as one or more storage volumes.
In order to facilitate the availability of desired data, it is often advantageous to maintain different versions of a data storage volume. Indeed, data storage systems are available that can provide at least limited data archiving through backup facilities and/or snapshot facilities. The use of snapshot facilities greatly reduces the amount of storage space required for archiving large amounts of data.
Snapshots provide a versatile feature that is useful for data recovery operations, such as backup and recovery of storage elements. However, traditional snapshots are read-only accessible and their contents cannot be modified, thereby rendering their use somewhat limited, particularly for operating systems and applications that do not have a notion of a read-only data store (e.g., a read-only file system) and that expect to write metadata at any time that the file system is accessible. When a storage element that is held in a snapshot is exported to a client or host and contains the data for such a problematic file system, an issue arises in that the host may attempt to write data to the read-only image. This is a fundamental issue in the design of a reliable system for backups. In general, once a backup image is made via a mechanism like a sparse snapshot, that image should be maintained as a point-in-time representation of the storage volume. A controller typically modifies snapshot data by what is known as a copy-on-write (COW) operation. The COW operation determines when a change to a storage volume is going to occur and then determines if the targeted blocks of that storage volume have changed since a snapshot was taken. If the blocks have not changed since the snapshot was taken, then the controller proceeds by copying the original contents of those blocks and writing them to the snapshot data prior to changing the storage volume. The COW operation ensures that the data from the storage volume at the point-in-time that a snapshot was taken either resides on the storage volume or on the snapshot. The controller therefore changes the snapshot only when doing so is required to preserve the data that was on the storage volume at the time the snapshot was taken, but that will be overwritten on the storage volume.
Direct modification of a snapshot image (e.g., direct modification by a client or host rather than a controller performing a COW operation) could have serious consequences. Such consequences may include the fact that the data of the snapshot is no longer a point-in-time copy and a consistent image of the storage volume may no longer be available for subsequent recovery operations. Accordingly, most snapshot facilities do not allow a host to write data directly to a snapshot without modifying the original data of the snapshot. Thus, many snapshot applications must be used for backup purposes only, where the snapshot cannot be mounted for write access or modification purposes. Furthermore, in some operating systems, a snapshot cannot be mounted as read-only.
The reason for this limited functionality is that traditional sparse snapshot designs employ a single data area to contain all data that is preserved in the snapshot or written to the snapshot by a host system. Although this spare snapshot configuration helps reduce the amount of memory used by a snapshot it severely limits the functionality available to snapshot applications. It would be useful to have a snapshot that provides enhanced snapshot functionality while making efficient use of data storage space.
The present invention is directed to solving these and other problems and disadvantages of the prior art. In accordance with embodiments of the present invention, a service for efficiently managing snapshot data is provided. The method generally comprises receiving a command to create a snapshot at a first point-in-time and in response to receiving the command, allocating a first set of memory addresses for storage of preserved data in association with the snapshot and allocating a second set of memory addresses for storage of write data. In accordance with at least some embodiments of the present invention, the second set of memory addresses are host writeable whereas the first set of memory addresses are not. This allows a user to write data directly to the snapshot using the second set of memory addresses without altering the point-in-time representation of the snapshot maintained by the first set of memory addresses. Furthermore, the second set of memory addresses is not populated with write data unless a user writes directly to the snapshot, thereby reducing the amount of data storage space needed to facilitate the write functionality.
In accordance with at least some embodiments of the present invention, a device for managing snapshot data is provided. The device generally comprises an input operable to receive instructions to create a snapshot of a master volume at a first point-in-time and a snapshot application operable to create a first snapshot in response to receiving the instructions, wherein the first snapshot comprises two separate data storage areas for storing different instances of data corresponding to a common data block range on the master volume. A data storage device is also provided to store snapshots created in accordance with embodiments of the present invention.
Additional features and advantages of embodiments of the present invention will become more readily apparent from the following description, particularly when taken together with the accompanying drawings.
In accordance with embodiments of the present invention, a snapshot is a block level point-in-time representation of data on a storage volume. The data is essentially frozen in time at the instant that the snapshot is taken. Although data on the storage volume may change as a result of write operations, the data within the snapshot will remain constant and frozen in time at the instant that the snapshot was taken. In order to preserve snapshot data, a backing store, also known as a snap pool, is used to store data that is not otherwise represented in the storage volume and snapshot metadata. All data and metadata associated with the snapshot is stored in the backing store. In accordance with embodiments of the present invention, data is stored within the snapshot in “chunks” or “block ranges.” A chunk is equivalent to a number of Logical Block Addresses (LBAs). Alternatively or in addition, data can be stored within subchunks. A subchunk is a fixed size subset of a chunk. Pointers, table entries, or other data structures can be used to identify the location of a chunk in the backing store.
The data storage systems 104, 108 are typically interconnected to one another through an in-band network 120. The in-band network 120 may also interconnect the data storage systems 104, 108 to a host computer 112 and/or an administrative computer 116. The electronic data system 100 may also include an out-of-band network 124 interconnecting some or all of the electronic data system 100 nodes 104, 108, 112 and/or 116. For example, one or more host computers 112 are connected to each data storage system 104, 108. For instance, a first data storage system 104 is connected to a second data storage system 108 across some distance by a Fibre Channel or a TCP/IP network 120, and each of these data storage systems 104, 108 is connected to a host computer 112 through an in-band 120 and/or an out-of-band 124 network.
The in-band or storage area network 120 generally functions to transport data between data storage systems 104 and/or 108 and host devices 112, and can be any data pipe capable of supporting multiple initiators and targets. Accordingly, examples of in-band networks 120 include Fibre Channel (FC), iSCSI, parallel SCSI, Ethernet, ESCON, or FICON connections or networks, which may typically be characterized by an ability to transfer relatively large amounts of data at medium to high bandwidths. The out-of-band network 124 generally functions to support the transfer of communications and/or commands between various network nodes, such as data storage resource systems 104, 108, host computer 112, and/or administrative computers 116, although such data may also be transferred over the in-band communication network 120. Examples of an out-of-band communication network 124 include a local area network (LAN) or other transmission control protocol/Internet protocol (TCP/IP) network. In general, the out-of-band communication network 124 is characterized by an ability to interconnect disparate nodes or other devices through uniform user interfaces, such as a web browser. Furthermore, the out-of-band communication network 124 may provide the potential for globally or other widely distributed management of data storage systems 104, 108 via TCP/IP.
Every electronic data system node or computer 104, 108, 112 and 116, need not be interconnected to every other node or device through both the in-band network 120 and the out-of-band network 124. For example, no host computer 112 needs to be interconnected to any other host computer 112, data storage system 104, 108, or administrative computer 116 through the out-of-band communication network 124, although interconnections between a host computer 112 and other devices 104, 108, 116 through the out-of-band communication network 124 are not prohibited. As another example, an administrative computer 116 may be interconnected to at least one storage system 104 or 108 through the out-of-band communication network 124. An administrative computer 116 may also be interconnected to the in-band network 120 directly, although such an interconnection is not required. For example, instead of a direct connection, an administrator computer 116 may communicate with a controller of a data storage system 104, 108 using the in-band network 120.
In general, a host computer 112 exchanges data with one or more of the data storage systems 104, 108 in connection with the performance of the execution of application programming, whether that application programming concerns data management or otherwise. Furthermore, an electronic data system 100 may include multiple host computers 112. An administrative computer 116 may provide a user interface for controlling aspects of the operation of the storage systems 104, 108. The administrative computer 116 may be interconnected to the storage system 104, 108 directly, and/or through a bus or network 120 and/or 124. In accordance with still other embodiments of the present invention, an administrative computer 116 may be integrated with a host computer 112. In addition, multiple administrative computers 116 may be provided as part of the electronic data system 100. Furthermore, although two data storage systems 104, 108 are shown in
A data storage system 104, 108, in accordance with embodiments of the present invention, may be provided with a first controller slot 208a. In addition, other embodiments may include additional controller slots, such as a second controller slot 208b. As can be appreciated by one of skill in the art, a controller slot 208 may comprise a connection or set of connections to enable a controller 212 to be operably interconnected to other components of the data storage system 104, 108. Furthermore, a data storage system 104, 108 in accordance with embodiments of the present invention includes at least one controller 212a. For example, while the data storage system 104, 108 is operated in a single controller, non-failover mode, the data storage system 104, 108 may include exactly one controller 212. A data storage system 104, 108 in accordance with other embodiments of the present invention may be operated in a dual redundant active-active controller mode by providing a second controller 212b. When a second controller 212b is used in addition to a first controller 212a, the second controller slot 208b receives the second controller. As can be appreciated by one of skill in the art, the provision of two controllers, 212a and 212b, permits data to be mirrored between the controllers 212a-212b, providing redundant active-active controller operation.
One or more busses or channels 216 are generally provided to interconnect a controller or controllers 212 through the associated controller slot or slots 208 to the storage devices 204. Furthermore, while illustrated as a single shared bus or channel 216, it can be appreciated that a number of dedicated and/or shared buses or channels may be provided. Additional components that may be included in a data storage system 104 include one or more power supplies 224 and one or more cooling units 228. In addition, a bus or network interface 220 may be provided to interconnect the data storage system 104, 108 to the bus or network 112, and/or to a host computer 108 or administrative computer 116.
Although illustrated as a complete RAID system in
A controller 212 also generally includes memory 308. The memory 308 is not specifically limited to memory of any particular type. For example, the memory 308 may comprise a solid-state memory device, or a number of solid-state memory devices. In addition, the memory 308 may include separate non-volatile memory 310 and volatile memory 312 portions. As can be appreciated by one of skill in the art, the memory 308 may include a read cache 316 and a write cache 320 that are provided as part of the volatile memory 312 portion of the memory 308, although other arrangements are possible. By providing caches 316, 320, a storage controller 212 can improve the speed of input/output (IO) operations between a host 112 and the data storage devices 204 comprising an array or array partition. Examples of volatile memory 312 include DRAM and SDRAM.
The non-volatile memory 310 may be used to store data that was written to the write cache of memory 308 in the event of a power outage affecting the data storage system 104. The non-volatile memory portion 310 of the storage controller memory 308 may include any type of data memory device that is capable of retaining data without requiring power from an external source. Examples of non-volatile memory 310 include, but are not limited to, compact flash or other standardized non-volatile memory devices.
A volume information block 324 may be stored in the non-volatile memory 310, although in accordance with at least some embodiments of the present invention, the volume information block 324 resides in volatile memory 312. The volume information block 324 comprises data that may be used to represent attribute and state information for master volumes, backing stores, and/or snapshots. Each master volume, backing store, and snapshot is typically associated with a different volume information block 324. The volume information block 324 is generally employed by the processor 304 to determine whether certain data is located on master volumes, backing stores, and/or snapshots and whether such data is safe to access based on the state of each. For example, the state of a master volume or backing store may be such that if data access were attempted, data corruption may occur. Accordingly, the volume information block 324 may be referenced prior to data access during an I/O operation.
The memory 308 also includes portions of the memory 308 comprising a region that provides storage for controller code 328. The controller code 328 may comprise a number of components, including an I/O application 332 comprising instructions for accessing and manipulating data. The I/O application 332 may provide the controller 212 with the ability to perform read and/or write operations of data on a storage volume and/or on a snapshot. The I/O application 332 may reference the volume information block 324 prior to executing such operations. The I/O application 332 may also employ the read and write caches 316 and 320 respectively when performing such operations.
A snapshot application 336 is an example of another application that may be included in the controller code 328. The snapshot application 336 may be adapted to create and manage snapshots of a master volume. In accordance with at least one embodiment of the present invention, the snapshot application 336 is characterized by the ability to create a writeable snapshot that represent a point-in-time but still allows for modification without disrupting data from the point-in-time. More specifically, the snapshot application 336 may be adapted to create snapshots that support controller 212 initiated read and write operations as well as host 112 initiated read and write operations.
A storage controller 212 may additionally include other components. For example, a bus and/or network interface 340 may be provided for operably interconnecting the storage controller 212 to the remainder of the data storage system 104, for example through a controller slot 208 and a bus or channel 216. Furthermore, the interface 340 may be configured to facilitate removal or replacement of the storage controller 212 in a controller slot 208 as a field replaceable unit (FRU). In addition, integral signal and power channels may be provided for interconnecting the various components of the storage controller 212 to one another.
As can be appreciated by one skilled in the art, the functionality of the snapshot application 336 may be performed on components other than the controller 212. More specifically, the snapshot functionality of the present invention could be integrated into a storage application such as an operating system of a computer or onto a switch that contains an operating system and software to implement the snapshot functionality.
With reference to
Each snapshot 408 may be created with separate and distinct preserved data 412 and write data 416 areas. Changes to the snapshot 408 by a COW operation may affect the preserved data 412 while host initiated changes to the snapshot 408 may affect data in the write data area 416.
Changes in the master volume 404 made after creation of the first snapshot 408a but before creation of the second snapshot 408b are written to the preserved data area 412 of the first snapshot 408a. The preserved data area 412 of the first snapshot 408a is changed by COW operations initiated by the controller 212 and/or by deletion of a snapshot 408. The change to a snapshot 408 by a COW and/or deletion operation is performed to ensure the point-in-time image of the snapshot 408 is preserved. Otherwise, the preserved data area 412 remains unchanged and continues to represent the point-in-time that the first snapshot 408a was created, even in the event of a host 112 initiated write operation. The preserved data area 412 is used to maintain the point-in-time representation of the snapshot 408, while the write data area 416 is used to maintain normal write data that is not specifically tied to a point-in-time.
However, once the newer second snapshot 408b is created, the preserved data area 412 of the first snapshot 408a will not change, unless either the first 408a or second 408b snapshot are deleted. Any changes to the master volume 404 are otherwise reflected in the preserved data area 412 of the second snapshot 408b.
Each block range is represented by a different letter (i.e., A, B, C, etc.) and each version of the block range is represented by a variation of that letter. More specifically, the data on the master volume 404 at the point-in-time corresponding to the first snapshot 408a includes A, B, C, D, and E, whereas data on the master volume 404 at the later point-in-time corresponding to the second snapshot 408b includes A′, B′, C, D′, and E. Since the E data block range has not been altered since the creation of either the first 408a or second 408b snapshot, it still resides on the master volume 404. The subsequent changes to a data block range on the master volume 404 are updated as A″, B″, or D″ respectively. Host 112 initiated changes made directly to a snapshot 408 are represented by lower case letters in the write data area 416. In accordance with at least some embodiments of the present invention, all snapshot 408 have separate preserved data areas 412 and write data areas 416, but the write data area 412 is empty until a host 112 writes directly to the snapshot 408. Since the write data area 412 remains empty until a host 112 initiated write command is received, the additional space required for the snapshot 408 having this improved functionality is kept as small as possible.
As a further example, the first instance of the A data block range that resided on the master volume 404 when the first snapshot 408a was taken is stored in the preserved data area 412 of the first snapshot 408a. After the second snapshot 408b was created, the second instance of the same A data block (i.e., A′) is maintained in the preserved data area 412 of the second snapshot 408b. Advantageously, a user may elect to mount the first snapshot 408a and write data to the same A data block range. Any host 112 initiated request like this will result in the storage of changes in the write data area 416 of the first snapshot 408a. A host 112 can access the newly created data (i.e., a′) in the write data area 416 without altering the point-in-time representation of the corresponding A data block range stored in the preserved data area 412. One unique aspect of the present invention is that the snapshot 408 is configured to allow two different instances of data for the same data block range to reside thereon. By allowing two instances of the same data block range to exist on a single snapshot 408, a user can manipulate the snapshot data without disrupting the point-in-time representation of the snapshot 408.
Additionally, if the user decides that the changes made to the first snapshot 408a are not worth saving and would rather revert back to the point-in-time corresponding to the first snapshot 408a, then the host 112 may request to delete the data from the write data area 416, thereby leaving only the data in the preserved data area 412.
Referring now to
Upon receiving the request to create a snapshot 408, the controller 212 employs the snapshot application 336 to ensure that sufficient space exists in the backing store for the snapshot 408 (step 508). The step of ensuring that sufficient space exists in the backing store may comprise determining the amount of storage available on the backing store and comparing that to a minimum amount of space required to store snapshot 408 metadata (e.g., space to keep track of the preserved data and write data). The minimum amount of space required to store a single snapshot 408 comprises the space required to keep track of the metadata associated with the preserved and write data currently held for the snapshot 408. The actual space required to retain the write and preserved data in the write data area 416 and the preserved data area 412 respectively is a function of the amount of data uniquely written to the master volume 404 and snapshot 408. The space required may increase for each additional snapshot taken of the master volume 404. If there is insufficient resources to track another snapshot, in step 508 the controller 212 may return an error message or allocate additional resources to accommodate. Resources could include memory allocation, metadata space on the backing store, etc.
After the controller 212 has ensured that there is sufficient space on the backing store, the method continues with the controller 212 allocating space on the backing store for the new snapshot 408 (step 512). In this step, the controller 212 may allocate space on the backing store used for the tracking of preserved data and write data associated with a snapshot 408. The data blocks on the backing store allocated for the snapshot 408 may be mapped to the assigned LUNs.
Once space has been allocated on the backing store for the snapshot 408, the controller 212 proceeds by separating the allocated space into two separate areas, namely a preserved data area 412 and a write data area 416 (step 516). The separation of the allocated space may occur at the block or chunk level in the data storage device 204, whereby a first range of storage addresses are allocated to the preserved data area 412 and a second range of storage addresses are allocated to the write data area 416. In accordance with at least one embodiment of the present invention, a greater amount of space is provided for the preserved data area 412 as opposed to the write data area 416. Of course, other embodiments may allocate an equal or greater amount of space to the write data area 416 as compared to the preserved data area 412. The separation of the allocated space allows for two separate data storage areas within the snapshot 408. By separating the allocated space, the snapshot 408 will be able to maintain the data corresponding to the point-in-time that the create request was received in the preserved data area 412 while allowing data to be written to the write data area 416. Accordingly, the snapshot 408 can facilitate the storage of two instances of data for the same master volume 404 block range. Space may be dynamically allocated to the preserved data area 412 and the write data area 416 on an “as needed basis.” Dynamically allocated storage space is assigned from the backing store to the preserved data area 412 when a COW operation occurs. Dynamically allocated storage space is assigned from the backing store to the snapshot 408 write data area 416 when a host 112 write to a snapshot 408 occurs. However, in accordance with other embodiments of the present invention, the space may be preallocated statically.
With the preserved data area 412 and write data area 416 established on the snapshot 408, the controller 212 creates an array partition to for the new snapshot 408 (step 524). As noted above, the array partition provides access to a virtual disk drive which can read or write fixed blocks addressed by LBA. In accordance with at least some embodiments of the present invention, the array partition corresponding to the new snapshot 408 has a valid LUN number assigned to it, thereby rendering it host addressable.
Following the creation of the array partition, the controller 212 updates the volume information block 324 to reflect the creation of the new snapshot 408 (step 524). The volume information block 324 is updated to provide the I/O application 332 the ability to verify that it is safe to access the new snapshot 408 prior to executing an I/O command. Once the volume information block 324 has been updated, the method ends (step 528).
Upon receiving the request, the controller 212 determines if the modification in snapshot data is due to the initiation of a COW operation (i.e., is controller 212 initiated) (step 612). In other words, the controller 212 determines if the request is directed toward a modification in the master volume 404 such that original data on the master volume 404 needs to be transferred to the snapshot 408 prior to modifying the master volume 404. In the event that the modification in the snapshot 408 is required as a part of a COW operation, the controller 212 continues by changing the data in the appropriate block range of the preserved data area 412 of the newest snapshot 408 associated with the master volume 404 (step 616). After the data has been transferred from the master volume 404 to the preserved data area 412, the controller 212 continues by completing the COW operation (step 624). As part of completing the COW operation, the controller 212 makes the requested modification to the master volume 404, thus changing the data from A to A′, for example.
In the event that the change to snapshot data is not due to a COW operation (i.e., is not controller 212 initiated), and is instead a direct request by a host 112 or administrative computer 116 to modify the snapshot 408, then the controller 212 continues by modifying the write data area 416 of the targeted snapshot 408 (step 620). A user may elect to alter the write data area 416 of any snapshot 408, in contrast to the COW operation that only modifies the preserved data area 412 of the newest snapshot 408. As an example, in this step the controller 212 may write a′ or a″ to the write data area 416 of the selected snapshot 408. Once the requested modification has been executed, the method returns to step 604, where the controller 212 awaits receipts of further commands.
After the user has mounted the snapshot 408, the user may write changes directly to the snapshot 408 by issuing write commands to the controller 212. The write commands are received at the bus and/or network interface 340 of the controller 212 and forwarded to the processor 304 (step 708). The processor 304 then engages the snapshot application 336 to locate the block range on the snapshot 408 corresponding to the requested write command (step 712). The block range that is located by the snapshot application 336 corresponds to a block range in the write data area 416 of the snapshot, since the write command was received directly from the host 112 or administrative computer 116.
Once the appropriate data block range has been located, the data is written to the located block range within the write data area 416 (step 716). Since the write only alters the write data area 416, the data in the preserved data area 412 of the snapshot 412 remains a representation of the point-in-time that the snapshot 408 was created. Additional writes may be registered on the snapshot 408 for the same block range or for different block ranges.
After such changes have been made, the user may decide to delete the changes to the snapshot 408 and restore the snapshot 408 back to its original point-in-time representation. Upon making such a decision the user may issue a restore command that is received at the controller 212 (step 720). When the controller 212 receives a restore command, the controller 212 will employ the processor 304 and snapshot application 336 to delete the data in the write data area 416 of the mounted snapshot 408 (step 724). With the write data area 416 cleared, the only remaining snapshot data is the stored in the preserved data area 412, which is the data corresponding to the point-in-time that the snapshot 408 was created. By issuing a restore command a user is allowed to modify a snapshot 408 then quickly restore it back to its original state. Once the write data area 416 has been cleared, the method ends (step 728).
The foregoing discussion of the invention has been presented for purposes of illustration and description. Furthermore, the description is not intended to limit the invention to the form disclosed herein. Consequently, variations and modifications commensurate with the above teachings, within the skill and knowledge of the relevant art, are within the scope of the present invention. The embodiments described hereinabove are further intended to explain the best modes presently known of practicing the invention and to enable others skilled in the art to utilize the invention in such, or in other embodiments, and with the various modifications required by their particular application or use of the invention. It is intended that the appended claims be construed to include alternative embodiments to the extent permitted by the prior art.
This application is a continuation-in-part of application Ser. No. 11/734,081, filed Apr. 11, 2007, entitled “Snapshot Preserved Data Cloning,” the entire disclosure of which is hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5551046 | Mohan et al. | Aug 1996 | A |
5778189 | Kimura et al. | Jul 1998 | A |
5812843 | Yamazaki et al. | Sep 1998 | A |
5963962 | Hitz et al. | Oct 1999 | A |
6073209 | Bergsten et al. | Jun 2000 | A |
6289356 | Hitz et al. | Sep 2001 | B1 |
6292808 | Obermarck et al. | Sep 2001 | B1 |
6341341 | Grummon et al. | Jan 2002 | B1 |
6548634 | Balinger et al. | Apr 2003 | B1 |
6557079 | Mason, Jr. et al. | Apr 2003 | B1 |
6594744 | Humlicek et al. | Jul 2003 | B1 |
6615223 | Shih et al. | Sep 2003 | B1 |
6771843 | Huber et al. | Aug 2004 | B1 |
6907512 | Hill et al. | Jun 2005 | B2 |
7047380 | Tormasov et al. | May 2006 | B2 |
7050457 | Erfurt et al. | May 2006 | B2 |
7100089 | Phelps | Aug 2006 | B1 |
7165156 | Cameron et al. | Jan 2007 | B1 |
7191304 | Cameron et al. | Mar 2007 | B1 |
7194550 | Chamdani et al. | Mar 2007 | B1 |
7206961 | Mutalik et al. | Apr 2007 | B1 |
7243157 | Levin et al. | Jul 2007 | B2 |
7313581 | Bachmann et al. | Dec 2007 | B1 |
7363444 | Ji et al. | Apr 2008 | B2 |
7373366 | Chatterjee et al. | May 2008 | B1 |
7426618 | Vu et al. | Sep 2008 | B2 |
7526640 | Bejarano et al. | Apr 2009 | B2 |
7593973 | Lee et al. | Sep 2009 | B2 |
20010039629 | Feague et al. | Nov 2001 | A1 |
20020083037 | Lewis et al. | Jun 2002 | A1 |
20020091670 | Hitz et al. | Jul 2002 | A1 |
20020099907 | Castelli et al. | Jul 2002 | A1 |
20020112084 | Deen et al. | Aug 2002 | A1 |
20030154314 | Mason et al. | Aug 2003 | A1 |
20030158863 | Haskin | Aug 2003 | A1 |
20030167380 | Green | Sep 2003 | A1 |
20030188223 | Alexis et al. | Oct 2003 | A1 |
20030191745 | Jiang | Oct 2003 | A1 |
20030229764 | Ohno et al. | Dec 2003 | A1 |
20040030727 | Armangau | Feb 2004 | A1 |
20040030846 | Armangau | Feb 2004 | A1 |
20040030951 | Armangau | Feb 2004 | A1 |
20040034647 | Paxton et al. | Feb 2004 | A1 |
20040054131 | Balinger et al. | Mar 2004 | A1 |
20040093555 | Therrien et al. | May 2004 | A1 |
20040117567 | Lee et al. | Jun 2004 | A1 |
20040133718 | Kodama et al. | Jul 2004 | A1 |
20040172509 | Takeda et al. | Sep 2004 | A1 |
20040204071 | Bahl | Oct 2004 | A1 |
20040260673 | Hitz et al. | Dec 2004 | A1 |
20040267836 | Armangau et al. | Dec 2004 | A1 |
20050004979 | Berkowitz et al. | Jan 2005 | A1 |
20050044088 | Lindsay et al. | Feb 2005 | A1 |
20050065985 | Tummala et al. | Mar 2005 | A1 |
20050066128 | Yagisawa et al. | Mar 2005 | A1 |
20050071393 | Ohno et al. | Mar 2005 | A1 |
20050122791 | Hajeck | Jun 2005 | A1 |
20050166022 | Watanabe | Jul 2005 | A1 |
20050182910 | Stager et al. | Aug 2005 | A1 |
20050193180 | Fujibayashi et al. | Sep 2005 | A1 |
20050198452 | Watanabe | Sep 2005 | A1 |
20050240635 | Kapoor | Oct 2005 | A1 |
20050246397 | Edwards et al. | Nov 2005 | A1 |
20050246503 | Fair | Nov 2005 | A1 |
20060020762 | Urmston | Jan 2006 | A1 |
20060053139 | Marzinski et al. | Mar 2006 | A1 |
20060064541 | Kano | Mar 2006 | A1 |
20060107006 | Green et al. | May 2006 | A1 |
20060155946 | Ji | Jul 2006 | A1 |
20060212481 | Stacey et al. | Sep 2006 | A1 |
20060271604 | Shoens | Nov 2006 | A1 |
20070038703 | Tendjoukian | Feb 2007 | A1 |
20070055710 | Malkin | Mar 2007 | A1 |
20070094466 | Sharma et al. | Apr 2007 | A1 |
20070100808 | Balogh | May 2007 | A1 |
20070143563 | Pudipeddi et al. | Jun 2007 | A1 |
20070185973 | Wayda et al. | Aug 2007 | A1 |
20070186001 | Wayda et al. | Aug 2007 | A1 |
20070198605 | Saika | Aug 2007 | A1 |
20070266066 | Kapoor et al. | Nov 2007 | A1 |
20070276885 | Valiyaparambil | Nov 2007 | A1 |
20080082593 | Komarov et al. | Apr 2008 | A1 |
20080177954 | Lee et al. | Jul 2008 | A1 |
20080177957 | Lee et al. | Jul 2008 | A1 |
20080256311 | Lee et al. | Oct 2008 | A1 |
20080281875 | Wayda et al. | Nov 2008 | A1 |
20080281877 | Wayda et al. | Nov 2008 | A1 |
20080320258 | Wayda et al. | Dec 2008 | A1 |
Number | Date | Country |
---|---|---|
2165912 | Jun 1997 | CA |
1003103 | May 2000 | EP |
WO9429807 | Dec 1994 | WO |
WO 0250716 | Jun 2002 | WO |
WO2005111773 | Nov 2005 | WO |
WO2005111802 | Nov 2005 | WO |
Number | Date | Country | |
---|---|---|---|
20080256141 A1 | Oct 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11734081 | Apr 2007 | US |
Child | 11779965 | US |