54
submitted 11 hours ago by [email protected] to c/[email protected]

From both a technical perspective and if the maintainers of these anti-cheat will consider porting or re-writing kernel level anti-cheat to work on linux, is it possible? Do you think that the maintainers of kernel level anti-cheat will be adamant in not doing it, or that the kernel even supports it or will support it. I think that if it ever happens, there will be a influx of people moving to linux, or abandoning their duelboots, and that alot of people will hate that such a thing is available on linux.

top 50 comments
sorted by: hot top new old
[-] [email protected] 27 points 4 hours ago

I surely hope they never will, no user program should ever be allowed to run at kernel level, that's what malware does.

I personally avoid those kind of games, but those who won't can dual-boot.

[-] Mwa 3 points 3 hours ago
[-] [email protected] 3 points 2 hours ago* (last edited 2 hours ago)

From technical point of view it is possible. eBPF already has almost everything needed for doing that. And I think it can be done with a simple LKM but if they want it included in the main tree I'm sure they'll get some colorful email from Linus.

[-] [email protected] 3 points 1 hour ago

I really want to see that email.

[-] [email protected] 1 points 2 hours ago* (last edited 2 hours ago)

Doesn't Splitgate 2 have kernel level anti cheat that works on Linux? Maybe it is "trapped" inside wine/proton but they explicitly made it work and people are thanking them on steam discussions.

[-] Mwa 2 points 3 hours ago

No Wine/Proton cannot translate calls that run too deep into the Kernel

[-] [email protected] 9 points 5 hours ago

I sure hope not. Play on someone else's pc if you want them to have control.

[-] [email protected] 15 points 5 hours ago

kernel level anti cheat is malware

abandon ranked, return to private lobbies

[-] [email protected] 1 points 2 hours ago
[-] [email protected] 28 points 7 hours ago

It's the other way around. Windows will stop supporting kernel level anti-cheat because of Crowdstrike

[-] [email protected] 24 points 8 hours ago* (last edited 5 hours ago)

AFAIK Microsoft have plans to block kernel level anti-cheat on Windows. After the CrowdSec issues last year, they're rethinking which types of programs should even be allowed to run in kernel space.

Edit: I was wrong. They actually want to increase what can be done in user mode, to reduce reliance on kernel mode code.

[-] [email protected] 9 points 5 hours ago

They don't. One article lied, people never read anything but the title and here we are this getting mentioned every once in a while.

[-] [email protected] 3 points 5 hours ago

Thanks. I looked into it a bit more and it looks like they actually want to increase what can be done in userland, to reduce the reliance on kernel mode. That's still a good solution, if things the anti-cheat code needs to do can be moved into userland.

[-] [email protected] 1 points 6 hours ago

i assume the problem with league of legends since last year is because they switched to kernel level anticheat then? would be nice if they get kicked in the face for the anti-linux decision they made so we can start playing again :P

[-] [email protected] 8 points 6 hours ago

Yes, linux does not work exactly because they require this kernel level anticheat. But guess which os is supported without this anticheat.. MacOs...

load more comments (1 replies)
[-] [email protected] 1 points 4 hours ago

I just itch my moba itch with dota

[-] [email protected] 1 points 4 hours ago

