Библиотека GNU C - GNU C Library

Библиотека GNU C
Heckert GNU white.svg
Оригинальный автор (ы)Роланд МакГрат
Разработчики)Проект GNU
изначальный выпуск1987; 33 года назад (1987)[1]
Стабильный выпуск2.32[2] (5 августа 2020 г.; 4 месяца назад (2020-08-05)) [±]
Репозиторий Отредактируйте это в Викиданных
Написано вC
Операционная системаUnix-подобный
ТипБиблиотека времени исполнения
ЛицензияLGPLv2.1[3]
Интернет сайтwww.gnu.org/программного обеспечения/ libc/
В Linux API состоит из интерфейса системных вызовов ядра Linux, библиотеки GNU C ( GNU ), libdrm, libalsa и libevdevfreedesktop.org ).
Библиотека GNU C - это оболочка для системные вызовы из Ядро Linux.
В Ядро Linux и библиотека GNU C вместе образуют Linux API. После компиляции двоичные файлы предлагают ABI.

В Библиотека GNU C, широко известный как glibc, это Проект GNU реализация Стандартная библиотека C. Несмотря на свое название, теперь он также напрямую поддерживает C ++ (и, косвенно, другие языки программирования ). Он был начат в начале 1990-х годов Фонд свободного программного обеспечения (FSF) за их GNU Операционная система.

Выпущено под Стандартная общественная лицензия ограниченного применения GNU,[3] glibc это бесплатно программное обеспечение. Проект библиотеки GNU C предоставляет базовые библиотеки для системы GNU и систем GNU / Linux, а также многих других систем, использующих Linux как ядро. Эти библиотеки предоставляют важные API включая ISO C11, POSIX.1-2008, BSD, API-интерфейсы для конкретных ОС и многое другое. Эти API включают такие базовые возможности, как открыто, читать, записывать, маллок, printf, getaddrinfo, dlopen, pthread_create, склеп, авторизоваться, выход и больше.

История

Первоначально проект glibc был написан в основном Роланд МакГрат, работая на Фонд свободного программного обеспечения (FSF) в 1980-х, будучи подростком.[4]

В феврале 1988 года FSF описал glibc как почти завершившую функциональность, требуемую ANSI C.[5] К 1992 году в нем были реализованы функции ANSI C-1989 и POSIX.1-1990, и велась работа над POSIX.2.[6]

В сентябре 1995 года Ульрих Дреппер сделал свой первый вклад в проект glibc и в течение 1990-х годов постепенно стал основным разработчиком и сопровождающим glibc.[7] Дреппер много лет занимал должность сопровождающего и до 2012 года собрал 63% всех обязательств по проекту.[8]

Linux libc

В начале 1990-х годов разработчики Ядро Linux раздвоенный glibc. Их форк «Linux libc» поддерживался отдельно.

Когда в январе 1997 года FSF выпустила glibc 2.0, разработчики ядра прекратили поддержку Linux libc из-за превосходного соответствия glibc 2.0 стандартам POSIX.[9] glibc 2.0 тоже был лучше интернационализация и более глубокий перевод, IPv6 возможности, 64-битный доступ к данным, возможности для многопоточных приложений, совместимость с будущими версиями и более переносимый код.[10]

Последняя используемая версия Linux libc использовала внутреннее имя (soname ) libc.so.5. Исходя из этого, glibc 2.x в Linux использует soname libc.so.6[11] (Альфа и IA64 архитектуры теперь используют libc.so.6.1, вместо). Имя файла * .so часто сокращается как libc6 (например, в имени пакета в Debian ) в соответствии с обычными соглашениями для библиотек.

В соответствии с Ричард Столмен, FSF не смог объединить изменения, внесенные в libc Linux, в glibc из-за неопределенного авторства. Проект GNU довольно строго относится к записи авторских прав и авторов.[12]

Установка руководящего комитета

Начиная с 2001 года развитие библиотеки курировал комитет,[13] с Ульрих Дреппер[14] остается ведущим участником и сопровождающим. В руководящий комитет установка была окружена общественными спорами, так как Ульрих Дреппер открыто назвал ее провальной. враждебный захват маневр Ричарда Столмена.[15][16][17]

Миграция на Git, распределенную VCS

Хотя ранее в CVS репозиторий, в 2009 году glibc был перенесен на Git (распределенная система контроля версий) репозиторий на Исходное ПО.[18]

