Call graph correction using control flow constraints
dc.contributor.advisor | McKinley, Kathryn S. | en |
dc.creator | Lee, Byeongcheol | en |
dc.date.accessioned | 2015-08-26T20:47:25Z | en |
dc.date.available | 2015-08-26T20:47:25Z | en |
dc.date.issued | 2006-05 | en |
dc.description.abstract | Dynamic optimizers for object-oriented languages collect a variety of profile data to drive optimization decisions. In particular, the dynamic call graph (DCG) informs key structural optimizations such as which methods to optimize and how to optimize them. Unfortunately, current low-overhead call-stack hardware and software sampling methods are subject to sampling bias, which loses accuracy of 40 to 50% when compared with a perfect call graph. This paper introduces DCG correction, a novel approach that uses static and dynamic control-flow graphs (CFGs) to improve DCG accuracy. We introduce the static frequency dominator (FDOM) relation, which extends the dominator relation on the CFG to capture relative execution frequencies and expose static constraints on DCG edges, which we use to correct DCG edge frequencies. Using conservation of flow principles, we further show how to use dynamic CFG basic block profiles to correct DCG edge frequencies intraprocedurally and interprocedurally. We implement and evaluate DCG correction in Jikes RVM on the SPEC JVM98 and DaCapo benchmarks. Default DCG sampling attains an average accuracy of 52-59% compared with perfect, whereas FDOM correction improves average accuracy to 64-68%, while adding 0.2% average overhead. The dynamic correction raises accuracy to 85% on average, while adding 1.2% average overhead. We then provide dynamically corrected DCGs to the inliner with mixed results -1% average degradations and improvements across a variety of configurations. However, prior work shows that increased DCG accuracy in production VMs has benefits. We believe that high-accuracy DCGs will become more important in the future as the complexity and modularity of object-oriented programs increases. | en |
dc.description.department | Computer Science | |
dc.format.medium | electronic | en |
dc.identifier.uri | http://hdl.handle.net/2152/30457 | en |
dc.language.iso | eng | en |
dc.relation.ispartof | UT Electronic Theses and Dissertations | en |
dc.rights | Copyright © is held by the author. Presentation of this material on the Libraries' web site by University Libraries, The University of Texas at Austin was made possible under a limited license grant from the author who has retained all copyrights in the works. | en |
dc.rights.restriction | Restricted | en |
dc.subject | Dynamic optimizers | en |
dc.subject | Object-oriented languages | en |
dc.subject | Computer programming | en |
dc.title | Call graph correction using control flow constraints | en |
dc.type | Thesis | en |
dc.type.genre | Thesis | en |
thesis.degree.department | Computer Sciences | en |
thesis.degree.discipline | Computer Sciences | en |
thesis.degree.grantor | The University of Texas at Austin | en |
thesis.degree.level | Masters | en |
thesis.degree.name | Master of Arts | en |
Access full-text files
Original bundle
1 - 1 of 1
No Thumbnail Available
- Name:
- txu-oclc-70869252.pdf
- Size:
- 427.88 KB
- Format:
- Adobe Portable Document Format
- Description:
- Access restricted to UT Austin EID holders
License bundle
1 - 1 of 1
No Thumbnail Available
- Name:
- license.txt
- Size:
- 1.66 KB
- Format:
- Item-specific license agreed upon to submission
- Description: