System and method for virtual vaulting

Information

  • Patent Grant
  • 7487009
  • Patent Number
    7,487,009
  • Date Filed
    Tuesday, December 6, 2005
    19 years ago
  • Date Issued
    Tuesday, February 3, 2009
    15 years ago
Abstract
The present invention is a tape library comprising both a small front-end portion and a larger back-end portion. The front-end portion is a visible virtual or physical tape library; and the back-end portion is a large invisible virtual or physical tape vault. The DPA is a typical DPA which only sees the front-end library. If desired, all messages regarding the importing and exporting of tapes are reviewed by an agent. The agent manages the automatic transfer of tapes between the front-end and the back-end, and notifies the user when a manual import or export is needed. This greatly reduces both the amount of hardware required to establish a virtual or physical tape library and also reduces the amount of labor required by a user to physically import and export tapes. If both the front-end library and the back-end vault are virtual and reside on the same virtual tape library appliance, no data movement is necessary and the tapes can be moved merely by performing small software state changes. In this case, manual operation may be acceptable.
Description
BACKGROUND

The present invention is generally related to storage systems. More particularly, the invention is directed to a disk-based storage system, which provides one or more back-end virtual vaults to one or more front-end visible virtual or physical tape libraries.


In physical or virtual tape libraries, users often purchase a relatively small tape library and license their backup application code for the relatively small tape library due to the tremendous expense associated with large tape libraries. Referring to FIG. 1, a typical small tape library 10 comprises a plurality of media slots 12 and one or more tape drives 14. The tape library 10 keeps track of all of the tapes in the media slots 12 and the tape drives 14, and provides overall management of the tapes. When a user desires to read from or write to a tape, the tape is removed from a media slot 12 and placed into the tape drive 14. Of course, the tapes 16 do not reside within the tape library 10 in perpetuity. Accordingly, tapes 16 may be removed from the tape library 10 to become external tapes 18. These external tapes are typically stored offsite for security or archiving purposes. External tapes 18 may also be imported into the tape library 10 as desired as long as there are enough media slots 12 available.


Although having a small tape library 10 is an inexpensive way, (in terms of hardware), for an organization to implement data storage using tapes, it is a relatively labor intensive environment. Since the tape library is small, the user is forced to continuously import and export tapes to and from the tape library 10 so that needed tapes can be utilized by the tape drive 14.


To alleviate the labor problem, a larger tape library may be used. Such a larger tape library is shown in FIG. 2. In this large tape library 20, 166 media slots 12 are provided. Although only two tape drives 14 are shown for simplicity, those skilled in the art would realize that more tape drives 14 would typically be provided for a tape library of this size unless the system is used exclusively for archiving purposes. As one could obviously deduce, having such a large tape library 20 would relieve the user from having to import and export tapes on a frequent basis.


However, large tape libraries 20 have the drawback that they are much more expensive in terms of the hardware and, equally importantly, the library software license.


A seemingly unrelated problem is the desire of physical tape library vendors to include a virtual tape library as a relatively small front-end cache. In order to do this, the virtual tape library cache must be able to track tapes that have been exported to a physical tape library and import the appropriate tapes whenever the data protection application (DPA) needs access to tapes that are not located within the virtual library. Unfortunately, the DPA cannot distinguish between tapes that have been completely exported and shipped off-site and tapes that have simply been moved electronically or robotically to a back-end vault.


Thus, the problem of importing and exporting tapes to and from a tape library is closely related to the problem of designing a small front-end cache to a large library. This is because much of the work in designing such a cache involves moving media between the front-end cache and the backend vault, effectively exporting media from one library and importing this media into the other and keeping track of this interaction.


Accordingly, present tape library configurations leave much to be desired in terms of flexible import/export mechanisms; particularly when media is moved between multiple libraries.


SUMMARY

The present invention is a tape library comprising both a small front-end portion and a larger back-end portion. The front-end portion is a visible virtual or physical tape library; and the back-end portion is a large invisible virtual or physical tape vault. The DPA is a typical DPA which only sees the front-end library. If desired, all messages regarding the importing and exporting of tapes are reviewed by an agent. The agent manages the automatic transfer of tapes between the front-end and the back-end, and notifies the user when a manual import or export is needed. This greatly reduces both the amount of hardware required to establish a virtual or physical tape library and also reduces the amount of labor required by a user to physically import and export tapes. If both the front-end library and the back-end vault are virtual and reside on the same virtual tape library appliance, no data movement is necessary and the tapes can be moved merely by performing small software state changes. In this case, manual operation may be acceptable.





