Array ( [0] => {{short description|Standard C Library of the GNU Project}} [1] => {{distinguish|GLib|Gnulib}} [2] => {{Use dmy dates|date=October 2023}} [3] => {{lowercase title}} [4] => {{Infobox software [5] => | name = GNU C Library [6] => | logo = [7] => | logo size = 100px [8] => | author = Roland McGrath [9] => | developer = [[GNU Project]], most contributions by Ulrich Drepper [10] => | released = {{start date and age|1987}}{{cite web [11] => | url = https://lwn.net/Articles/488847/ [12] => | title = A turning point for GNU libc [13] => | last = Corbet [14] => | first = Jonathan [15] => | date = 28 March 2012 [16] => | publisher = LWN.net}} [17] => | latest release version = {{wikidata|property|preferred|references|edit|Q856089|P348|P548=Q2804309}} [18] => | latest release date = {{wikidata|qualifier|preferred|single|Q856089|P348|P548=Q2804309|P577}} [19] => | latest preview version = {{wikidata|property|preferred|references|edit|Q856089|P348|P548=Q51930650}} [20] => | latest preview date = {{wikidata|qualifier|preferred|single|Q856089|P348|P548=Q51930650|P577}} [21] => | programming language = [[C (programming language)|C]] [22] => | operating system = [[Unix-like]] [23] => | genre = [[Runtime library]] [24] => | license = 2001: [[GNU Lesser General Public License|LGPL-2.1-or-later]]{{efn|LGPL-2.1-or-later since 2001-07-06, version 2.2.4.{{cite web [25] => | url = https://sourceware.org/git/?p=glibc.git;a=blob;f=Makefile;hb=HEAD [26] => | title = sourceware.org Git – glibc.git/blob – Makefile [27] => | quote = LGPL-2.1-or-later in the headers [28] => | website = sourceware.org [29] => | access-date = 10 June 2021}}{{cite web [30] => | url = https://sourceware.org/git/?p=glibc.git;a=commit;h=41bdb6e20c5d2df34a740cbd70e11c05025dfd12 [31] => | title = sourceware.org Git – glibc.git/commit – Update to LGPL v.2.1 [32] => | date = 6 July 2001 [33] => | quote = LGPL-2.1-or-later in the headers [34] => | website = sourceware.org [35] => | access-date = 10 June 2021}}}}
1992: [[GNU Lesser General Public License|LGPL-2.0-or-later]]{{efn|LGPL-2.0-or-later from 1992 to 2001-07-05. Version 1.04? to 2.2.3.{{cite web [36] => | url = https://www.nic.funet.fi/index/gnu/funet/historical-funet-gnu-area-from-early-1990s/glib/glibc-1.04.tar.Z [37] => | title = glibc-1.04.tar.Z [38] => | date = 4 Sep 1992 [39] => | access-date = 22 December 2021}}{{cite web [40] => | url = https://sourceware.org/git/?p=glibc.git;a=blob;f=Makefile;hb=28f540f45bbacd939bfd07f213bcad2bf730b1bf [41] => | title = sourceware.org Git – glibc.git/commit – Initial import: Makefile [42] => | date = 18 February 1995 [43] => | quote = LGPL-2.0-or-later in the headers [44] => | website = sourceware.org [45] => | access-date = 10 June 2021}}}} [46] => | website = {{URL|https://www.gnu.org/software/libc/}} [47] => }} [48] => [49] => The '''GNU C Library''', commonly known as '''glibc''', is the [[GNU Project]]'s implementation of the [[C standard library]]. It is a wrapper around the system calls of the Linux kernel for application use. Despite its name, it now also directly supports [[C++]] (and, indirectly, other [[programming language]]s). It was started in the 1980s by the [[Free Software Foundation]] (FSF) for the [[GNU]] operating system. [50] => [51] => glibc is [[free software]] released under the [[GNU Lesser General Public License]]. The GNU C Library project provides the core libraries for the GNU system, as well as many systems that use [[Linux kernel|Linux]] as the [[kernel (operating system)|kernel]]. These libraries provide critical [[API]]s including [[ISO]] [[C11 (C standard revision)|C11]], [[POSIX.1-2008]], [[Berkeley Software Distribution|BSD]], OS-specific APIs and more. These APIs include such foundational facilities as [[open (system call)|open]], [[read (system call)|read]], [[write (system call)|write]], [[malloc]], [[printf format string|printf]], [[getaddrinfo]], [[dynamic loading|dlopen]], [[pthreads|pthread_create]], [[crypt (C)|crypt]], [[login]], [[exit (system call)|exit]] and more. [52] => [53] => ==History== [54] => [55] => [56] => {| class="wikitable mw-collapsible mw-collapsed" [57] => ! style="width:6%;" | Version [58] => ! style="width:12%;" | Date [59] => ! style="width:86%;" | Highlights [60] => |- [61] => | 0.1 – 0.6 || October 1991 – February 1992 || [62] => |- [63] => | 1.0 || February 1992 || [64] => |- [65] => | 1.01 – 1.09.3 || March 1992 – December 1994 || [66] => |- [67] => | 1.90 – 1.102 || May 1996 – January 1997 || [68] => |- [69] => | 2.0 || January 1997 || [70] => |- [71] => | 2.0.1 || January 1997 || [72] => |- [73] => | 2.0.2 || February 1997 || [74] => |- [75] => | 2.0.91 || December 1997 || [76] => |- [77] => | 2.0.95 || July 1998 || [78] => |- [79] => | 2.1 || February 1999 || [80] => |- [81] => | 2.1.1 || March 1999 || [82] => |- [83] => | 2.2 || November 2000 || [84] => |- [85] => | 2.2.1 || January 2001 || [86] => |- [87] => | 2.2.2 || February 2001 || [88] => |- [89] => | 2.2.3 || March 2001 || [90] => |- [91] => | 2.2.4 || July 2001 || [92] => |- [93] => | 2.3 || October 2002 || [94] => |- [95] => | 2.3.1 || October 2002 || [96] => |- [97] => | 2.3.2 || February 2003 || [98] => |- [99] => | 2.3.3 || December 2003 || [100] => |- [101] => | 2.3.4 || December 2004 || Minimum for [[Linux Standard Base]] (LSB) 3.0 [102] => |- [103] => | 2.3.5 || April 2005 || [104] => |- [105] => | 2.3.6 || November 2005 || [106] => |- [107] => | 2.4 || March 2006 || Minimum for [[Linux Standard Base|LSB]] 4.0, initial [[inotify]] support [108] => |- [109] => | 2.5 || September 2006 || Full [[inotify]] support. [[Red Hat Enterprise Linux#RHEL 5|RHEL5 end of support]] was {{start date and age |2020|11|30}} [110] => |- [111] => | 2.6 || May 2007 || [112] => |- [113] => | 2.7 || October 2007 || [114] => |- [115] => | 2.8 || April 2008 || [116] => |- [117] => | 2.9 || November 2008 || [118] => |- [119] => | 2.10 || May 2009 || Minimum for [[Linux Standard Base|LSB]] 5.0. Initial [https://udrepper.livejournal.com/20948.html psiginfo] support. [120] => |- [121] => | 2.11 || October 2009 || SLES11 reached end of long-term support in [[SUSE Linux Enterprise#End-of-support schedule|March 2022]]. [122] => |- [123] => | 2.12 || May 2010 || [124] => |- [125] => | 2.13 || January 2011 || [126] => |- [127] => | 2.14 || June 2011 || [128] => |- [129] => | 2.15 || March 2012 || [130] => |- [131] => | 2.16 || June 2012 || [[x32 ABI]] support, [[C11 (C standard revision)|ISO C11]] compliance, [[SystemTap]] [132] => |- [133] => | 2.17 || December 2012 || [[ARMv8-A|64-bit ARM]] support [134] => |- [135] => | 2.18 || August 2013 || Improved [[C++11]] support. Support for Intel [[Transactional Synchronization Extensions|TSX]] lock elision. Support for the Xilinx [[MicroBlaze]] and IBM [[POWER8]] microarchitectures. [136] => |- [137] => | 2.19 || February 2014 || SystemTap probes for [[malloc]]. GNU Indirect Function (IFUNC) support for ppc32 and ppc64. New feature test macro _DEFAULT_SOURCE to replace _SVID_SOURCE and _BSD_SOURCE. Preliminary safety documentation for all functions in the manual. ABI change in ucontext and jmp_buf for s390/s390x. [138] => |- [139] => | 2.20 || September 2014 || Support for file description locks [140] => |- [141] => | 2.21 || February 2015 || New semaphore implementation [142] => |- [143] => | 2.22 || August 2015 || Support to enable [[Google Native Client]] (NaCl), that originally ran on x86, running on [[ARMv7-A]], [[Unicode]] 7.0 [144] => |- [145] => | 2.23 || February 2016 || [[Unicode]] 8.0 [146] => |- [147] => | 2.24 || August 2016 || Some deprecated features have been removed [148] => |- [149] => | 2.25 || February 2017 || The getentropy and getrandom functions, and the header file have been added. [150] => |- [151] => | 2.26 || August 2017 || Improved performance (per-thread cache for malloc), Unicode 10 support [152] => |- [153] => | 2.27 || February 2018 || Performance optimizations. [[RISC-V]] support. [154] => |- [155] => | 2.28 || August 2018 || statx, renameat2, Unicode 11.0.0 [156] => |- [157] => | 2.29 || February 2019 || [158] => * getcpu wrapper [159] => * build and install all locales as directories with files [160] => * optimized trigonomical functions [161] => * Transactional Lock Elision for powercp64le ABI [162] => * posix_spawn_file_actions_addchdir_np and posix_spawn_file_actions_addfchdir_np [163] => * popen and system do not run atfork handlers anymore [164] => * support for the C-SKY ABIV2 running on Linux [165] => * strftime's default formatting of a locale's alternative year; the '_' and '-' flags can now be applied to its "%EY"{{cite web [166] => | url = https://sourceware.org/git/?p=glibc.git;a=blob;f=NEWS;hb=de44ab67aa4eec369deea828733567c35a0611c0 [167] => | title = sourceware.org Git – glibc.git/blob – NEWS}} [168] => |- [169] => | 2.30 || August 2019 || Unicode 12.1.0, the dynamic linker accepts the --preload argument to preload shared objects, the gettid function has been added on Linux, Minguo (Republic of China) calendar support, new Japanese era added to ja_JP locale, memory allocation functions fail with total object size larger than PTRDIFF_MAX; {{CVE|2019-7309|2019-9169|leadout=and}} fixed{{cite web [170] => | url = https://sourceware.org/git/?p=glibc.git;a=blob;f=NEWS;hb=HEAD [171] => | title = sourceware.org Git – glibc.git/blob – NEWS}} [172] => |- [173] => | 2.31 || February 2020 || Initial [[C23 (C standard revision)|C23]] standard support [174] => |- [175] => | 2.32 || August 2020 || Unicode 13.0, 'access' attribute for better warnings in GCC 10, i.e. to "help detect buffer overflows and other out-of-bounds accesses"{{Cite web|title=The GNU C Library version 2.32 is now available|url=https://sourceware.org/pipermail/libc-announce/2020/000029.html|access-date=2020-08-13|website=sourceware.org}} [176] => |- [177] => | 2.33 || February 2021 || HWCAPS [178] => |- [179] => | 2.34 || August 2021 || libpthread, libdl, libutil, libanl has been integrated into libc. [180] => |- [181] => | 2.35 || February 2022 || Unicode 14.0, C.UTF-8 locale, restartable sequences. Removed [[Intel MPX]] support. [182] => |- [183] => | 2.36 || August 2022 || [184] => |- [185] => | 2.37 || February 2023 || [186] => |- [187] => | 2.38 || August 2023 || The strlcpy and strlcat functions added. libmvec support for ARM64. [188] => |- [189] => | 2.39 || January 2024 || The stdbit.h header has been added from ISO C2X. Support for shadow stacks on x86_64, new security features, and the removal of libcrypt. [190] => |} [191] => [[File:Ulrich Drepper.jpg|thumb|Ulrich Drepper in 2007, the main author of glibc]] [192] => [[File:Linux kernel System Call Interface and glibc.svg|thumb|The GNU C Library is a wrapper around the [[system call]]s of the [[Linux kernel]].]] [193] => [[File:Linux API and Linux ABI.svg|thumb|The [[Linux kernel]] and GNU C Library together form the [[Linux kernel interfaces#Kernel–user space API|Linux API]]. After compilation, the binaries offer an [[Application binary interface|ABI]].]] [194] => The glibc project was initially written mostly by Roland McGrath, working for the [[Free Software Foundation]] (FSF) in the summer of 1987 as a teenager.{{cite web|url=https://lwn.net/Articles/727383/|title=Roland McGrath bows out as glibc maintainer [LWN.net]|date=2017-07-07|website=lwn.net|access-date=2017-07-08}}{{cn|only partially in cited source|date=March 2024}} In February 1988, FSF described glibc as having nearly completed the functionality required by [[ANSI C]].{{cite web | url = https://www.gnu.org/bulletins/bull4.html | title = GNU's Bulletin, vol. 1 no. 4, February, 1988 | quote = 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.}} By 1992, it had the ANSI C-1989 and POSIX.1-1990 functions implemented and work was under way on POSIX.2.{{cite web | url = https://www.gnu.org/bulletins/bull12.html | title = GNU's Bulletin, vol. 1 no. 12 | quote = 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)}} In September 1995 Ulrich Drepper made his first contribution to the glibc and by 1997 most commits were made by him. Drepper held the maintainership position for many years and until 2012 accumulated 63% of all commits to the project.{{cite web|url=https://lwn.net/Articles/488847/ |title=A turning point for GNU libc|last=Corbet|first=Jonathan|date=28 March 2012|publisher=LWN.net |quote=''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.''}} [195] => [196] => In May 2009 glibc was migrated to a [[Git]] repository. [197] => [198] => In 2010, a licensing issue was resolved which was caused by the [[Sun RPC]] implementation in glibc that was not GPL [[License compatibility|compatible]]. It was fixed by re-licensing the Sun RPC components under the [[BSD licenses|BSD license]].{{Cite web|title=Glibc finally free software – The H Open: News and Features|url=http://www.h-online.com/open/news/item/Glibc-finally-free-software-1068035.html|access-date=2021-09-19|website=[[H-online]]}}{{Cite web|last=Phipps|first=Simon|date=2010-09-02|title=Gnu/Linux: Finally, it's really free software|url=https://www.infoworld.com/article/2626417/gnu-linux--finally--it-s-really-free-software.html|access-date=2021-09-19|website=[[InfoWorld]]|language=en}} [199] => [200] => In 2014, glibc suffered from an ABI breakage bug on s390.{{Cite web |last=Corbet |first=Jonathan |title=The glibc s390 ABI break [LWN.net] |url=https://lwn.net/Articles/605607/ |access-date=2022-03-17 |website=[[LWN.net]]}} [201] => [202] => In July 2017, 30 years after he started glibc, Roland McGrath announced his departure, "declaring myself maintainer emeritus and withdrawing from direct involvement in the project. These past several months, if not the last few years, have proven that you don't need me anymore". [203] => [204] => In 2018, maintainer Raymond Nicholson removed a joke about [[abortion]] from the glibc source code. It was restored later by [[Alexandre Oliva]] after [[Richard Stallman]] demanded to have it returned.{{Cite web |last=Claburn |first=Thomas |title=Glibc 'abortion joke' diff tiff leaves Richard Stallman miffed |url=https://www.theregister.com/2018/05/09/gnu_glic_abort_stallman/ |access-date=2023-01-17 |website=[[The Register]] |language=en}} [205] => [206] => In 2021, the [[copyright]] assignment requirement to the [[Free Software Foundation]] was removed from the project.{{Cite web |last=Halfacree |first=Gareth |title=Open-source projects glibc and gnulib look to sever copyright ties with Free Software Foundation |url=https://www.theregister.com/2021/06/16/glibc_gnulib_fsf_copyright/ |access-date=2023-01-17 |website=[[The Register]] |language=en}} [207] => [208] => ===Fork and variant === [209] => In 1994, the developers of the [[Linux kernel]] [[fork (software development)|forked]] glibc. Their fork, "Linux libc", was maintained separately until around 1998. Because the copyright attribution was insufficient, changes could not be merged back to the GNU Libc.{{Cite web|title=History of glibc and Linux libc|url=http://freesoftwaremagazine.com/articles/history_of_glibc_and_linux_libc/|access-date=2021-05-10|website=[[Free Software Magazine]]}} When the FSF released glibc 2.0 in January 1997, the kernel developers discontinued Linux libc due to glibc 2.0's superior compliance with POSIX standards.{{cite web | date=24 October 2000 | title=Forking: it could even happen to you | url=https://www.linux.com/news/forking-it-could-even-happen-you/ | archive-url=https://web.archive.org/web/20090915191339/https://www.linux.com/archive/feature/3874 | archive-date=15 September 2009 | quote=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}} glibc 2.0 also had better [[internationalisation]] and more in-depth translation, [[IPv6]] capability, 64-bit data access, facilities for multithreaded applications, future version compatibility, and the code was more portable.{{cite web | url = https://people.redhat.com/~sopwith/old/glibc-vs-libc5.html | title = A Technical Comparison of glibc 2.x With Legacy System Libraries| last = Lee | first = Elliot | date=Jul 9, 1998 |archive-url = https://web.archive.org/web/20040411191201/https://people.redhat.com/~sopwith/old/glibc-vs-libc5.html |archive-date = 11 April 2004}} The last-used version of Linux libc used the internal name ([[soname]]) {{mono|libc.so.5}}. Following on from this, glibc 2.x on Linux uses the soname {{mono|libc.so.6}}{{cite web | url = http://linuxmafia.com/faq/Licensing_and_Law/forking.html | title = Fear of Forking essay |at=6. glibc --> Linux libc --> glibc |first1=Rick |last1=Moen |date=May 20, 2021 |orig-date=14 Nov 1999 |website=linuxmafia.com |url-status=live |archive-url=https://web.archive.org/web/20231127145135/http://linuxmafia.com/faq/Licensing_and_Law/forking.html |archive-date= Nov 27, 2023 }}{{Better source needed|date=May 2021}} [210] => [211] => In 2009, [[Debian]] and a number of [[List of Linux distributions#Debian-based|derivatives]] switched from glibc to the variant{{Refn|The eglibc developers emphasized themselves that eglibc is not a fork of glibc, but a variant, accepting patches from the upstream glibc project.{{Cite web|title=EGLIBC: FAQ|url=http://www.eglibc.org/faq|access-date=2021-09-16|website=eglibc.org}}}} eglibc.{{Cite book|last=Vaduva|first=Alexandru|url=https://books.google.com/books?id=yIJcDgAAQBAJ&pg=PA24 |publisher=Packt Publishing |title=Linux : embedded development: leverage the power of Linux to develop captivating and powerful embedded Linux projects : a course in three modules|date=2016|others=Alex Gonzalez, Chris Simmonds|isbn=978-1-78712-445-5|location=Birmingham, UK|pages=24|oclc=960471438}} Eglibc was supported by a [[consortium]] consisting of [[Freescale Semiconductor|Freescale]], [[MIPS Technologies|MIPS]], [[MontaVista]] and [[Wind River Systems|Wind River]].{{Cite web|last=Stiebert|first=Julius|date=6 May 2009|title=Debian wechselt zur Eglibc|url=https://www.golem.de/0905/66930.html|access-date=2021-09-16|website=[[golem.de]]}} It contained changes that made it more suitable for [[Embedded system|embedded usage]] and had added support for architectures that were not supported by glibc, such as the [[PowerPC e500]]. The code of eglibc was merged back into glibc at version 2.20.{{Cite book|last=Simmonds|first=Chris|url=https://www.worldcat.org/oclc/995052708|title=Mastering embedded Linux programming: unleash the full potential of embedded Linux|date=2017|isbn=978-1-78728-885-0|edition=2nd|location=Birmingham, UK|pages=26|oclc=995052708}} Since 2014, eglibc is discontinued. The [[Yocto Project]] and Debian also moved back to glibc since the release of [[Debian Jessie]].{{Cite book|last=Vaduva|first=Alexandru|url=https://www.worldcat.org/oclc/914797028|title=Learning embedded Linux using the Yocto project: develop powerful embedded Linux systems with the Yocto project components|date=2015|isbn=978-1-78439-519-3|location=Birmingham, UK|pages=29|oclc=914797028}} [212] => [213] => ===Steering committee=== [214] => Starting in 2001 the library's development had been overseen by a committee,{{cite web|url=https://www.gnu.org/software/libc/ |title=glibc homepage |quote=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.}} with Ulrich Drepper{{cite web|url=https://www.linkedin.com/in/ulrichdrepper |title=Ulrich Drepper |publisher=LinkedIn |access-date=2012-06-13}} 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 a failed [[hostile takeover]] maneuver by [[Richard Stallman]].{{Cite web|last=online|first=heise|title=Open-Source-Entwickler kritisiert Stallman|url=https://www.heise.de/newsticker/meldung/Open-Source-Entwickler-kritisiert-Stallman-48836.html|access-date=2021-09-16|website=[[heise online]]|date=19 August 2001 |language=de}}{{cite web|url=https://sourceware.org/ml/libc-hacker/2000-06/msg00180.html|title=RMS is at it again|first=Ulrich|last=Drepper|date=2000-06-26 |access-date=2015-11-20 |quote=''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.''|publisher=sourceware.org}}{{cite web|url=https://sourceware.org/ml/libc-announce/2001/msg00000.html| title=glibc 2.2.4 |first=Ulrich |last=Drepper |date=2001-08-15 |access-date=2015-11-29 |publisher=sourceware.com |quote=''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).''}}[https://slashdot.org/story/01/08/19/2039211/rms-accused-of-attempting-glibc-hostile-takeover rms-accused-of-attempting-glibc-hostile-takeover] on [[slashdot]].com on 19 August 2001 [215] => [216] => 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).{{Cite web |title=The GNU C Library Steering Committee disbands – The H Open: News and Features |url=http://www.h-online.com/open/news/item/The-GNU-C-Library-Steering-Committee-disbands-1484707.html |access-date=2023-03-16 |website=[[Heise (company)|H-Online]]}}{{cite web|last=McGrath|first=Roland|date=26 March 2012|title=glibc steering committee dissolving|url=https://sourceware.org/ml/libc-alpha/2012-03/msg01038.html|access-date=2012-06-13|publisher=Sourceware.org}}{{cite web|last=Myers|first=Joseph S.|date=26 March 2012|title=GNU C Library development and maintainers|url=https://sourceware.org/ml/libc-alpha/2012-03/msg01040.html|access-date=2012-06-13|publisher=Sourceware.org}} [217] => [218] => ==Functionality== [219] => glibc provides the functionality required by the [[Single UNIX Specification]], [[POSIX]] (1c, 1d, and 1j) and some of the functionality required by [[International Organization for Standardization|ISO]] [[C11 (C standard revision)|C11]], [[International Organization for Standardization|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. [220] => [221] => In addition, glibc also provides extensions that have been deemed useful or necessary while developing [[GNU]]. [222] => [223] => ===Supported hardware and kernels=== [224] => glibc is used in systems that run many different [[kernel (operating system)|kernels]] and different [[Computer hardware|hardware]] architectures. Its most common use is in systems using the [[Linux kernel]] on [[x86]] hardware, however, officially supported hardware{{cite web | url = https://sourceware.org/glibc/wiki/MAINTAINERS#Machine_maintainers | title = The GNU C Library machine maintainers.}} includes: [[ARM architecture|ARM]], [[ARC (processor)|ARC]], [[C-SKY]], [[DEC Alpha]], [[IA-64]], [[Motorola 68000 series|Motorola m68k]], [[MicroBlaze]], [[MIPS architecture|MIPS]], [[Nios II]], [[PA-RISC]], [[PowerPC]], [[RISC-V]], [[IBM System z|s390]], [[SPARC]], and [[x86]] (old versions support [[TILE64|TILE]]). It officially supports the [[GNU Hurd|Hurd]] and [[Linux kernel|Linux]] kernels. Additionally, there are heavily patched versions that run on the kernels of [[FreeBSD]] and [[NetBSD]] (from which [[Debian gnu/kfreebsd|Debian GNU/kFreeBSD]] and [[Debian GNU/NetBSD]] systems are built, respectively), as well as a forked-version of [[OpenSolaris]].{{cite web|url=https://csclub.uwaterloo.ca/~dtbartle/opensolaris/|title=GNU/kOpenSolaris (GNU libc/base + OpenSolaris kernel)|last1=Bartley|first1=David|last2=Spang|first2=Michael|access-date=2008-12-16|archive-date=6 November 2019|archive-url=https://web.archive.org/web/20191106181358/http://csclub.uwaterloo.ca/~dtbartle/opensolaris/|url-status=dead}} It is also used (in an edited form) and named {{mono|libroot.so}} in [[BeOS]] and [[Haiku (operating system)|Haiku]].{{cite web [225] => | url = https://github.com/haiku/haiku/tree/master/src/system/libroot [226] => | title = Haiku Source [227] => | website = [[GitHub]] [228] => | quote = libroot.so is not part of GNU project and is included in Haiku source code.}} [229] => [230] => ===Use in small devices=== [231] => glibc has been criticized as being "[[Software bloat|bloated]]" and slower than other libraries in the past, e.g. by [[Linus Torvalds]]{{cite web|last=Torvalds|first=Linus|url=http://ecos.sourceware.org/ml/libc-alpha/2002-01/msg00079.html|title=Posting to the glibc mailing list|date=9 January 2002}} and [[embedded Linux]] programmers. For this reason, several [[C standard library#Implementations|alternative C standard libraries]] have been created which emphasize a smaller footprint. However, many small-device projects use GNU libc over the smaller alternatives because of its application support, standards compliance, and completeness. Examples include [[Openmoko]]{{cite web [232] => | url = http://wiki.openmoko.org/wiki/OpenMoko [233] => | title = OpenMoko components [234] => | quote = 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}} and [[Familiar Linux]] for iPaq handhelds (when using the [[GPE Palmtop Environment|GPE]] display software).{{cite web [235] => | url = https://marc.info/?l=familiar&m=118666899424374&w=2 [236] => | title = Re: [Familiar] Which glibc for Familiar 0.8.4  ? [237] => | quote = Question: which version of the GLIBC was used to build the Familiar 0.8.4 ? Answer: 2.3.3}} [238] => [239] => === Secure string functions === [240] => glibc does not implement bounds-checking interfaces defined in [[C11 (C standard revision)|C11]] and did not implement strlcpy and strlcat{{Cite web |last=Kerrisk |first=Michael |title=The ups and downs of strlcpy() |url=https://lwn.net/Articles/507319/ |access-date=2023-12-09 |website=[[LWN.net]]}}{{Cite web |last=Corbet |first=Jonathan |title=Adding strlcpy() to glibc |url=https://lwn.net/Articles/612244/ |access-date=2023-12-09 |website=[[LWN.net]]}} until 2023 on the grounds that "in practice these functions can cause trouble, as their intended use encourages silent data truncation, adds complexity and inefficiency, and does not prevent all buffer overruns in the destinations."{{Cite web |title=FAQ |url=https://sourceware.org/glibc/wiki/FAQ#Why_no_strlcpy_.2F_strlcat.3F |access-date=2023-12-09 |website=sourceware.org}} The FAQ pointed out that the bounds-checking interfaces were optional in the ISO standard and that snprintf was available as an alternative. [241] => [242] => ==Compatibility layers== [243] => There are [[compatibility layer]]s ("[[Shim (computing)|shims]]") to allow programs written for other ecosystems to run on glibc interface offering systems. These include [[Hybris (software)|libhybris]], a compatibility layer for [[Android (OS)|Android's]] [[Bionic (software)|Bionic]], and [[Wine (software)|Wine]], which can be seen as a compatibility layer from [[Windows]] APIs to glibc and other native APIs available on Unix-like systems. [244] => [245] => ==See also== [246] => {{Portal|Free and open-source software}} [247] => * [[Gnulib]] [248] => * [[Linux kernel API]] [249] => [250] => ==Notes== [251] => {{Notelist}} [252] => [253] => ==References== [254] => {{Reflist}} [255] => [256] => ==External links== [257] => {{Commons category|GNU C Library}} [258] => * {{Official website|https://www.gnu.org/software/libc/}} [259] => [260] => {{GNU}} [261] => {{CProLang|state=expanded}} [262] => [263] => [[Category:C standard library]] [264] => [[Category:Cross-platform free software]] [265] => [[Category:Free computer libraries]] [266] => [[Category:Free software programmed in C]] [267] => [[Category:GNU Project software|C Library]] [268] => [[Category:Interfaces of the Linux kernel]] [269] => [[Category:Linux APIs]] [] => )
good wiki

Glibc

The GNU C Library, commonly known as glibc, is the GNU Project's implementation of the C standard library. It is a wrapper around the system calls of the Linux kernel for application use.

More about us

About

Expert Team

Vivamus eget neque lacus. Pellentesque egauris ex.

Award winning agency

Lorem ipsum, dolor sit amet consectetur elitorceat .

10 Year Exp.

Pellen tesque eget, mauris lorem iupsum neque lacus.