Jump to content

POSIX: Difference between revisions

From Niidae Wiki
imported>Adrian Kulisch
m Fix Link to C17 in Introduction
 
(No difference)

Latest revision as of 16:32, 28 April 2025

Template:Short description Template:Distinguish Template:Use dmy dates Template:Infobox technology standard The Portable Operating System Interface (POSIX; Template:IPAc-en<ref name="FAQ">Template:Cite web</ref>) is a family of standards specified by the IEEE Computer Society for maintaining compatibility between operating systems.<ref name="FAQ"/> POSIX defines application programming interfaces (APIs), along with command line shells and utility interfaces, for software compatibility (portability) with variants of Unix and other operating systems.<ref name="FAQ"/><ref name="IET">Template:Cite web</ref> POSIX is also a trademark of the IEEE.<ref name="FAQ"/> POSIX is intended to be used by both application and system developers.<ref>Template:Cite web</ref> As of POSIX 2024, the standard is aligned with the C17 language standard.

Name

[edit]

Originally, the name "POSIX" referred to IEEE Std 1003.1-1988, released in 1988. The family of POSIX standards is formally designated as IEEE 1003 and the ISO/IEC standard number is ISO/IEC 9945.

The standards emerged from a project that began in 1984 building on work from related activity in the /usr/group association.<ref>Template:Cite web</ref> Richard Stallman suggested the name POSIX to the IEEE<ref>Template:Cite web</ref><ref>Template:Cite web</ref> instead of the former IEEE-IX.<ref>Template:Cite journal</ref> The committee found it more easily pronounceable and memorable, and thus adopted it.Template:Cn

Overview

[edit]

Unix was selected as the basis for a standard system interface partly because it was "manufacturer-neutral". However, several major versions of Unix existed—so there was a need to develop a common-denominator system. The POSIX specifications for Unix-like operating systems originally consisted of a single document for the core programming interface, but eventually grew to 19 separate documents (POSIX.1, POSIX.2, etc.).<ref>Template:Cite report</ref> The standardized user command line and scripting interface were based on the UNIX System V shell.<ref>Template:Cite web</ref> Many user-level programs, services, and utilities (including awk, echo, ed) were also standardized, along with required program-level services (including basic I/O: file, terminal, and network). POSIX also defines a standard threading library API which is supported by most modern operating systems. In 2008, most parts of POSIX were combined into a single standard (IEEE Std 1003.1-2008, also known as POSIX.1-2008).

Template:As of, POSIX documentation is divided into two parts:

  • POSIX.1, 2013 Edition: POSIX Base Definitions, System Interfaces, and Commands and Utilities (which include POSIX.1, extensions for POSIX.1, Real-time Services, Threads Interface, Real-time Extensions, Security Interface, Network File Access and Network Process-to-Process Communications, User Portability Extensions, Corrections and Extensions, Protection and Control Utilities and Batch System Utilities. This is POSIX 1003.1-2008 with Technical Corrigendum 1.)
  • POSIX Conformance Testing: A test suite for POSIX accompanies the standard: VSX-PCTS or the VSX POSIX Conformance Test Suite.<ref name = "VSX-PCTS">Template:Cite web</ref>

The development of the POSIX standard takes place in the Austin Group (a joint working group among the IEEE, The Open Group, and the ISO/IEC JTC 1/SC 22/WG 15).

Versions

[edit]

Parts before 1997

[edit]

Before 1997, POSIX comprised several standards:

Template:Cite web</ref>

Versions after 1997

[edit]

After 1997, the Austin Group developed the POSIX revisions. The specifications are known under the name Single UNIX Specification, before they become a POSIX standard when formally approved by the ISO.

POSIX.1-2001 (with two TCs)

[edit]

POSIX.1-2001 (or IEEE Std 1003.1-2001) equates to the Single UNIX Specification, version 3 minus X/Open Curses.<ref>Template:Cite web</ref>

This standard consisted of:

  • the Base Definitions, Issue 6,
  • the System Interfaces and Headers, Issue 6,
  • the Commands and Utilities, Issue 6.