BRIEF DESCRIPTION OF THE DRAWING(S)


FIG. 1 is a prior art small tape library.



FIG. 2 is a prior art large tape library.



FIG. 3 is a tape library made in accordance with the present invention having both a visible front-end and an invisible back-end.



FIG. 4 is a block diagram of the internal information flow of the system of the present invention.



FIG. 5 is a method for importing a tape in accordance with the preferred embodiment of the present invention.



FIG. 6 is a method for exporting a tape in accordance with the preferred embodiment of the present invention.



FIG. 7 is an alternative embodiment of the present invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT(S)

The present invention will be described with reference to the drawing figures where like numerals represent like elements throughout.


Referring to FIG. 3, a tape library system 30 made in accordance with the present invention is shown. The tape library system 30 comprises a front-end, visible virtual or physical tape library 32 and a back-end, invisible virtual or physical tape vault. As is evident from FIG. 3, the back-end library does not necessarily need to include any tape drives if it is used solely for vaulting purposes. Alternatively, one or more tape drives may be included if desired.


Hereinafter, reference will be made only to “tape library” or “tape vault” for simplicity. However, these terms should be understood by those skilled in the art to refer to both virtual or physical tape devices comprising an active medium (such as a disk drive), a passive medium (such as a tape cartridge), or a combination of both active and passive media. The front-end tape library 32 comprises a plurality of media slots 36 and a plurality of tape drives 38. Although there are ten media slots 36 and two tape drives 38 in the embodiment shown in FIG. 3, one skilled in the art would clearly realize that any number of media slots 36 and/or tape drives 38 may be utilized. The back-end tape vault comprises additional media slots 40 for seemingly exported tapes. Exported or external tapes are shown as tapes 42.


The DPA that is used in the front-end tape library 32 only sees tapes that are in the front-end tape library 32. Accordingly, the DPA operates in a manner that is exactly the same as with current tape libraries since current DPAs cannot distinguish between a virtual tape library and a physical tape library, or between a tape library with a vault and a tape library without a vault. However, as will be explained in greater detail hereinafter, the present invention may include an agent that intercepts all import and export messages from the DPA such that when a tape is exported from the front-end tape library 32, it may be exported only to the back-end invisible tape vault 34, and not exported as an external tape 42.


The back-end invisible tape vault 34 provides additional media slots 40 such that a tape exported from the front-end tape library 32 will be exported only to the back-end tape vault 34. When the DPA calls up a tape that it assumes was exported, the tape may actually reside within the back-end tape vault 34. The agent retrieves the tape from the back-end tape vault 34 and imports it into the front-end tape library 32 automatically, thus freeing the user from having to perform a manual tape import or export. Referring to the bottom of FIG. 3, the prior art required a manual intercession by the user in order to take the tapes from the front-end tape library at point one (1) and export them as external tapes 42 at point three (3). In contrast, the present invention provides an intermediate point two (2) by automatically transferring tapes between points one (1) and two (2) from the front-end tape library 32 to the back-end tape vault 34. Once the back-end tape vault 34 is full or, more typically, if a tape needs to be moved off-site either electronically or physically, a manual intercession by the user as shown between points two (2) and three (3) may be required to export the tapes as exported external tapes 42.


Referring to FIG. 4, a flow diagram of the internal information flow within the information storage system 30 of the present invention is shown. As shown, the information flow is between the DPA 41, the agent 43, the tape operator 44, the tape library 46 and the tape vault 48. Point one (1) of FIG. 3 represents normal interaction between the DPA 41 and a tape library 46. From the perspective of the DPA 41, the communication 50 between the DPA 41 and the tape library 46 is normal. Additionally, when the DPA 41 desires to import or export a tape, it sends a communication 52 to the tape operator 44. However, in accordance with the present invention, the communication 52 is intercepted by the agent 43. The agent 43 provides overall control and tracking of the tapes that are within the tape vault 48. If a tape is within the tape vault 48, the agent 43 sends a communication 56 to the tape vault 48 requesting that the tape vault 48 move the desired tape from the tape vault 48 to the tape library 46. If the desired tape is not in the tape vault 48, the agent 43 forwards a message via a communication 54 to the tape operator 44 requesting that the tape operator 44 manually insert a tape into the tape library 46 or, in an alternative embodiment, to the tape vault 48.


