This is my build of WINE based on/forked from the most recent bleeding-edge proton experimental wine repo. This is meant to be used with non-steam games outside of Steam.
For Steam games, I provide Proton-GE for usage with Lutris, found here:
https://github.com/gloriouseggroll/proton-ge-custom
Occasionally, I also release League of Legends builds -- These builds will specifically have 'lol' or 'LoL' in the name. Please note these 'LoL' builds are for specific use with League of Legends, and NO other games.
If you have an issue that happens with my Wine-GE or Wine-LoL-GE builds, provided FROM this repository, please contact me on Discord about the issue:
Things it contains that Valve's proton does not:
- Additional media foundation patches for better video playback support
- AMD FSR patches added directly to fullscreen hack that can be toggled with WINE_FULLSCREEN_FSR=1
- FSR Fake resolution patch (details here: GloriousEggroll/proton-ge-custom#52)
- Nvidia CUDA support for phsyx and nvapi
- Raw input mouse support
- fix for Mech Warrior Online
- fix for Asseto Corsa HUD
- fix for MK11 crash in single player
- fix for Killer Instinct Vulkan related crash
- fix for Cities XXL patches
- various upstream WINE patches backported
- various wine-staging patches applied as they become needed
- Spyro Reignited Trilogy
- Mortal Kombat 11
- Injustice 2
- Power Rangers: Battle for the Grid
- Borderlands 3
- Resident Evil 0
- Resident Evil
- Resident Evil 2 Remastered
- Resident Evil 3 Remastered
- Resident Evil 5
- Resident Evil 6
- Resident Evil 7
- Resident Evil 8
- Resident Evil Revalations
- Resident Evil Revalations 2
- Persona 4 Golden
- PC Building Simulator
- Dangonronpa V3
- Super Lucky's Tale
- Remnant: From the Ashes
- BlazBlue Centralfiction
- Bloodstained: Ritual of the Night
- Crazy Machines 3
- Devil May Cry 5
- Wasteland 3
- Mutant Year Zero
- Ultimate Marvel Vs. Capcom 3
- Industry of Titan
- Call of Duty Black Ops III
- Tokyo Xanadu eX+
- Haven
- Nier Replicant
- Scrap Mechanic
- Aven Colony
- American Fugitive
- Asrtonner
- Soul Caliber VI
- Monster Hunter Rise
- Seven: Days Gone
- Warframe is problematic with VSync. Turn it off or on in game, do not set to
Auto
- Warframe needs a set a frame limit in game. Unlimited framerate can cause slowdowns
- Warframe on Nvidia: you may need to disable GPU Particles in game otherwise the game can freeze randomly. On AMD they work fine
PLEASE NOTE: There are prerequisites for using this version of wine:
- You must have wine installed on your system
- You must have winetricks installed on your system
- You must have wine dependencies installed on your system. See https://www.gloriouseggroll.tv/how-to-get-out-of-wine-dependency-hell/
- You must have vulkan gpu drivers/packages installed properly on your system. See https://github.com/lutris/docs/blob/master/InstallingDrivers.md
This section is for manual installation of wine-ge for usage with Lutris.
- Extract
wine-name-branch-x86_64.tar.gz
to/home/USERNAME/.local/share/lutris/runners/wine/
- Restart lutris. You can now choose
wine-name-branch-x86_64
from the runners list in configuration options for any game.
Requirements:
- Vagrant with sshfs plugin
Notes:
- Most distros include the vagrant sshfs plugin as it's own package. You will need to install this package as the default that vagrant tries to install internally usually causes conflicts/failures.
- Example:
Ubuntu:
# apt install vagrant vagrant-sshfs
Fedora:
# dnf install vagrant vagrant-sshfs
- VirtualBox installed
Notes:__
- This differs per distro. You will need to find instructions for your distro.
- Please note that virtualbox is -required-. Libvirt will not work. Specifically libvirt causes segfaults when installing packages in the lxc 32 bit container. Why? who knows.__
Additional notes:__
-
It is important to note that the wine, wine-staging and patches repos/folders are here for my personal use. The build bot does -NOT- pull from any of these folders directly.__
-
It is recommended to:__
- replace the wine repository with a clone of your own wine repository,__
- then run
./patches/protonprep.sh
to apply my changes to your own wine repository,__ - then commit + push those changes to a separate branch on your -own- repository.__
- THEN follow the instructions below, using your own repository URL and branch.__
Instructions:
$ git clone --recurse-submodules https://github.com/gloriouseggroll/wine-ge-custom
$ cd wine-ge-custom
$ VAGRANT_DEFAULT_PROVIDER=virtualbox vagrant up
$ ./makebuild.sh name winerepo branch
Example: ./makebuild.sh lutris http://github.com/gloriouseggroll/wine ge-5.2
Final build will be placed in wine-ge-custom/vagrant_share/ with name format wine-name-branch-x86_64.tar.gz
:
Example: wine-lutris-ge-5.2-x86_64.tar.xz
Environment variable options:
Compat config string | Environment Variable | Description |
---|---|---|
WINE_FULLSCREEN_FSR | Enable AMD FidelityFX Super Resolution (FSR), use in conjunction with WINE_FULLSCREEN_FSR_STRENGTH Only works in vulkan games (dxvk and vkd3d-proton included). |
|
WINE_FULLSCREEN_FSR_STRENGTH | AMD FidelityFX Super Resolution (FSR), the default sharpening of 5 is enough without needing modification, but can be changed with 0-5 if wanted. 0 is the maximum sharpness, higher values mean less sharpening. 2 is the AMD recommended default and is set by proton-ge |
As many of you may or may not already know, there is a Credits section in the README for this Git repository. My proton-ge project contains some of my personal tweaks to Proton, but a large amount of the patches, rebases and fixes come from numerous people's projects. While I tend to get credited for my builds, a lot of the work that goes into it are from other people as well. I'd like to take some time to point a few of these people out of recognition. In future builds, I plan to make clearer and more informative Git commits, as well as attempt to give these people further crediting, as my README may not be sufficient in doing so.
I and many others owe TKG. In regards to both WINE and Proton. He has dedicated a lot of time (2+ years at least) to rebasing WINE and Proton patches, as well as making his own contributions. Before he came along, I did some rebasing work, and mainly only released things for Arch. These days he almost always beats me to rebasing, and it saves myself and others a lot of work.
Derek was responsible for the original rawinput patches, as well as several various game fixes in the past, just to name a few: MK11, FFXV, MHW, Steep, AC Odyssey FS fix. He has also done a massive amount of work on media foundation/mfplat, which should be hopefully working very soon.
Joshua is the creator of D9VK and also a huge contributor of DXVK. He is also known for his recent DOOM Eternal WINE fixes and also many of the Vulkan tweaks and fixes used, such as FS hack interger scaling.
Philip is the creator of DXVK and a heavy contributor of VKD3D. He also put up a lot of my bug reporting for Warframe years ago, when DXVK started.
Hans-Kristian is a heavy contributor of VKD3D and he also created a lot of WINE patches that allowed WoW to work.
Ethan is the creator of FAudio, and he also listened to my Warframe bug reports years ago.
Chris is the creator of the original Protonfixes project. The portions of Protonfixes I've imported are what allow customizations to be made to prefixes for various Proton games. without Proton fixes many games would still be broken and/or require manual prefix modification. Huge thanks to Chris.
Amine is the current maintainer of dxvk-async. This is a feature that was originally removed from dxvk as it happened around the same time a few overwatch bans happened. It was thought, but never confirmed whether or not this feature caused the bans, so the feature was removed as a safety precaution. It is still safe to use in many single player games, and games that do not have competitive anti-cheats. It has also been confirmed to work safely in Warframe and Path of Exile.
I also of course need to thank my fellow wine-staging maintainers: Alistair Leslie-Hughes, Zebediah Figura and Paul Gofman
They have contributed MANY patches to staging, far beyond what I have done, as well as kept up with regular rebasing. A lot of times when bug reports come to me, if it has to do with staging I end up testing and relaying information to these guys in order to get issues resolved.
Additionally, a thank you is owed to Andrew Aeikum (aeikum), and kisak (kisak-valve) for regularly keeping me in the loop with Proton and fsync patches, as well as accepting PRs I've made to fix Proton build system issues, or listening to bug reports on early Proton patches before they reach Proton release.
And finally - To all of my patrons that have supported me, thank you so much. It's because of you that I've been able to keep this project going, getting bug fixes reported, getting Proton/WINE issues fixed, getting various hardware and/or game fixes handled, and so on. Thanks to you, I have been able to use the spare budget in order to both help support the other people that make my project possible, as well as get things necessary for testing such as new game releases or specific hardware that hits odd issues. It's had a huge effect not just for this project, but a large trickle down effect.
My wine-staging co-maintainers are often able to ask me for testing games, or testing on different hardware if they don't have access to it. This also trickles into both Proton bug reporting AND Lutris bug reporting, as I'm able to provide bug testing and feedback and custom builds and upgrades to them as well. I'm also able to test driver related issues for things such as mesa and getting things reported + patched. This in turn leads to early patches for Mesa, the kernel, VKD3D, and other packages on my copr repos as well. The trickle down effect is just one gigantic awesome rabbit hole for getting things fixed. Thank you once again.
For anyone else interested, my Patreon can be found here: