GNU C Library

From Wikipedia, the free encyclopedia
  (Redirected from Glibc)
Jump to: navigation, search
"glibc" redirects here. It is not to be confused with GLib or Gnulib.
GNU C Library
Heckert GNU white.svg
Original author(s) Roland McGrath
Developer(s) GNU Project
Initial release 1987; 28 years ago (1987)[1]
Stable release 2.22 (August 14, 2015; 3 months ago (2015-08-14)[2]) [±]
Development status Active
Written in C
Operating system Unix-like
Type Runtime library
License GNU Lesser General Public License
The Linux API is composed out of the System Call Interface of the Linux kernel, the GNU C Library (by GNU), libdrm, libalsa and libevdev (by
The GNU C Library is a wrapper around the system calls of the Linux kernel.
The Linux kernel and GNU C Library together form the Linux API. After compilation, the binaries offer an ABI.

The GNU C Library, commonly known as glibc, is the GNU Project's implementation of the C standard library. Despite its name, it now also directly supports C++ (and indirectly other programming languages). Was started in the early 1990s by the Free Software Foundation (FSF) for their GNU operating system.

Released under the GNU Lesser General Public License, glibc is free software.


The Glibc project was initially written mostly by Roland McGrath, working for the Free Software Foundation (FSF) in the 1980s.

In February 1988, FSF described glibc as having nearly completed the functionality required by ANSI C.[3] By 1992, it had the ANSI C-1989 and POSIX.1-1990 functions implemented and work was under way on POSIX.2.[4]

In September 1995 Ulrich Drepper did his first contribution to the glibc project and gradually became over the 1990s the core contributor and maintainer of glibc.[5] Drepper hold the maintainership position for many years and accumulated until 2012 63% of all commits of the project.[6]

Fork "Linux libc"[edit]

In the early 1990s, the developers of the Linux kernel forked glibc. Their fork, called "Linux libc", was maintained separately for years and released versions 2 through 5.

When FSF released glibc 2.0 in January 1997, it had much more complete POSIX standards compliance, better internationalisation and multilingual function, IPv6 capability, 64-bit data access, facilities for multithreaded applications, future version compatibility, and the code was more portable.[7] At this point, the Linux kernel developers discontinued their fork and returned to using FSF's glibc.[8]

The last used version of Linux libc used the internal name (soname) Following on from this, glibc 2.x on Linux uses the soname[9] (Alpha and IA64 architectures now use, instead). The *.so file name is often abbreviated as libc6 (for example in the package name in Debian) following the normal conventions for libraries.

According to Richard Stallman, the changes that had been made in Linux libc could not be merged back into glibc because the authorship status of that code was unclear and the GNU project is quite strict about recording copyright and authors.[10]

Installation of a steering committee[edit]

Starting in 2001 the library's development had been overseen by a committee,[11] with Ulrich Drepper[12] kept as the lead contributor and maintainer. The steering committee installation was surrounded by a public controversy as it was openly described by Ulrich Drepper as failed hostile takeover maneuver by RMS.[13][14][15]

Switch to git[edit]

While before in a CVS repository, in 2009 glibc was migrated to a Git repository on Sourceware.[16]

Debian switches to EGLIBC[edit]

After long standing controversies around Drepper's leading style and external contribution acceptance,[17][18][19] Debian switched publicly to the glibc fork EGLIBC in 2009.[20]

Steering committee disbands[edit]

In March 2012, the steering committee voted to disband itself and remove Drepper in favor of a community-driven development process, with Ryan Arnold, Maxim Kuvyrkov, Joseph Myers, Carlos O'Donell, and Alexandre Oliva holding the responsibility of GNU maintainership (but no extra decision-making power).[21][22]

After the change in glibc maintainership Debian and other projects migrated back to the glibc, who before switched to alternatives.[23] Also, since the beginning of 2014, the glibc fork EGLIBC is no longer being developed, since its "goals are now being addressed directly in GLIBC".

Version history[edit]

For most systems, the version of glibc can be obtained by executing the lib file (for example, /lib/

Supported hardware and kernels[edit]

Glibc is used in systems that run many different kernels and different hardware architectures. Its most common use is in systems using the Linux kernel on x86 hardware, however, officially supported hardware[24] includes: AArch64, ARM, DEC Alpha, PA-RISC, IA-64, Motorola m68k, MicroBlaze, MIPS, Nios II, PowerPC, s390, SPARC, TILE, and x86. It officially supports the Hurd and Linux kernels. Additionally, there are heavily patched versions that run on the kernels of FreeBSD and NetBSD (from which Debian GNU/kFreeBSD and Debian GNU/NetBSD systems are built, respectively), as well as a forked-version of OpenSolaris.[25] It is also used (in an edited form) and named in BeOS and Haiku.[26]


glibc provides the functionality required by the Single UNIX Specification, POSIX (1c, 1d, and 1j) and some of the functionality required by ISO C11, ISO C99, Berkeley Unix (BSD) interfaces, the System V Interface Definition (SVID) and the X/Open Portability Guide (XPG), Issue 4.2, with all extensions common to XSI (X/Open System Interface) compliant systems along with all X/Open UNIX extensions.

In addition, glibc also provides extensions that have been deemed useful or necessary while developing GNU.

Use in small devices[edit]

glibc has been criticized as being "bloated" and slower than other libraries in the past, e.g. by Linus Torvalds[27] and embedded Linux programmers. For this reason, several alternative C standard libraries have been created which emphasize a smaller footprint. Alternative libcs are Bionic (based mostly on libc from BSD and used in Android[28]), dietlibc, uClibc, Newlib, Klibc, and musl.

However, many small-device projects use GNU libc over the smaller alternatives because of its application support, standards compliance, and completeness. Examples include Openmoko[29] and Familiar Linux for iPaq handhelds (when using the GPE display software).[30]

See also[edit]

Other C standard libraries


  1. ^ Corbet, Jonathan (28 March 2012). "A turning point for GNU libc". 
  2. ^ O'Donell, Carlos (2015-08-14). "The GNU C Library version 2.22 is now available." (Mailing list). info-gnu. Retrieved 2015-08-15. 
  3. ^ "". Most libraries are done. Roland McGrath [...] has a nearly complete set of ANSI C library functions. We hope they will be ready some time this spring. 
  4. ^ "GNU's Bulletin, vol. 1 no. 12". It now contains all of the ANSI C-1989 and POSIX.1-1990 functions, and work is in progress on POSIX.2 and Unix functions (BSD and System V) 
  5. ^ glibc changelog on
  6. ^ Corbet, Jonathan (28 March 2012). "A turning point for GNU libc". Of the nearly 19,000 commits found in the project's git repository (which contains changes back to 1995), over 12,000 were made by Ulrich. 
  7. ^ Lee, Elliot (2001). "A Technical Comparison of glibc 2.x With Legacy System Libraries". Archived from the original on 11 April 2004. 
  8. ^ "Forking: it could even happen to you". the split between GNU LIBC and the Linux LIBC -- it went on for years while Linux stabilized, and then the forks re-merged into one project 
  9. ^ "Fear of Forking essay, see "6. glibc --> Linux libc --> glibc"". 
  10. ^ "Fear of Forking, footnote on Stallman's merge comments". 
  11. ^ "glibc homepage". In 2001 The GNU C Library Steering Committee ..., was formed and currently consists of Mark Brown, Paul Eggert, Andreas Jaeger, Jakub Jelinek, Roland McGrath and Andreas Schwab. 
  12. ^ "Ulrich Drepper". LinkedIn. Retrieved 2012-06-13. 
  13. ^ Drepper, Ulrich (2000-06-26). "RMS is at it again". Retrieved 2015-11-20. A few weeks ago RMS started the next attack on me (a single mail, followed by indirect tries to take influence, followed by another mail today). The essence is that he complains I am not following "GNU policies" and therefore have to be replaced by a steering committee of which I could be a part. Some of you (namely Roland and Andreas S.) probably know about this since he proposed both as other members of the committee. In addition there was Mark Brown listed (I know somebody of this name at IBM who would also fit in this group but I'm not sure whether it is really him.) Anyhow, I completely reject this. It is not helping at all, the opposite is true. First, I am not aware of any essential policies I'm violating. The only ones are that I'm not following orders from RMS which clearly have political intends (which is of course a sacrilege) and possibly that I do not care about Winblowz (if the latter counts at all). None of this will change in any way. 
  14. ^ Drepper, Ulrich (2001-08-15). "glibc 2.2.4". Retrieved 2015-11-29. And now for some not so nice things. Stallman recently tried what I would call a hostile takeover of the glibc development. He tried to conspire behind my back and persuade the other main developers to take control so that in the end he is in control and can dictate whatever pleases him. This attempt failed but he kept on pressuring people everywhere and it got really ugly. In the end I agreed to the creation of a so-called "steering committee" (SC). 
  15. ^ rms-accused-of-attempting-glibc-hostile-takeover on on August 19, 2001
  16. ^ glibc repo on
  17. ^ Ulrich Drepper 2007-10-03 06:13:55 UTC "This has nothing to do with "x86 only". All ABIs designed by people who have a bit of understanding require no change. Any change will negatively impact well designed architectures for the sole benefit of this embedded crap. But your own version of the file in the add-on."
  18. ^ Drepper, Ulrich (2005-05-25). "Dictatorship of the Minorities". Retrieved 2012-01-15. Which architectures are worthwhile supporting? [...]. Not only do we have to look for irrelevance (what percentage cares about Vax, PArisc) support, we also have to look at the level of added complexity the support requires. Some ABIs are just deliberately defined to be different from others (see IA-64) which requires huge amounts of effort to be spent. There are also significantly diverging capabilities (e. g., the lack of atomic operations in too many architectures). This far too often causes to unnecessarily crippled code since writing code in a way which allows optimal use in all situations is very difficult. The solution must be to restrict support to only a handful of architectures which are supported in the project. All other support must happen outside the tree and therefore all the work has to be done by the special interest groups. I don't want to say we follow all these points perfectly, but for a big project glibc certainly comes closest to this. 
  19. ^ Jarno, Aurélien (2009-05-05). "Debian is switching to EGLIBC". Retrieved 2012-01-15. More friendly upstream (especially with regard to embedded architectures): “Encourage cooperation, communication, civility, and respect among developers” (as opposed to this). 
  20. ^ timothy (2009-05-06). "Debian Switching From Glibc To Eglibc". Slashdot. Retrieved 2012-01-14. 
  21. ^ McGrath, Roland (26 March 2012). "glibc steering committee dissolving". Retrieved 2012-06-13. 
  22. ^ Myers, Joseph S. (26 March 2012). "GNU C Library development and maintainers". Retrieved 2012-06-13. 
  23. ^ "Debian is switching (back) to GLIBC". Aurélien. 2014-06-19. Retrieved 2014-06-19. 
  24. ^ "The GNU C Library machine maintainers.". 
  25. ^ Bartley, David; Spang, Michael. "GNU/kOpenSolaris (GNU libc/base + OpenSolaris kernel)". Retrieved 2008-12-16. 
  26. ^ "Haiku Source". is not part of GNU project and is included in Haiku source code. 
  27. ^ Torvalds, Linus (9 January 2002). "Posting to the glibc mailing list". 
  28. ^ "Bionic libc README". 
  29. ^ "OpenMoko components". We will use glibc (not uClibC) ... The alternatives may save more space and be more optimized, but are more likely to give us integration headaches 
  30. ^ "Re: [Familiar] Which glibc for Familiar 0.8.4  ?". Question: which version of the GLIBC was used to build the Familiar 0.8.4 ? Answer: 2.3.3 

External links[edit]