With respect to the DPA 41 requesting that a tape be exported from the tape library 46, the same process is followed. The DPA 41 requests the tape operator 44 via a communication 52 to remove a tape from the tape library 46. The agent 43 intercepts this communication 52 and, if there is enough storage within the tape vault 48, sends a communication 56 to the tape vault 48 requesting that the tape vault 48 accept the tape from the tape library 46 via a communication 58. If there is no room within the tape vault 48, the agent 43 passes the message via a second communication 54 to the tape operator 44 requesting that the tape operator 44 remove the tape from the tape library 46 or, in an alternative embodiment, from the tape vault 48.


Accordingly, a tape could be removed from the tape vault 48, which could automatically trigger the tape vault 48 to fetch the tapes in the entry/exit slot of the front-end library 46 because it now definitely has free space; or the tape could be removed from the front-end library 46 directly. The DPA 41 cannot track the different states once a tape is out of the front-end library 46 unless the user manually enters this information. For example, the DPA 41 does not know if the tape is currently in the mailroom, in the FedEx central office, or simply lost. Similarly, it does not know whether it is in the tape vault 48.


Referring to FIG. 5, a method 60 for importing a tape in accordance with the present invention is shown. A DPA corresponds with a tape library in a normal manner (step 61). When the DPA requests a tape that is not in the tape library, (step 62), the DPA sends a message requesting that a tape be manually imported into the tape library (step 64). The agent intercepts the message and determines whether or not the requested tape is in the tape vault (step 66). If the tape is not in the tape vault, the agent forwards a message to the tape operator to manually import the tape (step 68). If the tape is located in the tape vault, the agent instructs the tape vault to import the tape into the tape library (step 70).


Referring to FIG. 6, a method 90 for exporting a tape in accordance with the present invention is shown. In this method, the DPA corresponds with the tape library in a normal manner (step 92). When the DPA requests that a tape be exported from the tape library (step 94), the DPA sends a message requesting that the tape be manually exported, (i.e., moved to the entry/exit slot of the tape library), from the tape library (step 96). The agent intercepts this message and determines whether there is enough storage space in the vault (step 98).


The intercepted signal, like the signal described in connection with FIG. 5, may be any type of signal. For example, the signal may be an E-mail (SMTP and MAPI), Pager, Printer, Net send, SNMP, Windows NT Event Log entry or any other type of signal that asks the operator to import or export a tape.


Referring again to FIG. 6, if there is enough space for the tape in the vault, the agent instructs the vault to export the tape automatically from the tape library (step 100) so that the tape may be stored therein. However, if there is not enough space for the tape in the vault, the agent forwards a message to the tape operator to manually export the tape (step 99) or to free space in the vault.


In accordance with the present invention, tapes can be exported from a relatively small library to a larger tape vault and other tapes from the larger tape vault into the tape library. Since this operation is under programmatic control, this process is much less labor intensive than handling of physical tapes. This process can be completely automated.


The present invention has the following advantages. First, it allows for simple implementation of one or more small front-end tape libraries that share a large physical tape vault. For example, as shown in FIG. 7, a plurality of small front-end physical tape libraries 110, 112, 114, 116 may be linked to a single tape vault 120. A single agent associated with the tape vault 120 will provide overall control of importing and exporting of tapes from all of the small front-end tape libraries 110, 112, 114, 116 and the tape vault 120. The agent may queue DPA requests from multiple front-end libraries and execute them in sequence, or may prioritize them according to a management policy. All other aspects of the system are the same for a multiple front-end tape library set up as shown in FIG. 7 as with the single front-end tape library embodiment shown in FIG. 3. The communications between the multiple small front-end tape libraries 110, 112, 114, 116 and the tape vault 120 will be the same as shown in FIG. 4 and as explained with reference to the procedures 60, 90 in FIGS. 5 and 6 respectively.


The present invention also makes it extremely easy to “clone” tapes. This is useful when one copy of a tape needs to be shipped off-site and another copy of the identical tape is kept on-site for fast restores. In this scenario, whenever a tape is written to and is subsequently removed from a tape drive, it is copied (instead of moved) to the tape vault. If data is appended to an existing tape, it is simply written in the front-end tape library and upon removal from a drive, the append is written to the back-end tape.