Debian переходит на EGLIBC и обратно

После долгих разногласий по поводу стиля руководства Дреппера и признания вклада извне,[19][20][21] Debian публично переключился на форк glibc EGLIBC в 2009 [22] и вернемся к glibc с выпуском Debian 8.0 (Jessie) в апреле 2015 года.[23]

Руководящий комитет распускается

В марте 2012 года руководящий комитет проголосовал за роспуск и удаление Drepper в пользу процесса разработки, управляемого сообществом, с Райаном Арнольдом, Максимом Кувырковым, Джозефом Майерсом, Карлосом О'Донеллом и Александр Олива несет ответственность за сопровождение GNU (но без дополнительных полномочий по принятию решений).[24][25]

После изменения в поддержке glibc Debian и другие проекты, которые перешли на альтернативы, мигрировали обратно в glibc.[26] С начала 2014 года форк glibc EGLIBC больше не разрабатывается, так как его «цели теперь решаются непосредственно в GLIBC».

В июле 2017 года, через 30 лет после создания glibc, Роланд МакГрат объявил о своем уходе, «объявив себя почетным сопровождающим и отказавшись от прямого участия в проекте. Последние несколько месяцев, если не последние несколько лет, доказали, что вы этого не сделаете. нужен мне больше ".[4]

История версий

Для большинства систем версию glibc можно получить, выполнив файл lib (например, /lib/libc.so.6).

Функциональность

glibc обеспечивает функциональность, требуемую Единая спецификация UNIX, POSIX (1c, 1d и 1j) и некоторые функции, необходимые для ISO C11, ISO C99, Беркли Unix (BSD) интерфейсы Определение интерфейса System V (SVID) и X / Open Руководство по переносимости (XPG), выпуск 4.2, со всеми расширениями, общими для XSI (X / интерфейс открытой системы ) совместимые системы вместе со всеми расширениями X / Open UNIX.

Кроме того, glibc также предоставляет расширения, которые были сочтены полезными или необходимыми при разработке. GNU.

Поддерживаемое оборудование и ядра

glibc используется в системах, в которых работает множество различных ядра и разные аппаратное обеспечение архитектуры. Чаще всего его используют в системах, использующих Ядро Linux на x86 оборудование, однако, официально поддерживаемое оборудование[42] включает: 32-битная ARM и ее новая 64-битная ISA (AArch64), C-SKY, DEC Alpha, IA-64, Motorola m68k, MicroBlaze, MIPS, Ниос II, PA-RISC, PowerPC, RISC-V, s390, SPARC, и x86 (поддержка старых версий ПЛИТКА ). Он официально поддерживает Херд и Linux ядра. Кроме того, есть сильно пропатченные версии, которые работают на ядрах FreeBSD и NetBSD (откуда Debian GNU / kFreeBSD и Debian GNU / NetBSD системы построены соответственно), а также форк-версия OpenSolaris.[43] Он также используется (в отредактированном виде) и называется libroot.so в BeOS и Хайку.[44]

Использование в небольших устройствах

glibc был раскритикован как "раздутый "и медленнее, чем другие библиотеки в прошлом, например, Линус Торвальдс[45] и встроенный Linux программисты. По этой причине несколько альтернативные стандартные библиотеки C были созданы, которые подчеркивают меньшую занимаемую площадь. Тем не менее, многие проекты для небольших устройств используют GNU libc вместо небольших альтернатив из-за поддержки приложений, соответствия стандартам и полноты. Примеры включают Openmoko[46] и Знакомый Linux для КПК iPaq (при использовании GPE программное обеспечение дисплея).[47]

Слои совместимости

Есть уровни совместимости ("прокладки "), чтобы программы, написанные для других экосистем, могли работать в системах, предлагающих интерфейс glibc. К ним относятся libhybris, уровень совместимости для Android Бионический, и Вино, который можно рассматривать как уровень совместимости из Windows API-интерфейсы для glibc и других собственных API-интерфейсов, доступных в Unix-подобных системах.

Смотрите также

