A compiler framework for recovery code generation in general speculative optimizations

被引:0
|
作者
Lin, J [1 ]
Hsu, WC [1 ]
Yew, PC [1 ]
Ju, RDC [1 ]
Ngai, TF [1 ]
机构
[1] Univ Minnesota, Dept Comp Sci & Engn, Minneapolis, MN 55455 USA
关键词
D O I
暂无
中图分类号
TP3 [计算技术、计算机技术];
学科分类号
0812 ;
摘要
A general framework that integrates both control and data speculation using alias profiling and/or compiler heuristic rules has shown to improve SPEC2000 performance on Itanium systems. However, speculative optimizations require check instructions and recovery code to ensure correct execution when speculation fails at runtime. How to generate check instructions and their associated recovery code efficiently and effectively is an issue yet to be well studied. Also, it is very important that the recovery code generated in the earlier phases integrate gracefully in the later optimization phases. At the very least, it should not hinder later optimizations, thus, ensuring overall performance improvement. This paper proposes a framework that uses an if-block structure to facilitate check instructions and recovery code generation for general speculative optimizations. It allows speculative instructions and their recovery code generated in the early compiler optimization phases to be integrated effectively with the subsequent optimization phases. It also allows multi-level speculation for multi-level pointers and multi-level expression trees to be handled with no additional complexity. The proposed recovery code generation framework has been implemented in the Open Research Compiler (ORC).
引用
收藏
页码:17 / 28
页数:12
相关论文
共 50 条
  • [1] General compiler framework for speculative optimizations using data speculative code motion
    Dai, XR
    Zhai, A
    Hsu, WC
    Yew, PC
    [J]. CGO 2005: INTERNATIONAL SYMPOSIUM ON CODE GENERATION AND OPTIMIZATION, 2005, : 280 - 290
  • [2] A compiler framework for speculative analysis and optimizations
    Lin, J
    Chen, T
    Hsu, WC
    Ju, RDC
    Ngai, TF
    Yew, PC
    Chan, S
    [J]. ACM SIGPLAN NOTICES, 2003, 38 (05) : 289 - 299
  • [3] A general compiler framework for speculative multithreaded processors
    Bhowmik, A
    Franklin, M
    [J]. IEEE TRANSACTIONS ON PARALLEL AND DISTRIBUTED SYSTEMS, 2004, 15 (08) : 713 - 724
  • [4] A Framework for Formal Verification of Compiler Optimizations
    Mansky, William
    Gunter, Elsa
    [J]. INTERACTIVE THEOREM PROVING, PROCEEDINGS, 2010, 6172 : 371 - 386
  • [5] The Effect of Combining Compiler Optimizations on Code Size
    Foleiss, Juliano Henrique
    da Silva, Anderson Faustino
    Ruiz, Linnyer Beatrys
    [J]. 2011 30TH INTERNATIONAL CONFERENCE OF THE CHILEAN COMPUTER SCIENCE SOCIETY (SCCC), 2012, : 187 - 194
  • [6] CcNav: Understanding Compiler Optimizations in Binary Code
    Devkota, Sabin
    Aschwanden, Pascal
    Kunen, Adam
    Legendre, Matthew
    Isaacs, Katherine E.
    [J]. IEEE TRANSACTIONS ON VISUALIZATION AND COMPUTER GRAPHICS, 2021, 27 (02) : 667 - 677
  • [7] Prospect: A Compiler Framework for Speculative Parallelization
    Suesskraut, Martin
    Knauth, Thomas
    Weigert, Stefan
    Schiffel, Ute
    Meinhold, Martin
    Fetzer, Christof
    [J]. CGO 2010: THE EIGHTH INTERNATIONAL SYMPOSIUM ON CODE GENERATION AND OPTIMIZATION, PROCEEDINGS, 2010, : 131 - +
  • [8] Compiler Optimizations for Code Density of Variable Length Instructions
    Kultala, Heikki
    Viitanen, Timo
    Jaaskelainen, Pekka
    Helkala, Janne
    Takala, Jarmo
    [J]. PROCEEDINGS OF THE 2014 IEEE WORKSHOP ON SIGNAL PROCESSING SYSTEMS (SIPS 2014), 2014, : 127 - 132
  • [9] A PVS based framework for validating compiler optimizations
    Kanade, Aditya
    Sanyal, Amitabha
    Khedker, Uday
    [J]. SEFM 2006: FOURTH IEEE INTERNATIONAL CONFERENCE ON SOFTWARE ENGINEERING AND FORMAL METHODS, PROCEEDINGS, 2006, : 108 - +