Jump to content

POSIX

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Arny (talk | contribs) at 10:56, 3 April 2019 (External links: dead link). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

The Portable Operating System Interface (POSIX)[1] is a family of standards specified by the IEEE Computer Society for maintaining compatibility between operating systems. POSIX defines the application programming interface (API), along with command line shells and utility interfaces, for software compatibility with variants of Unix and other operating systems.[2][3]

Name

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 international standard name is ISO/IEC 9945.

The standards emerged from a project that began circa 1985. Richard Stallman suggested the name POSIX to the IEEE instead of former IEEE-IX. The committee found it more easily pronounceable and memorable, and thus adopted it.[2][4]

Overview

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.).[5] The standardized user command line and scripting interface were based on the UNIX System V shell.[6] 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).

As of 2014, 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.[7]

The development of the POSIX standard takes place in the Austin Group (a joint working group linking the IEEE, The Open Group and the ISO/IEC JTC 1 organizations).

Versions

Parts before 1997

Before 1997, POSIX comprised several standards:

Versions after 1997

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

POSIX.1-2001 (or IEEE Std 1003.1-2001) equates to the Single UNIX Specification version 3.[9]

This standard consisted of:

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

POSIX.1-2004 (with two TCs)

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).[10] Its contents are available on the web.[11]

POSIX.1-2008 (with two TCs)

Base Specifications, Issue 7 (or IEEE Std 1003.1-2008, 2016 Edition) is similar to the current 2017 version (as of 22.7.2018).[12][13] A free online copy may still be available.[12]

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

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 and is, as of 22.7.2018, the current standard.

Controversies

512- vs 1024-byte blocks

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 POSIX_ME_HARDER was introduced to allow the user to force the standards-compliant behaviour.[14] The variable name was later changed to POSIXLY_CORRECT.[15] This variable is now also used for a number of other behaviour quirks, where "POSIX and common sense disagree".[citation needed]

POSIX-oriented operating systems

Depending upon the degree of compliance with the standards, one can classify operating systems as fully or partly POSIX compatible. Certified products can be found at the IEEE's website.[16]

POSIX-certified

Some 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.[17]

Mostly POSIX-compliant

The following, while not officially certified as POSIX compatible, comply in large part:

POSIX for Microsoft Windows

  • Cygwin provides a largely POSIX-compliant development and run-time environment for Microsoft Windows.
  • MinGW, a fork of Cygwin, provides a less POSIX-compliant development environment and supports compatible C-programmed applications via Msvcrt, Microsoft's old Visual C runtime library.
  • Microsoft POSIX subsystem, an optional Windows subsystem included in Windows NT-based operating systems up to Windows 2000. POSIX-1 as it stood in 1990 revision, without threads or sockets.
  • Interix, originally OpenNT by Softway Systems, Inc., is an upgrade and replacement for Microsoft POSIX subsystem that was purchased by Microsoft in 1999. It was initially marketed as a stand-alone add-on product and then later included it as a component in Windows Services for UNIX (SFU) and finally incorporated it as a component in Windows Server 2003 R2 and later Windows OS releases under the name "Subsystem for UNIX-based Applications" (SUA); later made deprecated in 2012 (Windows 8)[32] and dropped in 2013 (2012 R2, 8.1). It enables full POSIX compliance for certain Microsoft Windows products.[citation needed]
  • Windows Subsystem for Linux is a compatibility layer for running Linux binary executables natively on Windows 10 using an Ubuntu image, acting as an upgrade and replacement for Windows Services for UNIX. It was released in beta in April 2016.
  • UWIN from AT&T Research implements a POSIX layer on top of the Win32 APIs.
  • MKS Toolkit, originally created for MS-DOS, is a software package produced and maintained by MKS Inc. that provides a Unix-like environment for scripting, connectivity and porting Unix and Linux software to both 32- and 64-bit Microsoft Windows systems. A subset of it was included in the first release of Windows Services for UNIX (SFU) in 1998.[33]
  • Windows C Runtime Library and Windows Sockets API implement commonly used POSIX API functions for file, time, environment, and socket access,[34] although the support remains largely incomplete and not fully interoperable with POSIX-compliant implementations.[35][36][discuss]

POSIX for OS/2

Mostly POSIX compliant environments for OS/2:

  • emx+gcc – largely POSIX compliant

POSIX for DOS

Partially POSIX compliant environments for DOS include:

  • emx+gcc – largely POSIX compliant
  • DJGPP – partially POSIX compliant
  • DR-DOS multitasking core via EMM386 /MULTI – a POSIX threads frontend API extension is available

Compliant via compatibility feature

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 noncompliant.

