Back to Search Start Over

Zero-Overhead Path Prediction with Progressive Symbolic Execution

Authors :
Sunjae Park
Haider Adnan Khan
Alenka Zajic
Richard L. Rutledge
Alessandro Orso
Milos Prvulovic
Source :
ICSE
Publication Year :
2019
Publisher :
IEEE, 2019.

Abstract

In previous work, we introduced zero-overhead profiling (ZOP), a technique that leverages the electromagnetic emissions generated by the computer hardware to profile a program without instrumenting it. Although effective, ZOP has several shortcomings: it requires test inputs that achieve extensive code coverage for its training phase; it predicts path profiles instead of complete execution traces; and its predictions can suffer unrecoverable accuracy losses. In this paper, we present zero-overhead path prediction (ZOP-2), an approach that extends ZOP and addresses its limitations. First, ZOP-2 achieves high coverage during training through progressive symbolic execution (PSE)---symbolic execution of increasingly small program fragments. Second, ZOP-2 predicts complete execution traces, rather than path profiles. Finally, ZOP-2 mitigates the problem of path mispredictions by using a stateless approach that can recover from prediction errors. We evaluated our approach on a set of benchmarks with promising results; for the cases considered, (1) ZOP-2 achieved over 90% path prediction accuracy, and (2) PSE covered feasible paths missed by traditional symbolic execution, thus boosting ZOP-2's accuracy.

Details

Database :
OpenAIRE
Journal :
2019 IEEE/ACM 41st International Conference on Software Engineering (ICSE)
Accession number :
edsair.doi...........3ea55d340007c6a896f2765cb61d0721