The availability of debug information for optimized executables can largely ease crucial tasks such as crash analysis. Source-level debuggers use this information to display program state in terms of source code, allowing users to reason on it even when optimizations alter program structure extensively. A few recent endeavors have proposed effective methodologies for identifying incorrect instances of debug information, which can mislead users by presenting them with an inconsistent program state. In this work, we identify and study a related important problem: the completeness of debug information. Unlike correctness issues for which an unoptimized executable can serve as reference, we find there is no analogous oracle to deem when the cause behind an unreported part of program state is an unavoidable effect of optimization or a compiler implementation defect. In this scenario, we argue that empirically derived conjectures on the expected availability of debug information can serve as an effective means to expose classes of these defects. We propose three conjectures involving variable values and study how often synthetic programs compiled with different configurations of the popular gcc and LLVM compilers deviate from them. We then discuss techniques to pinpoint the optimizations behind such violations and minimize bug reports accordingly. Our experiments revealed, among others, 24 bugs already confirmed by the developers of the gcc-gdb and clang-lldb ecosystems.

Where Did My Variable Go? Poking Holes in Incomplete Debug Information / Assaiante, C.; D'Elia, D. C.; Di Luna, G. A.; Querzoni, L.. - 2:(2023), pp. 935-947. (Intervento presentato al convegno Architectural Support for Programming Languages and Operating Systems tenutosi a Vancouver; Canada) [10.1145/3575693.3575720].

Where Did My Variable Go? Poking Holes in Incomplete Debug Information

Assaiante C.
;
D'Elia D. C.
;
Di Luna G. A.
;
Querzoni L.
2023

Abstract

The availability of debug information for optimized executables can largely ease crucial tasks such as crash analysis. Source-level debuggers use this information to display program state in terms of source code, allowing users to reason on it even when optimizations alter program structure extensively. A few recent endeavors have proposed effective methodologies for identifying incorrect instances of debug information, which can mislead users by presenting them with an inconsistent program state. In this work, we identify and study a related important problem: the completeness of debug information. Unlike correctness issues for which an unoptimized executable can serve as reference, we find there is no analogous oracle to deem when the cause behind an unreported part of program state is an unavoidable effect of optimization or a compiler implementation defect. In this scenario, we argue that empirically derived conjectures on the expected availability of debug information can serve as an effective means to expose classes of these defects. We propose three conjectures involving variable values and study how often synthetic programs compiled with different configurations of the popular gcc and LLVM compilers deviate from them. We then discuss techniques to pinpoint the optimizations behind such violations and minimize bug reports accordingly. Our experiments revealed, among others, 24 bugs already confirmed by the developers of the gcc-gdb and clang-lldb ecosystems.
2023
Architectural Support for Programming Languages and Operating Systems
compiler bugs; compiler optimizations; debuggers
04 Pubblicazione in atti di convegno::04b Atto di convegno in volume
Where Did My Variable Go? Poking Holes in Incomplete Debug Information / Assaiante, C.; D'Elia, D. C.; Di Luna, G. A.; Querzoni, L.. - 2:(2023), pp. 935-947. (Intervento presentato al convegno Architectural Support for Programming Languages and Operating Systems tenutosi a Vancouver; Canada) [10.1145/3575693.3575720].
File allegati a questo prodotto
File Dimensione Formato  
Assaiante_Where_2023.pdf

accesso aperto

Note: https://doi.org/10.1145/3575693.3575720
Tipologia: Versione editoriale (versione pubblicata con il layout dell'editore)
Licenza: Tutti i diritti riservati (All rights reserved)
Dimensione 780.62 kB
Formato Adobe PDF
780.62 kB Adobe PDF

I documenti in IRIS sono protetti da copyright e tutti i diritti sono riservati, salvo diversa indicazione.

Utilizza questo identificativo per citare o creare un link a questo documento: https://hdl.handle.net/11573/1672065
Citazioni
  • ???jsp.display-item.citation.pmc??? ND
  • Scopus 4
  • ???jsp.display-item.citation.isi??? 2
social impact