The present application is related to U.S. patent application Ser. No. 10/244,434, filed on Sep. 17, 2002, to Nair et al., entitled “METHOD AND SYSTEM FOR EFFICIENT EMULATION OF MULTIPROCESSOR MEMORY CONSISTENCY”, to U.S. patent application Ser. No. 10/244,682, filed on Sep. 17, 2002, to Nair et al., entitled “HYBRID MECHANISM FOR MORE EFFICIENT EMULATION AND METHOD THEREFOR”, and to U.S. patent application Ser. No. 10/244,559, filed on Sep. 17, 2002, to Nair et al., entitled “METHOD AND SYSTEM FOR EFFICIENT EMULATION OF MULTIPROCESSOR ADDRESS TRANSLATION ON A MULTIPROCESSOR HOST”, and to U.S. patent application Ser. No. 10/244,564, filed on Sep. 17, 2002, to Nair et al., entitled “METHOD AND SYSTEM FOR TRANSPARENT DYNAMIC OPTIMIZATION IN A MULTIPROCESSING ENVIRONMENT”, each assigned to the present assignee, and incorporated herein by reference.
1. Field of the Invention
The present invention generally relates to computer systems, and more particularly to a method (and system) for reproducing the behavior of a multiprocessing computer system on another multiprocessing computing system.
2. Description of the Related Art
The need for emulating the behavior of one computer system on another has long been recognized. Several schemes have been proposed for doing this. A summary of these techniques appears in U.S. Pat. No. 5,832,205, incorporated herein by reference.
The solution of U.S. Pat. No. 5,832,205 includes a combined hardware/software scheme to perform the emulation of the instruction set of one processor on another. This scheme allows the hardware design to incorporate features that facilitate the execution of the target instruction set. For the same reason, however, this cannot emulate all systems equally efficiently.
SimOS (e.g., see Stephen A. Herrod, “Using Complete Machine Simulation to Understand Computer System Behavior,” Ph.D. Thesis, Stanford University, February 1998), incorporated herein by reference, and SimICS (e.g., see Peter S. Magnusson, “A Design For Efficient Simulation of a Multiprocessor,” Proceedings of the First International Workshop on Modeling, Analysis, and Simulation of Computer and Telecommunication Systems (MASCOTS), La Jolla, Calif., January 1993, pp. 69-78) are examples of systems that can emulate without special hardware features. However, their performance is not as effective as that of U.S. Pat. No. 5,832,205.
In general, these systems employ various levels of translation. Techniques have been described (e.g., see Jim Turley, “Alpha Runs x86 Code with FX!32”, Mar. 5, 1996, Microprocessor Report) where the extent of translation is varied according to the extent of execution of the code.
However, computer systems today comprise more than one processor (e.g., a multiprocessor system as opposed to a uniprocessor system). The emulation of these multiprocessor systems has not been adequately addressed in the conventional techniques.
Additionally, besides the emulation of the multiple processors in such a system, additional aspects that need to be emulated are the various forms of communication between the processors, as well as the rules governing the order of access to memory locations by the multiple processors.
Both SimOS and SimICS attempt to emulate the behavior of multiprocessor systems. However they do not use multiprocessor systems as a host computing system.
Thus, conventional techniques have not addressed the problems of emulation of multiprocessors in multiprocessor systems.
That is, the conventional techniques (and the instruction set architecture) very often have been limited to (and refer to) a single processor systems being emulated, whereas most systems today are multiprocessor systems, especially the large systems (e.g., beyond the realm of the personal computer (PC)). Hence, techniques which have been used to emulate one processor by another processor simply will not work in a multiprocessor system environment. That is, the conventional emulation techniques designed for uniprocessor systems are impossible to perform when multiple processors are present.
In view of the foregoing and other problems, drawbacks, and disadvantages of the conventional methods and structures, an object of the present invention is to provide a method and structure in which a multiprocessing system is enabled using some processor instruction set and memory architecture to efficiently emulate the behavior of another multiprocessing system using some other processor instruction.
In a first aspect of the present invention, a method (and system) for executing a program written for a target instruction set architecture on a host computing system having a plurality of processors designed to process instructions of a second instruction set architecture, includes representing each portion of the program designed to run on a processor of the target computing system as one or more program threads to be executed on the host computing system.
In a second aspect of the invention, a system (and method) includes means for mapping hardware resources of a target system into software threads, means for mapping threads to hardware resources of the host system, means for mapping state information of the target system into the memory of the host system, and means for improving performance of emulation by partitioning emulation tasks into larger number of threads.
In a third aspect of the present invention, a thread processing structure for a host computer of a multiprocessor system, includes a thread pool for holding threads, a thread processor for accessing a memory of the host system, and for determining which thread in the thread pool to select for emulation, a thread creator for creating new threads and placing said new threads in the thread pool, and a thread scheduler for scheduling the threads held in the thread pool, the scheduler scanning waiting threads and allocating a next thread in priority order to an available processor.
In a fourth aspect of the present invention, a signal-bearing medium tangibly embodying a program of machine-readable instructions executable by a digital processing apparatus to perform a method of executing a program written for a target instruction set architecture on a host computing system having a plurality of processors designed to process instructions of a second instruction set architecture, the method including representing each portion of the program designed to run on a processor of the target computing system as one or more program threads to be executed on the host computing system.
With the unique and unobvious aspects of the present invention, emulation of systems having many processors can be performed efficiently. Further, the invention uses a host computer for the emulation.
Additionally, a key feature of the invention is that the invention gets away from the notion that the guest system is a piece of hardware. Instead, the invention treats the guest system as a piece of software.
Hence, the guest is treated more abstractly as having a multiple parallel threads which need to be executed, and then the threads are mapped into the hardware resources of the host. This essentially eliminates the intermediate step of normally mapping the parallelism in the program into the hardware of the guest, and then the hardware of the guest would be emulated by the hardware in the host. The invention eliminates this intermediate step of even knowing that there might actually have even been hardware in the guest which would have mapped to the hardware in the host.
Thus, the invention eliminates a step of mapping software threads of an application of the guest to hardware in the guest. Thereafter, each of these threads of the guest is scheduled for execution onto one or more processors of the host.
Another advantage of the invention is that it is easier to build and debug such a system because it eliminates the need to worry about getting the details of the hardware of the guest machine correct.
The foregoing and other purposes, aspects and advantages will be better understood from the following detailed description of a preferred embodiment of the invention with reference to the drawings, in which:
Referring now to the drawings, and more particularly to
Each processor 110A-110D in
For example, an instruction may be broadly classified as a “local resource instruction” or a “shared resource instruction” depending on whether it affects resources local to the processor executing it, or whether it affects resources that are shared among all processors. Examples of local resources are general purpose registers, floating point registers, processor status register, and control registers local to each processor. Shared resources may include memory and I/O devices.
Shared resources must be emulated with particular care because multiple processors may attempt to access these in a given period of time. It is important that the order of access of the shared resource in the emulated system be such that the same order could possibly have occurred in the system being emulated.
In order to manage this efficiently, the shared resource instructions are further classified as (a) “exclusive instructions”, meaning that they access shared resources that are used exclusively by the executing processor, (b) “shared read instructions”, meaning that the shared resources used by the instruction are only read from and not changed, and (c) “communicating instructions”, which include all other shared resource instructions. Communicating instructions are so named because they typically are used to communicate information from one processor to another, for example by one processor writing a value which one or more other processors read.
For example, the instruction set of the host processor may be different from the instruction set of the target processor. The number of processors 310A-310D and memory size may also be different. The interconnection network 330 to access the shared resources may be different both in form and function. The host system will be assumed to be configured in an SMP (symmetric multiprocessing) configuration. One implication of this is that all processors 310A-310D in the host will access the same memory and have reasonably similar delay in accessing memory locations. Also shown is the Host I/O Processor 340 which is similar to processor 140 shown in
The state of each resource in the target system is modeled by allocating a region of the memory of the host system 300. It is assumed here that the emulation is being performed under a shared virtual memory operating system environment. This provides a host memory size that can accommodate all real resources of the target system.
It is noted that a 64-bit virtual addressing host can comfortably accommodate tens or even hundreds of gigabytes of real memory and the local resources of hundreds of processors, and still have enough addressing available for the emulation program itself.
Besides a shared-memory SMP, the existence of support will be assumed for multiple threads in the operating system. An example of such support is the p-threads package under the Unix™ operating system (e.g., see Bradford Nichols et al., “Pthreads Programming: A POSIX Standard for Better Multiprocessing,” (O'Reilly Nutshell), September 1996. Such a package allows the creation in software of multiple program streams that execute in parallel, while also allowing safe sharing of variables between the streams. In addition, these packages typically also provide means to spawn new threads, “kill” (terminate) threads, and interrupt or wake up threads.
It is noted that the systems shown in
As shown in
In the operation of processing the threads, sometimes the thread processor determines that some new threads must be created. Thus, threads are created by the thread creator 520, and are placed in the thread pool 530. Waiting threads are scanned by the thread scheduler 540 which allocates the next thread in priority order to an available processor.
The execution of a thread in a processor involves reading some locations in host virtual memory 400 and modifying these or other locations. Thus, the thread processor interacts with the host virtual memory 400 to map the memory of the guest system also into the memory of the host. The only thing available to the thread processor is the host virtual memory, and thus such a mapping occurs.
It is noted that, if the model of
Hence, the invention uses the inventive thread processor 500 to determine what threads need to be created and scheduled.
Assuming a large pool 530 of threads, the effectiveness of the system increases as the number of processors available to process these threads increases. The effectiveness, however, may be limited by the number of instructions that are of the communicating type as defined in
Even though the entire real memory of the target system is shared, it is often possible to divide the memory further into three categories corresponding to the three subclasses of shared resource instructions shown in
These regions are (a) “exclusive access regions”, (b) “read-only regions”, and (c) “other shared regions”. Exclusive access regions are those which are accessed only by a single thread. Read-only regions may be accessed by multiple threads, but are never modified. Hence, it is permissible to replicate these regions and include a copy as part of the local exclusive region of the thread.
The other shared regions should be treated differently. That is, if copies are made, for example, for efficient local access, it is important that changes made by one thread be communicated correctly to all other threads that may be accessing the same region or that may access the region in the future.
Hence, for efficiency, the memory can be divided out into a plurality (e.g., two) of portions. The first portion is where communication is minimal and the second portion is a portion where there is a lot of communication between the threads themselves.
Thus, if portions of memory are dedicated to each of the threads, then these portions can be made into a fast access memory, whereas threads which need to “talk” to each other (e.g., which need to be shared) and may not require fast access (e.g., since their privileges must be checked whether such accesses are allowed or not, etc.) can be formed into a shared portion of the host virtual memory. Hence, by separating the memory into two portions, a faster overall access speed of the memory can be achieved.
Each processor 710A, 710B, 710C, 710D, etc. along with its resources is emulated, respectively, as a thread 720A, 720B, 720C, 710D, etc. Also shown are the I/O processor 730 and the I/O thread 740. As is evident, the present invention does not require that the processing be just that associated with processors in the traditional sense, but also covers I/O processors, channels for the IBM 390™ system, coprocessors in some systems, etc.
Additionally, a system thread 750 is provided which includes all functions 760 of the target system that are not processor-specific, and also all functions of the emulation system itself, including the tasks of handling the creation of threads, communication between threads, debugging and performance monitoring aspects, etc.
It is noted that the concept of
The advantage with the approach of
However, one disadvantage with this approach in
Another disadvantage is the scalability of the technique. If the host system has many more processors than the target system, then many of the additional processors cannot be adequately utilized. Conversely, if the host system has fewer processors, then the one-to-one mapping of threads to processors can be accommodated only if multiple target processors are mapped to the same thread.
Thus, as mentioned earlier, the advantage of dynamic thread mapping over a static mapping is greater when the number of threads gets larger. Hence, it is possible to restructure an emulation system to provide more parallel threads rather than the one-thread-per-processor scheme shown in
That is, the invention is useful not only with a multiprocessing host, but also with a host similar to the IBM 390™ System as shown in
Additionally, the inventive system is not restricted to only emulation. That is, the particular system is not restricted to performing just emulation, but for example, an application (e.g., Linux) can be running directly on the host, with the application not being under emulation but instead running native on the host. In such a case, the host application threads 1040 can be run on the host, and can be scheduled/managed by the thread scheduler 1020 (which would also manage the threads of the emulation thread cluster). Hence, the invention has great utility not only for emulation but also for applications running directly the host directly.
It is noted that the above mentioned article by Herrod directed to SimOS and U.S. Pat. No. 5,832,205 have indicated that the performance of an emulation system can be dramatically improved by caching as follows.
That is, if a group of instructions is expected to be executed several times, it is first translated from the target instruction set to the host instruction set, and the translations are saved in a special area of memory called the “translation cache”. When the address of this group is encountered thereafter, the native host instructions are directly executed. By avoiding the refetch of the target instructions and retranslation of these instructions, the instruction group is executed considerably faster. Further benefit can be obtained by analyzing this group of instructions and optimizing the translation produced. Some examples of such optimization can be seen in U.S. Pat. No. 5,832,205, incorporated herein by reference.
The benefit obtained by caching translations depends both on the effort needed to translate the instruction group, as well as the number of times the translated group is eventually executed. Since the latter cannot be predicted for most types of code, heuristics are used to determine potential candidates for translation.
In step 1120, if there is a valid entry in the translation table 1110 corresponding to this address, it points to a location from which the translated native instructions should be fetched and executed.
If there is no valid entry as determined in step 1120, then the target instructions are interpreted directly (step 1130) and a counter associated with the group is incremented (step 1140).
If this counter exceeds a threshold (step 1150), for example if the group has been interpreted 5 times already, then the group is scheduled for translation (step 1160).
If in step 1120, it is determined that the instruction has been translated (e.g., a “YES”, then the cached translation of the instruction group is executed in step 1170 by accessing the translation cache 1175.
Then, in step 1180, the next instruction group to be emulated is determined.
In a system as described in U.S. Pat. No. 5,832,205, the emulated thread would perform the translation either at the point it is discovered that the threshold condition is satisfied, or just before executing the group the next time. The time spent by the thread performing the translation could potentially have been used to start executing the next group of instructions and hence represents an overhead to the system.
A more efficient approach would be for the thread to simply put the instruction group into the translation pool (e.g., 1190) and continue with the execution of the next group. Thus, when a translation has been completed, the translated object is put in the translation cache with a pointer in the translation table 1110, as shown in
In
Since the process of translating one group of instructions is largely independent of the process of translating another group, the translation pool manager 1210 could spawn several threads, each of which performs translation of a group from the pool, as shown in
In
The effect of this system/operation is essentially to partition the tasks of emulation further into independent parallel threads that can be exploited even better by a host multiprocessing system. Thus, the system of
In addition to the hardware/software environment described above, a different aspect of the invention includes a computer-implemented method for performing the above method. As an example, this method may be implemented in the particular environment discussed above.
Such a method may be implemented, for example, by operating a computer, as embodied by digital data processor(s), in a multiprocessor system to execute a sequence of machine-readable instructions. These instructions may reside in various types of signal-bearing media.
Thus, this aspect of the present invention is directed to a programmed product, including signal-bearing media tangibly embodying a program of machine-readable instructions executable by digital data processor(s) in a multiprocessing system incorporating a processor/central processing unit (CPU) and hardware above, to perform the method of the invention.
This signal-bearing media may include, for example, a RAM contained within the CPU, as represented by the fast-access storage for example. Alternatively, the instructions may be contained in another signal-bearing media, such as a magnetic data storage diskette 1400 (
Whether contained in the diskette 1400, the computer/CPU, or elsewhere, the instructions may be stored on a variety of machine-readable data storage media, such as DASD storage (e.g., a conventional “hard drive” or a RAID array), magnetic tape, electronic read-only memory (e.g., ROM, EPROM, or EEPROM), an optical storage device (e.g. CD-ROM, WORM, DVD, digital optical tape etc.). In an illustrative embodiment of the invention, the machine-readable instructions may comprise software object code, compiled from a language such as “C”, etc.
While the invention has been described in terms of several preferred embodiments, those skilled in the art will recognize that the invention can be practiced with modification within the spirit and scope of the appended claims.
It is noted that the invention has many benefits as discussed above including efficient emulation. Further, the invention could be used as a basis for performing “virtualization” which assists in load balancing. Virtualization can take various forms including load balancing. For example, virtualization can also be used for fault tolerance in which if one processor has failed in a system having a one-to-one mapping (or another mapping scheme), then the system can continue working since the failed system can be abstracted and there simply can be a smaller pool of host processors. Thus, another processor can take up the duties of the failed processor.
Another possible application for the invention is in power savings. That is, upon determination that too much power is being consumed in a multiprocessor system, then some processors could be shut down and yet the functionality of the entire emulation could be maintained at the lower power level. As such, the functions of the processor being shut down can be shifted to another processor. This is relatively simple to do by the invention since each processor is being treated as a thread, rather than as a one-to-one mapping of the threads to the processors.
That is, in the invention, the scheme is a many-to-many mapping, as opposed to the SimOS technique in the above-described Herrod article which is a many-to-one mapping, or to U.S. Pat. No. 5,832,205 which is a one-to-one mapping scheme.
Further, it is noted that, Applicant's intent is to encompass equivalents of all claim elements, even if amended later during prosecution.
The present application is a divisional application of U.S. patent application Ser. No. 10/244,414, filed on Sep. 17, 2002, now U.S. Pat. No. 7,496,494, having issue date of Feb. 24, 2009.
Number | Name | Date | Kind |
---|---|---|---|
4392196 | Glenn et al. | Jul 1983 | A |
4564903 | Guyette et al. | Jan 1986 | A |
5055999 | Frank et al. | Oct 1991 | A |
5307477 | Taylor et al. | Apr 1994 | A |
5390309 | Onodera | Feb 1995 | A |
5440710 | Richter et al. | Aug 1995 | A |
5481684 | Richter et al. | Jan 1996 | A |
5574878 | Onodera et al. | Nov 1996 | A |
5574922 | James | Nov 1996 | A |
5615327 | Magee et al. | Mar 1997 | A |
5619665 | Emma | Apr 1997 | A |
5668969 | Fitch | Sep 1997 | A |
5675762 | Bodin et al. | Oct 1997 | A |
5678032 | Woods et al. | Oct 1997 | A |
5751982 | Morley | May 1998 | A |
5761734 | Pfeffer et al. | Jun 1998 | A |
5768593 | Walters et al. | Jun 1998 | A |
5832205 | Kelly et al. | Nov 1998 | A |
5905998 | Ebrahim et al. | May 1999 | A |
5983012 | Bianchi et al. | Nov 1999 | A |
6031992 | Cmelik et al. | Feb 2000 | A |
6047323 | Krause | Apr 2000 | A |
6075937 | Scalzi et al. | Jun 2000 | A |
6075938 | Bugnion et al. | Jun 2000 | A |
6091897 | Yates et al. | Jul 2000 | A |
6134515 | Skogby | Oct 2000 | A |
6158049 | Goodwin et al. | Dec 2000 | A |
6189141 | Benitez et al. | Feb 2001 | B1 |
6195676 | Spix et al. | Feb 2001 | B1 |
6240490 | Lyles et al. | May 2001 | B1 |
6289369 | Sundaresan | Sep 2001 | B1 |
6289419 | Takahashi | Sep 2001 | B1 |
6339752 | Mann et al. | Jan 2002 | B1 |
6341371 | Tandri | Jan 2002 | B1 |
6351844 | Bala | Feb 2002 | B1 |
6381682 | Noel et al. | Apr 2002 | B2 |
6430657 | Mittal et al. | Aug 2002 | B1 |
6463582 | Lethin et al. | Oct 2002 | B1 |
6480845 | Egolf et al. | Nov 2002 | B1 |
6529862 | Mann et al. | Mar 2003 | B1 |
6539464 | Getov | Mar 2003 | B1 |
6728950 | Davis et al. | Apr 2004 | B2 |
6738974 | Nageswaran et al. | May 2004 | B1 |
6763328 | Egolf et al. | Jul 2004 | B1 |
6763452 | Hohensee et al. | Jul 2004 | B1 |
6915513 | Duesterwald et al. | Jul 2005 | B2 |
6920416 | Swoboda et al. | Jul 2005 | B1 |
6961806 | Agesen et al. | Nov 2005 | B1 |
6978233 | Burns | Dec 2005 | B1 |
20010020224 | Tomita | Sep 2001 | A1 |
20020019969 | Hellestrand et al. | Feb 2002 | A1 |
20020026304 | Deao et al. | Feb 2002 | A1 |
20020066086 | Linden | May 2002 | A1 |
20020083278 | Noyes | Jun 2002 | A1 |
20020104075 | Bala et al. | Aug 2002 | A1 |
20020147969 | Lethin et al. | Oct 2002 | A1 |
20020199172 | Bunnell | Dec 2002 | A1 |
20030093780 | Freudenberger et al. | May 2003 | A1 |
20030171907 | Gal-On et al. | Sep 2003 | A1 |
20040015888 | Fujii et al. | Jan 2004 | A1 |
Number | Date | Country |
---|---|---|
59-167756 | Sep 1984 | JP |
62-163149 | Jul 1987 | JP |
07-271738 | Oct 1995 | JP |
08-234981 | Sep 1996 | JP |
08-272686 | Oct 1996 | JP |
63-226740 | Sep 1998 | JP |
10-312298 | Nov 1998 | JP |
11-134307 | May 1999 | JP |
11-259437 | Sep 1999 | JP |
2000-207233 | Jul 2000 | JP |
2000-242512 | Sep 2000 | JP |
WO 9516967 | Jun 1995 | WO |
WO 9944131 | Sep 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20090157377 A1 | Jun 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10244414 | Sep 2002 | US |
Child | 12388728 | US |