Follow Slashdot stories on Twitter

 



Forgot your password?
typodupeerror
Security Linux

Hackers Can Now Bypass Linux Security Thanks To Terrifying New Curing Rootkit (betanews.com) 40

BrianFagioli writes: ARMO, the company behind Kubescape, has uncovered what could be one of the biggest blind spots in Linux security today. The company has released a working rootkit called "Curing" that uses io_uring, a feature built into the Linux kernel, to stealthily perform malicious activities without being caught by many of the detection solutions currently on the market.

At the heart of the issue is the heavy reliance on monitoring system calls, which has become the go-to method for many cybersecurity vendors. The problem? Attackers can completely sidestep these monitored calls by leaning on io_uring instead. This clever method could let bad actors quietly make network connections or tamper with files without triggering the usual alarms.

This discussion has been archived. No new comments can be posted.

Hackers Can Now Bypass Linux Security Thanks To Terrifying New Curing Rootkit

Comments Filter:
  • by Bert64 ( 520050 ) <bert.slashdot@firenzee@com> on Thursday April 24, 2025 @10:11AM (#65327633) Homepage

    io_uring is an optional kernel feature, which you can turn off or compile out if you're not using...

    • by Chris Mattern ( 191822 ) on Thursday April 24, 2025 @10:14AM (#65327641)

      Most people don't tune their kernels, much less compile them. The question is, is it turned on in the stock kernel of the distro you're using?

      Of course, if it is, this being made public mean it won't be for long. If you do your updates, I'd expect you'd be fine.

    • by mysidia ( 191772 ) on Thursday April 24, 2025 @10:19AM (#65327663)

      Also.. Linux "Security" is Not 3rd party antimalware programs that monitor syscalls.

      No Linux security has been defeated by the existence of the rootkit. Security was defeated when an intruder gained root.

      Security is the kernel's permissions and access control models. Things like non-root processes not having access to execute privileged operations.

      It sounds like the only thing that has been bypassed are EDR programs; tools such as Crowdstrike, Palo Alto Cortex, Microsoft Defender, Carbonblack, SeintnelOne which are not Linux security but Enterprise tools which attempt to monitor Linux systems.

      • by _merlin ( 160982 ) on Thursday April 24, 2025 @10:53AM (#65327773) Homepage Journal

        SELinux, a Linux security feature, depends heavily on monitoring system calls. The whole Linux security module system is largely based around monitoring system calls. It seems they didn't consider providing a mechanism for security modules to monitor io_uring for nefarious activity.

      • If io_uring requires root then this is a nothingburger.

        Raymond Chen, Microsoft developer, uses the phrase "It rather involved being on the other side of this airtight hatchway" to refer to such "exploits".

        • by Brain-Fu ( 1274756 ) on Thursday April 24, 2025 @11:56AM (#65327951) Homepage Journal

          The linked article is very light on details. I did a little searching around and it appears that one does, in fact, need root in order to set up io_uring, though it can also be done with sudo, and it looks like it is possible to set things up so it can subsequently be used for specific operations without root (though I am unsure about that).

          Apparently this isn't actually news, as the library has been under criticism for this sort of thing for a while. Some distributions, such as Ubuntu, don't use it by default, so you would have to go out of your way to set that up in those cases.

          Though my knowledge here is only as good as what I found in a few blog posts as I was searching around, so please feel free to correct me.

          • by _merlin ( 160982 ) on Thursday April 24, 2025 @12:51PM (#65328073) Homepage Journal

            To understand this, you need to take a step back and remember that root is a blunt instrument, but one you need to use frequently. This is why we have things like SELinux to give more fine-grained control over what things running as root can do.

            Consider a mail delivery agent. It needs to run as root because it has to be able to change uid/gid to the user that it's delivering mail for to access their mailbox, and that's something only root can do. But this is bad, because it means a but in the mail delivery agent could be exploited to anything root can do.

            So to mitigate this, we create an SELinux policy that says the only thing the mail delivery agent can do while running as root is read its configuration, accept a connection from the MTA, and switch to a non-root user/group. We create another policy that while running as a non-root user, the mail delivery agent is only allowed to access directories and files labelled as "user mailbox" content. (This is over-simplified, but you get the idea.) This greatly mitigates what an exploit can do. Now all it can do is impersonate a user and corrupt their mail. It can't even easily exfiltrate their mail, as it can't make connections or copy it to another location.

            The vulnerability here is that SELinux (and other Linux security modules) can't monitor what a process does via io_uring. So in this example, if the mail delivery agent is allowed to create an io_uring, an exploit may gain the ability to read/write any file/device and make network connections, and SELinux won't be able to stop it. This makes mitigations a lot less effective.

            This has been known since at least 2023. Android doesn't allow apps to use io_uring, ChromeOS has io_uring disabled completely, Docker doesn't allow use of io_uring from inside containers, and I think Ubuntu might have io_uring disabled by default, too.

            Now io_uring is useful and can give a big performance improvement, but mostly for processes that fall into a few categories: doing a lot of I/O, managing large numbers of network connections, and requiring low end-to-end latency. This is generally stuff like database servers, real-time streaming services (video streaming, telephony), electronic trading when you have a fast connection to the exchange, etc. You aren't likely to be running a lot of this stuff on your desktop.

            The article and the summary are alarmist clickbait. It's basically a known issue, but the mitigation of not allowing io_uring for the majority of processes is probably viable for most people.

            • by mysidia ( 191772 ) on Thursday April 24, 2025 @08:13PM (#65329155)

              and I think Ubuntu might have io_uring disabled by default, too.
              Eh?

              Linux s1 6.8.0-57-generic #59-Ubuntu SMP PREEMPT_DYNAMIC Sat Mar 15 17:40:59 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux
              root@s1:~# lsb_release -sd
              No LSB modules are available.
              Ubuntu 24.04.2 LTS
              root@s1:~# grep URING /boot/config-$(uname -r)
              CONFIG_IO_URING=y
              root@s1:~# sysctl -a|egrep uring
              kernel.apparmor_restrict_unprivileged_io_uring = 0
              kernel.io_uring_disabled = 0
              kernel.io_uring_group = -1

              This has been known since at least 2023. Android doesn't allow apps to use io_uring
              Yeah, about that... Android uses their SELinux policy to restrict access to io_uring, so that only trusted system apps can use it. It sounds like some of these system apps do actually benefit from uring and require it. So maybe SELinux is a bad example to be using here, since it doesn't really "break" SELinux. SELinux cannot monitor what uring is doing with granularity. It is up to the admin to choose a proper policy for their SELinux setup. The negligence many people run into is just adding complicated security software and leaving Default system policies that came with your system or apps in place.

              ChromeOS has io_uring disabled completely

              Google disabled uring in ChromeOS not because of a vulnerability, but because it is Very useful for attackers after exploitation; Most of the attacks would use uring after already compromising the system, and they have not found a means to sandbox uring to mitigate damage following successful attack.

              This is why we have things like SELinux to give more fine-grained control over what things running as root can do.

              Except when SELinux is not very fine-grained, because SELinux is not necessarily aware of every application and kernel addon. Since SELinux is an extension and not a core part of Linux.. It's kind of the job of a Sysadmin who has installed and chosen to use the SELinux kernel extensions and addon software to make certain that SELinux is aware and compatible of every component of your particular kernel and has suitable policies defined.

              Redhat has come to mind as the only distribution that provides SE Linux as available by default, and a huge issue with Redhat is Every 3rd party piece of software you'd actually need to put on your system to use it in the real world tells you to turn off SELinux as a required install step. And even if you don't the admin retains the burden of defining a whole detailed systemwide MAC policy, whereas few bother to do so.

              Consider a mail delivery agent. It needs to run as root because it has to be able to change uid/gid to the user that it's delivering mail for to access their mailbox

              Except a mail delivery agent doesn't need root at all. SELinux is not necessary. And this software is not designed to require SELinux to be secure or avoid such situations, in the first place. Generally you would design this service to run between dedicated users for example a postfix:mail user and a nobody:nogroup user.

              Changing UIDs does not require root access anyways; the privileged portion of your service IF you have one: only requires certain features which can be sectioned using the uid, euid, gid, egid, suid, and sgid, filesystem ACLs, and POSIX Capabilities list of the process.

              You can have a single process running as postfix:mail whose sole purpose in life is to Open a user's mailbox file and transfer control over a writable descriptor to that open file using sendmsg() over to the separate MDA process which runs as nobody:nogroup.

              You can also have the Mailbox files grant group ownership to the mail group allowing the system mail daemon to write the mailbox file where the MDA program runs as a member of the 'mail' group, and the mail group is granted through Ext3 filesystem ACLs group write access to user mailboxes.

              Choose a secure MDA, and the only time a part of it has to run as root is while your system is running its init unit during system boot.

              • by _merlin ( 160982 )

                Every 3rd party piece of software you'd actually need to put on your system to use it in the real world tells you to turn off SELinux as a required install step.

                News to me. I run all my Internet-facing Linux servers with SELinux in enforcing mode. It's a bit of work to implement policies and labelling rules, but it works. Most of the people I hear saying to disable SELinux are slashdot commenters and people on IRC.

                And even if you don't the admin retains the burden of defining a whole detailed systemwide

        • If io_uring requires root then this is a nothingburger.

          Raymond Chen, Microsoft developer, uses the phrase "It rather involved being on the other side of this airtight hatchway" to refer to such "exploits".

          That follows, pretty stereotypically, exactly how one might expect a Microsoft developer to reason. But, in practice, that "airtight" hatchway is surprisingly leaky - local privilege escalation exploits exist as well, and pop up regularly. So it just means a remote attacker needs to take advantage of two (or more) vulnerabilities to get at this - a remote access exploit followed by local privilege escalation. And, if you've paid attention over the past decade or more, you'll know the bad guys are used to do

    • by Mr. Dollar Ton ( 5495648 ) on Thursday April 24, 2025 @10:31AM (#65327701)

      It seems that in Debian testing at least it is present:

      grep -i uring /boot/config-$(uname -r)
      CONFIG_IO_URING=y

      • by mysidia ( 191772 ) on Thursday April 24, 2025 @10:40AM (#65327735)

        It's also enabled in Ubuntu 24.04.2 LTS' kernel 6.8.0-57-generic.

        • Yeah, so if there is indeed a rootkit going around and if it does what it is claimed, it probably makes sense to recompile without it.

          I'll read up on it later to decide how "terrifying" this new scourge is, TFS is a bit unclear on what's going on.

          • by _merlin ( 160982 ) on Thursday April 24, 2025 @11:00AM (#65327791) Homepage Journal

            The "rootkit" mentioned in TFA is just a proof of concept demonstrating that you can use io_uring to avoid being monitored by Linux security modules like SELinux or AppArmor. It isn't being used by malware in the wild.

            The trouble with disabling io_uring is that you'll get a pretty substantial performance hit in applications that actually use it. The Linux AIO API was basically broken. It only worked on files, only on portions of files that are already allocated, and in many situations an operation would unexpectedly become synchronous. The io_uring API was created to solve these issues. Things like databases or services that manage large numbers of network connections benefit substantially from io_uring. You could end up needing more servers to handle the same load as well as getting poorer end-to-end latency with it disabled.

            • by Mr. Dollar Ton ( 5495648 ) on Thursday April 24, 2025 @11:15AM (#65327837)

              Yeah, apparently it is so; hence one has to first check if something they need is using it, assess the risks and benefits of leaving it on (which to me isn't a straightforward thing to do right away) and then to consider what measures to take, if any, to alleviate those risks.

              Someone posted a link to an informative article from 2022, but it is hard to see how much of it applies today, as it seems some things were done to mitigate the issues since then.

              So I guess now that everyone and their dog is aware of the potential problem, we'll see the followup on LKML and then try to figure out what to do. As you say, this doesn't appear to be the immediate risk the word "terrifying" in the TFS is implying.

              • by _merlin ( 160982 )

                As you say, this doesn't appear to be the immediate risk the word "terrifying" in the TFS is implying.

                Correct, that part's just clickbait bullshit.

            • Alright, I'll cut right to the chase. What's the chances any video games actually need this thing for performance? If I'm just running a regular desktop for basic productivity, communication and entertainment tasks, not like a web or database server, do you think it's safe to disable out of an abundance of caution?

              • by _merlin ( 160982 )

                The first question is, are you using SELinux, AppArmor or some other Linux security module to monitor your system and enforce permissions? If not, this "exploit" is irrelevant. It's just a way to bypass security modules. If you aren't using a security module, it won't allow processes to do anything they couldn't do anyway.

                Video games definitely won't be using io_uring. About the only "desktop" application I can think of that might benefit is digital audio workstation and real-time audio stuff. Are you

        • Ah, I see you've answered that second question in your above post and it appears this isn't some sort of active exploit. Oh, well...

      • It's also enabled by default in Mint 21.3.

        How does one turn this off, and should it be turned off or disabled?

      • by jmccue ( 834797 ) on Thursday April 24, 2025 @10:56AM (#65327781) Homepage

        From what I can see, Slackware has it compiled in:

        cd /usr/src/linux-5.15.161/

        grep CONFIG_IO_URING .config

        CONFIG_IO_URING=y

    • by Tailhook ( 98486 ) on Thursday April 24, 2025 @10:35AM (#65327721)

      Google and others already turn off io_uring. io_uring is not available to apps in android, it's off entirely in ChromeOS and off on Google's own servers. Docker blocks io_uring calls by containers (by default) as well.

    • The other solution might be to turn it off when building everything but the most trusted applications. If you've got a performance critical database, go ahead and build the dbms system with it. For stuff like mystery apps you grab off the Internet, or apps that can pull in scripts and stuff, turn it off in their build.

  • by davidwr ( 791652 ) on Thursday April 24, 2025 @10:49AM (#65327757) Homepage Journal

    From Security requirements for new kernel features [lwn.net], Jonathan Corbet, July 28, 2022:

    "A recent discussion about security hooks for the new uring_cmd mechanism shows how easily requirements can be overlooked in a complex system with no overall supervision."

    [Corbet quoting from another source]
    "You're passing the complexity of uring-cmd directly into each and every security module. SELinux, AppArmor, Smack, BPF and every other LSM now needs to know the gory details of everything that might be in any arbitrary subsystem so that it can make a wild guess about what to do. And I thought ioctl was hard to deal with."

    There's more there and elsewhere [wikipedia.org].

  • then blacklist it, otherwise prepare to rebuild your kernel by first run make oldconfig then find that feature and disable it save and rebuild, you will have the same kernel minus the vulnerability
  • by Anonymous Coward

    This also impacts Windows as WSL is used to leverage the ubuntu Linux kernel that also has this enabled, intentionally.

    Imagine the power they have over your Windows machine by having root control of a Windows kernel running on your machine that's loading a Linux kernel that they have full control over.

  • by SlashbotAgent ( 6477336 ) on Thursday April 24, 2025 @11:14AM (#65327833)

    So I can bypass Linux security by hiding inside an SSL channel?

    A blindspot in 3rd party monitoring software is NOT a security bypass. It is a deficiency in the monitoring software.

    The world has changed. Tripwire and Clam-AV are not adequate protections, if they ever were.

    • Awww, come on, didn't you get immediately scared when you saw "terrifying" and "root kit" in the summary :)

      • Re: (Score:3, Funny)

        by Anonymous Coward

        I'm shaking in my reboots.

      • I never get worked up about anything mentioning "root kit". If you've gotten a root kit onto my machine, it's game over anyway.

  • by jd ( 1658 ) <imipak AT yahoo DOT com> on Thursday April 24, 2025 @11:42AM (#65327903) Homepage Journal

    Why are they monitoring syscalls?

    The correct solution is surely to use the Linux Kernel Security Module mechanism, as you can then monitor system functions, regardless of how they are accessed. All system functions, not just the ones that have provision for tracepoints.

    For something like security software, you want the greatest flexibility for the least effort, and Linux allows you to do just that.

    Because it's fine-grained, security companies can then pick and choose what to regard or disregard, giving them plenty of scope for varying the level of detail. And because the LSM allows services yo be denied, there's a easy way for the software to stop certain attacks.

    But I guess that the obvious and most functional approach would mean that the vendors would have to write a worthwhile product.

  • by hebertrich ( 472331 ) on Thursday April 24, 2025 @12:02PM (#65327961)

    The link is to an article talking about a vendor product.
    No normal source of information about this bug is talking about it anywhere.
    If it were genuine and important, we'd already have gotten word about this and bug fixes in our distro
    s updates.

    For now it's on ignore as far as i'm concerned.

    • That's not always true. It's not uncommon for info about bad vulnerabilities to get embargoed until patched, and we've also seem attention-seeking dolts prematurely break such embargoes before.

      Note that I'm not claiming that's what happened here.

  • At this time the attackers already have already compromised the system. Relying on anything on that compromised system for detection of that compromise seems to be quite foolish to me.

Waste not, get your budget cut next year.

Working...