Рекомендации

  1. ^ Корбет, Джонатан (28 марта 2012 г.). «Поворотный момент для GNU libc». LWN.net.
  2. ^ Карлос О'Донелл (6 августа 2020 г.). «Библиотека GNU C версии 2.32 теперь доступна» (Список рассылки). Получено 6 августа 2020.
  3. ^ а б "sourceware.org Git - glibc.git / blob - COPYING.LIB". sourceware.org. Получено 13 сентября 2017.
  4. ^ а б "Роланд МакГрат покидает пост сопровождающего glibc [LWN.net]". lwn.net. 7 июля 2017 г.. Получено 8 июля 2017.
  5. ^ "Бюллетень GNU, том 1, № 4, февраль 1988 г.". Большинство библиотек готово. Роланд МакГрат […] имеет почти полный набор функций библиотеки ANSI C. Надеемся, они будут готовы весной этого года.
  6. ^ "Бюллетень GNU, том 1, номер 12". Теперь он содержит все функции ANSI C-1989 и POSIX.1-1990, а также ведется работа над функциями POSIX.2 и Unix (BSD и System V).
  7. ^ журнал изменений glibc на GitHub.
  8. ^ Корбет, Джонатан (28 марта 2012 г.). «Поворотный момент для GNU libc». LWN.net. Из почти 19 000 коммитов, найденных в репозитории проекта git (который содержит изменения с 1995 года), более 12 000 были сделаны Ульрихом.
  9. ^ "Разветвление: это могло случиться даже с вами". 12 сентября 2008 г. раскол между GNU LIBC и Linux LIBC - он продолжался годами, пока Linux стабилизировался, а затем форки снова объединились в один проект
  10. ^ Ли, Эллиот (2001). «Техническое сравнение glibc 2.x с устаревшими системными библиотеками». Архивировано из оригинал 11 апреля 2004 г.
  11. ^ «Боязнь раздвоения», см. «6. glibc -> Linux libc -> glibc"".
  12. ^ "Fear of Forking, сноска к комментариям Столлмана о слиянии".
  13. ^ "домашняя страница glibc". В 2001 году был сформирован Руководящий комитет библиотеки GNU C…, который в настоящее время состоит из Марка Брауна, Пола Эггерта, Андреаса Йегера, Якуба Елинека, Роланда МакГрата и Андреаса Шваба.
  14. ^ "Ульрих Дреппер". LinkedIn. Получено 13 июн 2012.
  15. ^ Дреппер, Ульрих (26 июня 2000 г.). "RMS снова за дело". sourceware.org. Получено 20 ноября 2015. Несколько недель назад RMS начал очередную атаку на меня (одно письмо, затем непрямые попытки получить влияние, а сегодня - еще одно письмо). Суть в том, что он жалуется, что я не следую «политике GNU» и, следовательно, должен быть заменен руководящим комитетом, частью которого я мог бы быть. Некоторые из вас (а именно Роланд и Андреас С.), вероятно, знают об этом, поскольку он предлагал обоих в качестве других членов комитета. Вдобавок в списке был Марк Браун (я знаю в IBM кого-то с таким именем, который также подошел бы к этой группе, но я не уверен, действительно ли это он.) В любом случае, я полностью отвергаю это. Это совсем не помогает, все наоборот. Во-первых, я не знаю ни одной важной политики, которую нарушаю. Единственное, что я не выполняю приказы RMS, которые явно имеют политические намерения (что, конечно, кощунственно), и, возможно, меня не волнует Винблоуз (если последний вообще имеет значение). Ничего из этого никоим образом не изменится.
  16. ^ Дреппер, Ульрих (15 августа 2001 г.). "glibc 2.2.4". sourceware.com. Получено 29 ноябрь 2015. А теперь о не очень приятных вещах. Столмен недавно предпринял попытку того, что я бы назвал враждебным захватом разработки glibc. Он пытался за моей спиной устроить заговор и убедить других основных разработчиков взять под свой контроль, чтобы в конце концов он все контролировал и мог диктовать все, что ему угодно. Эта попытка провалилась, но он продолжал оказывать давление на людей повсюду, и это стало действительно ужасно. В конце концов я согласился на создание так называемого «руководящего комитета» (СК).
  17. ^ rms-обвиняемый-в-попытке-glibc-враждебном захвате на слэшдот.com 19 августа 2001 г.
  18. ^ репозиторий glibc на Sourceware.com
  19. ^ Ульрих Дреппер 2007-10-03 06:13:55 UTC «Это не имеет ничего общего с« только x86 ». Все ABI, разработанные людьми, имеющими хоть какое-то понимание, не требуют изменений. Любое изменение отрицательно повлияет на хорошо спроектированные архитектуры - единственное преимущество этой встроенной чуши. Но ваша собственная версия файл в дополнении ".
  20. ^ Дреппер, Ульрих (25 мая 2005 г.). «Диктатура меньшинств». udrepper.livejournal.com. Получено 15 января 2012. Какие архитектуры стоит поддерживать? […]. Мы не только должны искать нерелевантность (какой процент заботится о поддержке Vax, PArisc), мы также должны смотреть на уровень дополнительной сложности, который требуется для поддержки. Некоторые ABI просто намеренно определены, чтобы отличаться от других (см. IA-64), что требует огромных усилий. Возможности также существенно расходятся (например, отсутствие атомарных операций в слишком большом количестве архитектур). Это слишком часто приводит к излишнему искажению кода, поскольку писать код таким образом, чтобы его можно было оптимально использовать во всех ситуациях, очень сложно. Решение должно заключаться в том, чтобы ограничить поддержку только горсткой архитектур, которые поддерживаются в проекте. Вся остальная поддержка должна происходить за пределами дерева, и поэтому всю работу должны выполнять группы с особыми интересами. Я не хочу сказать, что мы точно следуем всем этим пунктам, но для большого проекта glibc определенно подходит ближе всего к этому.
  21. ^ Ярно, Орелиен (5 мая 2009 г.). «Debian переходит на EGLIBC». aurel32.net. Получено 15 января 2012. Более дружественный апстрим (особенно в отношении встроенных архитектур): «Поощряйте сотрудничество, общение, вежливость и уважение среди разработчиков» (в отличие от этого).
  22. ^ тимофей (6 мая 2009 г.). «Переход Debian с Glibc на Eglibc». Slashdot. Получено 14 января 2012.
  23. ^ Журнал изменений пакета Debian
  24. ^ Макграт, Роланд (26 марта 2012 г.). "роспуск руководящего комитета glibc". Sourceware.org. Получено 13 июн 2012.
  25. ^ Майерс, Джозеф С. (26 марта 2012 г.). "Разработка и сопровождение библиотеки GNU C". Sourceware.org. Получено 13 июн 2012.
  26. ^ «Debian переключается (обратно) на GLIBC». Орелиен. 19 июня 2014 г.. Получено 19 июн 2014.
  27. ^ "CosmicCuttlefish / ReleaseNotes - Ubuntu Wiki".
  28. ^ «Глава 5. RHEL 8.0.0, выпуск Red Hat Enterprise Linux 8».
  29. ^ «Глава 2. Что нового в Debian 10».
  30. ^ "Изменения / GLIBC228".
  31. ^ "Red Hat Bugzilla - Ошибка 1598403".
  32. ^ "sourceware.org Git - glibc.git / blob - НОВОСТИ".
  33. ^ "DiscoDingo / ReleaseNotes - Ubuntu Wiki".
  34. ^ "Изменения / GLIBC229".
  35. ^ "Red Hat Bugzilla - Ошибка 1653403".
  36. ^ "sourceware.org Git - glibc.git / blob - НОВОСТИ".
  37. ^ "EoanErmine / ReleaseNotes - Ubuntu Wiki".
  38. ^ "Изменения / GLIBC230".
  39. ^ «Focal (20.04): пакет glibc: Ubuntu».
  40. ^ "Изменения / GLIBC231".
  41. ^ «Библиотека GNU C версии 2.32 теперь доступна». sourceware.org. Получено 13 августа 2020.
  42. ^ «Сопровождающие машины с библиотекой GNU C».
  43. ^ Бартли, Дэвид; Спанг, Майкл. "GNU / kOpenSolaris (GNU libc / base + ядро ​​OpenSolaris)". Получено 16 декабря 2008.
  44. ^ "Источник хайку". libroot.so не является частью проекта GNU и включен в исходный код Haiku.
  45. ^ Торвальдс, Линус (9 января 2002 г.). "Отправка в список рассылки glibc".
  46. ^ «Компоненты OpenMoko». Мы будем использовать glibc (не uClibC)… Альтернативы могут сэкономить больше места и быть более оптимизированными, но с большей вероятностью доставят нам головную боль интеграции
  47. ^ "Re: [Familiar] Какой glibc для Familiar 0.8.4?". Вопрос: какая версия GLIBC использовалась для сборки Familiar 0.8.4? Ответ: 2.3.3

внешняя ссылка