The Paralax Infrastructure: Automatic Parallelization With a Helping Hand


Autoria(s): Vandierendonck, Hans; Rul, Sean; De Bosschere, Koen
Data(s)

2010

Resumo

Speeding up sequential programs on multicores is a challenging problem that is in urgent need of a solution. Automatic parallelization of irregular pointer-intensive codes, exempli?ed by the SPECint codes, is a very hard problem. This paper shows that, with a helping hand, such auto-parallelization is possible and fruitful. This paper makes the following contributions: (i) A compiler framework for extracting pipeline-like parallelism from outer program loops is presented. (ii) Using a light-weight programming model based on annotations, the programmer helps the compiler to ?nd thread-level parallelism. Each of the annotations speci?es only a small piece of semantic information that compiler analysis misses, e.g. stating that a variable is dead at a certain program point. The annotations are designed such that correctness is easily veri?ed. Furthermore, we present a tool for suggesting annotations to the programmer. (iii) The methodology is applied to autoparallelize several SPECint benchmarks. For the benchmark with most parallelism (hmmer), we obtain a scalable 7-fold speedup on an AMD quad-core dual processor. The annotations constitute a parallel programming model that relies extensively on a sequential program representation. Hereby, the complexity of debugging is not increased and it does not obscure the source code. These properties could prove valuable to increase the ef?ciency of parallel programming.

Formato

application/pdf

Identificador

http://pure.qub.ac.uk/portal/en/publications/the-paralax-infrastructure-automatic-parallelization-with-a-helping-hand(c72f52f1-4ba8-4059-8cba-6507f91cd67c).html

http://dx.doi.org/10.1145/1854273.1854322

http://pure.qub.ac.uk/ws/files/5240407/postprint.pdf

Idioma(s)

eng

Direitos

info:eu-repo/semantics/openAccess

Fonte

Vandierendonck , H , Rul , S & De Bosschere , K 2010 , ' The Paralax Infrastructure: Automatic Parallelization With a Helping Hand ' Paper presented at 19th International Conference on Parallel Architectures and Compilation Techniques , Vienna , Austria , 11/09/2010 - 15/09/2010 , pp. 389-399 . DOI: 10.1145/1854273.1854322

Tipo

conferenceObject