Static Backward Demand-Driven Slicing

被引:9
|
作者
Lisper, Bjorn [1 ]
Masud, Abu Naser [1 ]
Khanfar, Husni [1 ]
机构
[1] Malardalen Univ, Sch Innovat Design & Engn, Vasteras, Sweden
关键词
Static backward slicing; Unstructured control flow; Data flow equations; Computational complexity; Strongly live variable; Abstract Interpretation;
D O I
10.1145/2678015.2682538
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Program slicing identifies the program parts that may affect certain properties of the program, such as the outcomes of conditions affecting the program flow. Ottenstein's Program Dependence Graph (PDG) based algorithm is the state-of-practice for static slicing today: it is well-suited in applications where many slices are computed, since the cost of building the PDG then can be amortized over the slices. But there are applications that require few slices of a given program, and where computing all the dependencies may be unnecessary. We present a light-weight interprocedural algorithm for backward static slicing where the data dependence analysis is done using a variant of the Strongly Live Variables (SLV) analysis. This allows us to avoid building the Data Dependence Graph, and to slice program statements "on-the-fly" during the SLV analysis which is potentially faster for computing few slices. Furthermore we use an abstract interpretation-based value analysis to extend our slicing algorithm to slice low-level code, where data dependencies are not evident due to dynamically calculated addresses. Our algorithm computes slices as sets of Control Flow Graph nodes: we show how to adapt existing techniques to generate executable slices that correspond to semantically correct code, where jump statements have been inserted at appropriate places. We have implemented our slicing algorithms, and made an experimental evaluation comparing them with the standard PDG-based algorithm for a number of example programs. We obtain the same accuracy as for PDG-based slicing, sometimes with substantial improvements in performance.
引用
收藏
页码:115 / 126
页数:12
相关论文
共 50 条
  • [1] A demand-driven approach to slicing legacy COBOL systems
    Hajnal, Akos
    Forgacs, Istvan
    [J]. JOURNAL OF SOFTWARE-EVOLUTION AND PROCESS, 2012, 24 (01) : 67 - 82
  • [2] Static Analysis with Demand-Driven Value Refinement
    Stein, Benno
    Nielsen, Benjamin Barslev
    Chang, Bor-Yuh Evan
    Moller, Anders
    [J]. PROCEEDINGS OF THE ACM ON PROGRAMMING LANGUAGES-PACMPL, 2019, 3 (OOPSLA):
  • [3] Demand-driven register allocation
    Proebsting, TA
    Fischer, CN
    [J]. ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 1996, 18 (06): : 683 - 710
  • [4] Demand-Driven Land Evaluation
    Bacic, I. L. Z.
    [J]. DIGITAL SOIL MAPPING WITH LIMITED DATA, 2008, : 151 - +
  • [5] Demand-driven approach for sustainability
    SaxenRosendahl, A
    [J]. SUSTAINABILITY OF WATER AND SANITATION SYSTEMS, 1996, : 32 - 34
  • [6] Demand-driven specification partitioning
    Mittermeir, RT
    Bollin, A
    [J]. MODULAR PROGRAMMING LANGUAGES, PROCEEDINGS, 2003, 2789 : 241 - 253
  • [7] Demand-Driven Tag Recommendation
    Menezes, Guilherme Vale
    Almeida, Jussara M.
    Belem, Fabiano
    Goncalves, Marcos Andre
    Lacerda, Anisio
    de Moura, Edleno Silva
    Pappa, Gisele L.
    Veloso, Adriano
    Ziviani, Nivio
    [J]. MACHINE LEARNING AND KNOWLEDGE DISCOVERY IN DATABASES, PT II: EUROPEAN CONFERENCE, ECML PKDD 2010, 2010, 6322 : 402 - 417
  • [8] Demand-driven clustering in MANETs
    Cramer, C
    Stanze, O
    Weniger, K
    Zitterbart, M
    [J]. ICWN'04 & PCC'04, VOLS, 1 AND 2, PROCEEDINGS, 2004, : 81 - 87
  • [9] Demand-Driven Materials Design
    Zhang H.
    [J]. Shanghai Jiaotong Daxue Xuebao/Journal of Shanghai Jiaotong University, 2021, 55 : 93 - 94
  • [10] Demand-driven memory management
    [J]. Acta Polytechnica Scandinavica, Mathematics and Computer Science Series, 1991, (58):