Revision as of 13:15, 13 February 2011 editThumperward (talk | contribs)Administrators122,813 edits restoring updated version. if you don't like the referencing style then change it back, rather than simply stabbing the undo button← Previous edit | Revision as of 13:26, 13 February 2011 edit undoThumperward (talk | contribs)Administrators122,813 edits move quote into ref, remove tag again per previous user's edit summaryNext edit → | ||
Line 1: | Line 1: | ||
{{self-published|date=February 2011}} | |||
{{ infobox software | {{ infobox software | ||
| name = Wayland | | name = Wayland | ||
Line 59: | Line 57: | ||
Wayland consists of a protocol (largely complete) and some demonstration code. Currently, the Wayland code uses ], rather than the more traditional (in desktops) ].<ref>{{ cite news | url = http://www.phoronix.com/scan.php?page=news_item&px=ODMyNA | title = Wayland Meets Some Summer Love w/ New Changes | author = Michael Larabel |date= 2010-06-06 |publisher=]}}</ref> "Longer term we'll need an answer for apps that need full , but the problem is that libGL pulls in GLX and all the X dependencies."<ref>{{ cite web | url = http://lists.freedesktop.org/archives/wayland-devel/2010-December/000330.html | title = Blender3D & cursor clamping. | date = 2010-12-09 | author = Kristian Høgsberg}}</ref> The project is also developing versions of ] and ] that render to Wayland instead of to X. Most applications are expected to gain support for Wayland through one of these libraries without modification to the application. | Wayland consists of a protocol (largely complete) and some demonstration code. Currently, the Wayland code uses ], rather than the more traditional (in desktops) ].<ref>{{ cite news | url = http://www.phoronix.com/scan.php?page=news_item&px=ODMyNA | title = Wayland Meets Some Summer Love w/ New Changes | author = Michael Larabel |date= 2010-06-06 |publisher=]}}</ref> "Longer term we'll need an answer for apps that need full , but the problem is that libGL pulls in GLX and all the X dependencies."<ref>{{ cite web | url = http://lists.freedesktop.org/archives/wayland-devel/2010-December/000330.html | title = Blender3D & cursor clamping. | date = 2010-12-09 | author = Kristian Høgsberg}}</ref> The project is also developing versions of ] and ] that render to Wayland instead of to X. Most applications are expected to gain support for Wayland through one of these libraries without modification to the application. | ||
⚫ | Wayland does not currently provide ], but it may in the future.<ref>{{ cite web | url = http://lists.freedesktop.org/archives/wayland-devel/2010-November/000097.html | title = Network transparency argument | author = Kristian Høgsberg |date=2010-11-09 | quote = Wayland isn't a remote rendering API like X, but that doesn't exclude network transparency. Clients render into a shared buffer and then have to tell the compositor (...) what they changed. The compositor can then send the new pixels in that region out over the network. The wayland protocol is already violently asynchronous, so it should be able to handle a bit of network lag gracefully. Remote fullscreen video viewing or gaming isn't going to work well, I don't know any other display system that handles that well and transparently. }}</ref> | ||
Wayland does not currently provide ], but it may in the future: | |||
{{ quotation | |||
⚫ | | Wayland isn't a remote rendering API like X, but that doesn't exclude network transparency. Clients render into a shared buffer and then have to tell the compositor (...) what they changed. The compositor can then send the new pixels in that region out over the network. The wayland protocol is already violently asynchronous, so it should be able to handle a bit of network lag gracefully. Remote fullscreen video viewing or gaming isn't going to work well, I don't know any other display system that handles that well and transparently. | ||
| Kristian Høgsberg<ref>{{ cite web | url = http://lists.freedesktop.org/archives/wayland-devel/2010-November/000097.html | title = Network transparency argument | author = Kristian Høgsberg |date=2010-11-09}}</ref> | |||
}} | |||
One person has envisaged providing remote access to a Wayland application by either 'pixel-scraping' (as in ] and ]) or getting it to send a "rendering command stream" across the network (like ]).<ref>{{ cite web | url = http://lists.fedoraproject.org/pipermail/devel/2010-November/145306.html | title = [Re:] Ubuntu moving towards Wayland | author = Adam Jackson (ajax) |date=2010-11-09}}</ref> | One person has envisaged providing remote access to a Wayland application by either 'pixel-scraping' (as in ] and ]) or getting it to send a "rendering command stream" across the network (like ]).<ref>{{ cite web | url = http://lists.fedoraproject.org/pipermail/devel/2010-November/145306.html | title = [Re:] Ubuntu moving towards Wayland | author = Adam Jackson (ajax) |date=2010-11-09}}</ref> |
Revision as of 13:26, 13 February 2011
Original author(s) | Kristian Høgsberg |
---|---|
Initial release | 2008 |
Repository | |
Written in | C |
Operating system | Unix-like |
Type | Display server |
License | LGPL v2 |
Website | http://wayland.freedesktop.org/ |
Wayland is a display server protocol for the Linux desktop and a library implementing that protocol.
Wayland provides a method for compositing window managers to communicate directly with applications, eliminating their dependence on X, allowing them to communicate directly with video and input hardware, becoming the display server. Applications render graphics to their own buffers, and a Wayland display server composites those buffers into the screen image. This is a simpler and more efficient approach than using a compositing window manager with the X Window System.
Background
Kristian Høgsberg (krh), a software engineer who works on the Linux graphics stack, started Wayland as a spare-time project in 2008, while working for Red Hat; he is now at Intel. His earlier work on X included AIGLX, and involvement in the creation of DRI2. His stated goal was a system in which "every frame is perfect, by which I mean that applications will be able to control the rendering enough that we'll never see tearing, lag, redrawing or flicker."
Wayland is free software, and is released under the terms of the GNU Lesser General Public License (LGPL) v2. As of November 2010, Wayland only works with open source drivers for Intel, AMD (previously known as ATI) and Nvidia (nouveau driver) graphics cards. As of November 2010, Nvidia has no plans to support it in their proprietary drivers.
Høgsberg indicated that he came up with the name Wayland when driving through Wayland, MA.
Planned adoption
- MeeGo (2010-09-08)
- Intel is working on moving MeeGo to Wayland.
- Ubuntu (2010-11-04)
- Mark Shuttleworth announced plans to eventually replace X with Wayland as the primary Ubuntu display server with their Unity desktop.
- Fedora {{nowrap|(2010-11-09)
- Adam Jackson (ajax) said that Fedora is likely to eventually use Wayland by default, "...because it's a serious win for a lot of things, and the downsides are pretty negligible despite the fear from the peanut gallery."
Ubuntu and Fedora are the two most popular Linux distributions.
Design
In recent years, Linux desktop graphics has moved from having "a pile of rendering interfaces... all talking to the X server, which is at the center of the universe" towards putting the Linux kernel "in the middle", with "window systems like X and Wayland ... off in the corner". This will be "a much-simplified graphics system offering more flexibility and better performance".
Høgsberg could have added an extension to X as many recent projects have done, but preferred to " X out of the hotpath between clients and the hardware" for reasons explained in the project's FAQ:
What's different now is that a lot of infrastructure has moved from the X server into the kernel (memory management, command scheduling, mode setting) or libraries (cairo, pixman, freetype, fontconfig, pango etc) and there is very little left that has to happen in a central server process. ... a tremendous amount of functionality that you must support to claim to speak the X protocol, yet nobody will ever use this. ... This includes code tables, glyph rasterization and caching, XLFDs (seriously, XLFDs!) Also, the entire core rendering API that lets you draw stippled lines, polygons, wide arcs and many more state-of-the-1980s style graphics primitives. For many things we've been able to keep the X.org server modern by adding extension such as XRandR, XRender and COMPOSITE ... With Wayland we can move the X server and all its legacy technology to an optional code path. Getting to a point where the X server is a compatibility option instead of the core rendering system will take a while, but we'll never get there if don't plan for it.
Wayland consists of a protocol (largely complete) and some demonstration code. Currently, the Wayland code uses OpenGL ES, rather than the more traditional (in desktops) OpenGL. "Longer term we'll need an answer for apps that need full , but the problem is that libGL pulls in GLX and all the X dependencies." The project is also developing versions of Qt and GTK+ that render to Wayland instead of to X. Most applications are expected to gain support for Wayland through one of these libraries without modification to the application.
Wayland does not currently provide network transparency, but it may in the future.
One person has envisaged providing remote access to a Wayland application by either 'pixel-scraping' (as in VNC and SPICE) or getting it to send a "rendering command stream" across the network (like RDP).
Backward compatibility with X
X11 applications are supported through an X server, optionally rootless, running as Wayland client, although currently it only supports Intel X.org drivers.
Qt applications can switch between graphical backends like X and Wayland at run time with the -platform command line option. In January 2011, Wayland support was moved into the Lighthouse branch of the upstream Qt repository.
In December 2010, GTK+ added preliminary support for switching backends at run time, saying "interesting combinations are x11+wayland or quartz+x11". In January 2011, the GTK Wayland backend was updated to support the multiple-backends feature and moved to the gdk-wayland-backend branch of the upstream GTK git repository.
Development
Canonical Ltd., owner of Ubuntu, hired Sam Spilsbury, primary Compiz developer. He has been moving Compiz dependencies on X into a plugin. This will make it easier to enable Compiz to become a Wayland display server. Canonical is planning to help port Compiz to OpenGL ES, currently a requirement for Wayland display servers.
KWin, the KDE window manager, added support for OpenGL ES output.
See also
References
- ^ Kristian Høgsberg (2010-11-22). "Wayland license clarification".
- "Wayland".
Wayland is a protocol for a compositor to talk to its clients as well as a C library implementation of that protocol.
- "Wayland Architecture". Wayland project.
- Kristian Høgsberg. "Wayland - A New Display Server for Linux". Linux Plumbers Conference, 2009. (Video available here)
- Kristian Høgsberg. "EGL and GLES1/2 on Linux". Linux Plumbers Conference, 2010.
- "Interview: Kristian Høgsberg". FOSDEM 2007. 2007-02-06.
- Kristian Høgsberg (2008-09-08). "DRI2 Protocol Spec Draft".
- Kristian Høgsberg (2008-03-31). "DRI2 Direct Rendering".
- Michael Larabel (2008-11-03). "Wayland: A New X Server For Linux". Phoronix.
- Michael Larabel (2010-11-08). "NVIDIA Says It Has No Plans To Support Wayland". Phoronix.
- Aaron Plattner, nvidia's primary linux developer (2010-11-07). "nvidia and the wayland display server".
We have no plans to support Wayland.
- MeeGo* Graphics: Under the Hood. 2010-09-07. Event occurs at 4:24.
- Mark Shuttleworth (2010-11-04). "Unity on Wayland".
The next major transition for Unity will be to deliver it on Wayland....
- Adam Jackson (ajax) (2010-11-09). "[Re:] Ubuntu moving towards Wayland".
- "Top Ten Distributions". Retrieved 2011-01-02.
- Jonathan Corbet (2010-11-05). "Linux Plumbers Conference: Life after X (reporting a talk by [[Keith Packard]])". LWN.net.
{{cite web}}
: Cite has empty unknown parameter:|1=
(help); URL–wikilink conflict (help) - "Wayland FAQ". Wayland Project.
- Michael Larabel (2010-06-06). "Wayland Meets Some Summer Love w/ New Changes". Phoronix.
- Kristian Høgsberg (2010-12-09). "Blender3D & cursor clamping".
- Kristian Høgsberg (2010-11-09). "Network transparency argument".
Wayland isn't a remote rendering API like X, but that doesn't exclude network transparency. Clients render into a shared buffer and then have to tell the compositor (...) what they changed. The compositor can then send the new pixels in that region out over the network. The wayland protocol is already violently asynchronous, so it should be able to handle a bit of network lag gracefully. Remote fullscreen video viewing or gaming isn't going to work well, I don't know any other display system that handles that well and transparently.
- Adam Jackson (ajax) (2010-11-09). "[Re:] Ubuntu moving towards Wayland".
- Darxus (2010-11-27). ""hosted" patch for nouveau - X under wayland".
It's possible to run X.org as a client of wayland, rootless or not, if you have an Intel video card
- "Getting started with Lighthouse". Retrieved 2010-12-17.
- Kristian Høgsberg (2011-01-25). "Add wayland lighthouse plugin".
- Michael Larabel (2010-12-22). "GTK+3 Now Uses X Input 2 By Default, New Back-End Caps".
- Matthias Clasen (2010-12-21). "GTK+ 2.91.7 released".
- Kristian Høgsberg (2011-01-03). "Multiple backends for GTK+".
- Sam Spilsbury (2010-11-25). "A bright new future for Compiz".
...I was also hired by Canonical Ltd....
- Sam Spilsbury (2010-11-07). "Compiz in a strange new land".
- deebeeoh. "I am an Ubuntu Unity Developer, AMA". Retrieved 2010-01-12.
We are going to be helping compiz port to OpenGL ES
- Martin Gräßlin (2010-11-28). "KWin runs on OpenGL ES".
It does not only help, it is a must have to start working for Wayland. So to say it's the first part of the KWin port to Wayland
External links
- Official website
- source code repository
- Kristian Høgsberg's blog
- Wayland Display server demonstration on YouTube
- The way to Wayland: Preparing for life After X Joe 'Zonker' Brockmeier, LWN, November 17, 2010
- Wayland build script for Ubuntu
Free and open-source software projects hosted by freedesktop.org | ||||||||
---|---|---|---|---|---|---|---|---|
OS components |
| |||||||
Libraries | ||||||||
Frameworks | ||||||||
Meetings |