See also

References

  1. ^ "POSIX.1 FAQ". The Open Group. 5 October 2011.
  2. ^ a b "POSIX 1003.1 FAQ Version 1.12". 2 February 2006. Retrieved 16 July 2006.
  3. ^ "POSIX". Standards. IEEE.
  4. ^ "The origin of the name POSIX". 2011. Retrieved 28 September 2013.
  5. ^ PASC Status (including POSIX) (Report). IEEE Computer Society. 4 December 2003. Retrieved 1 March 2015.
  6. ^ "Shell Command Language - The Open Group Base Specifications Issue 7, 2013 Edition".
  7. ^ "POSIX". The Open Group.
  8. ^ "librt(3LIB)". docs.oracle.com. man pages section 3: Library Interfaces and Headers. Oracle Corporation. 4 August 1998. Retrieved 18 February 2016. librt, libposix4- POSIX.1b Realtime Extensions library [...] librt is the preferred name for this library. The name libposix4 is maintained for backward compatibility and should be avoided. Functions in this library provide most of the interfaces specified by the POSIX.1b Realtime Extension.
  9. ^ "The Open Group announces completion of the joint revision to POSIX and the Single UNIX Specification" (Press release). The Open Group. 30 January 2002. Retrieved 26 July 2009.
  10. ^ "IEEE Std 1003.1" (2004 ed.). Unix.org. Retrieved 26 July 2009Template:Inconsistent citations{{cite web}}: CS1 maint: postscript (link)
  11. ^ "IEEE Std 1003.1" (2004 ed.). The Open GroupTemplate:Inconsistent citations {{cite journal}}: Cite journal requires |journal= (help)CS1 maint: postscript (link).
  12. ^ a b "Base Specifications, Issue 7, 2016 Edition". The Open Group. Retrieved 18 December 2014.
  13. ^ "The Austin Common Standards Revision Group". The Open Group. Retrieved 1 March 2016.
  14. ^ "Announce" (Google Groups replica). GNUTemplate:Inconsistent citations {{cite journal}}: Cite journal requires |journal= (help)CS1 maint: postscript (link).
  15. ^ "GNU Coding Standards". GNU.
  16. ^ "POSIX Certification". IEEE.
  17. ^ "POSIX Certified by IEEE and The Open Group - Program Guide".
  18. ^ "IBM". The Open Group. Retrieved 26 January 2014.
  19. ^ a b "Hewlett-Packard". The Open Group. Retrieved 26 January 2014.
  20. ^ "Silicon Graphics, Inc". The Open Group. Retrieved 26 January 2014.
  21. ^ "Huawei Technology Co., Ltd". The Open Group. Retrieved 26 May 2017.
  22. ^ "The Open Brand - Register of Certified Products". Register of Open Branded Products. The Open Group. Retrieved 20 May 2015.
  23. ^ "Apple Inc". Register of Open Branded Products. The Open Group. Retrieved 20 May 2015.
  24. ^ "Oracle Corporation". The Open Group. Retrieved 26 January 2014.
  25. ^ "UnixWare ® 7.1.3 and later". The Open Group. 16 May 2003.
  26. ^ "QNX Achieves New POSIX Certification". QNX. 8 April 2008. Retrieved 16 January 2016.
  27. ^ "Inspur Co., Ltd". The Open Group. Retrieved 26 May 2017.
  28. ^ "POSIX Certification Register". get.posixcertified.ieee.org. Retrieved 9 March 2018.
  29. ^ Schweik. "POSIX utilities". FreeBSD.
  30. ^ Enterprise, I. D. G. (7 November 1994). Computerworld. IDG Enterprise.
  31. ^ Solter, Nicholas A.; Jelinek, Jerry; Miner, David (21 March 2011). OpenSolaris Bible. John Wiley & Sons. ISBN 9781118080313.
  32. ^ Features Removed or Deprecated in Windows Server 2012
  33. ^ Windows NT Services for UNIX Add-On Pack for NT 4; see also the November '98 press release for MKS toolkit 6.1, also archived elsewhere
  34. ^ "MSDN Library: Deprecated CRT Functions". Microsoft. Retrieved 8 October 2015.
  35. ^ "MSDN Library: Porting Socket Applications to Winsock". Microsoft. Retrieved 8 October 2015.
  36. ^ "Winsock Programmer's FAQ Articles: BSD Sockets Compatibility". Warren Young. 31 August 2015. Retrieved 8 October 2015.
  37. ^ "APE — ANSI/POSIX Environment". Plan 9. Bell Labs.
  38. ^ "POSIX Compatibility". MS Windows NT Workstation Resource Kit. Microsoft.