GNU Compiler Collection
From Wikipedia, the free encyclopedia
"Cc1" redirects here. For other uses of CC1 or CC-1, see CC1 (disambiguation).
Developer(s) | GNU Project |
---|---|
Initial release | May 23, 1987[1] |
Stable release | 4.5.1 / July 31, 2010 |
Operating system | Cross-platform |
Platform | GNU |
Type | Compiler |
License | GNU General Public License (version 3 or later) |
Website | gcc.gnu.org |
Originally named the GNU C Compiler, because it only handled the C programming language, GCC 1.0 was released in 1987, and the compiler was extended to compile C++ in December of that year.[1] Front endsFortran, Pascal, Objective-C, Java, and Ada, among others.[7] were later developed for
The Free Software Foundation (FSF) distributes GCC under the GNU General Public License (GNU GPL). GCC has played an important role in the growth of free software, as both a tool and an example.
Contents[hide] |
[edit] History
Richard Stallman started GCC in 1985. He extended an existing compiler to compile C. The compiler originally compiled Pastel, an extended, nonportable dialect of Pascal, and was written in Pastel. It was rewritten in C by Len Tower and Stallman,[8] and released in 1987[9] as the compiler for the GNU Project, in order to have a compiler available that was free software. Its development was supervised by the Free Software Foundation (FSF).[10]By 1991, GCC 1.x had reached a point of stability, but architectural limitations prevented many desired improvements, so the FSF started work on GCC 2.x.
As GCC was free software, programmers wanting to work in other directions—particularly those writing interfaces for languages other than C—were free to develop their own fork of the compiler. Multiple forks proved inefficient and unwieldy, however, and the difficulty in getting work accepted by the official GCC project was greatly frustrating for many. The FSF kept such close control on what was added to the official version of GCC 2.x that GCC was used as one example of the "cathedral" development model in Eric S. Raymond's essay The Cathedral and the Bazaar.
With the release of 4.4BSD in 1994, GCC became the default compiler for BSD systems.
[edit] EGCS fork
In 1997, a group of developers formed EGCS (Experimental/Enhanced GNU Compiler System),[11] to merge several experimental forks into a single project. The basis of the merger was a GCC development snapshot taken between the 2.7 and 2.81 releases. Projects merged included g77 (Fortran), PGCC (P5Pentium-optimized GCC), many C++ improvements, and many new architectures and operating system[12][13] variants.EGCS development proved considerably more vigorous than GCC development, so much so that the FSF officially halted development on their GCC 2.x compiler, "blessed" EGCS as the official version of GCC and appointed the EGCS project as the GCC maintainers in April 1999. Furthermore, the project explicitly adopted the "bazaar" model over the "cathedral" model. With the release of GCC 2.95 in July 1999, the two projects were once again united.
GCC is now maintained by a varied group of programmers from around the world, under the direction of a steering committee.[14] It has been ported to more kinds of processors and operating systems than any other compiler.[15]
[edit] Uses
GCC is often the compiler of choice for developing software that is required to execute on a wide variety of hardware and/or operating systems. System-specific compilers provided by hardware or OS vendors can differ substantially, complicating both the software's source code and the scripts which invoke the compiler to build it. With GCC, most of the compiler is the same on every platform, so only code which explicitly uses platform-specific features must be rewritten for each system.[edit] Current GCC release
The current stable release of GCC is 4.5.1, and was released on the 31st of July 2010. It brings several minor new features (new targets, new language dialects) and a couple major new features:- Link-time optimization optimizes across object file boundaries to directly improve the linked binary. Link-time optimization relies on an intermediate file containing the serialization of some -Gimple- representation included in the object file [1]. The file is generated alongside the object file during source compilation. Each source compilation generates a separate object file and link-time helper file. When the object files are linked, the compiler is executed again and uses the helper files to optimize code across the separately compiled object files.
- Plugins can extend the GCC compiler directly [2]. Plugins allow a stock compiler to be tailored to specific needs by external code loaded as plugins. For example, plugins can add, replace, or even remove middle–end passes operating on Gimple representations. Several GCC plugins have already been published, notably:
- TreeHydra to help with Mozilla code development
- DragonEgg to use the GCC front-end with LLVM
- MELT to enable coding GCC extensions in a lispy domain-specific language providing powerful Pattern-matching
- MILEPOST CTuning to use machine learning techniques to tune the compiler.
[edit] Languages
The standard compiler release 4.3 includes front ends for C (gcc), C++ (g++), Java (gcj), Ada (GNAT), Objective-C (gobjc), Objective-C++ (gobjc++), and Fortran (gfortran). Also available, but not in standard are Modula-2, Modula-3, Pascal (gpc), PL/I, D (gdc), Mercury, and VHDL (ghdl).[16] A popular parallel language extension, OpenMP, is also supported. The GCC steering committee has recently announced that it will also support the Go programming language in GCC 4.5 or later.[17]The Fortran front end was g77 before version 4.0, which only supports Fortran 77. In newer versions, g77 is dropped in favor of the new GFortran front end that supports Fortran 95 and parts of Fortran 2003 as well.[18] A front-end for CHILL was dropped due to a lack of maintenance.[19]
A few experimental branches exist to support additional languages, such as the GCC UPC compiler[20] for Unified Parallel C.
[edit] Architectures
GCC target processor families as of version 4.3 include:[edit] Structure
GCC's external interface is generally standard for a UNIX compiler. Users invoke a driver program namedgcc
, which interprets command arguments, decides which language compilers to use for each input file, runs the assembler on their output, and then possibly runs the linker to produce a complete executable binary.Each of the language compilers is a separate program that inputs source code and outputs assembly code. All have a common internal structure. A per-language front end parses the source code in that language and produces an abstract syntax tree ("tree" for short).
These are, if necessary, converted to the middle-end's input representation, called GENERIC form; the middle-end then gradually transforms the program towards its final form. Compiler optimizations and static code analysis techniques (such as FORTIFY_SOURCE,[23] a compiler directive which attempts to discover some buffer overflows) are applied to the code. These work on multiple representations, mostly the architecture-independent GIMPLE representation and the architecture-dependent RTL representation. Finally, assembly language is produced using architecture-specific pattern matching originally based on an algorithm of Jack Davidson and Chris Fraser.
GCC is written primarily in C except for parts of the Ada front end. The distribution includes the standard libraries for Ada, C++, and Java whose code is mostly written in those languages.[24] On some platforms, the distribution also includes a low-level runtime library, libgcc, written in a combination of machine-independent C and processor-specific assembly language, designed primarily to handle arithmetic operations that the target processor cannot perform directly.[25]
In May 2010, the GCC steering committee decided to allow use of a C++ compiler to compile GCC.[26] The compiler will be written in C plus a subset of features from C++. In particular, this was decided so that GCC's developers could use the "destructors" and "generics" features of C++.[27]
[edit] Front-ends
Frontends vary internally, having to produce trees that can be handled by the backend. Currently, the parsers are all hand-coded recursive descent parsers, though there is no reason why a parser generator could not be used for new front-ends in the future (version 2 of the C compiler used a bison based grammar).Until recently, the tree representation of the program was not fully independent of the processor being targeted.
The meaning of a tree was somewhat different for different language front-ends, and front-ends could provide their own tree codes. This was simplified with the introduction of GENERIC and GIMPLE, two new forms of language-independent trees that were introduced with the advent of GCC 4.0. GENERIC is more complex, based on the GCC 3.x Java front-end's intermediate representation. GIMPLE is a simplified GENERIC, in which various constructs are lowered to multiple GIMPLE instructions. The C, C++ and Java front ends produce GENERIC directly in the front end. Other front ends instead have different intermediate representations after parsing and convert these to GENERIC.
In either case, the so-called "gimplifier" then lowers this more complex form into the simpler SSA-based GIMPLE form which is the common language for a large number of new powerful language- and architecture-independent global (function scope) optimizations.
[edit] GENERIC and GIMPLE
GENERIC is an intermediate representation language used as a "middle-end" while compiling source code into executable binaries. A subset, called GIMPLE, is targeted by all the front-ends of GCC.The middle-end of GCC, starting with the GENERIC representation and ending after the expansion to Register Transfer Language, contains all the optimisers and analysers working independently of the compiled language and independently of the target architecture. The GENERIC representation contains only the subset of the imperative programming constructs optimised by the middle-end.
In transforming the source code to GIMPLE, complex expressions are split into a three address code using temporary variables. This representation was inspired by the SIMPLE representation proposed in the McCAT compiler[28] by Laurie J. Hendren[29] for simplifying the analysis and optimisation of imperative programs.
[edit] Optimization
Optimization can occur during any phase of compilation, however the bulk of optimizations are performed after the syntax and semantic analysis of the front-end and before the code generation of the back-end, thus a common, even though somewhat contradictory, name for this part of the compiler is "middle end."The exact set of GCC optimizations varies from release to release as it develops, but includes the standard algorithms, such as loop optimization, jump threading, common subexpression elimination, instruction scheduling, and so forth. The RTL optimizations are of less importance with the addition of global SSA-based optimizations on GIMPLE trees,[30] as RTL optimizations have a much more limited scope, and have less high-level information.
Some of these optimizations performed at this level include dead code elimination, partial redundancy elimination, global value numbering, sparse conditional constant propagation, and scalar replacement of aggregates. Array dependence based optimizations such as automatic vectorization and automatic parallelization are also performed. Profile-guided optimization is also possible as demonstrated here: http://gcc.gnu.org/install/build.html#TOC4
[edit] Back-end
The behavior of GCC's back end is partly specified by preprocessor macros and functions specific to a target architecture, for instance to define the endianness, word size, and calling conventions. The front part of the back end uses these to help decide RTL generation, so although GCC's RTL is nominally processor-independent, the initial sequence of abstract instructions is already adapted to the target. At any moment, the actual RTL instructions forming the program representation have to comply with the machine description of the target architecture.Towards the end of compilation, valid RTL is further reduced to a strict form in which each instruction refers to real machine registers and real instructions from the target's instruction set. Forming strict RTL is a very complicated task, done mostly by the register allocation first but completed only by a separate "reloading" phase which must account for the vagaries of all of GCC's targets.
The final phase is somewhat anticlimactic, because the patterns to match were generally chosen during reloading, and so the assembly code is simply built by running substitutions of registers and addresses into the strings specifying the instructions.
[edit] Compatible IDEs
Most integrated development environments written for GNU/Linux and some for other operating systems support GCC. These include:[edit] Debugging GCC programs
The primary tool used to debug GCC code is the GNU Debugger (gdb). Among more specialized tools are Valgrind, for finding memory errors and leaks, and the graph profiler (gprof) which can determine how much time is spent in which routines, and how often they are called; this requires programs to be compiled with profiling options.[edit] See also
- MinGW (Windows port of GCC)
- List of compilers
[edit] References
- ^ a b "GCC Releases". GNU Project. http://www.gnu.org/software/gcc/releases.html. Retrieved 2006-12-27.
- ^ "Symbian GCC Improvement Project". http://www.inf.u-szeged.hu/symbian-gcc/. Retrieved 2007-11-08.
- ^ "Linux Board Support Packages". http://www.freescale.com/webapp/sps/site/overview.jsp?code=CW_BSP&fsrch=1. Retrieved 2008-08-07.
- ^ "setting up gcc as a cross-compiler". ps2stuff. 2002-06-08. http://ps2stuff.playstation2-linux.com/gcc_build.html. Retrieved 2008-12-12.[dead link]
- ^ "sh4 g++ guide". Archived from the original on 2002-12-20. http://web.archive.org/web/20021220025554/http://www.ngine.de/gccguide.html. Retrieved 2008-12-12. "This guide is intended for people who want to compile C++ code for their Dreamcast systems"
- ^ "FSF Service Directory". http://www.fsf.org/resources/service.
- ^ "Programming Languages Supported by GCC". GNU Project. http://gcc.gnu.org/onlinedocs/gcc-4.4.0/gcc/G_002b_002b-and-GCC.html#G_002b_002b-and-GCC. Retrieved 2009-05-03.
- ^ Stallman, Richard M. (February 1986). "GNU Status". GNU's Bulletin (Free Software Foundation) 1 (1). http://web.cecs.pdx.edu/~trent/gnu/bull/01/bull01.txt. Retrieved 2006-09-26.
- ^ Tower, Leonard (1987) "GNU C compiler beta test release," comp.lang.misc USENET newsgroup; see also http://gcc.gnu.org/releases.html#timeline
- ^ Stallman, Richard M. (2001) "Contributors to GCC," in Using and Porting the GNU Compiler Collection (GCC) for gcc version 2.95 (Cambridge, Mass.: Free Software Foundation)
- ^ "Pentium Compiler FAQ". http://home.schmorp.de/pgcc-faq.html#egcs.
- ^ "A Brief History of GCC". http://gcc.gnu.org/wiki/History.
- ^ "The Short History of GCC development". http://www.softpanorama.org/People/Stallman/history_of_gcc_development.shtml.
- ^ "GCC steering committee". http://gcc.gnu.org/steering.html.
- ^ Linux Information Project (LINFO) accessed 2010-04-27
- ^ GCC Front Ends, GCC.org, Retrieved May 11, 2008.
- ^ "gccgo language contribution accepted", gmane.org, Retrieved January 26, 2010.
- ^ "Fortran 2003 Features in GNU Fortran". http://gcc.gnu.org/wiki/Fortran2003.
- ^ [PATCH] Remove chill, gcc.gnu.org, Retrieved July 29, 2010.
- ^ "GCC UPC (GCC Unified Parallel C) | intrepid.com". intrepid.com. http://www.intrepid.com/upc.html. Retrieved 2009-03-11.
- ^ "sx-gcc: port gcc to nec sx vector cpu". http://code.google.com/p/sx-gcc/.
- ^ "The GNU Compiler for the Java Programming Language". http://gcc.gnu.org/java/. Retrieved 2010-04-22.
- ^ "Security Features: Compile Time Buffer Checks (FORTIFY_SOURCE)". fedoraproject.org. http://fedoraproject.org/wiki/Security/Features. Retrieved 2009-03-11.
- ^ "languages used to make GCC". http://www.ohloh.net/projects/gcc/analyses/latest.
- ^ GCC Internals, GCC.org, Retrieved March 01, 2010.
- ^ "GCC allows C++ – to some degree". The H. 1 June 2010. http://www.h-online.com/open/news/item/GCC-allows-C-to-some-degree-1012611.html.
- ^ "An email by Richard Stallman on emacs-devel". http://lists.gnu.org/archive/html/emacs-devel/2010-07/msg00518.html. "The reason the GCC developers wanted to use it is for destructors and generics. These aren't much use in Emacs, which has GC and in which data types are handled at the Lisp level."
- ^ McCAT
- ^ Laurie J. Hendren
- ^ From Source to Binary: The Inner Workings of GCC, by Diego Novillo, Red Hat Magazine, December 2004
[edit] Further reading
- Richard Stallman: Using the GNU Compiler Collection (GCC), Free Software Foundation, 2008.
- Richard Stallman: GNU Compiler Collection (GCC) Internals, Free Software Foundation, 2008.
- Brian J. Gough: An Introduction to GCC, Network Theory Ltd., 2004 (Revised August 2005). ISBN 0-9541617-9-3.
- Arthur Griffith, GCC: The Complete Reference. McGrawHill/Osborne, 2002. ISBN 0-07-222405-3.
[edit] External links
Wikibooks has a book on the topic of |
- GCC homepage
- The official GCC manuals and user documentation, by the GCC developers
- Collection of GCC 4.0.2 architecture and internals documents at I.I.T. Bombay.
- Kerner, Sean Michael (2006-03-02). "New GCC Heavy on Optimization". internetnews.com. http://www.internetnews.com/dev-news/article.php/3588926.
- Kerner, Sean Michael (2005-04-22). "Open Source GCC 4.0: Older, Faster". internetnews.com. http://www.internetnews.com/dev-news/article.php/3499881.
- From Source to Binary: The Inner Workings of GCC, by Diego Novillo, Red Hat Magazine, December 2004
- A 2003 paper on GENERIC and GIMPLE
- Marketing Cygnus Support, an essay covering GCC development for the 1990s, with 30 monthly reports for in the "Inside Cygnus Engineering" section near the end.
- EGCS 1.0 announcement
- EGCS 1.0 features list
- Fear of Forking, an essay by Rick Moen recording seven well-known forks, including the GCC/EGCS one
- A compiler course project based on GCC at the University of Rochester
- The stack-smashing protector, a GCC extension
|
|