POSIX ((PortableOperatingSystemInterface) et leX exprime l'héritage UNIX) est une famille denormes techniques définie depuis1988 par l'Institute of Electrical and Electronics Engineers (IEEE), et formellement désignée parIEEE 1003. Ces normes ont émergé d'un projet de standardisation desinterfaces de programmation deslogiciels destinés à fonctionner sur les variantes dusystème d'exploitationUNIX.
Le termePOSIX a été suggéré parRichard Stallman, qui faisait partie du comité qui écrivit la première version de la norme. L'IEEE choisit de le retenir car il était facilement mémorisable[1],[2].
POSIX spécifie, dans dix-sept documents[3] différents, lesinterfaces utilisateurs et lesinterfaces logicielles, la ligne de commande standard et l'interface descript qu'est leBourne shell[4]. Les autres commandes, services et utilitaires comprennentawk,echo,ed, et des centaines d'autres. Les services d'entrées/sorties de base (fichiers,terminaux,réseau) doivent être présents ; le système doit supportercertains attributs spécifiques pour les fichiers. POSIX définit aussi uneinterface de programmation standard, et celle-ci est prise en charge par la plupart des systèmes d'exploitation récents.
Une suite de tests pour POSIX accompagne le standard. Elle est appeléePCTS (POSIX Conformance Test Suite, suite de tests pour la conformité POSIX).
Comme l'IEEE vend très cher la documentation POSIX et ne permet pas sa publication surInternet, certains se sont tournés vers le standardSingle UNIX Specification. En effet, ce dernier est ouvert, accepte les propositions de quiconque veut y contribuer, et est disponible gratuitement sur Internet. Ce travail remonte au début de1998, lorsqu'un groupe de travail commun, l'Austin Group (en), a commencé à développer un standard qui est devenu laSingle UNIX Specification Version 3.
Bien qu'il soit principalement implémenté sur des systèmes de type UNIX, le standard POSIX peut être utilisé par n'importe quel autre système d'exploitation. Par exemple, MicrosoftWindows NT 3.x et4 sont certifiés conformes à POSIX.1:1990, ce qui est suffisant pour des applications POSIX relativement simples. Cependant, des programmes plus complexes ont besoin d'une compatibilité plus large. Des logiciels supplémentaires tels queServices for UNIX ouCygwin peuvent apporter à Windows ce niveau de compatibilité.UWIN offre une compatibilité POSIX[5], y compris sur les chemins de fichiers.
Le consortiumLinux Standard Base publie plusieurs extensions et des standards de fait pour les systèmes d'exploitation basés surLinux. Ils sont peu susceptibles d'être repris par les autres systèmes de type UNIX, qui respectent d'autres standards plus anciens, bien que dans de nombreux cas laLinux Standard Base reprenne ces derniers.
Une grande partie desAPI de POSIX a été définie à une époque où l'adressage des machines se faisait sur 32 bits au maximum. Pour préserver la compatibilité entre les différents systèmes, on recommandait à l'époque de ne pas dépasser la taille de 2 Go pour les fichiers, ceci dans le cas où le type standard « size_t » défini dans la bibliothèque C standard « stddef.h » était défini comme un entier non signé de 31 bits (la valeur de retour de certaines fonctions étant signée, car utilisant le type signé POSIX « ssize_t », et renvoyant un nombre négatif en cas d'erreur). En effet, ce symbole était utilisé par la plupart des définitions d'interface d'accès aux fichiers du langage C (IEEE std 1003.1-1990). Actuellement, cette limite n'est souvent plus d'actualité, puisque que les systèmes utilisent pour « size_t » le plus souvent un type non signé d'au moins 63 bits.
Actuellement, la documentation de POSIX est divisée en trois parties :
- les API (permet de définir la manière dont un composant informatique peut communiquer avec un autre) de base (qui comprennent des extensions à POSIX.1, les servicestemps réel, lesprocessus légers, les extensions temps réel, l'interface de sécurité, l'accès aux fichiers par le réseau, et lescommunications inter-processus par le réseau) ;
- les commandes et utilitaires POSIX (extensions de portabilité des utilisateurs, corrections et extensions, utilitaire de protection et de contrôle, utilitaires pour le traitement par lots) ;
- test de conformité à POSIX.
La norme POSIX a connu plusieurs versions :
- POSIX.1, Services centraux (inclut le standardANSI C) (IEEE Std 1003.1-1988) porte sur :
- POSIX.1b, extension pour letemps réel (IEEE Std 1003.1b-1993) :
- POSIX.1c, extension sur lesprocessus légers (les threads) (IEEE Std 1003.1c-1995) :
- la création, le contrôle et la suppression des threads
- l'ordonnancement des threads
- la synchronisation des threads
- l'interception des signaux (Signal Handling)
Certains systèmes POSIX peuvent éventuellement présenter des limitations qui donnent aux utilisateurs le sentiment d'être exposés à des bugs connus et avérés. C'est notamment le cas dessecondes intercalaires[7] ou de la non prise en compte de la possible présence de l'indicateur d'ordre des octetsUTF-8 dans leshebang.
Lavariable d'environnement POSIXLY_CORRECT permet d'indiquer si une commande doit se conformer à POSIX ou non. Les commandes d'administration ne sont pas concernées par cette variable.
Plusieurs dizaines de commandes adaptent leur fonctionnement en fonction de la valeur de POSIXLY_CORRECT ; les exemples les plus typiques sont les commandesgrep etfind, mais il en existe bien d'autres : apropos, at[8], df[9], …, rgrep,setfacl, etc.
Cette variable d'environnement sert par exemple à définir si une commande doit utiliser le format de donnée conforme à POSIX ou celui qui est utilisé par défaut par cette commande.
/Unifix Linux 2.0 de la société allemande Unifix et Linux-FT de Lasermoon sont certifiés POSIX.1FIPS 151-2[10],[11],[12]. Noyau 1.2.13[13]
Le siteDebian explique que« [...] la certification POSIX.1 (et FIPS 151-2) est très chère [et] rend peu probable l'obtention par Debian d'une certification officielle de conformité »[10].
Sur les autres projets Wikimedia :
- LSB : ce projet est basé sur POSIX et a pour but de standardiser la structure interne des systèmes d'exploitation basés surGNU/Linux.
- unistd.h : Cet include indique la version de la norme Posix à utiliser pour la compilation
- Sanos