Code reuse in an optimizing compiler

被引:0
|
作者
AdlTabatabai, AR
Gross, T
Lueh, GY
机构
[1] ETH ZURICH,INST COMP SYST,CH-8092 ZURICH,SWITZERLAND
[2] CARNEGIE MELLON UNIV,ECE DEPT,PITTSBURGH,PA 15213
关键词
D O I
10.1145/236338.236342
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
This paper describes how the cmcc compiler reuses code - both internally (reuse between different modules) and externally (reuse between versions for different target machines). The key to reuse are the application frameworks developed for global data-flow analysis, code generation, instruction scheduling, and register allocation. The code produced by cmcc is as good as the code produced by the native compilers for the MIPS and SPARC, although significantly less resources have been spent on cmcc (overall, about 6 man years by 2.5 persons). cmcc is implemented in C++, which allowed for a compact expression of the frameworks as class hierarchies. The results support the claim that suitable frameworks facilitate reuse and thereby significantly improve developer effectiveness.
引用
收藏
页码:51 / 68
页数:18
相关论文
共 50 条
  • [1] P-CODE AND COMPILER PORTABILITY - EXPERIENCE WITH A MODULA-2 OPTIMIZING COMPILER
    LOUDEN, K
    [J]. SIGPLAN NOTICES, 1990, 25 (05): : 53 - 59
  • [2] 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
  • [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]. POPL 11: PROCEEDINGS OF THE 38TH ANNUAL ACM SIGPLAN-SIGACT SYMPOSIUM ON PRINCIPLES OF PROGRAMMING LANGUAGES, 2011, : 623 - 636
  • [4] 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):
  • [6] AN OPTIMIZING PROLOG COMPILER
    KOMATSU, H
    TAMURA, N
    ASAKAWA, Y
    KUROKAWA, T
    [J]. LECTURE NOTES IN COMPUTER SCIENCE, 1987, 264 : 104 - 115
  • [7] AN OPTIMIZING PASCAL COMPILER
    FAIMAN, RN
    KORTESOJA, AA
    [J]. IEEE TRANSACTIONS ON SOFTWARE ENGINEERING, 1980, 6 (06) : 512 - 519
  • [8] Not So Fast: Understanding and Mitigating Negative Impacts of Compiler Optimizations on Code Reuse Gadget Sets
    Brown, Michael D.
    Pruett, Matthew
    Bigelow, Robert
    Mururu, Girish
    Pande, Santosh
    [J]. PROCEEDINGS OF THE ACM ON PROGRAMMING LANGUAGES-PACMPL, 2021, 5 (OOPSLA):
  • [9] Mapping reference code to irregular DSPs within the retargetable, optimizing compiler COGEN(T)
    Gréwal, GW
    Wilson, CT
    [J]. 34TH ACM/IEEE INTERNATIONAL SYMPOSIUM ON MICROARCHITECTURE, MICRO-34, PROCEEDINGS, 2001, : 192 - 202
  • [10] RICE: An Optimizing Curry Compiler
    Libby, Steven
    [J]. PRACTICAL ASPECTS OF DECLARATIVE LANGUAGES, PADL 2023, 2023, 13880 : 3 - 19