XFree86 explained

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.

Usage

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]

Architecture

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

History

Early history and naming

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.

Rise with Linux

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]

2002: Growing dissent within the project

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]

2003: The fork and the disbanding of the Core Team

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]

2004: Licensing controversy

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.

Forks of XFree86

Xwin

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

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]

X.Org

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.

Release history

VersionRelease dateMost 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.

See also

References

Notes

External links

Notes and References

  1. http://www.mail-archive.com/cvs-commit@xfree86.org/maillist.html cvs-commit
  2. Constantine A. Murenin . May 2008 . Conference Reports, BSDCan: The BSD Conference, X.Org . . . August 2008 . 33 . 4 . 114 . 1044-6397 .
  3. Web site: xsrc/xfree/xc/ . . 2015-07-23 . 2019-04-18 .
  4. matthew green . 2015-07-23 . CVS commit: xsrc/xfree/xc . source-changes . . "remove obsolete XFree86 sources.".
  5. Web site: [//www.netbsd.org/releases/formal-5/NetBSD-5.0.html Announcing NetBSD 5.0].
  6. Web site: [//www.netbsd.org/releases/formal-8/NetBSD-8.0.html Announcing NetBSD 8.0 (July 17, 2018) ]. . "XFree86 has been removed, as all architectures have switched to XOrg." .
  7. Web site: Mitchell . Robert L. . 4 Feb 2002 . Q&A: The X Factor . dead . https://web.archive.org/web/20240612224505/https://www.computerworld.com/article/1363581/q-a-the-x-factor.html . 12 Jun 2024 . 12 Jun 2024 . Computerworld.
  8. http://slashdot.org/article.pl?sid=99/12/01/1342251&tid=104 XFree86 joins X.Org as Honorary Member
  9. http://xfree86.org/pipermail/forum/2003-April/003127.html (forum) Another teleconference partial edited transcript
  10. http://www.xfree86.org/pipermail/forum/2003-March/002018.html (forum) Keith Packard issue
  11. http://www.advogato.org/person/mharris/ Advogato: Blog for mharris
  12. http://xfree86.org/pipermail/forum/2003-March/000125.html (forum) Suggestion for XFree86
  13. http://cvsweb.xfree86.org/cvsweb/xc/doc/specs/Xfixes/Attic/ CVS commit: Finish removing XFIXES
  14. http://xfree86.org/pipermail/forum/2003-March/000128.html (forum) Some perspective from the cheap seats ...
  15. http://www.xfree86.org/pipermail/forum/2003-March/001997.html (forum) Invitation for public discussion about the future of X
  16. http://www.xfree86.org/pipermail/forum/2003-March/002165.html (forum) A Call For Open Governance Of X Development
  17. http://www.xfree86.org/pipermail/forum/2003-April/003016.html (forum) Notes from a teleconference held 2003-3-27
  18. https://web.archive.org/web/20031012063438/http://xwin.org/index.php?page=1 (Archived) XWin front page
  19. https://web.archive.org/web/20040128225716/http://www.xwin.org/bin/view/Software/xorg (Archived) X.org software page at xwin.org
  20. http://www.mail-archive.com/devel%40xfree86.org/msg04639.html (devel) Core Team disbands
  21. Web site: XFree86 Licenses. 2008-05-02. XFree86 Project, Inc.. 2005-01-01.
  22. Web site: Announcement: Modification to the base XFree86 license . 2007-07-12 . Dawes . David . 2004-01-29 . XFree86 Project . dead . https://web.archive.org/web/20070930185719/http://www.xfree86.org/pipermail/forum/2004-January/001892.html . 2007-09-30 .
  23. Web site: XFree86 4.4: List of Rejecting Distributors Grows . 2007-07-12 . 2004-02-18 . .
  24. Web site: Various Licenses and Comments about Them . 2013-03-12 . .
  25. Web site: XFree86 Licenses . 2007-07-12 . 2005-01-01 . XFree86 Project .
  26. Web site: The Cautionary Tale of XFree86 . 2007-07-12 . Wheeler . David A. . 2007-07-06 . 2004-09-01 . https://web.archive.org/web/20040901083643/http://www.dwheeler.com/essays/gpl-compatible.html#xfree86 . dead .
  27. Marc Aurele La France: Is there ever going to be a new version of xfree86 XFree86-Forum, December 3rd. 2011
  28. https://web.archive.org/web/20031012063438/http://xwin.org/index.php?page=5 (Archived) XWin front page
  29. http://developers.slashdot.org/story/03/04/13/0253224/Keith-Packards-Xfree86-Fork-Officially-Started Keith Packard's Xfree86 Fork Officially Started
  30. xwin.org goals by Keith Packard, 12 Apr 2003.Web site: Xwin.org - xwin.org goals . September 13, 2012 . unfit . https://web.archive.org/web/20031206063052/http://xwin.org/article.php?story=2003041221350542 . December 6, 2003 .
  31. http://www.osnews.com/comments/5105 Screenshots from freedesktop.org's New X Server
  32. http://developers.slashdot.org/story/03/08/17/160254/XFree86-Fork-Gets-a-Name-Website: XFree86 Fork Gets a Name, Website
  33. https://lwn.net/Articles/45434/ The Xouvert Project
  34. https://web.archive.org/web/20040328002044/http://www.xouvert.org/ (archived) Xouvert front page
  35. Web site: Release Notes for XFree86[tm] 4.0]. XFree86 Project. 7 March 2000. 16 September 2018.
  36. Web site: Release Notes for XFree86[tm] 4.0 - Introduction]. XFree86 Project. 7 March 2000. 16 September 2018.
  37. http://www.spinics.net/lists/rh-xf/msg01387.html XFree86 4.4.0 RC2 (fwd)