On a Technique for Transparently Empowering Classical Compiler Optimizations on Multithreaded Code

被引:1
|
作者
Joisha, Pramod G. [1 ]
Schreiber, Robert S. [1 ]
Banerjee, Prithviraj [1 ]
Boehm, Hans-J. [1 ]
Chakrabarti, Dhruva R. [1 ]
机构
[1] Hewlett Packard Labs, Palo Alto, CA 94304 USA
关键词
Algorithms; Languages; Performance; Theory; Data-flow analysis; parallel-program optimization; PARALLEL; EFFICIENT; FORM;
D O I
10.1145/2220365.2220368
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
A large body of data-flow analyses exists for analyzing and optimizing sequential code. Unfortunately, much of it cannot be directly applied on parallel code, for reasons of correctness. This article presents a technique to automatically, aggressively, yet safely apply sequentially-sound data-flow transformations, without change, on shared-memory programs. The technique is founded on the notion of program references being "siloed" on certain control-flow paths. Intuitively, siloed references are free of interference from other threads within the confines of such paths. Data-flow transformations can, in general, be unblocked on siloed references. The solution has been implemented in a widely used compiler. Results on benchmarks from SPLASH-2 show that performance improvements of up to 41% are possible, with an average improvement of 6% across all the tested programs over all thread counts.
引用
收藏
页码:1 / 42
页数:42
相关论文
共 19 条
  • [1] A Technique for the Effective and Automatic Reuse of Classical Compiler Optimizations on Multithreaded Code
    Joisha, Pramod G.
    Schreiber, Robert S.
    Banerjee, Prithviraj
    Boehm, Hans-J.
    Chakrabarti, Dhruva R.
    [J]. POPL 11: PROCEEDINGS OF THE 38TH ANNUAL ACM SIGPLAN-SIGACT SYMPOSIUM ON PRINCIPLES OF PROGRAMMING LANGUAGES, 2011, : 623 - 636
  • [2] Technique for the effective and automatic reuse of classical compiler optimizations on multithreaded code
    Joisha, Pramod G.
    Schreiber, Robert S.
    Banerjee, Prithviraj
    Boehm, Hans-J.
    Chakrabarti, Dhruva R.
    [J]. HP Laboratories Technical Report, 2010, (81):
  • [3] A Technique for the Effective and Automatic Reuse of Classical Compiler Optimizations on Multithreaded Code
    Joisha, Pramod G.
    Schreiber, Robert S.
    Banerjee, Prithviraj
    Boehm, Hans-J.
    Chakrabarti, Dhruva R.
    [J]. ACM SIGPLAN NOTICES, 2011, 46 (01) : 623 - 636
  • [4] 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
  • [5] 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
  • [6] 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
  • [7] Communication Optimizations for Multithreaded Code Generation from Simulink Models
    Huang, Kai
    Yu, Min
    Yan, Rongjie
    Zhang, Xiaomeng
    Yan, Xiaolang
    Brisolara, Lisane
    Jerraya, Ahmed Amine
    Feng, Jiong
    [J]. ACM TRANSACTIONS ON EMBEDDED COMPUTING SYSTEMS, 2015, 14 (03)
  • [8] A compiler framework for recovery code generation in general speculative optimizations
    Lin, J
    Hsu, WC
    Yew, PC
    Ju, RDC
    Ngai, TF
    [J]. 13TH INTERNATIONAL CONFERENCE ON PARALLEL ARCHITECTURE AND COMPILATION TECHNIQUES, PROCEEDINGS, 2004, : 17 - 28
  • [9] Practical compiler techniques on efficient multithreaded code generation for OpenMP programs
    Tian, XM
    Girkar, M
    Bik, A
    Saito, H
    [J]. COMPUTER JOURNAL, 2005, 48 (05): : 588 - 601
  • [10] 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