35
submitted 1 year ago by Yoru@lemmy.ml to c/linux@lemmy.ml

I saw from a post that you can basically host your own mini windows inside of linux to play games with, and you can choose what to share with that little windows so microsoft can't track you in any way. Does anyone have a tutorual/guide for that? Also what Distro would be best for it?

top 35 comments
sorted by: hot top controversial new old
[-] bear@slrpnk.net 22 points 1 year ago

What you're probably referring to is running a virtual machine with VFIO passthrough. I hate to be that guy, but this is one of those "if you have to ask for help, you probably shouldn't do it" kind of situations. It's complicated and easy to mess up, requires a decent amount of knowledge of both Linux and Windows, and every situation is unique. There's no cookie-cutter way to set it all up.

But if you're willing to buckle down and learn anyways, the best way would be to do it from scratch. This is the best documentation I'm aware of on the subject, but it's tailored heavily for Arch Linux, a rather advanced distro to use.

https://wiki.archlinux.org/title/PCI_passthrough_via_OVMF

[-] dinckelman@lemmy.world 5 points 1 year ago

This article is enough to teach you basically anything you could need. As long as you can follow instructions properly, that's it

[-] Yoru@lemmy.ml 4 points 1 year ago

alright, thanks. After I've read other comments I'll pass on it because it seems I need an extra GPU anyways.

[-] flashgnash@lemm.ee 1 points 1 year ago

Not necessarily, if your processor has an igpu which many do you can use that for Linux and the discrete GPU for the VM

though like others have said if you don't know about this technology already it's not going to be an easy plug and play job

[-] garrett@beehaw.org 8 points 1 year ago

There are a few ways...