I tried Dota but it feels too different :(

[-] [email protected] 53 points 11 hours ago

Sure hope not. If I wanted to run rookits I'd just use Windows. Why bother with Linux?

This is why I don't want more Linux adoption and don't understand people cheering every new user. We're in a sweet spot where a lot of games enable userland anticheat while we don't get kernel level ports (however they may be shipped doesn't matter). The only thing that'll come out of more adoption is kernel level anticheat ports that'll probably work with a few corporate backed distros only and we'll actually lose the games we have today. Because those will switch over the kernel level alternatives too.

The only way I'd like Linux to be a generic multiplayer platform is server side anticheats. It is very obviously the way to go and we are seeing extremely slow adoption (e.g. Marvel Rivals).

[-] [email protected] 5 points 3 hours ago

On one side, I'm one of those glad for people coming to Linux because Linux is truly fantastic and it can make your life easier on many things, I'm happy for them.

On the other side, I share your concerns, because everything that gets adopted by the masses is inevitably subject to enshittification, I would never want that to happen to Linux.

We should find a sweet middle-point tho I have no idea what that would be.

[-] [email protected] 2 points 4 hours ago* (last edited 4 hours ago)

TBH I'm not sure wider adoption would worsen things ? Gaming distros would probably ship bullshit anticheat modules by default while the others would not, or at most provide some documentation on how to opt in.

I think it's quite similar to the situation with NVIDIA proprietary drivers? (I don't own a graphics card so I'm not super aware on this topic)

[-] [email protected] 2 points 3 hours ago

My point is you would either have to run those modules on Linux or not play the games. Which is the same as running them on Windows or not play the games with the exception that you'd lose the games that run on Linux with userland anticheat now.

[-] [email protected] 4 points 6 hours ago

It is probably actually easier to create on linux as it is foss and there are also good projects like eBPF which can maybe even simplify and make it more secure.

[-] [email protected] 9 points 8 hours ago

Meanwhile in indie land, I just tried to cheat my way through a Chapter 3 minigame in Deltarune, and Toby Fox himself showed up in his dogsona to blow up the game and make me start the minigame over.

This is the extent to which anti-cheat measures should go.

[-] [email protected] 31 points 11 hours ago

I think its less a question of the technical feasibility, and more of an issue that we, as users, don't want more closed-source blobs in our kernels. Meanwhile, the publishers insist that they can't open-source their anti-cheat code; Their idea being that if we know what's in it, it will be easier to bypass.

Basically, one distro or a few(at most) may get anti-cheat integrated one day(like, say, SteamOS), but it will likely never be in your standard Linux kernal.

They could go the rought of kernel modules, I would think, but for whatever reason, we're still having this conversation.

[-] [email protected] 4 points 8 hours ago* (last edited 8 hours ago)

Basically, one distro or a few(at most) may get anti-cheat integrated one day(like, say, SteamOS), but it will likely never be in your standard Linux kernal.

Valve also has server side anticheat in his games (Counter Strike or Deadlock). They are also against it.

Kernel-level anticheats can be bypassed anyways, but they are the easy solution for the corps that want to sell their multiplayer game.

[-] [email protected] 2 points 7 hours ago

@MachineFab812 @SpiderUnderUrBed even if you have steamOS, what keeps you from downloading kernels from kernel.org and building?

[-] [email protected] 9 points 9 hours ago

One way I can imagine it being some certified Linux kernel versions that are accepted and worked together with anticheat creators. That way Valve could use the Kernel in Steam Deck or SteamOS, so any game works out of the box. And other distribution users can just install this Kernel too, if their distributions provide it.

Anyone who don't want to have Kernel level anticheat systems enabled on their system, do not need to install the Kernel. Therefore they are secure against it. But for anyone else who wants it, they can. At least this option would be a compromise.

[-] [email protected] 3 points 8 hours ago

if it's linux, it has to be open source. If it's open source, people will code around it immediately. How about not trying to shoehorn this useless crap in the first place?

[-] [email protected] 8 points 8 hours ago

It doesn’t have to be open source. There’s plenty of binary firmware and drivers around.

[-] [email protected] 2 points 8 hours ago

Besides your argumentation that open source is less secure, a driver or program does not need to be in the Kernel to work with it. Does it? Kernel level anti cheat systems are available on Windows too, without being in the Windows Kernel. All it needs is a Kernel module to load it separately. Something like the Nvidia proprietary driver. I don't know if this would work for Anticheat.

Back to your point of open source and code around it. Well they code around the proprietary tools too. Reverse engineering stuff is possible. So your argumentation is a bit weak. Open Source means more people are looking into and its actually more secure and up to date (for common and actually developed drivers).

And you don't have to use it, if you don't like. How about letting people give options instead calling something they want or need being useless? It has a use and reason, so its by definition not useless. Instead using Windows, they could use Linux.

load more comments (2 replies)
load more comments (1 replies)
[-] [email protected] 23 points 11 hours ago

Absolutely nothing prevents somebody from writing a kernel level anticheat on Linux.

Users would throw a fit, and it would be way easier to bypass, but it certainly could be made.

[-] [email protected] 3 points 9 hours ago

It would need to be open source, distributing proprietary kernel modules is a nightmare that can cause the OS to fail to boot after every kernel update. An open source anticheat kernel module would probably be useless and easy to bypass.

[-] [email protected] 10 points 9 hours ago

It doesn't "need" to be anything. It could be a DKMS module that is mandatory for playing a game.

Whether people would like it and use it is a completely different story.

[-] [email protected] 11 points 9 hours ago

I'm not a programmer or cheater or anything, but I think the answer is yes and no. Yes it could technically be done and even work as intended as long as the device is locked down to prevent the user from replacing the shipped kernel (which would be a bad thing for users). However, savvy people could (in theory) make custom kernels that lie to the kernel module, causing the module to report there is no cheating when there is. It's my understanding that it's close to the current situation with Windows and virtual machines and anticheat: you can cheat by running your game in a VM and then have that virtual hardware extract secret information or flip bits in the right spots. Most competitive games will refuse to run in a VM for this reason.

[-] [email protected] 2 points 6 hours ago

Kernel level anti cheats require secure boot. You can't just "lie" and load an unsigned kernel.

[-] [email protected] 6 points 5 hours ago* (last edited 5 hours ago)

You can add your own signing keys to the UEFI and boot an modified bootloader and Kernel that you have signed yourself. So yes, it is possible to "lie"

For such a locked down system, akin to game consoles or smartphones, would be needed. And even those get jail broken and manipulated, so "total security" on there is not complete but easier to check and ensure. Another way to make sure that the code is not manipulated would be to put all those games into the cloud and have every player only play via streaming. All the code would then run on secured, locked down and verified machines.

[-] [email protected] 2 points 4 hours ago* (last edited 3 hours ago)

Another technique that helps is to limit the amount of information shared with clients to need to know info. This can be computationally intensive server-side and hard to get right .. but it can help in many cases. There are evolving techniques to do this.

In FPS games, there can also be streaming input validation. eg. Accurate fire requires the right sequence of events and/or is used for cheat detection. At the point where cheats have to emulate human behaviour, with human-like reaction times, the value of cheating drops.

That's the advanced stuff. Many games don't even check whether people are running around out of bounds, flying through the air etc. Known bugs and map exploits don't get fixed for years.

[-] [email protected] 1 points 5 hours ago

And then your keys will be rejected by the anticheat. Just because you can sign your kernel and load it does not mean a kernel module can't verify who signed it.

[-] [email protected] 1 points 4 hours ago

Yes, but with a modified Kernel you can fake what the anticheat reads when it checks the key, so you just feed it the key it wants to see instead of your own. The anticheat module would need run on a higher level then the Kernel itself to prevent that, for example alongside the CPU (like the Intel Management Engine).

[-] [email protected] 1 points 3 hours ago

I am not an expert on secure boot so I can't tell whether that's possible or not. But if it is, what stops people from doing that with Windows now?

[-] [email protected] 1 points 2 hours ago

You can't really change the code of the windows Kernel and boot your own, that's one of the things stopping people now

[-] [email protected] 1 points 5 hours ago

This is where TPMs, measured boot, and remote attestation come in.

You can run whatever kernel you want, but if it is not an approved kernel, you wouldn't be able to attest to running an approved kernel; allowing whatever DRM scheme the developer put in to active.

I believe this is how the higher levels of Android's Play Integrity system work.

[-] [email protected] 13 points 11 hours ago

It already works, but studios using anticheats that DO support Linux CURRENTLY don't bother implementing it because we're maaaaaybe 3% of the market on a good day, so they say "fuck it" and don't expend a few dev hours to enable it because they see it as a pain to deal with v users who need it.

[-] [email protected] 5 points 8 hours ago

we're maaaaaybe 3% of the market on a good day, so they say "fuck it"

So true. And worse than that, we're probably also the 3% most likely to skip buying a game that requires anti-cheat, anyway. Many of us are famously un-friendly toward closed source code running with invasive permissions.

[-] [email protected] 9 points 11 hours ago

AFAIK the current anticheat systems on Linux only run in userspace not at kernel level. This does mean Linux is theoretically easier to bypass compared to windows, some games just dont seem to want to take that risk. For as you said 3% of the market.

I personally disagree with that stance though, because all it takes is a hardware device and all software anticheats are useless no matter the os (think a raspberry pi, and capture card). So anticheat is really a losing battle anyways.

load more comments (1 replies)
[-] [email protected] 5 points 10 hours ago

It's a lot more than just "a few dev hours". You need to invest in training your testers on Linux, potentially purchasing new hardware, invest in programmers that can deal with writing for Linux, etc... Just because something like BattlEye has a checkbox for Linux support doesn't mean that all it takes is to click the button and rebuild your game.

[-] [email protected] 8 points 10 hours ago

I hope to fuck not.

[-] [email protected] 5 points 10 hours ago* (last edited 10 hours ago)

Is it possible to have kernel-level anti-cheat in Linux?

Yes, Absolutely. But, people would throw a fit. There is probably no way to opensource it without also making it easier to bypass. There would be a concerted effort to reverse engineer it and remove it from the system while maintaining functionality

Maintainers of anti-cheat software are not volunteers. If there was an order from management to port the system to Linux, it would happen. It's just that with the Linux userbase as small as it is, it's simply not profitable to cater to them.

I think that if it ever happens, there will be a influx of people moving to linux, or abandoning their duelboots

I fully disagree. The thing keeping regular people away from Linux as an OS is not that they can't play some online game with Anti-cheat.

Linux is in a weird place right now. It's actually a perfect fit for non-technical users that use their computers for email, web browsing, and Netflix, but those users don't know what an operating system is, let alone that there are options. More technical users tend to require more specialized applications, and if there isn't a native linux port available, you have to do some research for alternatives, or to find a way to run it in wine.

Windows is shitty, but it's comfortable. And I know that it will run any software I throw at it with basically no research or troubleshooting.

[-] [email protected] 5 points 9 hours ago* (last edited 9 hours ago)

There is probably no way to opensource it without also making it easier to bypass.

I want to highlight this in case OP missed it. Your point here is critical.

Now I'm going to nerd out a bit about it:

To expand on your points above (for OP), there's an impasse here between the anti-cheat developer and the distro developers.

The anti-cheat developer needs support from the distro developer to get their anti-cheat packages signed, to allow them to run in the kernel. Any package not signed by the distro developer that tries to run at kernel level will be treated by the OS as a virus. (Windows has this protection as well.)

Getting the code signed is pretty easy. The only requirement is sharing the source code, so the distro developers can make sure there's nothing nasty in it.

But the anti-cheat developers feel that they need to never share their source code, to prevent cheating. In some cases, they have even have contracts that prevent them from legally sharing parts of their source code (if licensed from a third party).

That's also not a problem. All they have to do is sign a binding contract for secrecy with every contributor to the distro, and then privately share their source code, and get it signed.

On Windows, that means signing a contract with Microsoft. On Mac, with Apple.

But on Linux, is just means tracking down and making separate agreements with a few thousand independent individuals...

So the technical solution is pretty simple: share code, get code signed, run in kernel.

But the contrasting needs of everyone involved make it unlikely on Linux.

Interestingly, an Anti-cheat developer who felt very confident that their code was unbeatable, could just publish it publicly, and get it signed and running quite quickly.

But uh... Most anti-cheat is also pretty low quality code, according to most estimations.

load more comments (1 replies)
load more comments
view more: next ›
this post was submitted on 08 Jun 2025
54 points (96.6% liked)

Linux

54950 readers
463 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 6 years ago
MODERATORS