A Technique for the Effective and Automatic Reuse of Classical Compiler Optimizations on Multithreaded Code

被引:0
|
作者
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 USA
关键词
Data-Flow Analysis; Parallel-Program Optimization; EFFICIENT; PROGRAMS;
D O I
10.1145/1925844.1926457
中图分类号
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 paper 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.
引用
收藏
页码:623 / 636
页数:14
相关论文
共 50 条
  • [21] PADS: A Pattern-Driven Stencil Compiler-Based Tool for Reuse of Optimizations on GPGPUs
    Han, Dongni
    Xu, Shixiong
    Chen, Li
    Huang, Lei
    [J]. 2011 IEEE 17TH INTERNATIONAL CONFERENCE ON PARALLEL AND DISTRIBUTED SYSTEMS (ICPADS), 2011, : 308 - 315
  • [22] Dominance-Based Duplication Simulation (DBDS) Code Duplication to Enable Compiler Optimizations
    Leopoldseder, David
    Stadler, Lukas
    Wurthinger, Thomas
    Eisl, Josef
    Simon, Doug
    Moessenboeck, Hanspeter
    [J]. PROCEEDINGS OF THE 2018 INTERNATIONAL SYMPOSIUM ON CODE GENERATION AND OPTIMIZATION (CGO'18), 2018, : 126 - 137
  • [23] Dead code elimination technique in eclipse compiler for Java
    Department of Computer Engineering, Dharmsinh Desai University, Nadiad, India
    [J]. Int. Conf. Control, Instrum., Commun. Comput. Technol., ICCICCT, 2015, (275-278):
  • [24] A Compiler Technique for Processor-Wide Protection From Soft Errors in Multithreaded Environments
    Didehba, Moslem
    Shrivastava, Viral
    [J]. IEEE TRANSACTIONS ON RELIABILITY, 2018, 67 (01) : 249 - 263
  • [25] SoCeR: A New Source Code Recommendation Technique for Code Reuse
    Islam, Md Mazharul
    Iqbal, Razib
    [J]. 2020 IEEE 44TH ANNUAL COMPUTERS, SOFTWARE, AND APPLICATIONS CONFERENCE (COMPSAC 2020), 2020, : 1552 - 1557
  • [26] Improving effective bandwidth through compiler enhancement of global cache reuse
    Ding, C
    Kennedy, K
    [J]. JOURNAL OF PARALLEL AND DISTRIBUTED COMPUTING, 2004, 64 (01) : 108 - 134
  • [27] Automatic Recognition of Computational Kernels for Platform-Dependent Code Optimizations
    Blanco, Maria Rodriguez
    Reinke, Georg
    Ascheid, Gerd
    Leupers, Rainer
    [J]. PROCEEDINGS OF 2016 INTERNATIONAL CONFERENCE ON EMBEDDED COMPUTER SYSTEMS: ARCHITECTURES, MODELING AND SIMULATION (SAMOS), 2016, : 11 - 20
  • [28] Dead Code Elimination Technique in Eclipse Compiler for Java']Java
    Karer, Hiral H.
    Sani, Purvi B.
    [J]. 2015 INTERNATIONAL CONFERENCE ON CONTROL, INSTRUMENTATION, COMMUNICATION AND COMPUTATIONAL TECHNOLOGIES (ICCICCT), 2015, : 275 - 278
  • [29] BALLERINA: Automatic Generation and Clustering of Efficient Random Unit Tests for Multithreaded Code
    Nistor, Adrian
    Luo, Qingzhou
    Pradel, Michael
    Gross, Thomas R.
    Marinov, Darko
    [J]. 2012 34TH INTERNATIONAL CONFERENCE ON SOFTWARE ENGINEERING (ICSE), 2012, : 727 - 737
  • [30] Use of Code Structural Features for Machine Learning to Predict Effective Optimizations
    Kawarabatake, Yuki
    Agung, Mulya
    Komatsu, Kazuhiko
    Egawa, Ryusuke
    Takizawa, Hiroyuki
    [J]. 2018 IEEE INTERNATIONAL PARALLEL AND DISTRIBUTED PROCESSING SYMPOSIUM WORKSHOPS (IPDPSW 2018), 2018, : 1049 - 1055