XFree86 | |
Logo Size: | 128px |
Developer: | The XFree86 Project, Inc. |
Released: | (as X386) |
Discontinued: | yes |
Latest Release Version: | 4.8.0 |
Programming Language: | C |
Operating System: | Cross-platform |
Language: | Various |
Genre: | Display server |
License: | XFree86 License 1.1 |
XFree86 is an implementation of the X Window System. It was originally written for Unix-like operating systems on IBM PC compatibles and was available for many other operating systems and platforms. It is free and open source software under the XFree86 License version 1.1. It was developed by the XFree86 Project, Inc. The lead developer was David Dawes. The last released version was 4.8.0, released December 2008. The last XFree86 CVS commit was made on May 18, 2009;[1] the project was confirmed dormant in December 2011.
For most of the 1990s and early 2000s, the project was the source of most innovation in X and was the de facto steward of X development. Until early 2004, it was almost universal on Linux and the BSDs.
In February 2004, with version 4.4.0, The XFree86 Project began distributing new code with a copyright license that the Free Software Foundation considered GPL incompatible. Most open source operating systems using XFree86 found this unacceptable and moved to a fork from before the license change. The first fork was the abortive Xouvert, but X.Org Server soon became dominant. Most XFree86 developers also moved to X.Org.
While XFree86 was widely used by most Unix-like computer operating systems before its license change with version 4.4.0, it has since then been superseded by X.org and is used rarely nowadays.[2] The last remaining operating system distribution to use it was NetBSD, which shipped some platforms with 4.5.0 by default until removing it as obsolete in 2015.[3] [4] and later releases use X.org by default on various ports (including i386 and amd64), and X.org is available through NetBSD pkgsrc for architectures for which XFree86 remains the default because of better support.[5]
, the netbsd-7
branch and release were the last to potentially contain XFree86, and XFree86 was completely removed before netbsd-8
branch and release in 2018.[6]
The XFree86 server communicates with the host operating system's kernel to drive input and output devices, with the exception of graphics cards. These are generally managed directly by XFree86, so it includes its own drivers for all graphic cards a user might have. Some cards are supported by vendors themselves via binary-only drivers.
Since version 4.0, XFree86 has supported certain accelerated 3D graphics cards via the GLX and DRI extensions. Version 4.0 also moved to a new driver model, from one X server binary per driver to a unique X server capable of loading several drivers at a time.
Because the server usually needs low level access to graphics hardware, on many configurations it needs to run as the superuser, or a user with UID 0. However, on some systems and configurations it is possible to run the server as a normal user.
It is also possible to use XFree86 in a framebuffer device, which in turn uses a kernel graphics card driver.
On a typical POSIX-system, the directory /etc/X11 includes the configuration files. The basic configuration file is /etc/X11/XF86Config (or XF86Config-4) that includes variables about the screen (monitor), keyboard and graphics card. The program xf86config is often used, although xf86cfg also comes with the XFree86 server and is friendlier. Many Linux distributions used to include a configuration tool that was easier to use (such as Debian's debconf) or autodetected most (if not all) settings (such as Red Hat Linux and Fedora's Anaconda, SuSE's YaST and Mandrake Linux).
The project began in 1992 when David Wexelblat, Glenn Lai, David Dawes and Jim Tsillas joined forces addressing bugs in the source code of the X386 X display server (written by Thomas Roell), as contributed to X11R5. This version was initially called X386 1.2E. As newer versions of the (originally freeware) X386 were being sold under a proprietary software license by SGCS (of which Roell was a partner), confusion existed between the projects. After discussion, the project was renamed XFree86, as a pun (compare X-three-eighty-six to X-free-eighty-six). Roell has continued to sell proprietary X servers, most recently under the name Accelerated-X.
As Linux grew in popularity, XFree86 rose with it, as the main X project with drivers for PC video cards.
By the late 1990s, official X development was moribund.[7] Most technical advancement was happening in the XFree86 project. In 1999, XFree86 was sponsored onto X.Org (the official industry consortium) by various hardware companies interested in its use with Linux and its status as the most popular version of X.[8]
By 2002, while Linux's popularity, and hence the installed base of X, surged, X.Org was all but inactive; active development was largely carried out by XFree86.[9] However, there was considerable dissent within XFree86.
XFree86 used to have a Core Team which was made up of experienced developers, selected by other Core Team members for their merits. Only the members of this Core Team were allowed to commit to CVS. This was perceived as far too cathedral-like in its development model: developers were unable to get commit rights quickly and vendors ended up maintaining extensive patches.[10] [11]
A key event was Keith Packard losing his commit rights. Hours before the feature freeze window for XFree86 4.3.0 started, he committed the XFIXES extension (which he developed himself), without prior discussion or without review within the Core Team. The Core Team decided to remove Keith's commit access, but without removing him from the Core Team itself, and the XFIXES extension was backed out six weeks later.[12] [13]
In March 2003, the Core Team claimed that Packard had been trying to fork the XFree86 project by working inside the project while trying to attract core developers to a new X Server project of his own making. Packard denied this had been his aim, but some emails were provided as evidence otherwise.[14] Keith Packard was subsequently expelled from the Core Team.[15] [16] [17]
A short time later, Packard created xwin.org, which mainly served as a meeting point for cultivating the XFree86 fork.[18] The rest of the year, many of the developers that were still active at XFree86 went over to the project that was being set up at the freedesktop.org and X.org domains.[19]
By the end of the year, due to dwindling active membership and limited remaining development capacity, the XFree86 Core Team voted to disband itself.[20]
Versions of XFree86 up to and including some release candidates for 4.4.0 were under the MIT License, a permissive, non-copyleft free software license. In February 2004, XFree86 4.4 was released with a change to the XFree86 license, by adding a credit clause,[21] similar to that in the original BSD license,[22] but broader in scope. The newer terms are referred to as the XFree86 License 1.1.Many projects relying on XFree86 found the new license unacceptable,[23] and the Free Software Foundation considers it incompatible with the version 2 of the GNU General Public License, though compatible with version 3.[24] The XFree86 Project states that the license is "as GPL compatible as any and all previous versions were", but does not mention which version or versions of the GPL this is valid for.[25]
Some projects made releases (notably OpenBSD 3.5 and 3.6, and Debian 3.1 "Sarge") based on XFree86 version 4.4 RC2, the last version under the old license. Most operating systems incorporating XFree86 (including later versions of OpenBSD and Debian) migrated to the X.Org Server.[26]
The last code commit was in 2009; the project was confirmed dormant in 2011[27] and the website was last updated in 2014, commemorating the then-22nd anniversary.
Shortly after he was expelled from the XFree86 Core Team, Keith Packard started setting up xwin.org.[28] While this was claimed to be the fork of XFree86,[29] Keith Packard later refined this to "a forum for community participation in X".[30] XWin saw a lot of activity in the first two months after the announcements, but most of the activity was happening behind the scenes, and Keith moved his own development to freedesktop.org.[31]
Xouvert was later also hailed as the first XFree86 fork in August 2003.[32] Even though releases were announced for October 2003 and April 2004,[33] no releases were made. The last status change was made in March 2004 and it was communicated that there were delays in setting up a revision control system.[34]
See main article: X.Org Server.
The X.Org Server became the official reference implementation of X11. The first version, X11R6.7.0, was forked from XFree86 version 4.4 RC2 to avoid the XFree86 license changes, with X11R6.6 changes merged in. Version X11R6.8 added many new extensions, drivers and fixes. It is hosted by and works closely with corporate-sponsored freedesktop.org.
Most of the open-source Unix-like operating systems have adopted the X.Org Server in place of XFree86, and most of the XFree86 developers have moved to X.Org.
Version | Release date | Most important changes | |
---|---|---|---|
First X386 version by Thomas Roell, based on X11R4. | |||
Included with X11R5. | |||
First pre-XFree86 code by eventual team members. | |||
First version named "XFree86". | |||
Last version based on X11R5. | |||
Release for X11R6. | |||
XFree86 Acceleration Architecture (XAA) | |||
Last 3.x version. | |||
[35] | Complete new architecture.[36] X11R6.4 included. | ||
XRender | |||
[37] | Forked to X.Org Server | ||
First version under XFree86 License 1.1. | |||