Data-Driven Multithreading Using Conventional Microprocessors

C. Kyriacou, P. Evripidou, P. Trancoso
2006 IEEE Transactions on Parallel and Distributed Systems  
This paper describes the Data-Driven Multithreading (DDM) model and how it may be implemented using off-the-shelf microprocessors. Data-Driven Multithreading is a nonblocking multithreading execution model that tolerates internode latency by scheduling threads for execution based on data availability. Scheduling based on data availability can be used to exploit cache management policies that reduce significantly cache misses. Such policies include firing a thread for execution only if its data
more » ... s already placed in the cache. We call this cache management policy the CacheFlow policy. The core of the DDM implementation presented is a memory mapped hardware module that is attached directly to the processor's bus. This module is responsible for thread scheduling and is known as the Thread Synchronization Unit (TSU). The evaluation of DDM was performed using simulation of the Data-Driven Network of Workstations (D 2 NOW). D 2 NOW is a DDM implementation built out of regular workstations augmented with the TSU. The simulation was performed for nine scientific applications, seven of which belong to the SPLASH-2 suite. The results show that DDM can tolerate well both the communication and synchronization latency. Overall, for 16 and 32-node D 2 NOW machines the speedup observed was 14.4 and 26.0, respectively.
doi:10.1109/tpds.2006.136 fatcat:qvgr6qn6qfcqhme72cl64hsx7q