MILLIPEDE is an all user mode, no kernel-patches, "add on" software tool for standard corporate environments, that takes advantage of idle system resources and efficiently utilizes idle processor time in available distributed environments of personal workstations. MILLIPEDE presents to the user a powerful virtual parallel machine which abstracts away the underlying hardware configuration. In this way MILLIPEDE supports mapping of the applications to dynamically varying levels of parallelism according to both changes in the underlying hardware and changes in the application requirements.
MILLIPEDE is multi-threaded, thus taking full advantage of SMPs. MILLIPEDE provides a true distributed shared memory with several coherence protocols (and a flexible mechanism for easy inclusion of new ones) and dynamic thread migration [3]. MILLIPEDE studies the memory access pattern and optimizes the locality of memory references by adapting the thread distribution accordingly [5].
MILLIPEDE supports several of the more liberal parallel programming paradigms [2]. Currently we support PARC (which allows for example nested parallelism and barriers among sibling activities), PARC++ (which is as flexible as C++ except for additional parallelizing constructs), the SPLASH macros (which we had to adapt to Windows-NT and to the multi-threaded concept), and of course for best speedups one can use directly the MILLIPEDE job manager library. We are working on the implementation of PARFORTRAN90 and JAVA (for which we came up with a new definition of the JVM memory behavior, and with an efficient algorithm for distributed garbage collection [4]).
In order to support many different programming languages on top of a single virtual parallel machine we developed MILLIPEDE Job Event Control (MJEC) [2]. MJEC can be used to efficiently implement a variety of synchronization and communication protocols (e.g., PARC in about 250 lines of code).
MILLIPEDE is fully implemented at the Technion, Haifa, using the Windows-NT operating system (previous version on MACH [1]). We refer the reader to our WWW site (see above) for online versions of the papers, and for downloading a distribution of MILLIPEDE.
[1]
Assaf Schuster,et al.
Thread migration and its applications in distributed shared memory systems
,
1998,
J. Syst. Softw..
[2]
Assaf Schuster,et al.
Supporting multiple parallel programming paradigms on top of the Millipede virtual parallel machine
,
1997,
Proceedings Second International Workshop on High-Level Parallel Programming Models and Supportive Environments.
[3]
Roy Friedman,et al.
MILLIPEDE: Easy Parallel Programming in Available Distributed Environments
,
1997
.
[4]
Assaf Schuster,et al.
Collecting Garbage Pages in a Distributed Shared Memory with Reduced Memory and Communication Overhead
,
1997,
ESA.