Skip to Main content Skip to Navigation
New interface
Conference papers

Pointer Disambiguation via Strict Inequalities

Abstract : The design and implementation of static analyses that disambiguate pointers has been a focus of research since the early days of compiler construction. One of the challenges that arise in this context is the analysis of languages that support pointer arithmetics, such as C, C++ and assembly dialects. This paper contributes to solve this challenge. We start from an obvious, yet unexplored, observation: if a pointer is strictly less than another, they cannot alias. Motivated by this remark, we use the abstract interpretation framework to build strict less-than relations between pointers. To this end, we construct a program representation that bestows the Static Single Information (SSI) property onto our dataflow analysis. SSI gives us an efficient sparse algorithm, which, once seen as a form of abstract interpretation, is correct by construction. We have implemented our static analysis in LLVM. It runs in time linear on the number of program variables, and, depending on the benchmark, it can be as much as six times more precise than the pointer disambiguation techniques already in place in that compiler.
Complete list of metadata

Cited literature [43 references]  Display  Hide  Download

https://hal.archives-ouvertes.fr/hal-01387031
Contributor : Laure Gonnord Connect in order to contact the contributor
Submitted on : Thursday, December 22, 2016 - 10:59:37 AM
Last modification on : Tuesday, October 25, 2022 - 4:20:36 PM
Long-term archiving on: : Tuesday, March 21, 2017 - 8:21:21 AM

File

CGO17_AuthorVersion.pdf
Files produced by the author(s)

Identifiers

  • HAL Id : hal-01387031, version 1

Collections

Citation

Maroua Maalej, Vitor Paisante, Ramos Pedro, Laure Gonnord, Fernando Pereira. Pointer Disambiguation via Strict Inequalities. Code Generation and Optimisation , Feb 2017, Austin, United States. pp.134-147. ⟨hal-01387031⟩

Share

Metrics

Record views

239

Files downloads

395