Русская Википедия:POSIX

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску

Шаблон:Стандарт ISO

POSIX (Шаблон:Lang-en — переносимый интерфейс операционных систем) — набор стандартов, описывающих интерфейсы между операционной системой и прикладной программой (системный API), библиотеку языка C и набор приложений и их интерфейсов. Стандарт создан для обеспечения совместимости различных UNIX-подобных операционных систем и переносимости прикладных программ на уровне исходного кода, но может быть использован и для не-Unix систем.

Серия стандартов POSIX была разработана комитетом 1003 IEEE. Международная организация по стандартизации (ISO) совместно c Международной электротехнической комиссией (IEC) приняла стандарт POSIX под названием ISO/IEC 9945[1]. Версии стандарта POSIX являются основой соответствующих версий стандарта Single UNIX Specification. Стандарт POSIX определяет интерфейс операционной системы, а соответствие стандарту Single UNIX Specification определяет реализацию интерфейса и позволяет операционным системам использовать торговую марку UNIX[2].

Название «POSIX» было предложено Ричардом Столлманом[3]. Введение в POSIX.1 гласит: «Ожидается произношение „позикс“ как в слове „позитив“, а не „посикс“. Произношение опубликовано в целях обнародования стандартного способа ссылки на стандартный интерфейс операционной системы». «POSIX» является зарегистрированным товарным знаком IEEE[3].

Задачи

  • Содействовать облегчению переноса кода прикладных программ на иные платформы.
  • Способствовать определению и унификации интерфейсов заранее при проектировании, а не в процессе их реализации.
  • Сохранять по возможности и учитывать все главные, созданные ранее и используемые прикладные программы.
  • Определять необходимый минимум интерфейсов прикладных программ для ускорения создания, одобрения и утверждения документов.
  • Развивать стандарты в направлении обеспечения коммуникационных сетей, распределённой обработки данных и защиты информации.
  • Рекомендовать ограничение использования бинарного (объектного) кода для приложений в простых системах.

Состав

Стандарт состоит из четырёх основных разделов.

  • Основные определения (Шаблон:Lang-en) — список основных определений и соглашений, используемых в спецификациях, и список заголовочных файлов языка Си, которые должны быть предоставлены соответствующей стандарту системой.
  • Оболочка и утилиты (Шаблон:Lang-en) — описание утилит и командной оболочки sh, стандарты регулярных выражений.
  • Системные интерфейсы (Шаблон:Lang-en) — список системных вызовов языка Си.
  • Обоснование (Шаблон:Lang-en) — объяснение принципов, используемых в стандарте.

Версии

Версии POSIX до 2001 года

До 2001 года было создано много стандартов POSIX, часть из которых использовались для формирования стандартов Single UNIX Specification. Множество операционных систем частично или полностью реализовывали поддержку этих стандартов, в связи с чем в руководствах к системным вызовам и к программам часто встречаются ссылки на данные стандарты. На данный момент эти стандарты являются устаревшими и представляют лишь исторический интерес.

POSIX.1. Системное API для языка Си

Стандарт: IEEE Std 1003.1-1988, затем IEEE Std 1003.1-1990; ISO/IEC 9945-1:1990.

Стандарт был выпущен в 1988 году, занимал 317 страниц, включал в себя стандарт ANSI C и являлся первым стандартом POSIX. До присвоения названия POSIX Ричардом Столлманом стандарт был известен как IEEE-IX. В 1990 вышло обновление стандарта с небольшими изменениями под названием IEEE Std 1003.1-1990, занимавшее 356 страниц. Заголовок обновлённого стандарта гласил: «Part 1: System Application Program Interface (API) [C Language]». Таким образом, было явно указано, что стандарт представляет собой системное API для языка Си[4].

Разделы стандарта
  • Создание и управление процессами[4]
  • Сигналы[5]
    • Исключения плавающей точки
    • Нарушение сегментации
    • Запрещённые директивы
    • Ошибки шины
    • Таймеры
  • Операции над файлами (каталогами)[4]
  • Каналы[6]
  • Библиотека Си (стандарт Си)
  • Интерфейс и контроль ввода-вывода
  • Триггеры процессов
