Copy Fail – CVE-2026-31431

(copy.fail)

214 points | by unsnap_biceps 2 hours ago

30 comments

  • smlacy 54 minutes ago
    The fetishism of "byte count" (here, as "732 byte python script") needs to stop, especially when in a context like this where they're trying to illustrate a real failure modality.

    Looking at their source code [1] it starts with this simple line:

    import os as g,zlib,socket as s

    And already I'm perplexed. "os as g"? but we're not aliasing "zlib as z"? Clearly this is auto-generated by some kind of minimizer? Likely because zlib is called only once, and os multiple times. As a code author/reviewer, I would never write "os as g" and I would absolutely never approve review of any code that used this.

    Anyway, I could go on. :) Let's just stop fetishizing byte count

    [1] https://github.com/theori-io/copy-fail-CVE-2026-31431/blob/m...

    • fragmede 0 minutes ago
      Then go on. zlib is only used once, so "zlib as z" in exchange for using z once doesn't get you anything, and then os is used multiple times, so "os as g" is a wash. It's 732 bytes either way.

      https://gist.github.com/fragmede/4fb38fb822359b8f5914127c2fe...

    • tptacek 30 minutes ago
      I don't get the 732-byte thing either and while I think it's a relatively punchy and unusually informative landing page for named vulnerability there are little snags like this all over it.

      But the fact that it's not a kernel-exec LPE and it's reliable across kernels and distributions is important; it's close to the maximum "exploitability" you're going to see with an LPE. Which the page does communicate effectively; it just gilds the lily.

    • debo_ 34 minutes ago
      I don't see it as fetishizing byte count. I think of it as a proxy measure for how complicated or uncomplicated the exploit might be. They could just as well have said "we can do it in 3 lines of python" or "the Shannon entropy of the script implementing the exploit is really small" and I would have interpreted it similarly.

      Where do you see this "fetishizing" happening most often? It's a strange thing to counter-fetishize about.

    • embedding-shape 50 minutes ago
      > I would absolutely never approve review of any code that used this.

      How often do you review, and subsequently block the release, of PoCs in this sort of context? Sounds like you've faced this a lot.

      I always thought code quality mattered less in those, as long as you communicate the intent.

      • Xirdus 15 minutes ago
        If you have a choice between posting minimized exploit code, and posting regular exploit code, posting minimized code is virtually always the wrong choice.

        If you have a choice between pointing out the byte size of the exploit, and not pointing out the byte size of the exploit, pointing it out is virtually always the wrong choice.

        In both cases, doing the right thing is less work. So somebody is going the extra way to ensure they are doing it wrong. If they didn't care, they'd end up doing it right by default.

      • opello 22 minutes ago
        While not formally reviewing code like this, I read a lot of it for fun. When it's clear and understandable, it's more educational and enjoyable. If the PoC code can also serve as a means of communication, that seems like an extra win.
    • ok123456 38 minutes ago
      This is pretty legible compared to the 90s C rootshell.org exploits.
    • refulgentis 49 minutes ago
      It's just lazy AI* writing w/0 editing.

      "Just" is doing a lot of work there, I'm so annoyed reading it.

      It's like an anti-ad and they had pretty cool material to work with.

      * Claude loves stacatto "Some numeric figure. Something else. Intensifier" (ex. the "exploitable for a decade." or whatever sentences)

      • bonzini 7 minutes ago
        Completely without editing, to the point of hallucinating a RHEL version (14.3) that doesn't exist.
    • john_strinlai 49 minutes ago
      >As a code author/reviewer, I would never write "os as g" and I would absolutely never approve review of any code that used this.

      lucky for them, its an exploit script, not enterprise code.

      all that needs to be "reviewed" is whether or not it exploits the thing its supposed to.

      • Xirdus 8 minutes ago
        I'd imagine that at minimum, the team in charge of patching the vulnerability would need to review how the exploit works.
        • john_strinlai 7 minutes ago
          id imagine that they received more than just the poc in the report they received
  • xeeeeeeeeeeenu 48 minutes ago
    It seems there was some kind of confusion during the disclosure process, because the vendors aren't treating this vulnerability as serious and it remains unpatched in many distros.

    https://access.redhat.com/security/cve/cve-2026-31431 "Moderate severity", "Fix deferred"

    https://security-tracker.debian.org/tracker/CVE-2026-31431

    https://ubuntu.com/security/CVE-2026-31431

    https://www.suse.com/security/cve/CVE-2026-31431.html

    • MarleTangible 34 minutes ago
      Seems like distros consider it a medium risk because it doesn't involve remote code execution and requires local access. Though it allows local root privilege escalation which is considered high priority.

      https://ubuntu.com/security/cves/about#priority

      > Medium: A significant problem, typically exploitable for many users. Includes network daemon denial of service, cross-site scripting, and gaining user privileges.

      • oskarkk 29 minutes ago
        Strange that it's not classified as "high", which specifically includes "local root privilege escalations".

        > High: A significant problem, typically exploitable for nearly all users in a default installation of Ubuntu. Includes serious remote denial of service, local root privilege escalations, local data theft, and data loss.

    • Tuna-Fish 35 minutes ago
      Yeah, by ubuntu's own guidelines linked on that page, this should be priority: high, but instead it's marked as medium.
  • jzb 1 hour ago
    This is amazing. Page says it works on RHEL 14.3, which doesn’t exist. Current RHEL is 10.x, this must’ve been done in a TARDIS.
    • bryanlarsen 59 minutes ago
      On the same line it says kernel version 6.12.0-124.45.1.el10_1. Which is RHEL 10. This is the kind of typo that humans make -- the hard to type numbers are accurate because they're cut and pasted, but the "easy" numbers have errors because they're not cut and pasted.
    • rdtsc 1 hour ago
      > This is amazing. Page says it works on RHEL 14.3, which doesn’t exist. Current RHEL is 10.x, this must’ve been done in a TARDIS.

      Indeed. "Distributions we directly verified: RHEL 14.3". Directly verified by me to be AI slop (the release page at least).

      https://access.redhat.com/articles/red-hat-enterprise-linux-...

      > Talk to our security experts

      (at the bottom of the page)

      I have a sneaking suspicion his first name is Claude. Don't get me wrong though, he is pretty good I hear.

      • tptacek 1 hour ago
        I have no idea about this page, but Theori/Xint has a staff of veterans, they are a serious thing.
        • rdtsc 1 hour ago
          The fact that they have no idea RHEL 14, probably the most well known enterprise distro, is not a thing, and yet they "directly verified on it" casts some doubt on seriousness.
          • tptacek 1 hour ago
            I don't know what to tell you. I'm sure you have them dead to rights on Linux distro knowledge reliability, but the exploit here is real, and the vulnerability researchers they have on staff are also real. Xint is not generally a slop factory.

            It's ironic that the one thing LLMs can't do reliably in this space is "write copy for humans" (I don't trust them for that either).

          • stackghost 56 minutes ago
            Is it more likely they have no idea what version RHEL is on, or that it's just a typo?
  • rkeene2 6 minutes ago
    Interestingly it fails for me because my `su` isn't world-readable:

      $ stat /bin/su
        File: /bin/su
        Size: 59552           Blocks: 118        IO Block: 59904  regular file
      Device: 0,52    Inode: 796854      Links: 1
      Access: (4711/-rws--x--x)  Uid: (    0/    root)   Gid: (    0/    root)
      Access: 2023-09-18 13:23:03.117105665 -0500
      Modify: 2021-02-13 05:15:56.000000000 -0600
      Change: 2023-09-18 13:23:03.119105665 -0500
       Birth: 2023-09-18 13:23:03.117105665 -0500
    
    I'm not sure I have any setuid/setgid binaries that are world-readable...
  • aniou 3 minutes ago
    Looks like a LLM hallucination - there is no thing like "RHEL 14.3", although referenced kernel signature (6.12.0-124.45.1.el10_1) contains reference to real RHEL release, i.e. 10.1.
  • embedding-shape 1 hour ago
    For mitigation, the page currently basically just says:

    > Update your distribution's kernel package to one that includes mainline commit a664bf3d603d

    But it isn't very clear to me what Kernel version you can expect that to be in. For Arch/CachyOS, the patch seems to be included in 6.18.22+, 6.19.12+ and 7.0+. If you're on any of the lower versions in the same upstream stable series, you're likely vulnerable right now. Some distro kernels may include the fix in other versions, so check for your distribution.

    • kro 1 hour ago
      Major os vendors will publish pages with the fixed versions:

      https://security-tracker.debian.org/tracker/CVE-2026-31431

      https://ubuntu.com/security/CVE-2026-31431

      Also, disabling algif_aead is suggested as mitigation

      • 1p09gj20g8h 53 minutes ago
        Where are you seeing the disabling algif_aead mitigation?
        • oskarkk 49 minutes ago
          In TFA: https://copy.fail/#mitigation

          > Before you can patch: disable the algif_aead module.

          > echo "install algif_aead /bin/false" > /etc/modprobe.d/disable-algif.conf

          > rmmod algif_aead 2>/dev/null || true

          Edit: and I can confirm that on my system with kernel 6.19.8 the above fixes the exploit.

    • nh2 32 minutes ago
      On a git repo that has as remotes

          https://github.com/torvalds/linux.git
          https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git as remotes:
      
      running a search for commit a664bf3d603d's commit message:

          git log --all --grep 'crypto: algif_aead - Revert to operating out-of-place' '--format=%H' | xargs -I '{}' git tag --contains '{}' | sort -u
      
      outputs these tags as having the fix:

          v6.18.22
          v6.18.23
          v6.18.24
          v6.18.25
          v6.19.12
          v6.19.13
          v6.19.14
          v7.0
          v7.0.1
          v7.0.2
          v7.0-rc7
          v7.1-rc1
  • phreack 1 hour ago
    The page itself seems vibecoded and a bit of an advertisement, but it does look like the vulnerability is real and high risk. It does explain the big security update I just got, guess I'll prioritize updating today.
  • bblb 1 hour ago
    What is "RHEL 14.3"? Was this site a one shot prompt. Quality.
  • not_your_vase 2 hours ago
    Is there a readable version of the exploit readily available by any chance? Gotta admit that I failed binary-zip-interpretation-with-naked-eye class twice
    • progval 1 hour ago
      The binary "zip" isn't the exploit, it's the shellcode. The exploit is the rest, which changes the code of a SUID executable (su).
  • dgellow 1 hour ago
    That’s the most AI-written page ever made
  • layer8 1 hour ago
  • rany_ 1 hour ago
    Could this be used to root Android devices? Does Android ship with algif_aead?
    • notpushkin 1 hour ago
      I’ve poked around on my phone and it didn’t work:

          File "/data/data/com.termux/files/home/a.py", line 5, in c
            a=s.socket(38,5,0); # ...
          File "/data/data/com.termux/files/usr/lib/python3.13/socket.py", line 233, in __init__
            _socket.socket.__init__(self, family, type, proto, fileno)
            ~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
        PermissionError: [Errno 13] Permission denied
      • int0x29 1 hour ago
        I got line 5 to run and failed on line 8 due to lack of su. I'd need to find a user accessible setuid binary for it to work.

        Traceback (most recent call last): File "/data/data/com.termux/files/home/exploit.py", line 8, in <module> f=g.open("/usr/bin/su",0);i=0;e=zlib.decompress(d("78daab77f57163626464800126063b0610af82c101cc7760c0040e0c160c301d209a154d16999e07e5c1680601086578c0f0ff864c7e568f5e5b7e10f75b9675c44c7e56c3ff593611fcacfa499979fac5190c0c0c0032c310d3")) ^^^^^^^^^^^^^^^^^^^^^^^ FileNotFoundError: [Errno 2] No such file or directory: '/usr/bin/su'

        • notpushkin 1 hour ago
          Try /system/bin/ping
          • int0x29 55 minutes ago
            Now the socket is blocked. Also probably should have realized the socket is defined earlier than its called

            Traceback (most recent call last): File "/data/data/com.termux/files/home/exploit.py", line 9, in <module> while i<len(e):c(f,i,e[i:i+4]);i+=4 ^^^^^^^^^^^^^^^ File "/data/data/com.termux/files/home/exploit.py", line 5, in c a=s.socket(38,5,0);a.bind(("aead","authencesn(hmac(sha256),cbc(aes))"));h=279;v=a.setsockopt;v(h,1,d('0800010000000010'+'0'64));v(h,5,None,4);u,_=a.accept();o=t+4;i=d('00');u.sendmsg([b"A"4+c],[(h,3,i4),(h,2,b'\x10'+i19),(h,4,b'\x08'+i*3),],32768);r,w=g.pipe();n=g.splice;n(f,w,o,offset_src=0);n(r,u.fileno(),o) ^^^^^^^^^^^^^^^^ File "/data/data/com.termux/files/usr/lib/python3.12/socket.py", line 233, in __init__ _socket.socket.__init__(self, family, type, proto, fileno) PermissionError: [Errno 13] Permission denied

    • tripdout 54 minutes ago
      There’s SELinux, everything is mounted nosuid, barely anything runs as root except init. I doubt it.
    • zb3 1 hour ago
      Android is smarter than setuid + system partitions aren't writable.
      • firer 1 hour ago
        System partitions being non-writable has nothing to do with the vulnerability - it allows modifying the cache of any file that you can open for reading.

        Not using setuid anywhere means you'd have to build a slightly more clever exploit, but it's still trivial - just modify some binary you know will run as root "soon".

        But... I didn't check, but IIRC the untrusted_app secontext that apps run in is not allowed to open AF_ALG sockets - so you can't directly trigger the vulnerability as a malicious app. Although it might be possible in some roundabout way (requesting some more privileged crypto service to do so).

        • int0x29 59 minutes ago
          Edit: Ignore this I overlooked calling order. It is indeed blocked

          ~~My allegedly fully patched pixel 8 pro allowed an AF_ALG socket to open under termux without virtualization so I'm not sure the last but is true~~

        • zb3 15 minutes ago
          Ah, I blindly assumed such memory would be mapped readonly...
      • int0x29 1 hour ago
        Its not writing to the partition though is it? It is polluting the cache page via a write with a buffer overrun in the kernel. I don't think buffer overruns follow permissions.
        • zb3 13 minutes ago
          I assumed such memory would be mapped readonly (PROT_READ), without actually looking into it..
  • progval 1 hour ago
    So this replaces a SUID binary, in order to run as PID 0. The website claims it can escape "Kubernetes / container clusters" and "CI runners & build farms" but I don't see anything supporting the claim it can escape a container (or specifically, a user namespace).

    I ran the exploit in rootless Podman, and predictably it doesn't escape the container.

    They also claim their script "roots every Linux distribution shipped since 2017.", but only tested four; and it doesn't work on Alpine

    • john_strinlai 1 hour ago
      >The website claims it can escape "Kubernetes / container clusters" and "CI runners & build farms" but I don't see anything supporting the claim it can escape a container

      they state that the write-up is forthcoming. presumably there is some additional steps or modifications that will be detailed in the 'part 2'.

      "Next: "From Pod to Host," how Copy Fail escapes every major cloud Kubernetes platform."

    • microtherion 10 minutes ago
      It also doesn't work on Raspberry Pi, though presumably it could easily be made to; it does replace the su binary, but the replacement is not executable.
      • unsnap_biceps 5 minutes ago
        It's patching the binary in memory, so the binary patch would be architecture dependent. The existing one is only x86_64, but with an updated payload, it would work on arm.
    • layer8 49 minutes ago
      The 2017 claim is based on the vulnerability having been introduced in this commit in the second half of 2017: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/lin...

      The details will depend on whether the kernel is a newer release or a maintenance version of an older release.

    • amusingimpala75 1 hour ago
      Their PoC does as you say, but is built upon arbitrary modification of the page cache, which could be abused for the other things
      • progval 56 minutes ago
        Ah indeed, it can be used to overwrite the page cache for files on read-only volumes.
    • rcxdude 1 hour ago
      If you can get to real UID 0 from a rootless container, you can escape it, but you do need to take extra steps. Same with it working on Alpine: the underlying vulnerability probably still exists, but the script might need some adjusting. It's a PoC, not a full exploit for every situation.
    • embedding-shape 1 hour ago
      Did you try it on systems that don't have the patch already? Seems many distributions already shipped kernels with the patch ~a month ago.
      • progval 1 hour ago
        Yes. Alpine in rootless Podman doesn't work (after replacing "/usr/bin/su" with "/bin/su" in the .py, running the .py just doesn't do anything) while it does in Debian in rootless Podman on the same host.
  • deep2secure 7 minutes ago
    I checked it. Very nice efforts made to create it
  • Lorin 1 hour ago
    What is the rationale behind naming CVEs and individual domains? Marketing?
    • diath 1 hour ago
      It's an advertisement for their tool that found the exploit: https://copy.fail/#contact, https://xint.io/products/xint-code
    • evanjrowley 1 hour ago
      The AI generated prose screams marketing. Marketing is why there's a "Contact our Security Team" form at the bottom of the page.
    • john_strinlai 1 hour ago
      can you remember what CVE-2021-44228 is without looking it up? CVE-2014-6271? CVE-2017-5753?

      i bet if i told you their names, you would instantly know what vulns those are.

      its easier to talk about things with names. it hurts no one. it takes approximately no effort or time.

      CVEs are, for whatever reason, like the only thing on the planet that people seem to have a problem with when they receive a name. i am not sure why.

      • QuantumNomad_ 56 minutes ago
        > CVEs are, for whatever reason, like the only thing on the planet that people seem to have a problem with when they receive a name. i am not sure why.

        What, you guys talk about books based on their “title” instead of just memorising the ISBN of each book? Pssh, count me disappointed!

        • john_strinlai 54 minutes ago
          after work i have to stop at Y87794H0US1R65VBXU25 for some groceries.
          • akerl_ 40 minutes ago
            I only refer to my kids by their social security numbers until they do something suitably remarkable.

            I guess it’s a good thing I’m not a SovCit or I’d just have to call them Traveller Three and Traveller Four

    • eddythompson80 1 hour ago
      Giving catchy names for bad exploits has been a thing for a while. Probably to make sure it's easy to reference and make sure you're patches as opposed to passing numbers around. Heartbleed, Shellshock, BEAST, Goto Fail, etc
    • tptacek 1 hour ago
      It's certainly marketing, but it's prosocial: there's no scarcity of names, and "copy.fail" is much easier to remember and talk about than "CVE-2026-31431".
    • skilled 1 hour ago
      Probably to some extent it is marketing, but generally it has to do with significant bug finds to get the message out to the people who need to apply patches and/or be informed. Heartbleed, Log4Shell, etc.

      Very few CVE’s get names dedicated to them like this, because usually when they do - it is very serious, as in this case.

    • dgellow 1 hour ago
      Yes, originally it was to help spread awareness. Now it has become more of a gimmick I would say
    • ronsor 1 hour ago
      It makes sure people don't forget about the vulnerabilities, at least
    • Fuzzbit 1 hour ago
      Same reason they name storms, numbers scare normies
  • skilled 1 hour ago
    This looks like an extraordinary find at first glance.

    Does this mean you can go from a basic web shell from a shared hosting account to root? I can see how that could wreak havoc really quickly.

    • barbegal 1 hour ago
      Yes I would imagine lots of those type of services would be vulnerable if they hadn't updated to the latest kernel versions.
  • chasil 1 hour ago
    On the downside, I need to push new kernels to all my servers.

    On this bright side, does this mean Magisk is coming to all unpatched Android phones?

  • corvad 1 hour ago
    If this is verified, this is a very big deal. Root access on any shared computer. Additionally do we know what kernel versions and stable versions have the patch?
    • Tuna-Fish 1 hour ago
      I just tested on my home server running ubuntu 24.04 LTS with newest kernel from repositories, got root.
      • Avamander 35 minutes ago
        Can Livepatch mitigate this or is it already? I don't know where to look this up.
  • porridgeraisin 1 hour ago
    Better explanation of the write up (still from original exploit author) : https://xint.io/blog/copy-fail-linux-distributions
  • w2seraph 1 hour ago
    holy smokes it just rooted my just installed from ISO Ubuntu server
  • TehCorwiz 1 hour ago
    It does not behave as described on EndeavorOS (arch-based) running kernel 6.19.14-arch1-1. I receive the error:

    Password: su: Authentication token manipulation error

    I'm guessing this means it's already patched?

    • john_strinlai 1 hour ago
      yes, it was reported on march 23rd, patches on april 1.

      you are reading about it now because it has been patched.

      • marshray 1 hour ago
        No it hasn't.

        Ubuntu before 26.04 LTS (released a week ago) are currently listed as vulnerable.

        Debian other than forky and sid are currently listed as vulnerable.

        This is a disgrace.

        • john_strinlai 59 minutes ago
          Disclosure timeline

              2026-03-23Reported to Linux kernel security team
              2026-03-24Initial acknowledgment
              2026-03-25Patches proposed and reviewed
              2026-04-01Patch committed to mainline
              2026-04-22CVE-2026-31431 assigned
              2026-04-29Public disclosure (https://copy.fail/)
          
          kernel 6.19.14-arch1-1, the kernel in question from the parent comment, has been patched.
    • dimastopel 1 hour ago
      same result on my arch machine as well.
  • Ekaros 1 hour ago
    So this could be usable in lot of places with Python and Linux running? Not that I have too many Linux devices around. Still, might be handy sometimes on personal devices.
    • kro 1 hour ago
      This can likely be shipped as binary code without dependencies like python, as the bug is in the kernel.
    • SteveNuts 1 hour ago
      There's nothing specific about this related to Python, that's just demonstrating how it works.

      This is usable anywhere on an affected Kernel version

  • krunck 24 minutes ago
    Wow. I tried it on an old testing VM of Ubuntu 24.04 that had not been touched for a few months. Instant root with the bonus that any user that runs "su" gets root too. I updated the VM thinking it would be fixed afterward. Nope.
  • dist-epoch 37 minutes ago
    > Will you release the full PoC?

    > Yes — it's on this page. We held it for a month while distros prepared patches; the major builds are out as of this writing.

    There is no update available for Ubuntu 24, PoC works and just tried updating.

  • themafia 1 hour ago
    > If your kernel was built between 2017 and the patch

    This is why I compile my own kernel. I disable things I don't use. If it's not present it can't hurt you.

    > block AF_ALG socket creation via seccomp regardless of patch state.

    Likewise I use seccomp to only allow syscalls that are necessary. Everything else is disabled. In the programs I have that need to connect to a backend socket, that is done, and then socket creation is disabled.

  • DetroitThrow 1 hour ago
    Despite the copy/images being weird about RHEL 14.3, this seems to work. Wow?
  • charcircuit 1 hour ago
    SUID binaries once again assisted a local privilege escalation attack. This is a major problem that distros can't keep ignoring.
  • baggy_trough 1 hour ago
    Is this fixed in any stable release kernel yet?
    • Wingy 1 hour ago
      7.0-rc1 has a tag with it:

          % git describe a664bf3d603d
          v7.0-rc1-10-ga664bf3d603d
      
      I suspect this means the stable 7.0 has it too.
  • nickcw 1 hour ago
    [dead]
  • maxtaco 1 hour ago
    Use extreme caution running arbitrary code on your machines, especially obfuscated code that tickles kernel bugs! (edited)
    • stackghost 1 hour ago
      Analysis of the POC concurs with my tests that confirm that the portion of `su` that gets overwritten does not survive a reboot.
    • charcircuit 1 hour ago
      The page explicitly describes that it is stealthy as it does not make permanent changes, only corrupting the binary in memory.