Developer(s) | GNU Project |
---|---|
Stable release | 2.14.1 / October 17, 2011[1] |
Development status | Active |
Written in | C |
Operating system | Cross-platform |
Type | Runtime library |
License | GNU Lesser General Public License |
Website | http://www.gnu.org/software/libc |
The GNU C Library, commonly known as glibc, is the C standard library released by the GNU Project. Originally written by the Free Software Foundation (FSF) for the GNU operating system, the library's development has been overseen by a committee since 2001,[2] with Ulrich Drepper from Red Hat as the lead contributor and maintainer.
Released under the GNU Lesser General Public License, glibc is free software.
Contents |
glibc was initially written mostly by Roland McGrath, working for the 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 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 support, better internationalisation/multilingual support, support for IPv6, 64-bit data access, support for multithreaded applications, future version compatibility support, and the code was more portable.[5] At this point, the Linux kernel developers discontinued their fork and returned to using FSF's glibc.[6]
The last used version of Linux libc used the internal name (soname) libc.so.5. Following on from this, glibc 2.x on Linux uses the soname libc.so.6[7] (Alpha and IA64 architectures now use libc.so.6.1, instead). The soname 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.[8]
This version history uses dates from the ChangeLog files packaged in the 2.13 release.
Version | Date | Notes |
---|---|---|
2.14 | June 2011 | |
2.13 | January 2011 | |
2.12 | May 2010 | Used in RHEL 6 |
2.11 | October 2009 | Used in SLES 11 |
2.10 | May 2009 | |
2.9 | November 2008 | |
2.8 | April 2008 | |
2.7 | October 2007 | |
2.6 | May 2007 | |
2.5 | September 2006 | Used in RHEL 5 |
2.4 | March 2006 | Standard for LSB 4.0, Used in SLES 10 |
2.3.4 | December 2004 | Standard for LSB 3.0 |
2.3.3 | December 2003 | |
2.3.2 | February 2003 | |
2.3.1 | October 2002 | |
2.3 | October 2002 | |
2.2.4 | July 2001 | |
2.2.3 | March 2001 | |
2.2.2 | February 2001 | |
2.2.1 | January 2001 | |
2.2 | November 2000 | |
2.1.1 | March 1999 | |
2.1 | February 1999 | |
2.0.95 | July 1998 | |
2.0.91 | December 1997 | |
2.0.2 | February 1997 | |
2.0.1 | January 1997 | |
2.0 | January 1997 | |
1.90 – 1.102 | May 1996 – January 1997 | |
1.01 – 1.09.3 | March 1992 – December 1994 | |
1.0 | February 1992 | |
0.1 – 0.6 | Oct 1991 – February 1992 |
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 includes: x86, Motorola 680x0, DEC Alpha, PowerPC, ETRAX CRIS, s390, and SPARC. 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 the kernel of OpenSolaris.[9] It is also used (in an edited form) and named libroot.so in BeOS and Haiku.
glibc provides the functionality required by the Single UNIX Specification, POSIX (1c, 1d, and 1j) and some of the functionality required by 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.
glibc has been criticized as being "bloated" and slower than other libraries in the past, e.g. by Linus Torvalds[10] and embedded Linux programmers. As one example why, glibc must support insecure, deprecated, and "dangerous" functions like gets()[11] for POSIX compatibility. For this reason, several alternative C standard libraries have been created which emphasize a smaller footprint. Among them are Bionic (based mostly on libc from BSD and used in Android[12]), dietlibc, uClibc, Newlib, Klibc, and EGLIBC (used in Debian, Ubuntu and ArkLinux).[13]
However, many small-device projects use GNU libc over the smaller alternatives because of its application support, standards compliance, and completeness. Examples include Openmoko[14] and Familiar Linux for iPaq handhelds (when using the GPE display software).[15]
|
|