Особенности стандарта

Из числа описанного в стандарте стоит отметить следующее:

  • добавлена функция mkfifo(), как более простой вариант создания именованных каналов по сравнению с активно использовавшейся в то время функцией mknod()[7];
  • описан формат архивов tar и cpio[4];
  • описаны файлы с информацией о пользователях и о группах[4].

POSIX.2. Командная оболочка и утилиты

Стандарт: IEEE Std 1003.2-1992; ISO/IEC 9945-2:1993[8].

Стандарт вышел в 1992 году в двух томах общим размером около 1300 страниц. Заголовок гласил: «Part 2: Shell And Utilities», что переводится как «Часть 2: Командный интерпретатор и утилиты»[4].

Разделы стандарта
  • Командный интерпретатор
  • Программные утилиты
Особенности стандарта

Стандарт описывал командный интерпретатор на основе System V Bourne shell[4] и около сотни утилит командной строки (включая basename, awk, vi, yacc и многие другие)[4].

POSIX.1b. Расширения реального времени

Также известен как POSIX.4[8].

Стандарт: IEEE Std 1003.1b-1993, IEEE Std 1003.1i-1995 (технические исправления к 1003.1b).

Изначально известный как IEEE P1003.4, стандарт являлся обновлением стандарта IEEE Std 1003.1-1990. Обновление из 590 страниц включало в себя расширения реального времени, разработанные рабочим комитетом P1003.4[4]. В 1995 году стандарт был дополнен техническими исправлениями (IEEE Std 1003.1i-1995).

Разделы стандарта
  • Планировка приоритетов[4]
  • Сигналы реального времени[9]
  • Часы и таймеры[4]
  • Семафоры[4]
  • Передача сообщений[4]
  • Управление памятьюШаблон:Efn[4]
  • Синхронизация файлов и асинхронный ввод-вывод[4]
  • Интерфейс блокировки виртуальной памяти[9]

POSIX.1c. Потоки

Стандарт: IEEE Std 1003.1c-1995.

Разделы стандарта
  • Создание, контроль и завершение выполнения потоков
  • Планировщик потоков
  • Синхронизация потоков
  • Обработка сигналов
Особенности стандарта

Основной задачей стандарта являлось обеспечение возможности написания реентерабельного кода для использования в многопоточных программах. Из числа значительных изменений стоит отметить следующие:

  • глобальная переменная errno языка Си более не является глобальной переменной и должна указывать на отдельную память для каждого потока[10];
  • добавлены реентерабельные аналоги некоторых функций, к которым добавляется суффикс «_r»[10];
  • все функции для работы со вводом-выводом должны быть реализованы реентерабельными, иначе в их названии необходимо явно обозначать их небезопасность (например, суффиксом «_unlocked»)[10];
  • добавлены функции flockfile(), ftrylockfile() и funlockfile() для осуществления блокирующих операций над потоками данных в рамках многопоточной программы[10].

POSIX.1-1996

Стандарт: IEEE Std 1003.1, 1996 Edition, также известный как IEEE 1996 (ISO/IEC 9945-1:1996).

Стандарт занимал 743 страницы, объединял ранее разработанные версии POSIX и включал в себя следующие стандарты[4][11]:

  • IEEE Std 1003.1-1990 (базовый API);
  • IEEE Std 1003.1b-1993 (расширения реального времени);
  • IEEE Std 1003.1c-1995 (потоки);
  • IEEE Std 1003.1i-1995 (технические исправления к стандарту 1003.1b).
Разделы стандарта
  • Часть 1. Системное API (Язык Си)[4]
  • Часть 2. Командный интерпретатор и утилиты[4]
  • Часть 3. Системное администрирование (в разработке)[4]

При этом около четверти страниц стандарта занимала историческая справка и пояснения причин, по которым в него были включены те или иные функции[4].

POSIX.1d. Дополнительные расширения реального времени

Стандарт: IEEE Std 1003.1d-1999.

