Hybrid Inlining: A Framework for Compositional and Context-Sensitive Static Analysis

被引:1
|
作者
Liu, Jiangchao [1 ,2 ]
Liu, Jierui [1 ]
Di, Peng [1 ]
Wu, Diyu [1 ]
Zheng, Hengjie [1 ]
Liu, Alex X. [1 ]
Xue, Jingling [3 ]
机构
[1] Ant Grp, Hangzhou, Peoples R China
[2] ByteDance, Hangzhou, Peoples R China
[3] UNSW Sydney, Sydney, Australia
关键词
context sensitivity; compositional static analysis; pointer analysis; POINTS-TO ANALYSIS; PRECISE;
D O I
10.1145/3597926.3598042
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Context-sensitivity is essential for achieving good precision in inter-procedural static analysis. To be context-sensitive, top-down analysis needs to fully inline all the statements in a callee at all its callsites, leading to statement explosion. Compositional analysis, which inlines summaries of all the callees, scales up but often loses precision, as it is not strictly context-sensitive. We propose a compositional and strictly context-sensitive framework for static analysis. This framework is based on a key observation: a compositional analysis often loses precision only on some critical statements that need to be analyzed context-sensitively. Our approach hybridly inlines the critical statements and the summaries of non-critical statements of each callee, thus avoiding re-analyzing non-critical ones. In addition, our analysis lazily summarizes the critical statements, by stopping propagating the critical statements once the calling context accumulated is adequate. We have designed and implemented several analyses (including a pointer analysis) based on this framework. Our evaluation on the pointer analysis shows that it can analyze large Java programs from the DaCapo benchmark suite and industry in minutes. Compared to context-insensitive analysis, Hybrid Inlining introduces only 65% and 1% additional time overheads on DaCapo and industrial applications, respectively.
引用
收藏
页码:114 / 126
页数:13
相关论文
共 50 条
  • [1] Adaptive online context-sensitive inlining
    Hazelwood, K
    Grove, D
    [J]. CGO 2003: INTERNATIONAL SYMPOSIUM ON CODE GENERATION AND OPTIMIZATION, 2003, : 253 - 264
  • [2] Context-sensitive trace inlining for Java']Java
    Haeubl, Christian
    Wimmer, Christian
    Moessenboeck, Hanspeter
    [J]. COMPUTER LANGUAGES SYSTEMS & STRUCTURES, 2013, 39 (04) : 123 - 141
  • [3] A Framework for Memory Efficient Context-Sensitive Program Analysis
    Mathias Hedenborg
    Jonas Lundberg
    Welf Löwe
    Martin Trapp
    [J]. Theory of Computing Systems, 2022, 66 : 911 - 956
  • [4] A Framework for Memory Efficient Context-Sensitive Program Analysis
    Hedenborg, Mathias
    Lundberg, Jonas
    Lowe, Welf
    Trapp, Martin
    [J]. THEORY OF COMPUTING SYSTEMS, 2022, 66 (05) : 911 - 956
  • [5] A generic framework for context-sensitive analysis of modular programs
    Puebla, G
    Correas, J
    Hermenegildo, MV
    Bueno, F
    de la Banda, MG
    Marriott, K
    Stuckey, PJ
    [J]. PROGRAM DEVELOPMENT IN COMPUTATIONAL LOGIC: A DECADE OF RESEARCH ADVANCES IN LOGIC-BASED PROGRAM DEVELOPMENT, 2004, 3049 : 233 - 260
  • [6] A context-sensitive framework for lexical ontologies
    Veale, Tony
    Hao, Yanfen
    [J]. KNOWLEDGE ENGINEERING REVIEW, 2008, 23 (01): : 101 - 115
  • [7] A framework for context-sensitive metadata description
    Industrial Ontologies Group, Agora Center, University of Jyväskylä, P.O. Box 35, FIN-40014-Jyväskylä, Finland
    不详
    [J]. Int. J. Metadata Semant. Ontol., 2006, 2 (154-164):
  • [8] Context-sensitive content representation for static document
    Chu, WC
    Chen, YW
    Chen, JN
    [J]. 11TH ASIA-PACIFIC SOFTWARE ENGINEERING CONFERENCE, PROCEEDINGS, 2004, : 719 - 725
  • [9] A context-sensitive conceptual framework for activity modeling
    Das, Rahul Deb
    Winter, Stephan
    [J]. JOURNAL OF SPATIAL INFORMATION SCIENCE, 2016, (12): : 45 - 85
  • [10] A language independent framework for context-sensitive formatting
    van den Brand, M. G. J.
    Kooiker, A. T.
    Vinju, J. J.
    Veerman, N. P.
    [J]. 10TH EUROPEAN CONFERENCE ON SOFTWARE MAINTENANCE AND REENGINEERING, PROCEEDINGS, 2006, : 101 - +