1. Field of the Invention
The present invention relates to a secure software execution mechanism. In particular, it relates to a mechanism appropriate for software circulation.
2. Description of the Related Art
One of the most notable features of the Internet is that it is a truly open environment. Not only is it being constantly extended worldwide, but also no one can fully control or determine who the users are, or what software and contents are distributed through it. These features are in stark contrast to traditional, closed computer environments such as batch, TSS, LAN, or personal systems. Throughout the history of computer systems, the computer environment has almost always been closed, so designers of system software have implicitly assumed a closed environment was the norm. The worldwide spread of the Internet occurred within a relatively short portion of the history of computer system development, so there was little time for designers of system software to fully anticipate the issues that would arise when closed environments became open. Though the environment has drastically opened up, system software whose basic design is based on an assumption of a closed environment is still used. Thus, current computer systems can often be characterized as putting new wine in old bottles.
If a network environment is closed and users cannot access an open network environment such as the Internet, malicious users and the files created by such users are far less likely to exist. Unfortunately, in the Internet environment, this cannot be assumed. Thus, obtaining files, particularly software that includes executable or interpretable code, from the Internet can be a risky activity. One approach now being used to lessen the risk is to use a code-signing technique such as Microsoft's Authenticode. A promising technical approach to solve this problem is to create a ‘sandbox’ and encapsulate risky effects in a limited, controllable environment separate from the users' ordinary environment. This approach has been adopted in many systems, such as Java, SFI, Janus, MAPbox, and SubDomain.
To clarify the concept of secure software circulation, a model for unsecure software circulation, which is a generalization of software distribution as conventionally performed, is first presented. A model for secure software circulation is then presented and explained how it can be used.
(A Model for Unsecure Software Circulation)
Software circulation is the term used hereafter to refer to a generalization of the ‘software distribution’ concept. Software distribution usually means unidirectional, one-time, one-to-many distribution of a software package. By relaxing these properties, that is, by making software distribution multidirectional, multi-time, many-to-many, the concept of software circulation is obtained. Software circulation is composed of four basic operations: encapsulation, transfer, extraction, and execution. For each operation, a graphic representation as shown in
The ‘encapsulation operation’ shown in
By combining these operations, typical software circulation scenarios can be represented.
The presented model in
From these reasons, this model is called the unsecure software circulation (USC) model.
The objectives of the present invention are to solve the above-mentioned problems, and to provide a secure software execution mechanism appropriate for software circulation.
In order to achieve the above objectives, one aspect of the present invention is a secure software execution system allowing secure software execution, which includes a pot that includes a file name storage unit, which stores the names of files to be used including an executable file, and a file storage unit, which stores files; and a mapping means that translates a file name in the file name storage unit into the file name of an execution system, wherein the mapping means limits accessible files to only those described in the file name storage unit in the pot.
The mapping means extracts a file from the file storage unit and provides it to an execution system before execution or when required during execution.
An executable file name to be initiated first can be stored in the file name storage unit.
In addition, the file name storage unit stores a file name of a file other than those in the file storage unit, and the mapping means maps that file name to a file for an execution system and/or a file in another pot.
Furthermore, the file name storage unit can store directory names, and the mapping means maps each of those directory names to a directory for an execution system and/or a directory in another pot. In this case, the mapping means associates the directory names with a plurality of directories in a predetermined order, and maps them to files in the directories in that order.
The file name storage unit can store file names in a site on a network, and the mapping means transfers a file having the file name from a site to an execution system.
The mapping means can map a process as a file and map to a file created by a process.
The mapping means carries out mapping in conformity with a security policy specification for an execution system. The security policy specification includes specification of system calls that can be issued during execution.
The security policy specification can be downloaded from another site on the network.
Another aspect of the present invention is a server system including pot information and security policy information, which includes: a database that stores pot information and security policy specification corresponding to the pot information; and a retrieving means that can retrieve the security policy by identifying a pot.
Yet another aspect of the present invention is a recording medium that records a program describing implementation of a mapping means in a computer system, which translates a file name in a file name storage unit in a pot into a file name for an execution system, wherein the pot includes a file name storage unit, which stores the names of files to be used including an executable file, and a file storage unit, which stores files; wherein the mapping means limits accessible files to only those described in the file name storage unit in the pot when executing that program.
An embodiment of the present invention is described forthwith while referencing the drawings.
Now, a model for secure software circulation (the SSC model) is considered. To start with, the term ‘secure’ should be explained. First, it is generally accepted that an absolutely ‘secure’ system is virtually impossible to design. This model and our implemented system based on this model is simply more secure than the USC model regarding security-related issues that are more easily handled in a systematic way. Second, the unsecure aspects of the transfer operation are not limited to software circulation; they are also issues of concern in general information transfer.
The central idea of the SSC model to be described below is that the inner and the outer parts of circulated software during both the execution and the encapsulation are distinguished. To enable this, two concepts have been introduced into the model. First, files are not extracted from archives; instead, the concept of using archive files as a file system is extended. Second, program execution is enabled within a distinct virtual address space associated with the archive space. The SSC model integrates the two spaces—the virtual address space and the file system—into one to create a sandbox called a pot. Each pot has its own, distinct view for both a virtual address space and a virtual file space.
(Basic Operation of the SSC Model)
The basic operation of the SSC model is defined as follows (see
The encapsulation operation shown in
The mapping operation in the SSC model is a substitute for the extraction operation of the USC model. In
d) shows the execution operation. In the execution operation, a program 242 in a pot 240 is not executed in a virtual address space that shares a file system of the execution site 234. A pot 240 is instead associated with a virtual process space just like its own file system, and the program 242 in the pot is executed within that environment; no files other than those appearing in the pot can be seen. It specifies a mapping scheme and the resources allowed to be used.
As described above, a pot of the present invention has two states depending on whether a process is associated with the pot. To distinguish between the two states, the term pot-file is used when a process is not associated with the pot, and pot-process when it is associated.
At the receiver site 314, the user prepares a security policy description 340 that specifies the mapping schemes between the file in the pot and a local file and between the file in the pot and a file in another pot. This security policy 340 specifies that during the execution, no other files in the local file system of the receiver site can be seen. The security policy file 340 can also specify system calls of the OS kernel allowed to be issued in the execution. This security policy will be described later in detail.
At the receiver site 314, intangible files 336 and 338 within a pot may be mapped to a file 354 in a local file system or a file 356 within another pot 350 and processed using a file 334 in a pot or the mapped file 354 or 356 by executing a program 332, in conformity with the specification of the security policy 340. In this way, a pot forms a sandbox that is distinguished from the users' ordinary process execution environment.
Two slight extensions to the mapping operation are pointed out.
(1) Directory Mapping
The mapping of a directory in a pot to a directory in another pot or a local ordinary file system as shown in
(2) Cascade Mapping
Cascading of the mapping is permitted. The informal operational semantics of the cascade mapping is as follows. The cascade mapping operation results in a totally ordered relationship between multiple directories in pots and/or an ordinary file system. When the pathname of a file is retrieved through a mapping operation, the totally ordered directories are retrieved in the total order, and the first one found is the result. These extensions are useful in that they facilitate and simplify the description of security policies, and also make the computing of transferred pots more flexible. This is described using
In
(Utilization of the Secured Software Circulation (SSC) Model)
Now, how the SSC model can be applied to represent typical computation requiring secure software transfer in an open network environment is shown.
(1) Secure Interpretation of Downloaded Code
A typical usage of SSC is the secure interpretation of downloaded codes. This form of computation has been made popular by the widespread use of Java and its applet system. SSC can be used to provide a general framework that enables secure interpretation of a downloaded code as shown in
(2) Secure Execution of Dynamically Generated Native Code
Next, a more advanced form of downloaded code execution is described (
In
In
As shown in
(3) Secure Execution of Mobile Agents
Mobile agent systems represent one of the most sophisticated forms of distributed computation. Interestingly, this form of computation can be represented in a straightforward way, in principle, by using the SSC model.
In
(4) Secure Workflow Computing
A representation for secure workflow computation can be obtained by slightly modifying that for the secure mobile agent computation. The difference is that the program code is included in the transferred pot in mobile agent computation, while each executed program code is usually locally prepared at each computing site in workflow computation. Typical settings are shown in
a) shows that a pot 530, which includes files to be computed by executing a program, is transferred to each of sites 512 and 514, and those files are processed by executing program codes 522 and 542 in the pots 520 and 540 at each site. At each site, mapping the pots 520 and 540 that include the programs 522 and 542 to the transferred files in the pot 530 is carried out, respectively.
In
(SoftwarePot: An Implementation of the SSC Model)
The SSC model described above can be implemented in several ways. This section describes a portable approach that does not modify the OS kernel. Instead, it uses functionalities extensively to interpret and manipulate issued system calls. Such functionalities are provided in many modern operating systems such as Solaris, Linux, and FreeBSD. The system designed based on this approach is called SoftwarePot. It supports the four basic operations of the SSC model described in
(1) Encapsulation Operation
The encapsulation operation is implemented by collecting files specified as encapsulated and storing these files in a pot-file.
This is described using
In
The pathname of the statically stored file in the static file section 610 (see
In addition to the basic function of statically storing a file in a pot-file, the SoftwarePot system has a function used to store only the original location of the files to be stored, and the contents of the files are dynamically transferred when required. This is specified in the dynamic file section 620 preceded by ‘dynamic:’ 622, which specifies encapsulation as shown in
The static method is useful for storing absolutely necessary files, while the dynamic method is useful for storing optionally necessary files and for reducing the size of a pot-file.
The section 630 preceded by ‘required:’ 632 specifies which files or directories must be mapped at the execution time. In
The section 640 preceded by ‘saved:’ 642 specifies that the modification of files in the listed directories should be permanently reflected in the pot-file system; and that the modification of other files is only temporarily reflected within the execution session and is thrown away after the session. The section 650 preceded by ‘entry:’ 652 specifies the default program file (see 654 in
(2) Mapping and Execution Operations
The implementation of the mapping and execution operations is integrated in the SoftwarePot system, thus they will be described together.
The essence of both operations is name translation; that is, every primitive operation to manipulate files (such as open, read, write, lseek, close system-calls) is redirected to the mapped destination file.
In
Furthermore, a temporary file 982 created by another process 980 can be accessed. This function allows limitation on information that can be revealed in the pot-process 910, or a disguised file not actually existing to appear in the pot-process 910.
The file system space viewed from a pot-process 910 is a virtual one created in conformity with the name translation specification, and the pot-process 910 can never directly see the ‘real’ file system of the executing operating system.
For the extraction, there are two modes: the eager extraction mode and the lazy extraction mode. In the eager extraction mode, all the files statically stored in a pot-file are extracted at once when the execution operation is initiated. In the lazy extraction mode, on the other hand, each file is extracted only when it needs to be accessed.
How to describe a specification for name mapping and security policy in SoftwarePot is explained using the example shown in
The ‘map:’ section 1010 specifies that each file or directory in the pot-file specified in the first column is mapped to the existing files or directories specified in the second column. In the example, the line ‘/etc/termcap /lib/tools.pot:/etc/termcap’ specifies that the ‘/etc/termcap’ file accessed in the pot-process is redirected to the file having the same name in the pot-file named ‘/lib/tools.pot’. The line ‘/alpha /beta,/gamma,/delta’ shows a way to specify cascade mapping. For instance, accesses to the file ‘/alpha/x’ will be redirected to either file ‘/beta/x’, ‘/gamma/x’, or ‘/delta/x’, where in this file selection, ‘/beta/x’ has the highest priority and ‘/delta/x’ has the lowest.
The ‘temporary:’ section 1020 specifies that the execution output of a program specified by an initiation command ‘/sbin/account_processing/users all’ is stored in a temporary file, and a file named ‘/etc/account’ in the pot-process is mapped to that temporary file.
The ‘indirect:’ section 1030 specifies a special mapping function called ‘process mapping’; that is, inputting and outputting files in a pot-process is redirected to interprocess communication. In the example, ‘/etc/passwd /home/user2/bin/passwd_filter’ specifies that accesses the file ‘/etc/passwd’ in the pot-file is redirected to interprocess communication with the process initiated by the command ‘/home/user2/bin/passwd_filter’.
As described above, a function specified by the ‘indirect:’ section maps interprocess communication with the initiated process as if it is a file; while a function specified by the ‘temporary:’ section stores an execution result output in a temporary file, and maps it to that temporary file. When costs (time and file capacitance) for generating the temporary file are low, the ‘temporary:’ section function should be used, otherwise, when high, the ‘indirect:’ section function should be used. In addition, the ‘indirect:’ section function is more dynamic, therefore, the contents can be generated dynamically. Note that the temporary file contents must be generated by the program specified in the ‘temporary:’ section before the mapping operation.
The remaining sections 1040 and 1050 are used for specifying the security policy. In the ‘network:’ section 1040, the example specifies that all communication-related system calls are prohibited, with exception that connection to TCP-port 80 of IP address 130.158.80.*, connection to TCP-port 21 of 130.158.85.97, and bindings to TCP-port 22 of ‘*.tsukuba.ac.jp’ are allowed.
On the other hand, the ‘syscall:’ section 1050 specifies the permission given for system calls other than network-related ones. In the example, all system calls other than network-related ones and those listed in the last two lines (preceded by the keyword ‘deny’) are allowed.
Now implementation of the name translation is explained using
Most modern operating systems support functions to intercept system calls just before and after the execution of the calls in the OS kernel, and for user-level code to be executed upon each interception. Also, modern OSs allow a user process to examine and modify the contents of another user process in a controlled manner. By combining these functions, a required name mapping mechanism is implemented transparently without modifying the OS kernels.
In
When a pot-process 1100 issues an open system call, a kernel 1300 catches the call and calls up the monitor (S1302). The monitor 1200 looks into the contents of the pot-process 1100 and obtains the pathname 1122 of the file being opened (S1204). By referring to the pathname translation table 1220, the monitor 1200 decides to which actual file the open system call should be applied. If the lazy file extraction mode is specified, the file is extracted from the file storage region in the pot-file; if cascade mapping is specified, file-retrieving is done according to the specified totally-ordered directory list; if dynamic file transfer is specified in the mapping specification, an appropriated file is obtained via the network; if the ‘indirect:’ option is specified, a specified process is initiated and inter-process communication between the pot-process and the initiated process is established.
The monitor process 1200 writes the translated pathname 1142 to the unused area (a stacking segment 1140 in
The monitor 1200 then instructs the kernel 1300 to perform the actual processing for open (S1208). The kernel 1300 performs the processing for open (S1310). The kernel 1300 again calls up the monitor 1200 (S1312). The monitor 1200 restores the content of the register and erases the translated pathname written in step S1206 (S1214). Finally, the monitor 1200 instructs the kernel 1300 to resume execution of the pot-process 1100.
During the execution, the pot-process may issue a fork system call and spawn other pot-processes. This is described using
(Secure Software Circulation)
When executing software in the SoftwarePot, behavior of that software is monitored. When the software behaves contrary to the user's intention, the user must determine either abnormal termination or permission for continuation of that behavior. The security policy to specify the above must be created for each software. The user knowledgeable on the computer system may create that security policy. For a user other than the above, a third-party organization must be able to create a security policy. The relationship therebetween is described using
In
In addition, a creator who created the security policy for that software (see a security policy site 1520 in
Those processes are described in detail using
(Pot-File Registration)
Registration of a pot-file with the pot-file creation site 1510 and the authentication/registration site 1530 of
In
(Security Policy Registration)
The registration of a security policy by the security policy site 1520 and the authentication/registration site 1530 in
To begin with, a creator who created the security policy corresponding to the obtained pot-file calculates a hash value or a digest of that pot-file using an algorithm such as MD5 for registration of that created security policy (S1712 and S1714). By pressing a send button 1746 in a window 1740 of
After reception, the authentication site 1530 registers that received security policy entity (file) or the URL so that it is associated with the pot-file (S1730), and informs of completion of registration in the window 1770 shown in
(Downloading Security Policy)
Pot-file authentication at the user site 1540 and the authentication/registration site 1530 of
A user obtains a pot-file via e-mail, Web, or CD-ROM (S1812). To do this, authentication that this file is not infected by, for example, a virus, and a corresponding security policy must be obtained. Accordingly, to begin with, a digest (hash value) of the obtained pot-file is calculated by MD5, for example (S1814). By pressing a send button 1846 in a window 1840 of
At the user site 1540, the received file attribute information 1852 is displayed as shown in an exemplary window 1850 of
(Experiments)
The SoftwarePot system is implemented in the Solaris 5.6 operating system based on the implementation scheme described above (see Table 1). About 5,000 lines of C program code were required for implementation. This section describes the experimental results obtained from the implementation. The hardware platform was a Sun Ultra 60 workstation (CPU: UltraSPARC II, 4 MB Cache Memory, 512 MB main memory, 36 GB hard disc).
Three microbenchmark programs were written and the overhead imposed on system calls was identified by comparing the execution time for these programs with and without SoftwarePot. The benchmark programs were as follows:
(1) Fib
This program calculates a Fibonacci number. It invokes no system calls while calculating.
(2) Getpid-Caller
This program calls the ‘getpid’ system call repeatedly in its main loop (10 million times), but does not invoke any other system call.
(3) Open-Caller
This program repeats an operation that opens the same file and immediately closes it. It invokes pathname system calls many times: it executes 10,000 pairs of an open system call and a close system call.
The eager extraction mode is used in this experiment. The file extraction times in the above programs were extremely small and are not included in the results shown. Experimental results are given in Table 2.
In Table 2, the performance of Fib was little influenced by whether it ran with SoftwarePot. This was quite natural because the monitoring process in SoftwarePot intercepts nothing but system calls. ‘Getpid-caller’ was slower when it ran with SoftwarePot. This was unexpected because ‘getpid’ is not a pathname system call, and such calls are never intercepted. When some system calls are configured for interception, a certain overhead is assumed to be added to all system calls. The benchmark ‘open-caller’ ran an order of magnitude slower with SoftwarePot (the difference in overall execution time was 8,246 milliseconds). Since ‘open-caller’ invoked ‘open’ 10,000 times, the penalty paid for each ‘open’ was about 0.8 milliseconds. Since the amount of computation by executing the software when intercepting one pathname system call does not depend on the kind of system call, the same penalty will be paid for all pathname system calls.
(File Access Control Function)
As described above, the secure software execution system of the present invention allows execution of software separated within a pot-file while verifying safety. This allows assurance of the safety for user's computer resources even if malicious operation or malfunction occurs when introducing and executing software.
In addition, the system of the present invention provides a function to dynamically determine a file obtaining method and a file generation method when circulating a file. This allows implementation transparent to application (i.e., unbeknown to application), of obtaining a file at the execution time by storing not only a file entity, but also a file location or a dynamic file obtaining method when storing a file in SoftwarePot.
However, there is another problem with the conventional file circulation in that giving file access authority (read-out or write-in authority) to a specific user has not yet been implemented transparently to application.
To solve this problem, a file access control function can be added to the secure software execution system of the present invention. The file access control function is a function to give reading out and writing in authorities of a file only to a predetermined user. This function can be implemented through the following steps (1) and (2).
In the following, the above step (1) is described first, and then step (2).
(1) Description of Access Control Specification
As described in section (1) Encapsulation operation of (SoftwarePot: SSC Model Implementation), the encapsulation operation is implemented by collecting files specified as encapsulation targets and storing those files in a pot-file. In the above description, an example of encapsulation specification is described using
In the lines 618 of
Similarly, in the lines 628 of
Note that in
The lines 664 or the second through fourth lines in the hybrid file section 660 specify registration, as a hybrid file /mybin/viewer13 pluginA, of two files (the priority decreases from left to right): http://www.foo.com/viewer_pluginA—1 and http://www.foo.com/viewer_pluginA—2, which are specified by ‘dynamic=’ as dynamic files, and a file http://www.foo.com/viewer_pluginA—1, which is specified by ‘static=’ as a static file.
Note that specifications other than those described above in
(2) Access Control Using Encryption Technique
A pot-file creator may specify users having read-out or write-in authority of a file entity by describing access control specification as shown in the above step (1). The specified access control is implemented using an encryption technique.
The access control using the encryption technique is described forthwith while referencing
The present invention uses the following three methods 1 through 3 to implement access control.
Method 1: Access control using simple public key method
Method 2: Access control using secret key method
Method 3: Access control based on read/write key method using public key technique
These three methods are described forthwith in order.
(Method 1: Access Control Using Simple Public Key Method)
Method 1 is available when specifying only read-in authority.
In
In this case, the file entities F (1910) are encrypted using the public keys of the users A, B, and C, and stored in the pot-file 1920 (in the case of a static file) or a server on the network (in the case of a dynamic file).
The file entity F is then decrypted using each user's secret key when each user uses the pot-file 1920. For example, the file entity F (1932) encrypted using the user A's public key is decrypted by the user A's secret key. This decryption allows read out of the file entity F (1910) for each user. On the other hand, since users who do not have read-out authority cannot carry out decryption, the contents of the file entity F (1910) cannot be read out.
(Method 2: Access Control Using Secret Key Method)
Since according to the above described method 1, the file entities must be encrypted for the number of users to whom read-out authority is given, a large storage area may be needed. Method 2 is an improved method 1, and allows conservation of storage region by decreasing the number of encrypted file entities.
Method 2 is available when specifying only read-in authority as with method 1.
In
In this case, to begin with, a secret key K (1940) for a secret key encryption algorithm (e.g., DES algorithm) is generated, and the file entity F (1910) is then encrypted using that secret key K and secret key encryption algorithm. The secret key K is then encrypted using the public keys of the users A, B, and C. Those encrypted files are stored in the pot-file 1920 (in the case of a static file) or a server on the network (in the case of a dynamic file).
When each user uses the pot-file 1920, to begin with, the secret key K is decrypted using each user's secret key. For example, the secret key K (1942) encrypted using the user A's public key is decrypted by user A's secret key. The file entity F (1930) encrypted using the secret key K is decrypted using the secret key K and secret key encryption algorithm. This decryption allows read out of the file entity F (1910) for each user. On the other hand, since users who do not have read-out authority cannot carry out decryption of the secret key K, the contents of the file entity F (1910) cannot be read out.
(Method 3: Access Control Based on Read/Write Key Method Using Public Key Technique)
Method 3 is available when specifying only read-out authority and when specifying both read-out authority and write-in authority of a single file.
In
In this case, to begin with, a pair of a public key and a secret key for a public key algorithm is generated for the file entity F (1910); one is the a read key (1950), and the other is a write key (1960). The file entity F (1910) is then encrypted using the write key. The write key is then encrypted using the public keys of the users (A and B) who have write-in authority. On the other hand, the read key is then encrypted using the public keys of the users (A, B, and C) who have read-out authority. Those encrypted files are stored in the pot-file 1920 (in the case of a static file) or a server on the network (in the case of a dynamic file).
To begin with, the read keys are decrypted using the secret keys when each of users (A, B, and C) who has read-out authority uses the pot-file 1920. For example, the read key (1952) encrypted using the user A's public key is decrypted by user A's secret key. The file entity F (1930) encrypted using the write key is decrypted using the read key. This decryption allows read out of the file entity F (1910) for each user who has read-out authority.
On the other hand, the write key is decrypted using each user's secret key when each user (A, B) who has write-in authority writes in the file entity F. The file entity F after being written in is then encrypted using the write key.
On the other hand, since users who do not have read-out authority cannot carry out decryption of the read key, the contents of the file entity F (1910) cannot be read out. In addition, since users who do not have write-in authority cannot carry out decryption of the write key, the fact that they do not have write-in authority is detected by the SoftwarePot system. Since the file entity F cannot be correctly encrypted even if attempting to write-in by falsely manipulating the SoftwarePot system, unauthorized write-in operation is detected by the users who have read-out authority.
(Effectiveness of File Access Control Function)
Usage of the above described access control function allows implementation transparent to application (i.e., unbeknown to application), of giving file access authorities (read-out authority and write-in authority) to a specific user.
In addition, since the above described access control function uses the encryption technique, even if a user who does not have access authority falsely changes the SoftwarePot system, other SoftwarePot systems that are not changed can carry out correct access control (i.e., only users who have read-out/write-in authority can carry out a read-out/write-in operation).
According to the above described method 3, if a file which is falsely written is to be circulated, the correct SoftwarePot system can detect that false write-in. In other words, when a file, which is falsely written (changed) by a user who does not have access authority, is to be circulated, that false write-in (change) is detected when the users who have read-out authority read that file.
In addition, a pot-file creator can configure a user group ad hoc, and carry out a groupware process by providing access control within that user group. At this time, the groupware process can be carried out without modifying the existing single user application.
According to the above described configuration, a secure software execution mechanism appropriate for software circulation can be provided.
Number | Date | Country | Kind |
---|---|---|---|
2001-380629 | Dec 2001 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP02/12659 | 12/3/2002 | WO | 00 | 4/15/2005 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO03/050662 | 6/19/2003 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6167522 | Lee et al. | Dec 2000 | A |
20020092003 | Calder et al. | Jul 2002 | A1 |
Number | Date | Country |
---|---|---|
2001-175526 | Jun 2001 | JP |
WO 9844404 | Oct 1998 | WO |
Number | Date | Country | |
---|---|---|---|
20050228990 A1 | Oct 2005 | US |