Описывал дополнительные расширения реального времени[8]. Например, системный вызов sem_timedwait() появился именно в этом стандарте[12].

POSIX.1g. Протоколо-независимые интерфейсы

Первоначальное название: POSIX 1003.12[12].

Стандарт: IEEE Std 1003.1g.

Стандарт был выпущен в 2000 году, описывал API взаимодействия процессов друг с другом и включал в себя два основных API[13]:

  • Simple Network Interface (SNI)[13];
  • Detailed Network Interface (DNI), включающий в себя API сокетов на основе сокетов 4.4BSD[14] и помеченный устаревшим X/Open Transport Interface (XTI)[15].

POSIX.1j. Продвинутые расширения реального времени

Стандарт: IEEE Std 1003.1j-2000.

Описывает продвинутые расширения реального времени[8].

Версии POSIX после 2001 года

В марте 1997 года рабочий комитет Austin Group разработал стандарт Single UNIX Specification version 2, который по своей сути был продолжением развития стандарта POSIX.1-1996[4][16][17].

В 1999 году было принято решение, согласно которому консорциум The Open Group и Институт инженеров по электротехнике и электронике (IEEE) приняли решение об объединении усилий в совместной разработке стандартов POSIX и Single UNIX Specification. Новый стандарт POSIX должен был заменить существующие на тот момент стандарты POSIX (POSIX.1 и POSIX.2 и др.), став основой для Single UNIX Specification version 3. Также было решено обнародовать будущий стандарт, разработку которого планировалось закончить к 2001 году[18].

В 2001 году все предыдущие стандарты POSIX были объединены в один общий стандарт, который предполагалось использовать как основу для будущих стандартов Single UNIX Specification[12].

POSIX.1-2001

Стандарт: IEEE Std 1003.1-2001; ISO/IEC 9945:2002[12].

В 2001 году основные опциональные стандарты POSIX, разработанные ранее, были объединены в единый стандарт POSIX.1-2001. С тех пор принято именовать стандарты POSIX, добавляя к ним в конец год издания[19]. POSIX.1-2001 является основой стандарта Single UNIX Specification version 3[20].

POSIX.1-2001 ориентирован на стандарт языка C99 и может включать в себя функции и заголовочные файлы из C99[21].

Стандарт включает в себя:

  • основные понятия и определения;
  • системные интерфейсы и заголовочные файлы;
  • описание командного интерпретатора на уровне исходного кода и утилит командной строки.

POSIX.1-2004

Стандарт: IEEE Std 1003.1-2004.

Стандарт является незначительным обновлением стандарта POSIX.1-2001. Включает в себя два технических исправления[22]. Описание стандарта доступно в интернете[23].

POSIX.1-2008

Стандарты: IEEE Std 1003.1-2008 (ISO/IEC 9945:2009), техническое исправление IEEE Std 1003.1-2008/Cor 1-2013 (ISO/IEC/IEEE 9945:2009/Cor 1:2013).

Стандарт разработан в 2008. В 2013 году к стандарту было разработано техническое исправление № 1 под названием IEEE Std 1003.1-2008/Cor 1-2013. Общедоступную бесплатную копию стандарта можно найти в интернете[24]. POSIX.1-2008 лежит в основе стандарта Single UNIX Specification version 4[25].

Стандарт описывает:

  • основные понятия и определения стандарта;
  • системные интерфейсы и заголовочные файлы;
  • описание командного интерпретатора на уровне исходного кода и утилит командной строки;
  • пояснения о необходимости стандарта, о причинах включения возможностей (или отказа от включения) в стандарт.

POSIX.1-2017

Стандарт: IEEE Std 1003.1-2017 (ISO/IEC/IEEE 9945:2009/Cor 2:2017).

Стандарт разработан в 2017 и является текущим[26]. Является второй поправкой к редакции ISO/IEC/IEEE 9945:2009.

По сравнению с предыдущим стандартом содержит в основном исправления ошибок и перенос опциональных возможностей в категорию обязательных. В том числе опциональными перестали быть многие функции для работы с потоками, включая блокировки чтения-записи. В число новых функций в основном входят функции для работы с локалями[27].