Since the DPA is only aware of the small front-end library, the back up software can be purchased for the small library, rather than a large back-end tape vault. For the example shown in FIG. 3, the DPA only sees ten (10) media slots even though the vault extension expands the library to a thirty-eight (38) slot library.


In an alternative embodiment, no agent is used. Instead, several slots in the front-end library are reserved. These slots are then used to rotate media from the back-end library through. Whenever a new set of media is moved from the back-end library to the reserved slots, the backup application is informed, (for example, via standard SCSI commands), that an inventory change has occurred. The backup software then reads the new inventory and fetches the tapes it needs from the reserved slots. The two approaches can also be combined. For example, the most frequent import/export operation is to move full tapes out of the library to replace them with empty tapes. This can be completely automated. Once a tape is full and moved to a slot in the library, the tape can immediately be replaced by a blank tape and the backup application can be informed of the inventory change. This avoids many export requests altogether.

Claims
  • 1. A storage system comprising: a front-end portion configured to store at least one tape;a data protection application running on the front-end portion;a back-end portion configured to store tapes exported from the front-end portion; andan agent configured to intercept messages sent by the data protection application;wherein in response to the agent intercepting a message from the data protection application requesting an end user to manually import a tape located in the back-end portion, the agent automatically transfers the tape to the front-end portion from the back-end portion without forwarding the intercepted message.
  • 2. The storage system of claim 1 wherein the front-end portion is a tape library.
  • 3. The storage system of claim 1 wherein the back-end portion is a tape vault.
  • 4. The storage system of claim 1 wherein the data protection application is unaware of the back-end portion.
  • 5. The storage system of claim 1 wherein in response to the agent intercepting a message from the data protection application requesting an end user to manually export a tape from the front-end portion, the agent transfers the tape to an empty space in the back-end portion without forwarding the intercepted message.
  • 6. The storage system of claim 1 wherein the front-end portion is one of a plurality of front-end portions that share the back-end portion.
  • 7. A method for managing the transfer of tapes in a storage system having at least one front-end portion and a back-end portion, the method comprising the steps of: intercepting a message sent from a data protection application to an operator requesting a tape be manually imported to a front-end portion of a tape library;determining whether the requested tape is located in a back-end portion of the tape library;importing the requested tape volume from the back-end portion to the front-end portion where the determination is positive; andforwarding the intercepted message along to the operator where the determination is negative.
  • 8. The method of claim 7 wherein the front-end portion is a tape library.
  • 9. The method of claim 7 wherein the back-end portion is a tape vault.
  • 10. The method of claim 7 wherein the data protection application is running on the front-end portion and is unaware of the existence of the back-end portion.
  • 11. The method of claim 7 wherein the front-end portion is a one of a plurality of front-end portions that share the back-end portion.
  • 12. The method of claim 7 further comprising the steps of: intercepting a message sent from a data protection application to an operator requesting a tape be manually exported from a front-end portion of a tape library;determining whether the requested tape may be stored in a back-end portion of the tape library;importing the requested tape volume from the front-end portion to the back-end portion where the determination is positive; andforwarding the intercepted message along to the operator where the determination is negative.
  • 13. An agent for managing the transfer of tapes in a storage system comprising: the agent being configured to intercept messages in a storage system having a front-end portion running a data protection application and a back-end portion; andwherein if the agent intercepts a message from the data protection application requesting an end user to manually import a tape located in the back-end portion, the agent automatically transfers the tape to the front-end portion without forwarding the intercepted message.
  • 14. The agent of claim 13 wherein the front-end portion is a tape library.
  • 15. The agent of claim 13 wherein the back-end portion is a tape vault.
  • 16. The agent of claim 13 wherein if the agent intercepts a message from the data protection application requesting an end user to manually export a tape from the front-end portion, the agent transfers the tape to an empty space in the back-end portion without forwarding the intercepted message.
  • 17. The agent of claim 13 wherein the front-end portion is one of a plurality of front-end portions that share the back-end portion.
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 10/387,319, filed on Mar. 12, 2003, which is incorporated herein by reference as if fully set forth.

