Publication | Closed Access
Automatic extraction of functional parallelism from ordinary programs
187
Citations
16
References
1992
Year
EngineeringComputer ArchitectureSoftware EngineeringSystem-level DesignHierarchical Task GraphSoftware AnalysisParallel AlgorithmsParallel SoftwareParallel ComputingCompilersProgramming LanguagesParallelizing CompilerCode GenerationComputer EngineeringTask ParallelismDistributed SystemsComputer ScienceTask-level ParallelismFunctional ParallelismProgram AnalysisFormal MethodsParallel ProgrammingParallel Programming ModelData-level Parallelism
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.< <ETX xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">></ETX>
| Year | Citations | |
|---|---|---|
Page 1
Page 1