DocumentCode :
1453816
Title :
Support of Probabilistic Pointer Analysis in the SSA Form
Author :
Hung, Ming-Yu ; Chen, Peng-Sheng ; Hwang, Yuan-Shin ; Ju, Roy Dz-Ching ; Lee, Jenq-Kuen
Author_Institution :
Dept. of Comput. Sci., Nat. Tsing Hua Univ., Hsinchu, Taiwan
Volume :
23
Issue :
12
fYear :
2012
Firstpage :
2366
Lastpage :
2379
Abstract :
Probabilistic pointer analysis (PPA) is a compile-time analysis method that estimates the probability that a points-to relationship will hold at a particular program point. The results are useful for optimizing and parallelizing compilers, which need to quantitatively assess the profitability of transformations when performing aggressive optimizations and parallelization. This paper presents a PPA technique using the static single assignment (SSA) form. When computing the probabilistic points-to relationships of a specific pointer, a pointer relation graph (PRG) is first built to represent all of the possible points-to relationships of the pointer. The PRG is transformed by a sequence of reduction operations into a compact graph, from which the probabilistic points-to relationships of the pointer can be determined. In addition, PPA is further extended to interprocedural cases by considering function related statements. We have implemented our proposed scheme including static and profiling versions in the Open64 compiler, and performed experiments to obtain the accuracy and scalability. The static version estimates branch probabilities by assuming that every conditional is equally likely to be true or false, and that every loop executes 10 times before terminating. The profiling version measures branch probabilities dynamically from past program executions using a default workload provided with the benchmark. The average errors for selected benchmarks were 3.80 percent in the profiling version and 9.13 percent in the static version. Finally, SPEC CPU2006 is used to evaluate the scalability, and the result indicates that our scheme is sufficiently efficient in practical use. The average analysis time was 35.59 seconds for an average of 98,696 lines of code.
Keywords :
graph theory; optimising compilers; probability; program diagnostics; Open64 compiler; PPA technique; PRG; SPEC CPU2006; SSA form; compact graph; compile-time analysis method; compiler optimization; compiler parallelization; pointer relation graph; probabilistic pointer analysis; probabilistic points-to relationships; profiling version; reduction operations; static single assignment form; static version; transformation profitability; Algorithm design and analysis; Benchmark testing; Complexity theory; Flow graphs; Probabilistic logic; Program processors; Compiler; control flow graph (CFG); pointer analysis; static single assignment (SSA) form;
fLanguage :
English
Journal_Title :
Parallel and Distributed Systems, IEEE Transactions on
Publisher :
ieee
ISSN :
1045-9219
Type :
jour
DOI :
10.1109/TPDS.2012.73
Filename :
6155713
Link To Document :
بازگشت