DocumentCode :
921315
Title :
Automatic extraction of functional parallelism from ordinary programs
Author :
Girkar, Milind ; Polychronopoulos, Constantine D.
Author_Institution :
Center for Superconducting Res. & Dev., Illinois Univ., Urbana, IL, USA
Volume :
3
Issue :
2
fYear :
1992
fDate :
3/1/1992 12:00:00 AM
Firstpage :
166
Lastpage :
178
Abstract :
Presents the hierarchical task graph (HTG) as an intermediate parallel program representation which encapsulates minimal data and control dependences, and which can be used for the extraction and exploitation of functional, or task-level parallelism. The hierarchical nature of the HTG facilitates efficient task-granularity control during code generation, and thus applicability to a variety of parallel architectures. The construction of the HTG at a given hierarchy level, the derivation of the execution conditions of tasks which maximizes task-level parallelism, and the optimization of these conditions which results in reducing synchronization overhead imposed by data and control dependences are emphasized. Algorithms for the formation of tasks and their execution conditions based on data and control dependence constraints are presented. The issue of optimization of such conditions is discussed, and optimization algorithms are proposed. The HTG is used as the intermediate representation of parallel Fortran and C programs for generating parallel source as well as parallel machine code
Keywords :
directed graphs; parallel programming; program compilers; programming theory; automatic extraction; code generation; control dependences; execution conditions; functional parallelism; hierarchical task graph; intermediate parallel program representation; minimal data; optimization algorithms; ordinary programs; parallel C programs; parallel Fortran programs; parallel architectures; parallel machine code; parallel source code; synchronization overhead; task-granularity control; task-level parallelism; Computational modeling; Concurrent computing; Data mining; Helium; Parallel architectures; Parallel languages; Parallel machines; Parallel processing; Parallel programming; Program processors;
fLanguage :
English
Journal_Title :
Parallel and Distributed Systems, IEEE Transactions on
Publisher :
ieee
ISSN :
1045-9219
Type :
jour
DOI :
10.1109/71.127258
Filename :
127258
Link To Document :
بازگشت