IEEE Std 1003.1-2004 involved a minor update of POSIX.1-2001. It incorporated two minor updates or errata referred to as Technical Corrigenda (TCs).<ref>Template:Cite web</ref> Its contents are available on the web.<ref>Template:Cite web.</ref>

POSIX.1-2008 (with two TCs)

[edit]

Base Specifications, Issue 7 (or IEEE Std 1003.1-2008, 2016 Edition).<ref name=AustinGroup>Template:Cite web</ref>

This standard consists of:

  • the Base Definitions, Issue 7,
  • the System Interfaces and Headers, Issue 7,
  • the Commands and Utilities, Issue 7,
  • the Rationale volume.

POSIX.1-2017

[edit]

IEEE Std 1003.1-2017 (Revision of IEEE Std 1003.1-2008) - IEEE Standard for Information Technology—Portable Operating System Interface (POSIX(R)) Base Specifications, Issue 7 is available from either The Open Group or IEEE. It is technically identical to POSIX.1-2008 with Technical Corrigenda 1 and 2 applied. Its contents are available on the web.<ref>Template:Cite web</ref>

POSIX.1-2024

[edit]

IEEE Std 1003.1-2024 - IEEE Standard for Information Technology—Portable Operating System Interface (POSIX(R)) Base Specifications, Issue 8 was published on 14 June 2024.<ref name=AustinGroup/> Its contents are available on the web.<ref>Template:Cite web.</ref>

Controversies

[edit]

512- vs 1024-byte blocks

[edit]

Template:Primary sources POSIX mandates 512-byte default block sizes for the df and du utilities, reflecting the typical size of blocks on disks. When Richard Stallman and the GNU team were implementing POSIX for the GNU operating system, they objected to this on the grounds that most people think in terms of 1024 byte (or 1 KiB) blocks. The environment variable Template:Tt was introduced to allow the user to force the standards-compliant behaviour.<ref>Template:Cite newsgroup</ref> The variable name was later changed to Template:Tt.<ref>Template:Cite web</ref> This variable is now also used for a number of other behaviour quirks.

POSIX-oriented operating systems

[edit]

Depending upon the degree of compliance with the standards, one can classify operating systems as fully or partly POSIX compatible.

POSIX-certified

[edit]

Current versions of the following operating systems have been certified to conform to one or more of the various POSIX standards. This means that they passed the automated conformance tests<ref name="achieve_status">Template:Cite web</ref> and their certification has not expired and the operating system has not been discontinued.<ref name="renew_certification">Template:Cite web</ref><ref>Template:Cite web</ref> Template:Div col

Template:Div col end

Formerly POSIX-certified

[edit]

Some versions of the following operating systems had been certified to conform to one or more of the various POSIX standards. This means that they passed the automated conformance tests. The certification has expired and some of the operating systems have been discontinued.<ref name="renew_certification" /> Template:Div col

Template:Div col end

Mostly POSIX-compliant

[edit]

The following are not certified as POSIX compliant yet comply in large part: Template:Div col

Template:Div col end

POSIX for Microsoft Windows

[edit]

POSIX for OS/2

[edit]

Mostly POSIX compliant environments for OS/2:

  • emx+gcc – largely POSIX compliant

POSIX for DOS

[edit]

Partially POSIX compliant environments for DOS include:

  • emx+gcc – largely POSIX compliant
  • DJGPP – partially POSIX compliant
  • DR-DOS multitasking core via Template:Mono – a POSIX threads frontend API extension is available

Template:Anchor

Compliant via compatibility layer

[edit]

The following are not officially certified as POSIX compatible, but they conform in large part to the standards by implementing POSIX support via some sort of compatibility feature (usually translation libraries, or a layer atop the kernel). Without these features, they are usually non-compliant.

See also

[edit]

References

[edit]

Template:Reflist

[edit]

Template:Commons category

Template:Open Group standards Template:IEEE standards Template:ISO standards Template:List of International Electrotechnical Commission standards Template:Inter-process communication Template:Authority control