A new framework for debugging globally optimized code

LC Wu, R Mirani, H Patil, B Olsen, WW Hwu - ACM SIGPLAN Notices, 1999 - dl.acm.org
LC Wu, R Mirani, H Patil, B Olsen, WW Hwu
ACM SIGPLAN Notices, 1999dl.acm.org
With an increasing number of executable binaries generated by optimizing compilers today,
providing a clear and correct source-level debugger for programmers to debug optimized
code has become a necessity. In this paper, a new framework for debugging globally
optimized code is proposed. This framework consists of a new code location mapping
scheme, a data location tracking scheme, and an emulation-based forward recovery model.
By taking over the control early and emulating instructions selectively, the debugger can …
With an increasing number of executable binaries generated by optimizing compilers today, providing a clear and correct source-level debugger for programmers to debug optimized code has become a necessity. In this paper, a new framework for debugging globally optimized code is proposed. This framework consists of a new code location mapping scheme, a data location tracking scheme, and an emulation-based forward recovery model. By taking over the control early and emulating instructions selectively, the debugger can preserve and gather the required program state for the recovery of expected variable values at source breakpoints. The framework has been prototyped in the IMPACT compiler and GDB-4.16. Preliminary experiments conducted on several SPEC95 integer programs have yielded encouraging results. The extra time needed for the debugger to calculate the limits of the emulated region and to emulate instructions is hardly noticeable, while the increase in executable file size due to the extra debug information is on average 76% of that of the executable file with no debug information.
ACM Digital Library