The present invention relates to accessing media libraries. More particularly, the present invention relates systems and methods of providing access to multiple physical media libraries.
Data represents a significant asset for many entities. Consequently, data loss, whether accidental or caused by malicious activity, can be costly in terms of wasted manpower, loss of goodwill from customers, loss of time and potential legal liability. To ensure proper protection of data for business and legal purposes, many entities back up data to a physical storage media such as magnetic tapes or optical disks. Traditionally, backup would occur at each machine controlled by an entity. As the sophistication of network technology increased, many entities turned to enterprise level backup in which data from multiple machines on a network is backed up to a remote media library. Centralized data backup allows storage problems to be identified at one location and has the advantage of increased efficiency.
One example of a media library commonly used in enterprise backup systems is a magnetic tape library. In a typical magnetic tape library, tapes are contained in cartridges and the tape library contains multiple cartridge slots in which tape cartridges can be stored. The tape cartridges are physically moved between cartridge slots and tape drives by a robot. The robot is controlled by access commands received from the host devices on the network. When specific data is required, the host device determines which cartridge slot contains the tape cartridge that holds the desired data. The host device then transmits a move-element command to the robot and the robot moves the tape cartridge.
In a SCSI tape library, devices that are part of the library are typically addressed by target number and logical unit numbers (“LUN”). Thus, each drive and robot of a tape library typically has a target number and LUN. Cartridge slots, on the other hand, are addressed by element numbers that are used by the robot to locate the slots. Because the robot also places tape cartridges in the drives, each drive is also associated with an element number. If multiple tape libraries are connected to a single device (e.g., a fibre channel to SCSI router), the tape libraries may be further addressed by bus number.
In current tape library systems, each tape library presents itself as an independent entity on the network. Each host in these systems maintains a view (i.e., a table of target numbers, LUNs and element numbers) of each of the tape libraries. Using this address information a host can format commands to the tape library to perform read/write, backup and other operations. In order to coordinate activities, hosts must cooperate with each other in issuing these commands. Enabling cooperation, however, requires reconfiguration of the hosts each time a new media library is added to the SAN. Moreover, to prevent conflicts between hosts, each host must typically use the same application to access a shared tape library. This can be inefficient as individual tape libraries cannot store data from multiple applications.
Prior art media libraries suffer additional shortcomings including lack of scalability. Currently, when an entity's need for storage outgrows the capabilities of its media library, the entity must, in many cases, purchase an additional independent media library. Because the independent media libraries present themselves as independent entities on a network, there is typically no single point of control for the libraries. Each host on the network will have access to each media library, often leading to conflicts. One solution to this problem is an expandable media library in which physical units can be combined. In these systems, the robots which control the physical movement of media within a particular library can communicate with robots in connected libraries to transfer media such that the multiple libraries act as a single library. The use of multiple robots can allow some backup operations to continue even if one robot is offline. These systems, however, are often very expensive and require a large amount of space in single location so that the libraries can be connected together. Additionally, the entity installing such a system must have enough foresight to initially install a media library that is capable of expanding in this manner.
Another, more cost effective solution, is a set of modular media libraries that use a single robot. In these systems, each library installed after the initial library does not have its own robot, but, instead, is designed to stack on the initial library so that the robot from the initial library can move between the libraries. In essence, the libraries are combined into a single library using one robot. Again, however, this solution requires enough space in a single location and sufficient foresight on part of the installing entity to purchase a media library configured to allowing stacking. As a further deficiency, if the single robot experiences problems, the entity may not be able to perform any backup operations at all.
Embodiments of the present invention provide a system and method of media library access that eliminates, or at least substantially reduces, the shortcomings of prior art media library access systems and methods. More particularly, embodiments of the present invention provide a media library controller that can communicate with multiple physical libraries that are physically separate from each other (i.e., that cannot pass media back and forth). The media library controller can maintain a virtualized aggregate media library representing the physical media libraries with which it is in communication. From the physical media libraries, the media library controller can establish a virtual media library and associate a host with the virtual media library. The virtual media library can represent the portions of a physical media library to which the host is allowed access. The media library-controller can receive a data operation command from the host and determine if the data operation command corresponds to a portion of the physical media library to which the host has access. If so, the media library controller can forward the data operation command to the appropriate physical robot and/or drives. Otherwise, the media library controller can reject the data operation command.
In another embodiment of the present invention, the media library controller can present the virtual media library to the host such that the host sees a media library with a virtual drive, virtual robot and virtual slots (i.e., the host will see a virtual robotic controller and virtual slots). The host can then formulate data operation commands based on the virtual media library (e.g., based on the addressing information seen by the host). When the media library controller receives the command, the media library controller can forward the command to the robot and/or drives at the physical media library to which the host has access based on a mapping of the virtual drive(s), virtual robot(s) and virtual slots to physical drives, robots and slots.
Another embodiment of the present invention can include a set of computer instructions executable by a computer processor to communicate with at least a first physical media library and a second physical media library, wherein said first physical media library and said second physical media library are physically separate. The computer instructions can also be executable to maintain a virtualized aggregate media library representing at least the first physical media library and the second physical media library and associate a first host with a virtual media library that represents at least a portion of the first physical media library to which the host has access. In this manner, the computer instructions can be executable to control the access of a host to multiple media libraries.
Yet another embodiment of the present invention can include a method of aggregating multiple media libraries that comprises: (i) associating a host with a virtual media library, wherein the virtual media library represents the portion of a physical media library to which the host has access; (ii) receiving a data operation command from a host; (iii) determining whether the received command is directed to the portion of the physical media library which is accessible by the host; and (iv) if the command is directed to the portion of the physical media library which is accessible by the host, forwarding the received command to the robots and/or drives at the physical media library accessible by the host. In one embodiment of the present invention, the command can be changed during forwarding to account for the mapping between virtual drives, robots and slots and physical drives, robots and slots.
The present invention provides an advantage over prior art systems and methods of aggregating media libraries by providing a single point of control for multiple media libraries without requiring that the media libraries be preconfigured to connect with existing media libraries. This can substantially reduce the complexity and cost of expanding data storage abilities.
Embodiments of the present invention provide another advantage over prior art systems of aggregating media libraries by allowing hosts running different applications to share media libraries. Because multiple hosts can share the same physical media libraries, data can be stored more efficiently. Moreover, because access can be controlled at a central point, the hosts do not have to be extensively reconfigured to allow sharing without conflict.
In addition, embodiments of the present invention provide another advantage over prior art systems by allowing a central control point to be established for media libraries that may reside at different locations. This can reduce the amount of space required at a single location for expanding media libraries.
A more complete understanding of the present invention and the advantages thereof may be acquired by referring to the following description, taken in conjunction with the accompanying drawings in which like reference numbers indicate like features and wherein:
Preferred embodiments of the invention are illustrated in the FIGURES, like numerals being used to refer to like and corresponding parts of the various drawings.
Embodiments of the present invention provide a system and method for providing a central point of control for multiple, physically separate media libraries. By providing a central point of control, embodiments of the present invention can eliminate, or substantially reduce, conflicts between multiple hosts attempting to access the same media libraries. In the preferred embodiment, a plurality of hosts are connected to multiple tape libraries via a fibre channel storage area network (“SAN”). Each tape library includes one or more tape drives to perform read/write operations and slots to store tape cartridges and utilizes a robot to load individual tape cartridges into the tape drives. A media library controller is connected to the SAN between the hosts and the media libraries and acts as a central control point for the libraries. The controller maintains a virtualized aggregate media library representing each of the media libraries behind the controller. The controller can also maintain a set of virtual media libraries with each virtual media library representing a portion of a single physical media library behind the controller. By associating each host with a virtual media library such that the host can only have access to certain portions of the physical media library, the media library controller can reduce conflicts between the hosts.
Media library 130 and media library 140, in the preferred embodiment of the present invention, comprise tape libraries, though, in other embodiments, the media libraries can comprise any media library known in the art such as optical jukeboxes. A tape library, as would be understood by one of ordinary skill in the art, typically consists of one or more tape drives that can read/write data from/to magnetic tape (contained within cartridges), eject tape cartridges and perform other operations. A series of slots stores the magnetic tape cartridges when they are not in a drive and a robot moves the magnetic tape cartridges between the drives and slots. As an example, media library 130 can comprise drives 131-133, robot 134 and slots 135 (individually slots 135a-j) while media library 140 can comprise drives 141-142, robot 144 and slots 145 (individually slots 145a-j). Media libraries 130 and 140, in the preferred embodiment, are physically separate from each other. That is, even if media libraries 130 and 140 are in physical contact with each other, they can not pass tape cartridges back and forth. It should be noted that a media library that employs a single robot or multiple robots in an expandable or modular configuration, but presents itself as a single media library to a network can be considered a single media library for the purposes of this application.
Media library controller 115 can comprise one or more communications interfaces (e.g., fibre channel interface, Ethernet port or other communications interface known in the art) to connect media library controller 115 to SAN 120 and media libraries 130 and 140. Additionally, media library controller 115 can comprise a computer processor 152 and a computer readable memory 154 (e.g., RAM, ROM, magnetic disk, optical disk and/or any other computer readable memory known in the art) that can store computer instructions 155, which are executable by processor 152. Computer instructions 155 can be implemented as hardware, software, firmware or in any other suitable manner as would be understood by those of ordinary skill in the art.
It should be understood that media library controller 115 can be implemented in a variety manners. For example, when implemented in a SAN, the media library controller can be part of a fibre channel-to-SCSI router, part of a media library to which other media libraries are connected or at any other location in the command flow path.
In operation, computer instructions 155 can be executable such that media library controller 115 can maintain a virtualized aggregate media library representing the drives, slots and robots available at physical media libraries 130 and 140. Additionally, media library controller 115 can associate each host with a virtual media library that represents the robots, drives and slots on a particular physical media library accessible by the associated host. In one embodiment of the present invention, a host will only see the robots, drives and slots that it is authorized to access. When a host issues a data operation command (e.g., read/write) referencing a virtual drive and slot in a virtual media library, media library controller 115 can determine if the command references a portion of physical media library to which the host has access and, if so, forward the command to the corresponding physical drive and robot. To forward the command, media library controller 115 can, if necessary, translate the command received from the host into a format usable by the physical robot to find particular tape cartridges.
In one embodiment of the present invention, a media library controller can contain a map of physical drives 131, 132, 133, 141 and 142, represented by logical drives 201-205, and a map of physical slots 135a-j and 145a-j, represented by logical slots 210a through 210t. Additionally, the media library controller can map robots 134 and 144, represented by logical robots 207 and 209, respectively. Virtualized aggregate media library 200, thus, represents the media library controller's view of the separate physical libraries that may have duplicate addresses for drives and robots.
If tape libraries 130 and 140 are SCSI tape libraries, for example, the media library controller can maintain virtualized aggregate media library 200 as a table of the target numbers and LUNs for physical drives and physical robots and a table of element numbers for the slots and drives at each physical media library. Table 1 is an example of a table that can be maintained by the media library controller as its “view” of the connected physical libraries. It should be noted that this table is provided by way of example only. It should be further noted that the data in table 1 can be maintained as one table, multiple tables (e.g., an address and element number table) as a file, as a database, or in any other format known in the art.
By maintaining a mapping of targets, LUNs and element numbers, the media library controller can maintain an aggregate view of the tape libraries which it controls. The addressing information contained in Table 1 is provided by way of example only and any addressing information sufficient to forward commands from the media library controller to the connected media libraries can be used to maintain virtualized aggregate media library 200.
In addition to establishing a virtualized aggregate media library 200, the media library controller can associate hosts with virtual media libraries. Each virtual media library represents the robots, drives and cartridge slots accessible by an associated host.
As shown in
The slots discussed above are each included in only one of the pools and, hence, only one of the virtual media libraries. The drives and robots, however, may be shared by multiple virtual media libraries so long as the virtual media libraries represent portions of the same physical media library. In order to avoid conflicts between hosts concurrently accessing the same drive or robot, the media library controller can establish access rules such as first come first served, giving priority to particular hosts or other such rules. In other embodiments of the present invention, there may be overlap between the slot pools. For instance, some slots may be shared as import/export slots that allow tape cartridges to be transferred between pools. Overlapping pools, however, are drawn from the same physical media library as tape cartridges can not be passed from one physical media library to another as the physical media libraries are physically separate.
By associating hosts with virtual media libraries, a media library controller can filter out tape access commands that affect drives, robots or slots not associated with a particular host. For instance, if host 110 attempts to access the tape cartridge in slot 135d, the media library controller can recognize that the target slot is not in the slot pool of Virtual Media Library A and can reject the command. Rejection of unauthorized commands can be handled in various manners, such as discarding the command without notification to the host, returning an error message or in another manner.
A Media library controller can also control access to each host in a variety of other ways, such through the access control method described in U.S. Pat. No. 5,941,972 entitled “Storage Router and Method for Providing Virtual Local Storage,” to Hoese, which is hereby fully incorporated by reference herein. In another embodiment of the present invention, access can be controlled by presenting the hosts with virtual drives, robots and slots and mapping the virtual robots, drives and slots to physical drives, robots and slots. In this embodiment, the hosts do not see drives, robots or slots that they are not allowed to access, but only see the virtual drives, robots and/or slots in the virtual media library with which they are associated. Rather than simply filtering commands, the media library controller can thus act as a virtualization layer between the physical media libraries and the hosts.
Table 2 is an example of a mapping between physical drives, robots and slots and virtual counterparts for Virtual Media Library A according to one embodiment of the present invention. It should be noted that this table is provided by way of example only. It should be further noted that the mappings of Table 2 can be maintained as one table, multiple tables (e.g., an address and element number table) as a file, as a database, or in any other format known in the art.
The virtual attributes of Table 2 can represent those seen by host 110 (i.e., as presented by a media controller) while the physical attributes can represent the media controller's view of the attached physical media libraries. Thus, for example, host 110 may see physical robot 134 as being at LUN 3, whereas the physical robot may actually be at LUN 4. When host 110 issues commands referencing physical robot 134, the command can be directed to the virtual attributes presented by the media controller. In other words, the commands can be based on host 110's view that robot 134 is at LUN 4. The media library controller can map the command to robot 134 and forward the command to the robot.
It should be noted that forwarding of the command may include changing the command. For example, if host 110 issues a command for robot 134 to place the tape cartridge from slot 135a in drive 131, host 110 can issue the command based on the virtual attributes with which it is presented. The media controller, upon receipt of the command may have to change the command to, for example, reference the proper element numbers for physical drive 131 and physical slot 135a. Thus, the command received from host 110, which can reference virtual element number 4 for drive 131 and virtual element number 1 for slot 135a, can be changed to reference physical element number 1 for drive 131 and physical element number 4 for slot 135a.
As can be noted from Table 2, the physical and virtual counterparts do not have to share the same target number, LUNs and/or element numbers. Thus, slot 435c, which represents physical slot 135h, can be assigned a different element number, for example, than that assigned to physical slot 135h. Host 110 could therefore see physical slot number 8 (i.e., slot 135h) of media library 130 as slot number 3. Because any address attributes can be assigned to a virtual drive, robot or slot, media library controller 115 can similarly configure a virtual slot presented to host 111 as slot number 3. Thus, host 111 may also see physical slot number 4 (i.e., slot 135d) as virtual slot number 3. Different hosts may thereby access what is seen by each as the same cartridge slot, when in reality, each host is accessing a different cartridge slot (assuming the hosts are associated with different pools).
Furthermore, as can be seen in
At step 510, the media library controller can associate hosts with virtual media libraries. Each virtual library can represent the portions of the physical media library to which the associated host has access. In the case of tape libraries, the virtual libraries can include the robots, drives and cartridge slots to which a host has access. The cartridge slots can be associated in pools with a particular host, each cartridge slot in a pool coming from a single physical host. In one embodiment of the present invention, the pools will not overlap. Thus, only hosts associated with a particular virtual media library will be able access a particular cartridge slot. In other embodiments of the present invention, the pools can overlap to provide, for example, import/export slots so that tape cartridges can be passed between pools. Each virtual media library can be associated with zero, one or multiple hosts.
In one embodiment of the present invention, the virtual media libraries can represent filtering rules. In this embodiment, each host can still see drives, robots and slots with which is not associated. But, if the host issues a command that affects a drive, robot or slot with which it is not associated, media library controller 115 will reject the command. In the embodiment shown in
In the case of a tape library, for example, the media library controller can map the physical drives, slots and robots to virtual drives, slots and robots that can, but do not necessarily, exhibit the same address attributes as the physical drive. When a host looks for available tape libraries on the network, the media library controller will present the virtual tape library to the host as a tape library available to that host. As the host will “see” a virtual robot and virtual drives, the host will in essence see a virtual robotic controller with access to virtual tape cartridges. The host can then format data operation commands based on the virtual media library with which it is presented.
At step 520, the media library controller can receive a data operation command from a host. Because the host sees the virtual drives, robots and slots presented to it by the media library controller (i.e., sees a virtual robotic controller, virtual drives and virtual slots), the command will be addressed to the virtual robots and drives and will reference the virtual slots. The media library controller, at step 525, can route the commands to the physical drives and robots according to the mapping between the virtual media library and the physical media library. Additionally at step 525, the media library controller can perform a translation, if necessary, to convert the command received from the host into a command usable by the physical robot to locate the correct tape cartridge. At step 530, the media library controller can pass the command to the appropriate physical media library so that the physical media library can carry out the data operation command initiated by the host. It should be noted that in passing the command to the physical robots and drives, the media library controller can change the command to account for the mapping between virtual attributes and physical attributes. For each additional data operation command, the media controller can repeat steps 520-530. The media controller can also optionally repeat the entire process of
The media library controller provides a central point of control for multiple, physically separate media libraries. By providing a central point of control, embodiments of the present invention can eliminate or substantially reduce conflicts between multiple hosts attempting to access the same media libraries. In the preferred embodiment, a plurality of hosts are connected to multiple tape libraries via a fibre channel storage area network (“SAN”). Each tape library includes one or more tape drives to perform read/write operations and slots to store tape cartridges and utilizes a robot to load individual tape cartridges into the tape drives. The media library controller is connected to the SAN between the hosts and the media libraries and acts as a central control point for the libraries. The media library controller maintains a virtualized aggregate view of the physical media libraries to which it is connected and creates a set of virtual libraries that represent partitions of the physical libraries. Hosts can be associated with the virtual libraries so that each host can only access the portions of the physical media libraries with which it is associated.
Although described as a separate unit in the embodiment of
Embodiments of the present invention provide advantages over prior art systems of managing media libraries by allowing multiple separate media libraries to be aggregated at a single point of control. Because the media libraries are independent, each will have its own robot or robots. This can allow backup operations to continue even if one of the media libraries experiences problems. The advantages of a multiple robot media library can thereby be achieved through the use of less expensive independent media libraries. Additionally, because embodiments of the present invention can partition multiple media libraries at a central control point, hosts running different applications can share portions of the same group of media libraries without conflict and without extensive reprogramming.
While the present invention has been described with reference to particular embodiments, it should be understood that the embodiments are illustrative and that the scope of the invention is not limited to these embodiments. Many variations, modifications, additions and improvements to the embodiments described above are possible. It is contemplated that these variations, modifications, additions and improvements fall within the scope of the invention as detailed in the following claims.
This Application claims priority under 35 U.S.C. §119(e) to U.S. Provisional Patent Application No. 60/425,034, entitled “A Method for Presenting a Single Logical Media Library Robotics Controller While Actually Operating Multiple Physical Media Library Robotics Controllers in an Aggregated Media Library Environment,” filed Nov. 8, 2002, by inventors John Tyndall, William Moody, and Robert Sims the contents of which are fully incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
4104718 | Poublan et al. | Aug 1978 | A |
4430701 | Christian et al. | Feb 1984 | A |
4945428 | Waldo | Jul 1990 | A |
5214768 | Martin et al. | May 1993 | A |
5455926 | Keele et al. | Oct 1995 | A |
5506986 | Healy | Apr 1996 | A |
5546315 | Kleinschnitz | Aug 1996 | A |
5546557 | Allen et al. | Aug 1996 | A |
5548521 | Krayer et al. | Aug 1996 | A |
5568629 | Gentry et al. | Oct 1996 | A |
5592638 | Onodera | Jan 1997 | A |
5598385 | Mizukami et al. | Jan 1997 | A |
5612934 | Dang et al. | Mar 1997 | A |
5740061 | Dewey et al. | Apr 1998 | A |
5761503 | Fisher | Jun 1998 | A |
5764615 | Ware et al. | Jun 1998 | A |
5790852 | Salm | Aug 1998 | A |
5870732 | Fisher et al. | Feb 1999 | A |
5892633 | Ayres et al. | Apr 1999 | A |
5914919 | Fosler et al. | Jun 1999 | A |
5959866 | Hanaoka et al. | Sep 1999 | A |
5963971 | Fosler et al. | Oct 1999 | A |
5971281 | Frary et al. | Oct 1999 | A |
6031798 | James et al. | Feb 2000 | A |
6041329 | Kishi | Mar 2000 | A |
6041381 | Hoese | Mar 2000 | A |
6044442 | Jesionowski | Mar 2000 | A |
6052341 | Bingham et al. | Apr 2000 | A |
6058494 | Gold et al. | May 2000 | A |
6085123 | Baca et al. | Jul 2000 | A |
6185165 | Jesionowski et al. | Feb 2001 | B1 |
6327519 | Ostwald et al. | Dec 2001 | B1 |
6327594 | Van Huben et al. | Dec 2001 | B1 |
6328766 | Long | Dec 2001 | B1 |
6336172 | Day et al. | Jan 2002 | B1 |
6356803 | Goodman et al. | Mar 2002 | B1 |
6360232 | Brewer et al. | Mar 2002 | B1 |
6374241 | Lamburt et al. | Apr 2002 | B1 |
6385706 | Ofek et al. | May 2002 | B1 |
6425035 | Hoese et al. | Jul 2002 | B2 |
6425059 | Basham et al. | Jul 2002 | B1 |
6480934 | Hino et al. | Nov 2002 | B1 |
6487561 | Ofek et al. | Nov 2002 | B1 |
6493721 | Getchius et al. | Dec 2002 | B1 |
6507883 | Bello et al. | Jan 2003 | B1 |
6507889 | Tsurumaki et al. | Jan 2003 | B1 |
6574641 | Dawson et al. | Jun 2003 | B1 |
6604165 | Terao | Aug 2003 | B1 |
6665786 | McMichael et al. | Dec 2003 | B2 |
6675260 | Torrey et al. | Jan 2004 | B2 |
6715031 | Camble et al. | Mar 2004 | B2 |
6725352 | Goodman et al. | Apr 2004 | B2 |
6725394 | Bolt | Apr 2004 | B1 |
6738885 | Zhang et al. | May 2004 | B1 |
6763419 | Hoese et al. | Jul 2004 | B2 |
6772231 | Reuter et al. | Aug 2004 | B2 |
6804753 | Moody, II et al. | Oct 2004 | B1 |
6839824 | Camble et al. | Jan 2005 | B2 |
6845431 | Camble et al. | Jan 2005 | B2 |
6950723 | Gallo et al. | Sep 2005 | B2 |
7136988 | Gallo | Nov 2006 | B2 |
7199809 | Lacy et al. | Apr 2007 | B1 |
20010020197 | Nakano et al. | Sep 2001 | A1 |
20020004883 | Nguyen et al. | Jan 2002 | A1 |
20020019863 | Reuter et al. | Feb 2002 | A1 |
20020144048 | Bolt | Oct 2002 | A1 |
20020169521 | Goodman et al. | Nov 2002 | A1 |
20020188592 | Leonhardt et al. | Dec 2002 | A1 |
20020199077 | Goodman et al. | Dec 2002 | A1 |
20030014585 | Ji | Jan 2003 | A1 |
20030070053 | Gallo et al. | Apr 2003 | A1 |
20030084240 | Torrey et al. | May 2003 | A1 |
20030126360 | Camble et al. | Jul 2003 | A1 |
20030126361 | Slater et al. | Jul 2003 | A1 |
20030126362 | Camble et al. | Jul 2003 | A1 |
20030126395 | Camble et al. | Jul 2003 | A1 |
20030126396 | Camble et al. | Jul 2003 | A1 |
20030126460 | Camble et al. | Jul 2003 | A1 |
20030131157 | Hoese et al. | Jul 2003 | A1 |
20030131253 | Martin et al. | Jul 2003 | A1 |
20030135580 | Camble et al. | Jul 2003 | A1 |
20030212873 | Lee et al. | Nov 2003 | A1 |
20030221054 | Wu | Nov 2003 | A1 |
20040044828 | Gibble et al. | Mar 2004 | A1 |
20040044871 | Weber et al. | Mar 2004 | A1 |
20040054838 | Hoese et al. | Mar 2004 | A1 |
20040064641 | Kodama | Apr 2004 | A1 |
20040088513 | Biessener et al. | May 2004 | A1 |
20040107300 | Padmanabhan et al. | Jun 2004 | A1 |
20040111580 | Weber et al. | Jun 2004 | A1 |
20040133915 | Moody et al. | Jul 2004 | A1 |
20040139094 | Tyndall et al. | Jul 2004 | A1 |
20040139240 | DiCorpo et al. | Jul 2004 | A1 |
20040139260 | Steinmetz et al. | Jul 2004 | A1 |
20040148460 | Steinmetz et al. | Jul 2004 | A1 |
20040148461 | Steinmetz et al. | Jul 2004 | A1 |
20060069844 | Gallo et al. | Mar 2006 | A1 |
20060149919 | Arizpe et al. | Jul 2006 | A1 |
Number | Date | Country |
---|---|---|
1 156 408 | Nov 2001 | EP |
WO 0227463 | Apr 2002 | WO |
WO03104971 | Dec 2003 | WO |
Number | Date | Country | |
---|---|---|---|
20040139094 A1 | Jul 2004 | US |
Number | Date | Country | |
---|---|---|---|
60425034 | Nov 2002 | US |