Alexandros Frantzis
February 19, 2021
Reading time:
Two months ago we announced a first proposal for a Wayland driver for Wine, the compatibility layer for Windows applications.
The goal of this driver is to allow Windows applications to run directly on Wayland compositors, eventually removing the need for XWayland for many use cases. XWayland, like X11 in general, is receiving less and less developer attention and is unlikely to support modern features like improved fence synchronization or HDR. In addition, since it's yet another layer to go through it's a source of complexity and potentially of inefficiency. Some more details and thoughts about XWayland vs direct Wayland in the context of Wine can be found here.
We are now excited to announce a first update for this effort, proposed on the upstream mailing list as a new RFC (Request for Comment), which contains more details and instructions for building and running the Wayland driver.
The focus of this update is to support a number of new features that are useful for applications and games, and which have also been considered potential integration pain points for the Wayland driver. These are copy/paste, drag-and-drop and support for changing the display mode.
Copy/paste support works well in both directions (native Wayland apps <=> Wine apps) with many common formats already supported. Drag and drop works in the direction of native Wayland apps to Wine apps for many common formats.
Implementing the display mode change is particularly interesting since Wayland doesn't allow applications to directly change the mode in the display hardware. However a similar effect can be achieved for particular surfaces by scaling in the compositor (typically using the GPU). In case of a Wine mode that doesn't match the current compositor mode, the driver instructs the compositor to scale the window contents so that they appear as if the hardware display mode had been changed while respecting the aspect ratio.
Below is a video showcasing the new features. Enjoy!
07/01/2025
A testament to its long standing community interest and devote volunteers, FOSDEM will be celebrating its 25th anniversary this year. Join…
20/12/2024
The Rockchip RK3588 upstream support has progressed a lot over the last few years. As 2024 comes to a close, it is a great time to have…
09/12/2024
Collabora will be at NeurIPs this week to dive into the latest academic findings in machine learning and research advancements that are…
Comments (6)
Hi-Angel:
Feb 19, 2021 at 07:44 PM
Oh, this is amazing.
> Wayland doesn't allow applications to directly change the mode in the display hardware. However a similar effect can be achieved for particular surfaces by scaling in the compositor
Wow, if I read it correctly, this is a great new feature that was *not* supported by plain X11 wine! There're various old games that try to change resolution into something low, so on X11 people usually run them in a "virtual desktop". However, the latter lacks ability to upscale content. Which means, if you play a game with 1024×768 on a 4k monitor, the game window will be so small it is barely playable.
This Wayland feature gives it, like, a new life, thanks folks!
Reply to this comment
Reply to this comment
Anonymous:
Feb 22, 2021 at 11:33 AM
There are old games that run on 640x480, those are a real pain.
Anyway, this is really nice indeed. Now, a wayland compositor that allows to use the scaling/CRT shader from retroarch for upscaling would be cool :)
Reply to this comment
Reply to this comment
Anony Moose:
Feb 25, 2021 at 03:51 PM
> Wow, if I read it correctly, this is a great new feature that was *not* supported by plain X11 wine!
It's not supported in vanilla Wine, but Valve's Proton does upscale games instead of changing the display resolution.
Reply to this comment
Reply to this comment
Anon:
Feb 19, 2021 at 10:27 PM
Hi. Would this proposed driver be able to integrate with the closed-source Nvidia driver?
Reply to this comment
Reply to this comment
Peter:
Mar 13, 2021 at 04:26 PM
Please keep up the good work this is very important update because the Xwayland wine driver is really rough and one of the reasons i couldn't fully switch to wayland, having a native wayland driver would be amazing!
Reply to this comment
Reply to this comment
Parag Agarwal:
Apr 02, 2021 at 05:55 PM
Eagerly awaiting development updates on this driver. Hope it gets accepted in wine staging soon so that users can give feedback and help report bugs. It will accelerate its development further.
Reply to this comment
Reply to this comment
Add a Comment