Профили POSIX 1003.13

Стандарт POSIX 1003.1 подходит не для всех операционных систем. Встраиваемые операционные системы не всегда реализуют поддержку тех или иных функций. Стандарт POSIX 1003.13 описывает подмножество стандарта POSIX 1003.1 для встраиваемых систем, которое разделено на 4 профиля. Профили были разработаны, чтобы обеспечить переносимость программ на уровне исходных кодов для операционных систем с ограниченными возможностями. Они представляют собой подмножество стандарта POSIX 1003.1, то есть описывают только часть возможностей, включённых в оригинальный стандарт. Таким образом, профили не конфликтуют с оригинальным стандартом[28].

Текущим является стандарт IEEE 1003.13-2003[29], который является развитием стандарта IEEE Std 1003.13-1998 и основывается на стандарте IEEE Std 1003.1-2001. Также в стандарт включены POSIX.26-2003 (IEEE Std 1003.26-2003), POSIX.13a, POSIX.13b[30] и ISO/IEC 14519:2001Шаблон:Нет АИ.

На 2016 год разработаны следующие профили:

  • POSIX PSE54 (многопользовательская многопроцессная операционная система с поддержкой потоков и файловой системы);
  • POSIX PSE53 (многопроцессная операционная система с поддержкой потоков и файловой системы);
  • POSIX PSE52 (однопроцессная операционная система с поддержкой потоков и файловой системы);
  • POSIX PSE51 (однопроцессная операционная система с поддержкой потоков, без файловой системы).

Сравнительная характеристика профилей

Поддерживаемые возможности[28] PSE51 PSE52 PSE53 PSE54 Первое появление
Процессы - - + + 1003.1-90
Конвейеры - - + + 1003.1-90
Файлы и каталоги - + Шаблон:Efn + Шаблон:Efn + 1003.1-90
Пользователи и группы - - - + 1003.1-90
Защита памяти - - + + 1003.1b-93
Часы и таймеры высокого разрешения + + + + 1003.1b-93
Сигналы реального времени + + + + 1003.1b-93
Семафоры + + + + 1003.1b-93
Разделяемая память + + + + 1003.1b-93
Межпроцессовый обмен данными + + + + 1003.1b-93
Потоки + + + + 1003.1c-95
Потокобезопасные функции + + + + 1003.1c-95
Атрибуты потоков, адрес стека + + + + 1003.1c-95
Атрибуты потоков, размер стека + + + + 1003.1c-95
Разделение процесса между потоками - - + + 1003.1c-95
Приоритеты потоков + + + + 1003.1c-95
Наследование приоритетов потоками + + + + 1003.1c-95
Защита приоритетов потоков + + + + 1003.1c-95

Поддержка операционными системами

В зависимости от степени совместимости со стандартами, ОС могут быть полностью или частично совместимы с POSIX. Сертифицированные продукты могут быть найдены на сайте IEEE[31]. Бесплатный доступ к версии стандарта IEEE Std 1003.1-2017 находится на сайте «The Open Group»[32].

POSIX-сертифицированные

C 1996 года стандарт SUS включает в себя стандарт POSIX, поэтому сертифицированные на стандарт UNIX операционные системы можно считать одновременно сертифицированными и на стандарт POSIX.

POSIX-совместимые

Заявлена полная совместимость с одной из версий стандарта POSIX.

По большей части POSIX-совместимые

Официально не сертифицированные как POSIX-совместимые, но соответствующие по большей части.

Частично POSIX-совместимые

