• DocumentCode
    2442297
  • Title

    Understanding integer overflow in C/C++

  • Author

    Dietz, Will ; Li, Peng ; Regehr, John ; Adve, Vikram

  • Author_Institution
    Dept. of Comput. Sci., Univ. of Illinois at Urbana-Champaign, Champaign, IL, USA
  • fYear
    2012
  • fDate
    2-9 June 2012
  • Firstpage
    760
  • Lastpage
    770
  • Abstract
    Integer overflow bugs in C and C++ programs are difficult to track down and may lead to fatal errors or exploitable vulnerabilities. Although a number of tools for finding these bugs exist, the situation is complicated because not all overflows are bugs. Better tools need to be constructed - but a thorough understanding of the issues behind these errors does not yet exist. We developed IOC, a dynamic checking tool for integer overflows, and used it to conduct the first detailed empirical study of the prevalence and patterns of occurrence of integer overflows in C and C++ code. Our results show that intentional uses of wraparound behaviors are more common than is widely believed; for example, there are over 200 distinct locations in the SPEC CINT2000 benchmarks where overflow occurs. Although many overflows are intentional, a large number of accidental overflows also occur. Orthogonal to programmers´ intent, overflows are found in both well-defined and undefined flavors. Applications executing undefined operations can be, and have been, broken by improvements in compiler optimizations. Looking beyond SPEC, we found and reported undefined integer overflows in SQLite, PostgreSQL, SafeInt, GNU MPC and GMP, Firefox, GCC, LLVM, Python, BIND, and OpenSSL; many of these have since been fixed. Our results show that integer overflow issues in C and C++ are subtle and complex, that they are common even in mature, widely used programs, and that they are widely misunderstood by developers.
  • Keywords
    C++ language; SQL; optimising compilers; program debugging; BIND; C++ programs; Firefox; GCC; GMP; GNU MPC; IOC; LLVM; OpenSSL; PostgreSQL; Python; SPEC; SQLite; SafeInt; compiler optimizations; dynamic checking tool; integer overflow bugs; integer overflow understanding; wraparound behaviors; Computer bugs; Optimization; Program processors; Runtime; Semantics; Standards; Weapons; integer overflow; integer wraparound; undefined behavior;
  • fLanguage
    English
  • Publisher
    ieee
  • Conference_Titel
    Software Engineering (ICSE), 2012 34th International Conference on
  • Conference_Location
    Zurich
  • ISSN
    0270-5257
  • Print_ISBN
    978-1-4673-1066-6
  • Electronic_ISBN
    0270-5257
  • Type

    conf

  • DOI
    10.1109/ICSE.2012.6227142
  • Filename
    6227142