US Referenced Citations (162)
Number Name Date Kind
4361202 Minovitch Nov 1982 A
4635145 Horie et al. Jan 1987 A
4727512 Birkner et al. Feb 1988 A
4775969 Osterlund Oct 1988 A
5235695 Pence Aug 1993 A
5297124 Plotkin et al. Mar 1994 A
5438674 Keele et al. Aug 1995 A
5455926 Keele et al. Oct 1995 A
5465289 Kennedy, Jr. Nov 1995 A
5485321 Leonhardt et al. Jan 1996 A
5666538 DeNicola Sep 1997 A
5673382 Cannon et al. Sep 1997 A
5774292 Georgiou et al. Jun 1998 A
5774643 Lubbers et al. Jun 1998 A
5774715 Madany et al. Jun 1998 A
5805864 Carlson et al. Sep 1998 A
5809511 Peake Sep 1998 A
5809543 Byers et al. Sep 1998 A
5854720 Shrinkle et al. Dec 1998 A
5864346 Yokoi et al. Jan 1999 A
5872669 Morehouse et al. Feb 1999 A
5875479 Blount et al. Feb 1999 A
5911779 Stallmo et al. Jun 1999 A
5949970 Sipple et al. Sep 1999 A
5961613 DeNicola Oct 1999 A
5963971 Fosler et al. Oct 1999 A
5974424 Schmuck et al. Oct 1999 A
6021408 Ledain et al. Feb 2000 A
6023709 Anglin et al. Feb 2000 A
6029179 Kishi Feb 2000 A
6041329 Kishi Mar 2000 A
6044442 Jesionowski Mar 2000 A
6049848 Yates et al. Apr 2000 A
6061309 Gallo et al. May 2000 A
6067587 Miller et al. May 2000 A
6070224 LeCrone et al. May 2000 A
6098148 Carlson Aug 2000 A
6128698 Georgis Oct 2000 A
6131142 Kamo et al. Oct 2000 A
6131148 West et al. Oct 2000 A
6163856 Dion et al. Dec 2000 A
6173359 Carlson et al. Jan 2001 B1
6185421 Alperovich et al. Feb 2001 B1
6195730 West Feb 2001 B1
6225709 Nakajima May 2001 B1
6247096 Fisher et al. Jun 2001 B1
6260110 LeCrone et al. Jul 2001 B1
6266784 Hsiao et al. Jul 2001 B1
6269423 Kishi Jul 2001 B1
6269431 Dunham Jul 2001 B1
6282609 Carlson Aug 2001 B1
6289425 Blendermann et al. Sep 2001 B1
6292889 Fitzgerald et al. Sep 2001 B1
6301677 Squibb Oct 2001 B1
6304880 Kishi Oct 2001 B1
6304882 Strellis et al. Oct 2001 B1
6317814 Blendermann et al. Nov 2001 B1
6324497 Yates et al. Nov 2001 B1
6327418 Barton Dec 2001 B1
6336163 Brewer et al. Jan 2002 B1
6336173 Day et al. Jan 2002 B1
6339778 Kishi Jan 2002 B1
6341329 LeCrone et al. Jan 2002 B1
6343342 Carlson Jan 2002 B1
6353792 Murthy Mar 2002 B1
6353837 Blumenau Mar 2002 B1
6360232 Brewer et al. Mar 2002 B1
6389503 Georgis et al. May 2002 B1
6408359 Ito et al. Jun 2002 B1
6487561 Ofek et al. Nov 2002 B1
6496791 Yates et al. Dec 2002 B1
6499026 Rivette et al. Dec 2002 B1
6557073 Fujiwara Apr 2003 B1
6557089 Reed et al. Apr 2003 B1
6578120 Crockett et al. Jun 2003 B1
6615365 Jenevein et al. Sep 2003 B1
6625704 Winokur Sep 2003 B2
6650948 Atkinson et al. Nov 2003 B1
6654912 Viswanathan et al. Nov 2003 B1
6658435 McCall Dec 2003 B1
6683538 Wilkes, Jr. Jan 2004 B1
6690292 Meadows et al. Feb 2004 B1
6694447 Leach et al. Feb 2004 B1
6725331 Kedem Apr 2004 B1
6766520 Rieschl et al. Jul 2004 B1
6779057 Masters et al. Aug 2004 B2
6779058 Kishi et al. Aug 2004 B2
6779081 Arakawa et al. Aug 2004 B2
6816941 Carlson et al. Nov 2004 B1
6816942 Okada et al. Nov 2004 B2
6834324 Wood Dec 2004 B1
6850964 Brough et al. Feb 2005 B1
6877016 Hart et al. Apr 2005 B1
6915397 Lubbers et al. Jul 2005 B2
6931557 Togawa Aug 2005 B2
6950263 Suzuki et al. Sep 2005 B2
6957291 Moon et al. Oct 2005 B2
6973534 Dawson Dec 2005 B2
6978325 Gibble Dec 2005 B2
7032126 Zalewski et al. Apr 2006 B2
7032131 Lubbers et al. Apr 2006 B2
7055009 Factor et al. May 2006 B2
7072910 Kahn et al. Jul 2006 B2
7096331 Haase et al. Aug 2006 B1
7100089 Phelps Aug 2006 B1
7107417 Gibble et al. Sep 2006 B2
7111136 Yamagami Sep 2006 B2
7127388 Yates et al. Oct 2006 B2
7127577 Koning et al. Oct 2006 B2
7143307 Witte et al. Nov 2006 B1
7152077 Veitch et al. Dec 2006 B2
7155586 Wagner et al. Dec 2006 B1
7200546 Nourmohamadian et al. Apr 2007 B1
20010047447 Katsuda Nov 2001 A1
20020004835 Yarbrough Jan 2002 A1
20020016827 McCabe et al. Feb 2002 A1
20020026595 Saitou et al. Feb 2002 A1
20020095557 Constable et al. Jul 2002 A1
20020133491 Sim et al. Sep 2002 A1
20020144057 Li et al. Oct 2002 A1
20020163760 Lindsey et al. Nov 2002 A1
20020166079 Ulrich et al. Nov 2002 A1
20020171546 Evans et al. Nov 2002 A1
20020199129 Bohrer et al. Dec 2002 A1
20030004980 Kishi et al. Jan 2003 A1
20030037211 Winokur Feb 2003 A1
20030097462 Parent et al. May 2003 A1
20030120476 Yates et al. Jun 2003 A1
20030120676 Holavanahalll et al. Jun 2003 A1
20030126388 Yamagami Jul 2003 A1
20030135672 Yip et al. Jul 2003 A1
20030149700 Bolt Aug 2003 A1
20030182301 Patterson et al. Sep 2003 A1
20030182350 Dewey Sep 2003 A1
20030188208 Fung Oct 2003 A1
20030217077 Schwartz et al. Nov 2003 A1
20030225800 Kavuri Dec 2003 A1
20040015731 Chu et al. Jan 2004 A1
20040098244 Dailey et al. May 2004 A1
20040181388 Yip et al. Sep 2004 A1
20040181707 Fujibayashi Sep 2004 A1
20050010529 Zalewski et al. Jan 2005 A1
20050044162 Liang et al. Feb 2005 A1
20050063374 Rowan et al. Mar 2005 A1
20050065962 Rowan et al. Mar 2005 A1
20050066118 Perry et al. Mar 2005 A1
20050066222 Rowan et al. Mar 2005 A1
20050066225 Rowan et al. Mar 2005 A1
20050076070 Mikami Apr 2005 A1
20050076261 Rowan et al. Apr 2005 A1
20050076262 Rowan et al. Apr 2005 A1
20050076264 Rowan et al. Apr 2005 A1
20050144407 Colgrove et al. Jun 2005 A1
20060047895 Rowan et al. Mar 2006 A1
20060047902 Passerini Mar 2006 A1
20060047903 Passerini Mar 2006 A1
20060047905 Matze et al. Mar 2006 A1
20060047925 Passerini Mar 2006 A1
20060047989 Delgado et al. Mar 2006 A1
20060047998 Darcy Mar 2006 A1
20060047999 Passerini et al. Mar 2006 A1
20060143376 Matze et al. Jun 2006 A1
Foreign Referenced Citations (13)
Number Date Country
1333379 Apr 2006 EP
1 671 231 Jun 2006 EP
1 671231 Jun 2006 EP
9854682 Dec 1998 WO
WO9903098 Jan 1999 WO
WO9906912 Feb 1999 WO
WO2005031576 Apr 2005 WO
WO2006023990 Mar 2006 WO
WO2006023991 Mar 2006 WO
WO2006023992 Mar 2006 WO
WO2006023993 Mar 2006 WO
WO2006023994 Mar 2006 WO
WO2006023995 Mar 2006 WO
Related Publications (1)
Number Date Country
20060074520 A1 Apr 2006 US
Continuations (1)
Number Date Country
Parent 10387319 Mar 2003 US
Child 11294955 US