1. Field of the Invention
The present invention relates to an information processing system including a plurality of processors and a memory managing method used in the information processing system.
2. Description of the Related Art
Conventionally, computer systems such as server computers have utilized system architecture such as a multiprocessor and a parallel processor in order to improve in throughput. Both of the multiprocessor and parallel processor achieve a parallel computing operation using a plurality of processing units.
Jpn. Pat. Appln. KOKAI Publication No. 10-143380 discloses a computer system having a plurality of processing units. This computer system includes a single high-speed CPU, a plurality of low-speed CPUs and a shared memory. Processes are assigned to the high-speed and low-speed CPUs in consideration of parallelism and execution time of each process.
Not only the computer system but also an embedded device, which needs to process a large amount of data such as AV (audio video) data in real time, has recently required that system architecture such as a multiprocessor and a parallel processor be introduced to improve in throughput.
Under the present circumstances, however, a real-time processing system that is predicated on the above system architecture including a plurality of processors is hardly reported.
In a real-time processing system, each operation needs performing under given timing constraint. If, however, system architecture such as a multiprocessor and a parallel processor is applied to the real-time processing system, there occurs a problem that the performance of each of the processors cannot be used sufficiently because of the conflict of access with a shared memory, the constraints of the bandwidth of a memory bus and the like. Moreover, communications for transferring data between threads executed by different processors are carried out through a buffer on the shared memory. Therefore, latency associated with the communications between the threads that are frequently interacting with each other becomes a serious problem.
An object of the present invention is to provide an information processing system and a memory managing method capable of efficiently executing a plurality of threads in parallel to each other using a plurality of processors.
According to an embodiment of the present invention, there is provided an information processing system comprising a first processor having a first local memory, a second processor having a second local memory, a third processor having a third local memory, means for mapping one of the second local memory and the third local memory in part of an effective address space of a first thread to be executed by the first processor, the one of the second local memory and the third local memory being the local memory of a corresponding one of the second processor and the third processor, which executes a second thread interacting with the first thread, and means for changing a local memory to be mapped in part of the effective address space of the first thread from the one of the second local memory and the third local memory to the other of the second local memory and the third local memory when a processor that executes the second thread is changed from the one of the second processor and the third processor to the other of the second processor and the third processor.
An embodiment of the present invention will now be described with reference to the accompanying drawings.
The connecting device 13 has a QoS (quality of service) function that guarantees a data transfer rate. The QoS function is fulfilled by transferring data through the connecting device 13 at a reserved bandwidth (transfer rate). The QoS function is used when write data needs transmitting to the memory 14 from one VPU 12 at e.g., 5 Mbps or when data needs transferring between one VPU 12 and another VPU 12 at e.g., 100 Mbps. Each of the VPUs 12 designates (reserves) a bandwidth (transfer rate) for the connecting device 13. The connecting device 13 assigns the designated bandwidth to the VPU 12 by priority. If a bandwidth is reserved for data transfer of a VPU 12, it is secured even though another VPU 12, MPU 11 or I/O controller 15 transfers a large amount of data during the data transfer of the former VPU 12. The QoS function is particularly important to computers that perform real-time operations.
The computer system shown in
The processing unit 31 uses the local storage 32 as a main memory. The processing unit 31 does not gain direct access to the memory 14 but instructs the memory controller 33 to transfer the contents of the memory 14 to the local storage 32. The processing unit 31 accesses the local storage 32 to read/write data. Moreover, the processing unit 31 instructs the memory controller 33 to write the contents of the local storage 32 to the memory 14.
The memory management unit 22 of the MPU 11 and the memory controllers 33 of the VPUs 12 perform virtual memory management as shown in
For example, the following data items are mapped in the real address (RA) space viewed from the MPU 11 and each VPU 12, as shown in
1. Memory 14 (main storage device)
2. Control registers of MPU 11
3. Control registers of VPUs 12
4. Local storages of VPUs 12
5. Control registers of I/O devices (including control registers of I/O controller 15)
The MPU 11 and VPUs 12 can access any address in the real address space by the virtual memory management function in order to read/write data items 1 to 5 described above. It is particularly important to be able to access the real address space and thus access the local storage 32 of any VPU 12 from the MPU 11 and VPUs 12 and even from the I/O controller 15. Furthermore, the segment table 50 or page table 60 can prevent the contents of the local storage 32 of each VPU 12 from being read or written freely.
The MPU 11 can manage the VPUs 12 using a hardware mechanism such as a control register. For example, the MPU 11 can read/write data from/to the register of each VPU 12 and start/stop each VPU 12 to execute programs. Communication and synchronization between the MPU 11 and each of the VPUs 12 can be performed by means of a hardware mechanism such as a mailbox and an event flag, as can be communication and synchronization between the VPUs 12.
The computer system according to the present embodiment allows an operation of an electric device, which makes a stringent demand on real-time operations as conventionally implemented by hardware, to be carried out by software. For example, one VPU 12 performs a computation corresponding to some hardware components that compose the electric device and concurrently another VPU 12 performs a computation corresponding to other hardware components that compose the electric device.
In order to perform operations of the hardware shown in
The structural description 117 is information indicative of how the programs (threads) in the program module 100 are combined and executed. The structural description 117 includes information indicative of a relationship in input/output between the programs 111 to 116 and costs (time) necessary for executing each of the programs 111 to 116.
The structural description 117 shows modules (programs in the program module 100) each executed as a thread and their corresponding inputs, outputs, execution costs, and buffer sizes necessary for the outputs. For example, the V-DEC program of No. (3) receives the output of the DEMUX program of No. (1) as an input and transmits its output to the PROG program of No. (5). The buffer necessary for the output of the V-DEC program is 1 MB and the cost for executing the V-DEC program in itself is 50. The cost can be described in units of time (time period) necessary for executing the program, or step number of the program. It also can be described in units of time required for executing the program by a virtual processor having some virtual specifications. Since the VPU specifications and performance may vary from computer to computer, it is desirable to describe the cost in such virtual units. If the programs are executed according to the structural description 117 shown in
The structural description 117 also shows coupling attribute information, which indicates a coupling attribute between threads corresponding to the programs 111 to 116, as thread parameters. The coupling attribute includes two different attributes of a tightly coupled attribute and a loosely coupled attribute. A plurality of threads having the tightly coupled attribute are executed in cooperation with each other and referred to as a tightly coupled thread group. The computer system of the present embodiment schedules the threads belonging to each tightly coupled thread group such that the threads belonging to the same tightly coupled thread group can simultaneously be executed by different VPUs. A plurality of threads having the loosely coupled attribute is referred to as a loosely coupled thread group. A programmer can designate a coupling attribute between threads corresponding to the programs 11 to 16 using thread parameters. The tightly and loosely coupled thread groups will be described in detail with reference to
Referring to
An operation to determine which program is executed by each of the VPUs 2 and when it is done to perform a desired operation without delay is called scheduling. A module to carry out the scheduling is called a scheduler. In the present embodiment, the scheduling is carried out based on the above structural description 117 contained in the program module 100.
The program module 100 shown in
Operating System
When only one OS (operating system) 201 is loaded into the computer system of the present embodiment, it manages all real resources (MPU 11, VPUs 12, memory 14, I/O controller 15, I/O device 16, etc.), as shown in
On the other hand, a plurality of OSes can be performed at once using a virtual machine system. In this case, as shown in
The virtual machine OS 301 schedules the guest OSes 302 and 303 to allocate all the resources in the computer system to the guest OSes 302 and 303 on a time-division basis. Assume that the guest OS 302 carries out a real-time operation. To perform the operation thirty times per second at an exact pace, the guest OS 302 sets its parameters to the virtual machine OS 301. The virtual machine OS 301 schedules the guest OS 302 to reliably assign necessary operation time to the guest OS 302 once per 1/30 second. The operation time is assigned to a guest OS that does not require a real-time operation by priority lower than a guest OS that requires a real-time operation.
In order to execute programs using a plurality of VPUs 12 in the present embodiment, a software module called a VPU runtime environment is used. The soft module includes a scheduler for scheduling threads to be assigned to the VPUs 12. When only one OS 201 is implemented on the computer system of the present embodiment, a VPU runtime environment 401 is implemented on the OS 201 as illustrated in
1. Mode of implementing the VPU runtime environment 401 in the virtual machine OS 301 (
2. Mode of implementing the VPU runtime environment 401 as one OS managed by the virtual machine OS 301 (
3. Mode of implementing a dedicated VPU runtime environment in each of the guest OSes managed by the virtual machine OS 301 (
4. Mode of implementing the VPU runtime environment 401 in one of the guest OSes managed by the virtual machine OS 301 (
The above modes have the following merits:
Merits of Mode 1
The scheduling of a guest OS managed by the virtual machine OS 301 and that of the VPUs can be combined into one. Thus, the scheduling can be done efficiently and finely and the resources can be used effectively; and
Since the VPU runtime environment can be shared among a plurality of guest OSes, a new VPU runtime environment need not be created when a new guest OS is introduced.
Merits of Mode 2
Since a scheduler for the VPUs can be shared among guest OSes on the virtual machine OS, the scheduling can be performed efficiently and finely and the resources can be used effectively;
Since the VPU runtime environment can be shared among a plurality of guest OSes, a new VPU runtime environment need not be created when a new guest OS is introduced; and
Since the VPU runtime environment can be created without depending upon the virtual machine OS or a specific guest OS, it can be standardized easily and replaced with another. If a VPU runtime environment suitable for a specific embedded device is created to perform scheduling utilizing the characteristics of the device, the scheduling can be done with efficiency.
Merit of Mode 3
Since the VPU runtime environment can optimally be implemented in each guest OS, the scheduling can be performed efficiently and finely and the resources can be used effectively.
Merit of Mode 4
Since the VPU runtime environment need not be implemented in all the guest OSes, a new guest OS is easy to add.
As is evident from the above, all the modes 1 to 4 can be used to implement the VPU runtime environment. Any other modes can be used when the need arises.
Service Provider
In the computer system according to the present embodiment, the VPU runtime environment 401 provides various services (a communication function using a network, a function of inputting/outputting files, calling a library function such as a codec, interfacing with a user, an input/output operation using an I/O device, reading of date and time, etc.) as well as functions of managing and scheduling various resources (operation time of each VPU, a memory, bandwidth of a connection device, etc.) associated with the VPUs 12. These services are called from application programs running on the VPUs 12. If a simple service is called, it is processed by service programs on the VPUs 12. A service that cannot be processed only by the VPUs 12, such as communication processing and file processing, is processed by service programs on the MPU 11. The programs that provide such services are referred to as a service provider (SP).
Upon receiving a service request called by the application program on each VPU 12, the VPU-side VPU runtime environment 502 processes only services that are processable in the VPU 12 and requests the service broker 512 to process services that are not processable therein.
Results reply to some service requests issued from the program to be executed by each VPU 12, and no results reply to other service requests. The destination of the reply is usually a thread that issues a service request; however, another thread, a thread group or a process can be designated as the destination of the reply. It is thus favorable that the destination be included in a message to request a service. The service broker 512 can be realized using a widely used object request broker.
Real-Time Operation
The computer system according to the present embodiment serves as a real-time processing system. The operations to be performed by the real-time processing system are roughly divided into the following three types:
1. Hard real-time operation
2. Soft real-time operation
3. Best effort operation (non-real-time operation)
The hard and soft real-time operations are a so-called real-time operation. The real-time processing system of the present embodiment has concepts of both thread and process like a number of existing OSes. First, the thread and process in the real-time processing system will be described.
The thread has the following three classes:
1. Hard Real-Time Class
Timing requirements are very important. This thread class is used for such an important application as to cause a grave condition when the requirements are not met.
2. Soft Real-Time Class
This thread class is used for an application whose quality simply lowers even if the timing requirements are not met.
3. Best Effort Class
This thread class is used for an application including no timing requirements.
In the present embodiment, the thread is a unit of execution for the real-time operation. The threads have their related programs that are to be executed by the threads. Each of the threads holds its inherent information that is called a thread context. The thread context contains, for example, information of a stack and values stored in the register of the processor.
In the real-time processing system, there are two different threads of MPU and VPU threads. These two threads are classified by processors (MPU 11 and VPU 12) that execute the threads and their models are identical with each other. The thread context of the VPU thread includes the contents of the local storage 32 of the VPU 12 and the conditions of a DMA controller of the memory controller 33.
A group of threads is called a thread group. The thread group has the advantage of efficiently and easily performing, e.g., an operation of giving the same attribute to the threads of the group. The thread group in the hard or soft real-time class is roughly divided into a tightly coupled thread group and a loosely coupled thread group. The tightly coupled thread group and loosely coupled thread group are discriminated from each other by attribute information (coupling attribute information) added to the thread groups. The coupling attribute of the thread groups can explicitly be designated by the codes in the application programs or the above-described structural description.
The tightly coupled thread group is a thread group that is made up of threads running in cooperation with each other. In other words, the threads belonging to the tightly coupled thread group tightly collaborate with each other. The tightly collaboration implies an interaction such as frequent communication and synchronization between threads or an interaction that decreases in latency. The threads belonging to the same tightly coupled thread group are always executed simultaneously. On the other hand, the loosely coupled thread group is a thread group that obviates a tightly collaboration between threads belonging to the group. The threads belonging to the loosely coupled thread group carry out communications for transferring data through the buffer on the memory 14.
Tightly Coupled Thread Group
As shown in
In the VPU0 that executes the thread A, an RA space corresponding to the local storage 32 of the VPU1 that executes the thread B is mapped in part of an EA space of the thread A. For this mapping, an address translation unit 331 provided in the memory controller 33 of the VPU0 performs address translation using a segment table and page table. The address translation unit 331 converts (translates) a part of the EA space of the thread A to the RA space corresponding to the local storage 32 of the VPU1, thereby to map the RA space corresponding to the local storage 32 of the VPU1 in part of the EA space of the thread A.
In the VPU1 that executes the thread B, an RA space corresponding to the local storage 32 of the VPU0 that executes the thread A is mapped in part of an EA space of the thread B. For this mapping, an address translation unit 331 provided in the memory controller 33 of the VPU1 performs address translation using the segment table and page table. The address translation unit 331 converts a part of the EA space of the thread B to the RA space corresponding to the local storage 32 of the VPU0, thereby to map the RA space corresponding to the local storage 32 of the VPU0 in part of the EA space of the thread B.
According to the present embodiment described above, tightly coupled threads can be specified by the coupling attribute information, and the tightly coupled threads A and B are sure to be executed at once by different VPUs, respectively. Thus, an interaction of communication and synchronization between the threads A and B can be performed more lightly without delay.
Loosely Coupled Thread Group
The execution term of each of threads belonging to the loosely coupled thread group depends upon the relationship in input/output between the threads. Even though the threads are subject to no constraints of execution order, it is not ensured that they are executed at the same time. The threads belonging to the loosely coupled thread group are called loosely coupled threads.
Process and Thread
As shown in
In the real-time processing system of the present embodiment, there are two models of a thread first model and an address space first model as method for creating a new thread. The address space first model is the same as that adopted in the existing OS and thus can be applied to both the MPU and VPU threads. On the other hand, the thread first model can be applied only to the VPU threads and is peculiar to the real-time processing system of the present embodiment. In the thread first model, the existing thread (which is one for creating a new thread, i.e., a parent thread of the new thread) first designates a program to be executed by a new thread and causes the new thread to start to execute the program. The program is then stored in the local storage of the VPU and starts to run from a given address. Since no address space is related to the new thread at this time, the new thread can gain access to the local storage of the VPU and not to the memory 14. After that, when the need arises, the new thread in itself calls a service of VPU runtime environment and creates an address space. The address space is related to the new thread, and the new thread can gain access to the memory 14. In the address space first model, the existing thread creates a new address space or designates the existing address space, and arranges program, which is to execute by the new thread, in the address space. Then, the new thread starts to run the programs. The merit of the thread first model is that a thread can be executed only by the local storage to reduce overhead costs required for generating, dispatching and exiting the thread.
Scheduling of Threads
A scheduling operation performed by the VPU runtime environment 401 will now be described with reference to the flowchart shown in
The scheduling of threads belonging to the tightly coupled thread group is performed as follows. In order to execute threads of a tightly coupled thread group, which are selected from the threads to be scheduled, by their respective VPUs at once, the scheduler in the VPU runtime environment 401 reserves an execution term of each of the VPUs, whose number is equal to that of the threads, and dispatches the threads to the VPUs at once (step S123). The scheduler maps an RA space in part of an EA space of a thread using the address translation unit 331 in a VPU that executes the thread (step S124), the RA space corresponding to the local storage of a VPU that executes a partner thread interacting with the former thread. As for the threads belonging to the loosely coupled thread group which are selected from the threads to be scheduled, the scheduler dispatches the threads in sequence to one or more VPUs based on the relationship in input/output between the threads (step S125).
If a tightly coupled thread group, which is a set of threads running in cooperation with each other, is selected based on the coupling attribute information, it can be ensured that the threads belonging to the tightly coupled thread group are executed at once by different processors. Consequently, communication between threads can be achieved by a lightweight mechanism of gaining direct access to, e.g., the registers of processors that execute their partner threads each other. The communication can thus be performed lightly and quickly.
Mapping of Local Storage
In the real-time processing system of the present embodiment, when MPU and VPU threads or VPU threads perform an operation of communication or synchronization in cooperation with each other, it is necessary to access the local storage of the partner VPU thread. For example, a more lightweight, high-speed synchronization mechanism is implemented by a synchronous variable assigned on the local storage. It is thus necessary that the local storage of a VPU 12 be accessed directly by another VPU 12 or the MPU 11. If a segment table or page table is set appropriately when the local storage of a VPU 12 is allocated to the real address space as shown in
The first issue relates to a change in the VPU to which a VPU thread is dispatched. Assume that there are VPU threads A and B and they are executed by their respective VPUs 0 and 1 as shown in
The second issue relates to a correspondence between physical VPUs and logical VPUs. Actually, there are two levels to allocate VPUs to VPU threads. The first level is to allocate logical VPUs to VPU threads and the second level is to allocate physical VPUs to the logical VPUs. The physical VPUs are real VPUs 12 managed by the virtual machine OS 301. The logical VPUs are virtual VPUs allocated to the guest OSes by the virtual machine OS 301. This correspondence is also shown in
Assume that the virtual machine OS 301 allocates physical VPUs 1, 2 and 3 to their respective logical VPUs 0, 1, 2 at a certain time, as shown in
In order to resolve the above two issues described above, the real-time processing system of the present embodiment controls the virtual memory mechanism such that the local storage of a VPU, which executes its partner thread, is always mapped in the fixed address of the EA space viewed from a thread. In other words, when the scheduler dispatches a logical VPU, or when the virtual machine OS changes a correspondence between physical and logical VPUs, the page table and segment table are rewritten appropriately to allow a thread executed by a VPU to see the local storage of a VPU that executes the partner thread at all times in the same address.
There now follows an explanation as to the relationship in EA space between two threads. The EA spaces of two threads are shared or unshared in the following three patterns:
1. Shared EA pattern: Two threads 1 and 2 share both the segment table and page table (
2. Shared VA pattern: Two threads 1 and 2 share the page table and not the segment table but have their respective segment tables (
3. Unshared pattern: Two threads 1 and 2 share neither the page table nor the segment table but have their respective page tables and segment tables (
There now follows an explanation as to how the mapping of local storages of VPUs to the EA space are controlled, taking the shared EA type as an example.
First, as shown in
Assume here that a correspondence between the physical and logical VPUs changes because the virtual machine OS 301 dispatches the guest OS. As shown in
As described above, when the logical VPU that executes a thread changes due to the dispatch of the thread, the segment table of mapping from EA space to VA space is rewritten to resolve the first issue. When a correspondence between physical and logical VPUs is changed by the virtual machine OS 301 or the like, the page table of mapping from VA space to RA space is rewritten to resolve the second issue.
The local memory (local storage) of a processor corresponding to the partner thread, which is mapped in the effective address space, is automatically changed in accordance with a processor that executes the partner thread. Thus, each thread can efficiently interact with its partner thread without being aware of a processor to which the partner thread is dispatched. Consequently, a plurality of threads can be executed with efficiency and in parallel to one another.
The shared EA type has been described so far. In the shared VA type and unshared type, too, the first and second issues can be resolved by rewriting the segment table or the page table as in the shared EA type.
Another method of resolving the above first and second issues will be described taking the shared EA type as an example. If there are a plurality of VPU threads that run in cooperation with each other, the page table and segment table are set such that the local storages of VPUs that execute the threads are consecutively mapped on the segment in the EA space. In
A procedure for address management performed by the VPU runtime environment 401 will now be described with reference to the flowchart shown in
The example described up to now is directed to a system for accessing a local storage of the VPU that executes the partner thread. The system is suitable for the tightly coupled threads that are always executed simultaneously. However, there is a case where the threads that run in cooperation with each other are not always assigned to the VPUs at once, as in the loosely coupled thread group. In this case, too, the EA space has a segment for mapping the local storage of VPU 12 that executes the partner thread and thus the segment is used as follows to deal with the local storage.
First method: If a segment for mapping the local storage of a VPU corresponding to a partner thread is accessed while the partner thread is not running, a thread is caused to wait until the partner thread starts to run.
Second method: If a segment for mapping the local storage of a VPU corresponding to a partner thread is accessed while the partner thread is not running, a thread becomes aware of it by an exception or an error code.
Third method: When a thread exits, the contents of the local storage, which are provided when the thread runs finally, are stored in the memory area. The mapping is controlled such that the entries of the page table or segment table, which indicate the local storage corresponding to the thread, indicate the memory area. According to this method, even though the partner thread is not running, a thread can continues to run as if there were a local storage corresponding to the partner thread. A specific example thereof is shown in
(1) Assume that threads A and B are executed by VPUs 0 and 1, respectively and the local storage LS0 of VPU0 that executes the thread A is mapped in the EA space of the thread B.
(2) When the thread A exits, the thread A or VPU runtime environment 401 stores (saves) the contents of local storage LS0 of VPU0 that executes the thread A in a memory area on the memory 14 (step S211).
(3) The VPU runtime environment 401 changes the address space for the local storage of the thread A, which is mapped in the EA space of the thread B, from the LS0 of VPU0 to the memory area on the memory 14 that stores the contents of the LS0 (step S212). Thus, the thread B can continue to run even after the thread A stops running.
(4) When a VPU is allocated to the thread A again, the VPU runtime environment 401 restores the content of the memory area on the memory 14 to the local storage of the VPU that executes the thread A (step S213). If the VPU0 is allocated to the thread A again, the content of the memory area is restored to the local storage LS0 of the VPU0.
(5) The VPU runtime environment 401 changes the address space of the local storage of the thread A, which is mapped in the EA space of the thread B, to the local storage of the VPU that executes the thread A (step S214). If the VPU0 is allocated to the thread A again, the address space of the local storage of the thread A, which is mapped in the EA space of the thread B, is changed to the local storage LS0 of the VPU0.
If the VPU2 is allocated to the thread A, the content of the memory area on the memory 14 is restored to the local storage LS2 of the VPU2. Then, the address space of the local storage of the thread A, which is mapped in the EA space of the thread B, is changed to the local storage LS2 of the VPU2.
As described above, in the information processing system according to the present embodiment, each of VPUs 1 and 2 includes a local memory 32; therefore, each thread can execute a program by simply accessing the local memory 32 in the VPU, not the shared memory 14. The local memory of a VPU corresponding to a partner thread, which is mapped in the effective address space of each thread is automatically changed in accordance with a VPU that executes the partner thread interacting with the thread. Each thread can efficiently interact with its partner thread without being aware of a processor to which the partner thread is dispatched. Consequently, a plurality of threads can be executed with efficiency in parallel to each other.
The MPU 11 and VPUs 12 provided in the computer system shown in
If the programs running as the VPU running environment or the programs of the operating system including the VPU running environment are stored in a computer readable storage medium and then introduced and executed in a computer including a plurality of processors each having a local memory, the same advantages as those of the foregoing embodiment of the present invention can be obtained.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the invention in its broader aspects is not limited to the specific details and representative embodiments shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
2003-185416 | Jun 2003 | JP | national |
This application is a continuation of co-pending U.S. patent application Ser. No. 10/808,320, filed Mar. 25, 2004, which claims benefit of priority from prior Japanese Patent Application No. 2003-185416, filed Jun. 27, 2003, the entire contents of each of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5269013 | Abramson et al. | Dec 1993 | A |
5729714 | Dei | Mar 1998 | A |
6336177 | Stevens | Jan 2002 | B1 |
6622155 | Haddon et al. | Sep 2003 | B1 |
7356666 | Kanai et al. | Apr 2008 | B2 |
20020062352 | Asano et al. | May 2002 | A1 |
20060143350 | Miloushev et al. | Jun 2006 | A1 |
Number | Date | Country |
---|---|---|
2-242434 | Sep 1990 | JP |
4-246745 | Sep 1992 | JP |
8-180025 | Jul 1996 | JP |
10-143380 | May 1998 | JP |
WO 8401043 | Mar 1984 | WO |
WO 0036509 | Jun 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20070220230 A1 | Sep 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10808320 | Mar 2004 | US |
Child | 11751728 | US |