POSIX для Windows

  • Cygwin — обеспечивает частичное соответствие POSIX для некоторых продуктов Microsoft Windows.
  • Подсистема для UNIX-приложений (SUA) — необязательная подсистема Windows, обеспечивающая готовое окружение для компиляции и исполнения POSIX-совместимых приложений[66]. Соответствие стандарту POSIX.2 на уровне командной строки обеспечивается с помощью командной оболочки ksh[67].
  • «Microsoft Windows Services for UNIX» — обеспечивает полное соответствие POSIX для некоторых продуктов Microsoft Windows. Операционные системы на базе Windows NT до Windows 2000 имели POSIX-уровень, встроенный в ОС, и «UNIX Services for Windows» предоставляло UNIX-подобное окружение. Для получения POSIX-совместимости в Windows XP нужно скачать и установить бесплатный пакет «Windows Services for UNIX». UNIX-подсистема встроена в Enterprise и Ultimate редакции Windows Vista и не может быть добавлена в другие редакции.
  • Windows Subsystem for Linux — прослойка совместимости, впервые появившаяся в Windows 10 и реализующая API ядра Linux поверх Windows. Позволяет запускать окружение некоторых дистрибутивов в пространстве пользователя.
  • UWIN — набор библиотек и утилит, обеспечивающих POSIX-совместимое окружение поверх Win32 API[68].
  • UnxUtils — набор портированных под библиотеку Microsoft C Run-time (msvcrt.dll) утилит GNU[69].

См. также

Примечания

Комментарии

Шаблон:Комментарии

Источники

Шаблон:Примечания

Литература

Ссылки

Шаблон:Стандарты Open Group Шаблон:Стандарты IEEE Шаблон:Стандарты ISO Шаблон:Команды Unix

  1. Шаблон:Cite web
  2. Шаблон:Cite web
  3. 3,0 3,1 Шаблон:Cite web
  4. 4,00 4,01 4,02 4,03 4,04 4,05 4,06 4,07 4,08 4,09 4,10 4,11 4,12 4,13 4,14 4,15 4,16 4,17 4,18 4,19 4,20 Шаблон:Книга
  5. Шаблон:Cite web
  6. Шаблон:Книга
  7. Шаблон:Книга
  8. 8,0 8,1 8,2 8,3 Шаблон:Cite web
  9. 9,0 9,1 Шаблон:Статья
  10. 10,0 10,1 10,2 10,3 Шаблон:Cite web
  11. Шаблон:Cite web
  12. 12,0 12,1 12,2 12,3 Шаблон:Книга
  13. 13,0 13,1 Шаблон:Статья
  14. Шаблон:Книга
  15. Шаблон:Книга
  16. Шаблон:Cite web
  17. Шаблон:Cite web
  18. Шаблон:Cite web
  19. Шаблон:Книга
  20. Шаблон:Cite web
  21. Шаблон:Cite web
  22. Шаблон:Cite web
  23. Шаблон:Cite web
  24. Шаблон:Cite web
  25. Шаблон:Cite web
  26. Шаблон:Cite web
  27. Шаблон:Cite web
  28. 28,0 28,1 28,2 Шаблон:Cite web
  29. Шаблон:Cite web
  30. Шаблон:Cite web
  31. Шаблон:Cite web
  32. Шаблон:Cite web
  33. Шаблон:Cite web
  34. Шаблон:Cite web
  35. Шаблон:Cite web
  36. Шаблон:Cite web
  37. Шаблон:Cite web
  38. Шаблон:Cite web
  39. Шаблон:Cite web
  40. Шаблон:Cite web
  41. Шаблон:Cite web
  42. Шаблон:Cite web
  43. Шаблон:Cite web
  44. Шаблон:Cite web
  45. Шаблон:Cite web
  46. Шаблон:Книга
  47. Шаблон:Cite web
  48. Шаблон:Книга
  49. Шаблон:Cite web
  50. Шаблон:Книга
  51. Шаблон:Книга
  52. Шаблон:Cite web
  53. Шаблон:Cite web
  54. Шаблон:Книга
  55. Шаблон:Cite web
  56. Шаблон:Cite web
  57. Шаблон:Cite web
  58. Шаблон:Cite web
  59. Шаблон:Cite web
  60. Шаблон:Cite web
  61. Шаблон:Cite web
  62. Шаблон:Cite web
  63. Шаблон:Cite web
  64. Шаблон:Статья
  65. Шаблон:Cite web
  66. Шаблон:Cite web
  67. Шаблон:Cite web
  68. Шаблон:Cite web
  69. Шаблон:Cite web