FEB
18
2011

KWin Embraces New Platforms with OpenGL ES 2.0 Support

Over the last few months the KWin development team worked on bringing the Window Manager for KDE's Plasma workspaces to mobile devices. This has required porting the compositing code to OpenGL ES 2.0, the open graphics API for programmable embedded graphics hardware. With the migration of KWin's codebase to git, the code was imported into the master development tree to be part of the next release of the KDE Platform.


KWin running on mobile devices (Ogg Theora version)

The import of the OpenGL ES 2.0 code base marks an important milestone in developing a Plasma Workspace for mobile devices. Providing a mobile shell also requires us to deliver a fast, feature rich and mature compositing window manager. With KWin, KDE can deliver a proven and mature compositor for devices like the Nokia N900 and upcoming tablet devices (in the video to the right, KWin is running on an early Intel-powered tablet and a Nokia N900). KWin is the first major X11 window manager to offer these capabilities.

Desktop Improvements

The work on OpenGL ES not only brings improvements for the use of KDE Plasma on mobile devices, but also significant performance improvements to all users of the Plasma Workspaces. The code written for the mobile platform is reused in KWin for the Plasma Desktop and Plasma Netbook Workspaces. It also provides the basis for a new OpenGL 2-based compositor while keeping the existing codebase as a fallback for legacy graphics cards not supporting OpenGL 2.

KWin is therefore the first major window manager to make full use of the capabilities provided by OpenGL 2 without leaving users of older hardware behind. KWin is the only window manager to support a non-composited mode, as well as OpenGL ES 2.0, OpenGL 2, OpenGL 1 and XRender for compositing. Thus, the Plasma Workspaces provide the best possible user experience even with no hardware acceleration. At the same time, KWin delivers the best compositing experience to users of modern hardware, providing smooth effects and improved visual effects such as the gaussian blur filter for translucent Plasma elements.

By implementing an OpenGL 2 compositor, the complete effect framework received performance improvements; more are still to come. Various parts of the OpenGL stack were abstracted to better support both OpenGL 1 and OpenGL 2 in the effects. This eases future development and maintenance of the code base. Improvements to the underlying rendering stack will be available immediately for all effects.

Future Developments and Free Drivers


KWin running with nouveau (Ogg Theora version)

The availability of an OpenGL ES 2.0 compositing backend also marks the beginning of further challenging development efforts to improve the user experience of advanced graphics in the complete free software stack. Support for OpenGL ES 2.0 is a requirement for porting the KDE Plasma Workspaces to the Wayland infrastructure that may be a long term successor to the X Server. By porting to OpenGL ES, the KDE development team has a good starting point on the long road to Wayland.

In this regard, it is important to note that the OpenGL ES port has been developed and tested on regular NVIDIA desktop hardware using the free nouveau drivers provided by the Mesa development team. The KWin developers are thankful for the efforts of the free driver developers for delivering OpenGL ES drivers alongside regular desktop OpenGL drivers. It is pleasing to see that the free drivers have reached a stage where they can be used as the base for the development of a new compositing backend. As seen in the video to the right, vast performance improvements can be delivered with the new compositing backend. Altogether the OpenGL ES port has had more than 120 single commits changing more than 80 source files.

Comments

This is fantastic. It's great to see KWin remaining at the front of new technologies. I was also impressed to see it running with nouveau - the only thing holding me back from switching over to nouveau was its compatibility with KWin.


By Matt Williams at Fri, 2011/02/18 - 5:34pm

I tried Nouveau a couple of months ago and it still has some stability problems.


By trixl at Sat, 2011/02/19 - 12:18pm

Sorry, but made up your mind !


By yglodt at Fri, 2011/02/18 - 8:47pm

It also provides the basis for a new OpenGL 2-based compositor

When will this be available? 4.7?


By Jorge Adriano at Sat, 2011/02/19 - 10:19am

It is already the default in master, so yes with 4.7.


By Martin Gräßlin at Sat, 2011/02/19 - 10:23am

Great job guys, I hope you have the drive and resources to make KDE Mobile a real thing. What I really want is to have KDE and most of its apps running on my smartphone - I don't want any exotic and funny GUIs - just my perfect KDE... I hope one not so distant day this wish of mine would come true.


By Atanas at Sun, 2011/02/20 - 8:51am