The easiest is using Steam, which handles everything for you (once you flip a switch in settings). The second easiest is using Bottles or Heroic, both of which lets you run Windows games and apps on Linux via Wine. The third is VMs, but that's just Windows itself running virtualized (in its own virtual machine) in Linux. The fourth way to use the same computer for Linux and games is to dual boot (reboot from one OS into the other) and stick with Linux except for particular games that might not work with other methods — which is thankfully very rare these days (as most games work in Linux via Proton or in Wine via Bottles or Heroic).

  1. Steam on Linux has a switch in the settings to enable Proton for all games. Flip that on, and it's basically transparent. For setting up Steam, the easiest way is to install it from Flathub.org. Depending on your distribution, it's most likely set up for you. If not, then follow the setup guide @ https://flathub.org/setup. Once Flathub is set up on your system, you can install the flatpak of Steam from your app store (GNOME Software, KDE Discover, etc.)

  2. An alternate method is to set up Wine outside of Steam. There are a few ways to do that; Bottles is the most straightforward and super easy way, letting you have different Wine environments for different apps or games (or just one for everything, if you'd rather)... Bottles is easy to use and has installers for a lot of common apps and launcher. Additionally, Heroic is also a good way to run GOG, Epic, and Amazon games on Linux. Both are on Flathub too.

  3. There's a third major way, and that's installing Windows as a virtual machine on Linux. You'd probably want to use GNOME Boxes or virt-manager for that. Boxes is easier (and on Flathub) and will give you adequate GPU performance for a lot of things (however, isn't ideal for high performance gaming), but if you have two GPUs (often one integrated and one discrete), then you can use GPU passthrough with virt-manager, but that's way outside the scope of this comment. 😉 Perhaps having a Windows install in a VM just for some games that don't work on Linux is what that person meant? But that would still get you tracked by Microsoft whenever you're using Windows in that VM. (So I'm guessing they're talking about Wine instead, which is option 1 and 2.)

  4. Dual boot is basically reusing the same hardware for two different operating systems, but only one at a time. When you're in Linux, Microsoft doesn't track you (unless you're using Edge on Linux or specifically using a Microsoft service). You'd want to minimize your time in Windows.

You could use any of the above or a combination (perhaps even all of the above), depending on what you want. I only use 1 and 2 myself. While I do play a lot of games, all on Linux, I don't play any that require Windows.

(There are only a few these days that don't work on Linux. The notable ones I'm aware of are Fortnite, Destiny 2, Genshin Impact, and a few others that rely on lootboxes where the maker didn't flip the switch to enable "anti-cheat" on Linux. Most everything else works these days, even a lot of other lootbox/pay-to-win games.)

[-] PorkrollPosadist@hexbear.net 5 points 1 year ago* (last edited 1 year ago)

The Distro isn't super important, since Valve started shipping their own runtime (for Linux ports) and Proton (for Windows games). Anything modern outside of the strictly free-software distros (things like Ututo, Guix, etc. which do not ship proprietary firmware or drivers of any kind) will suffice.

There are a few different approaches to playing Windows games. Some have direct ports. Games like Doom, Quake, were open-sourced a long time ago and have dozens of ports with all sorts of features. Other games, like CS:GO, Kerbal Space Program, X-Com: Enemy Unknown, etc. are not open source, but have ports produced by either the developer or the publisher. A LOT of indy games have ports available, and most modern game engines like Unreal, Unity, Godot, etc support Linux targets (whether the publishers give a shit is another story.) These typically target the Steam Runtime (a collection of specific versions of graphics, audio, and auxiliary libraries that Steam will install). These libraries are also provided by distributors, but the distribution libraries will typically be newer. This is normally a good thing, but commercial ports don't receive frequent updates and are likely only tested against the Steam Runtime.

If there is no port available, the next option is Wine. Wine is a Windows compatibility layer which is capable of loading Windows PE format executables on Linux and dynamically linking them to a large collection of substitute DLLs which implement Windows functionality on top of Linux. Proton is the version of Wine shipped by Steam, with a bunch of tweaks specifically focusing on graphics performance. Most of the time, games will work in Proton, but there are a handful of cases where they work in Wine/Wine-Staging but not in Proton.

If the game requires an anti-cheat component, it will almost certainly not work in WINE/Proton, because the whole basis of getting Windows games to work on Linux operates using the same mechanism as cheats: replacing "genuine" components of the Windows operating system with 3rd party code to intercept system calls and do something other than intended.

A much more complicated route would be to set up a virtual machine. A virtual machine is a full blown PC-emulator, except since the host machine shares the same instruction set as the guest, it is a lot faster. This is not enough not yield good performance in games though, because games also require direct access to the video hardware. To do this, you need a SECOND graphics card for the guest operating system, then you can try to configure PCI-e passthrough (so the video driver in the guest OS talks directly to the video hardware). This is probably the most complicated approach, but you end up running genuine Windows virtualized on real hardware. In addition to the second GPU, you need to make sure you have the overhead in CPU / RAM / storage to run multiple operating systems concurrently such that gaming performance won't be substantially impacted. Additionally, you probably need a second monitor if you want to interact with both the guest and host operating system simultaneously.

Finally, if none of that works, it may be worth looking into whether ports for other platforms exist. If you struggle running a dated Windows game in WINE, you might have better luck emulating a release for PS2/3, GameCube/Wii/WiiU/Switch, etc. The state of Nintendo platform emulation in particular is phenomenal, and it is trivial to increase the video resolution beyond what the official hardware supports if your machine has the horsepower for it.

[-] Yoru@lemmy.ml 1 points 1 year ago

I see, It seems virtualization won't be the way to go as I don't have a second monitor nor a second GPU.

[-] merthyr1831@lemmy.world 2 points 1 year ago

It's pretty advanced. You'll need 2 GPUs (so gaming laptop or gaming PC with at least 2 graphics adapters) and some more advanced Linux stuff like editing kernel/boot configs, messing with drivers, and BIOS settings.

Look at BlandManStudios on Youtube, he has a bunch of tutorials on this. But make sure you back up your system because, like I said, it's not a simple setup.

[-] Titou@feddit.de 2 points 1 year ago

Are you talking about a VM ?

[-] mechinn@kbin.social 2 points 1 year ago
[-] mechinn@kbin.social 3 points 1 year ago

Just a thing to note, if you’re considering virtualizing windows to play games that have anti-cheat software like BattleEye if they notice you’re virtualizing windows it might ban you. You’re almost better off using the other advice here and using proton with those that support it. For things that don’t you probably will have to flip the setup around and have the base os be windows and virtualize Linux :(

[-] Yoru@lemmy.ml 1 points 1 year ago

yes, thank you for the advice, I appreciate it!

[-] Yoru@lemmy.ml 1 points 1 year ago

Thank you everyone for all the lengthy and informative replies! I appreciate them all. I'll probably go with gaming normally on linux and not do anything fancy

[-] jernej@lemmy.ml 1 points 1 year ago

I remember there being a script for fedora, that apperently workes since it made me realize my PC only has one GPU (no GPU)

[-] PotatoesFall@discuss.tchncs.de 1 points 1 year ago

Not sure what you mean. You can virtualize a whole windows machine but that will NOT be good for performance.

What you really want is a compatibility layer than maps syscalls to your linux kernel and emulates a windows filesystem. I'm fairly sure that's what Wine and Proton do, but am no expert.

If you install steam (on most distros) it should also install Proton to play games with (check ProtonDB for which games work well). Again no expert but maybe this helps a little.

[-] wildbus8979@sh.itjust.works 9 points 1 year ago

You can virtualize a whole windows machine but that will NOT be good for performance.

Sorry but that is totally not true, if you have a second graphics card to passthrough to the virtual machine.

[-] cujo@sh.itjust.works 1 points 1 year ago* (last edited 1 year ago)

It will still be subpar performance, bottlenecked by the CPU resources you can allocate to the VM as well as your original hardware's capabilities to power the VM among many other variables. Running a VM to game will always produce subpar results. Using GPU passthrough will increase performance, but it's almost always preferable to play on real hardware.

The real answer will always be: if you want to game on Linux, utilize Wine/Proton and Steam/Lutris/Bottles/Heroic/some other launcher that lets you fine tune Wine/Proton to cater to the specific game.

[-] wildbus8979@sh.itjust.works 8 points 1 year ago* (last edited 1 year ago)

Maybe if you're using type 2 virtualization bullshit like VirtualBox, but for type 1 like KVM? Performance is near identical to host CPU, the overhead is somewhere between 2~4%. Hardly something you'd ever notice.

https://forum.level1techs.com/t/how-fast-is-kvm-host-vs-virtual-machine-performance/110192

Wine is fine, but it comes with its lot of compatibility issues you'll never have to deal with with a VM with GFX passthrough.

[-] cujo@sh.itjust.works 2 points 1 year ago

Sure. I admit my experience running a VM is limited to "type 2 bullshit" like VirtualBox. But that also requires that OP have a spare GPU lying around they care enough to pop into their machine and set up passthrough for, which most people don't. Especially with these GPU prices lately, yikes. Chances are they have a decent GPU already in their system, and buying an equivalent GPU just for passthrough is... 😬

So while baremetal-like performance is certainly possible with a VM, it's still not an ideal solution for most people.

[-] wildbus8979@sh.itjust.works 3 points 1 year ago* (last edited 1 year ago)

Use the iGPU for your main OS, and discreet for gaming in a VM. Works wonders and you don't need to deal with NVIDIA drivers in your main OS. And save some energy to boot.

[-] cujo@sh.itjust.works 1 points 1 year ago

Hmm that's a neat solution. What if you do video or photo editing in your main OS, though, or any other kind of work that would benefit from discreet graphics? Is your only option then essentially two GPUs, or can you switch between passthrough neatly, or...?

[-] wildbus8979@sh.itjust.works 2 points 1 year ago

You can switch between the two, but it does require a reboot. So in that case two discreet would be more convenient. But for encoding and what not you probably can get away with a rather cheap discreet that works well on nouveau (or go Radeon) and keep the 4090 for gaming.

[-] cujo@sh.itjust.works 2 points 1 year ago

Interesting.

My system is all AMD, I prefer not to wrestle with Nvidia's drivers on Linux, lol.

It's been years since I ran Windows on my machine, but I still miss my photo editing software. Nice as DarkTable is, it's no replacement for CaptureOne. And it's pretty much not possible to get CaptureOne running in a productive manner under Wine. I looked into doing passthrough to a VM a while back, but it just seemed a hassle and I didn't have a spare GPU. I game on my Linux install, so iGPU isn't sufficient for my needs there. My photography hobby just has to suffer. 😂

[-] sudotstar@kbin.social 2 points 1 year ago

I haven't adopted this kind of setup, mainly because Proton just does such a good job I have almost zero need for Windows, but my plan for eventually doing something like this was to also maintain a passthrough Linux VM for any GPU-intensive work on that side.

When I realized that the practical end-state of my system would mean I'd just be running things from within the Linux VM 98% of the time (games that can run on Linux) I kind of dropped the idea.

[-] cujo@sh.itjust.works 1 points 1 year ago

My single remaining use for Windows is to run the CaptureOne photo editing software. It is, in my opinion, peerless. I love using it so much that it ruined basically all other photo editing suites for me. DarkTable, PhotoTherapee, ART, none of them come close for me. Everything else has some alternative that I've come to term with using, or even prefer using, but not CaptureOne.

I'm only a hobbyist photographer so it's not like my livelihood is tied up in this software... I just get tired and sour working in other softwares, no matter how long of a trial I give them. Sometimes you find a solution that's just absolutely perfect for you and the way you work, and CaptureOne is that for me. 🤷‍♂️

In my case, I'd have my host Linux OS for 99.99% of my use case, and then Windows solely for photo editing. But I opted not to do that just because of all my previous experiences trying to use a VM for any production level work with anything that's graphically intensive. Apparently that has changed a lot since I last looked at it, or I didn't dig deep enough and I missed the actually worthwhile software. I'm just not sure I'm going to put in the work. I've got a baby now, and haven't taken a photo on anything other than my smartphone since she was born. 😅

[-] dinckelman@lemmy.world 3 points 1 year ago

This is factually incorrect. Yes, you will have to allocate at least one thread and some RAM to your host system, but calling it subpar is just a completely uneducated statement. I have ran my system like this for multiple years, and compared to running booting Windows directly, the loss of fps in games is so negligible that it might not even be there

[-] cujo@sh.itjust.works 3 points 1 year ago* (last edited 1 year ago)

If you have to allocate resources to your host system, that's resources your virtual machine cannot use. It is subpar. If you're going to allocate your host the bare minimum resources, why not run the other operating system to begin with? You're now missing out in performance in the complete opposite direction. The most straightforward solution still remains to run games on your host system. If you want to game on Linux, game on Linux. It's easy enough nowadays, and what tinkering you may have to do will be a fantastic opportunity to get more comfortable with the DIY side of Linux.

I will be the first to admit that I am no expert on the topic of virtualization, as I have said in other comments already. However, this is a community, not an expert consultation, and I have used virtualization to varying degrees of success for various different tasks over the years, all of which has culminated in my opinion that it's best not to use virtualization to game unless you're really intent on running a game that cannot under any circumstances run in Linux, such as Valorant. To follow, if that is your use case I encourage picking up an extra drive (storage is incredibly cheap) and running a dual boot. You're free to disagree and provide reasoning why I'm wrong, but calling my statement "completely uneducated" is disingenuous at best.

EDIT: I concede on my word choice, it's not "subpar ." I'm certain you can achieve average or even above average performance in a VM with the right set up. The word I'm looking for is "suboptimal." My apologies.

[-] dinckelman@lemmy.world 2 points 1 year ago

I can definitely agree with suboptimal. While it's certainly not an end-all/be-all solution, it did exactly what it was designed to do. People spin up machines through Virtmanager for many reasons outside of gaming, me included, but when it came to gaming specifically, rebooting your system to play one game, and then switching back, didn't make any sense. Wine and Proton were not nearly as mature, as they are today.

Needless to say though, this is not the kind of setup you would run on an underpowered machine. With 24 threads of CPU performance, 32-64gb of RAM, and a full GPU, I can't really name a game that would exceed the limits of what is allocated

[-] dragnet@kbin.social 1 points 1 year ago

Super late reply here, but I was searching the Linux sub for vfio because I love this topic, lol. I'm happy to report that as others are saying, a vfio setup can be very performant! The GPU is near native, and with the proper CPU configuration, you won't be dealing with much overhead there either. The biggest factor is the overall load on your machine from running a host OS with the guest layered on top. I use my PC host OS primarily as a QEMU/KVM hypervisor, so when I need maximum gaming performance I simply turn off or suspend operation on all other VMs to free the resources for Windows. The only game I've had trouble with recently at 3440x1440 is Starfield, and unfortunately I think that is more a sign that an upgrade is finally due. I've used this setup for all kinds of games with no problem, including demanding virtual reality titles.

The biggest problem I've run into? Some anticheats truly despise any kind of virtualization. I've only run into issues with 2 games I like to play, but that is a real caveat. I consider it 100% an issue with the companies implementing these policies, who as I see it don't deserve my money in the first place. But other than the initial configuration headache and extra hardware required (if you don't have an iGPU anyway), this is the main drawback in my eyes.

[-] cujo@sh.itjust.works -1 points 1 year ago* (last edited 1 year ago)

As the other comment says, what you're referring to is running a Windows VM (virtual machine) inside of your Linux machine. It's a great asset for a lot of things, but gaming is not it's strong point. A VM shares resources with it's host machine, meaning it can only access so many of your CPU cores, utilize only so much of your RAM, and take advantage of CPU powered graphics -- unless, as was pointed out in another comment, you happen to have a spare graphics card laying around. The set up for GPU passthrough is more trouble than it's worth, IMO, especially for gaming. And you still have the other bottlenecks to contend with.

Gaming on Linux is best enjoyed by using a combination of Wine and Proton (Wine suped up for the express purpose of gaming by the fine folks behind Steam) paired with a launcher of some kind, usually Steam. For non-Steam games, Lutris is a fantastic second choice. These platforms make gaming on Linux easier than ever, and are actually the technologies powering the SteamDeck. If you decide to go this route and need any help setting up, please reach out! The community is here and (usually) quite helpful, lol.

If you decide to try the VM anyway, you should look into a software called VirtualBox. You will need to install a few packages to make your system a suitable host, and you'll need the Windows installation ISO image to get it up and running. You can usually acquire it directly from Microsoft by running a search for "Windows XX ISO" where the XX is the version number you're looking for. If you need help getting any of that together, I'd be glad to assist as well. ☺️

All this comes from years of running Linux and only Linux, on a PC I almost exclusively game on. I've had great success, especially with all the headway Valve has made into making the ecosystem viable and accessable.

However you decide to proceed, best of luck to you!

EDIT: As has been pointed out, if you want to virtualize a gaming setup, you should look into KVM, not VirtualBox! It sounds like it's a much more performant option, I am just not very familiar with it myself.

[-] wildbus8979@sh.itjust.works 7 points 1 year ago

If you decide to try the VM anyway, you should look into a software called VirtualBox.

God, please, no. Why do people insist on using subpar virtualization when KVM is far superior and built into the kernel? I will never understand.

Please, I beg of you, stop this madness.

[-] cujo@sh.itjust.works 3 points 1 year ago

Because it's accessable, and is also the extent of my knowledge in running a VM. I won't speak about KVM because I am not intimately familiar with KVM, nor will I ever be. I'm certain it's a better solution than VirtualBox, just as running games in Linux with Wine/Proton is a better solution than setting up a VM to game in.

I'd be happy to hear about the details of why KVM is so superior, if you'd care to enlighten me! I'm always looking to learn new things.

The real question is why we're down voting people who are adding to the discussion just because we disagree with them, instead of just having a conversation?

[-] wildbus8979@sh.itjust.works 6 points 1 year ago

Because it's accessable

Here, enjoy: https://virt-manager.org/

I'd be happy to hear about the details of why KVM is so superior

Essentially type 1 hypervisors, like KVM/Qemu, make direct use of the CPU's virtualization technology (VT-d and VT-x) while type 2 hypervisors run all the calls through the kernel which is significantly slower. In a way type 2 hypervisors are closer to an emulator.

[-] cujo@sh.itjust.works 2 points 1 year ago

Thanks for the link! And for the info. I'll give KVM an honest try, and maybe I'll get motivated enough to spin up a VM for CaptureOne. A 1080 should be decent enough for light photo editing, and I was recently given one as-is. It may or may not work, neither I or the person who gave it to me had time to test it.

[-] Yoru@lemmy.ml 2 points 1 year ago

thank you for the lengthy reply! I think I'll go with alternative options and not to virtualize windows, because I don't have a separate GPU that I can pass in, nor a second monitor.

load more comments
view more: next ›
this post was submitted on 07 Aug 2023
35 points (94.9% liked)

Linux

48335 readers
1111 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS