Open64 Explained

Open64
Developer:Silicon Graphics, Inc., Institute of Computing Technology, Chinese Academy of Sciences, Hewlett-Packard, University of Delaware
Discontinued:yes
Latest Release Version:5.0
Operating System:Cross-platform, Linux
Genre:Compiler
License:GNU General Public License

Open64 is a free, open-source, optimizing compiler for the Itanium and x86-64 microprocessor architectures. It derives from the SGI compilers for the MIPS R10000 processor, called MIPSPro. It was initially released in 2000 as GNU GPL software under the name Pro64. The following year, University of Delaware adopted the project and renamed the compiler to Open64. It now mostly serves as a research platform for compiler and computer architecture research groups. Open64 supports Fortran 77/95 and C/C++, as well as the shared memory programming model OpenMP. It can conduct high-quality interprocedural analysis, data-flow analysis, data dependence analysis, and array region analysis. Development has ceased, although other projects can use the project's source.

The infrastructure

Its major components are the frontend for C/C++ (using GCC) and Fortran 77/90 (using the CraySoft front-end and libraries), Interprocedural analysis (IPA), loop nest optimizer (LNO), global optimizer (WOPT), and code generator (CG). Despite being initially written for a single computer architecture, Open64 has proven that it can generate efficient code for CISC, RISC, and VLIW architectures, including MIPS, x86, IA-64, ARM, and others.

Intermediate representation

A hierarchical intermediate representation (IR) with five main levels is used in this compiler to serve as the common interface among all the frontend and backend components. This IR is named WHIRL.

Versions

The original version of Open64 that was released in 2002 was missing its very advanced software pipelining code generator, and had only a rudimentary code generator for Itanium. The entire original MIPSPro compiler, with this code generator, is available under a commercial license as the Blackbird compiler from Reservoir Labs. The Showdown Paper documents the code generator that was not included in Open64. The very advanced compiler from Tilera, for its 64-core TILE64 chip, is based on Blackbird.

Open64 exists in many forks, each of which has different features and limitations. The "classic" Open64 branch is the Open Research Compiler (ORC), which produces code only for the Itanium (IA-64), and was funded by Intel. The ORC effort ended in 2003, and the current official branch (which originated from the Intel ORC project) is managed by Hewlett-Packard and the University of Delaware's Computer Architecture and Parallel Systems Laboratory (CAPSL).

Other important branches include the compilers from Tensilica and the AMD x86 Open64 Compiler Suite.[1]

Nvidia is also using an Open64 fork to optimize code in its CUDA toolchain.[2]

Open64 is used as the backend for the HPE NonStop OS compilers on the x86-64 platform.[3]

Open64 releases

Version Release date
5.02011-11-11
4.2.42011-04-12
4.2.32010-04-09
4.2.12008-12-08
4.22008-10-01
4.12007-12-03
4.02007-06-15
3.12007-04-13
3.02006-11-22
2.02006-10-02
1.02006-09-22
0.162003-07-07
0.152002-11-30
0.142002-03-04
0.132002-01-10

AMD x86 Open64 releases

Version Release date
4.5.2.12013-03-28
4.5.22012-08-08
4.5.12011-12-19
4.2.42010-06-29
4.2.3.22010-05-17
4.2.3.12010-01-29
4.2.32009-12-11
4.2.2.32009-11-23
4.2.2.22009-08-31
4.2.2.12009-06-03
4.2.22009-04-24

Current development projects

Open64 is also used in a number of research projects, such as the Unified Parallel C (UPC) and speculative multithreading work at various universities. The 2010 Open64 Developers Forum describes projects done at Absoft, AMD, Chinese Academy of Sciences, Fudan University, HP, National Tsing Hua University, Nvidia, Tensilica, Tsinghua University, and University of Houston.[4] The Chinese Academy of Sciences ported Open64 to the Loongson II platform.[5]

AMD has extended and productized Open64 with optimizations designed for x86 multi-core processor advancements and multi-threaded code development.[6] AMD supports Open64 as a complementary compiler to GCC.[7]

The University of Houston's OpenUH project, which is based on Open64, released a new version of its compiler suite in November 2015.[8]

See also

External links

Notes and References

  1. Web site: x86 Open64 Compiler Suite . . 12 November 2013 . dead . https://web.archive.org/web/20131113100944/http://developer.amd.com/tools-and-sdks/cpu-development/x86-open64-compiler-suite/ . 13 November 2013 .
  2. http://www.capsl.udel.edu/conferences/open64/2008/Papers/101.doc NVIDIA’s Experience with Open64
  3. Web site: John Reagan Interview on LLVM, part 2. 2019-05-01. 2020-12-21. ecubesystems.com. 2020-11-25. https://web.archive.org/web/20201125080221/http://blog.ecubesystems.com/john-reagan-interview-on-llvm-part-2/. dead.
  4. Web site: 2010 Open64 Developers Forum, August 25, 2010 . September 6, 2010 . June 12, 2010 . https://web.archive.org/web/20100612125720/http://dynopt.ece.udel.edu/open64/program.shtml . dead .
  5. http://www.capsl.udel.edu/conferences/open64/2009/Papers/102-Open64onMIPS2.pdf Open64 on MIPS: porting and enhancing Open64 for Loongson II
  6. Web site: Sweet Suite, blog posting . https://web.archive.org/web/20100906085610/http://blogs.amd.com/nigel-dessau/2009/06/22/sweet-suite/. dead. Nigel Dessau, AMD CMO. June 22, 2009. 2010-09-06.
  7. Web site: AMD Open64 download page . 2012-11-13 . https://web.archive.org/web/20130313225744/http://developer.amd.com/tools/cpu-development/x86-open64-compiler-suite/ . 2013-03-13 . dead .
  8. http://web.cs.uh.edu/~openuh/download/ OpenUH downloads page