cbcvebase.
CVE-2025-39835
published 2025-09-16

CVE-2025-39835: In the Linux kernel, the following vulnerability has been resolved: xfs: do not propagate ENODATA disk errors into xattr code ENODATA (aka ENOATTR) has a very…

high7.8CVSS 3.1
AVLACLPRLUINSUCHIHAH
In the Linux kernel, the following vulnerability has been resolved: xfs: do not propagate ENODATA disk errors into xattr code ENODATA (aka ENOATTR) has a very specific meaning in the xfs xattr code; namely, that the requested attribute name could not be found. However, a medium error from disk may also return ENODATA. At best, this medium error may escape to userspace as "attribute not found" when in fact it's an IO (disk) error. At worst, we may oops in xfs_attr_leaf_get() when we do: error = xfs_attr_leaf_hasname(args, &bp); if (error == -ENOATTR) { xfs_trans_brelse(args->trans, bp); return error; } because an ENODATA/ENOATTR error from disk leaves us with a null bp, and the xfs_trans_brelse will then null-deref it. As discussed on the list, we really need to modify the lower level IO functions to trap all disk errors and ensure that we don't let unique errors like this leak up into higher xfs functions - many like this should be remapped to EIO. However, this patch directly addresses a reported bug in the xattr code, and should be safe to backport to stable kernels. A larger-scope patch to handle more unique errors at lower levels can follow later. (Note, prior to 07120f1abdff we did not oops, but we did return the wrong error code to userspace.)

Affected

27 ranges· showing 25
VendorProductVersion rangeFixed in
debiandebian_linux
debianlinux< linux 6.1.153-1 (bookworm)linux 6.1.153-1 (bookworm)
debianlinux-6.1< linux 6.1.153-1 (bookworm)linux 6.1.153-1 (bookworm)
linuxlinux
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < 157ddfb05961c68ab7d457a462822a698e4e4bf4157ddfb05961c68ab7d457a462822a698e4e4bf4
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < 90bae69c2959c39912f0c2f07a9a7894f3fc49f590bae69c2959c39912f0c2f07a9a7894f3fc49f5
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < e358d4b6225e4c1eb208686a05e360ef8df59e07e358d4b6225e4c1eb208686a05e360ef8df59e07
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < d3cc7476b89fb45b7e00874f4f56f6b928467c60d3cc7476b89fb45b7e00874f4f56f6b928467c60
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < dcdf36f1b67884c722abce9b8946e34ffb9f67c8dcdf36f1b67884c722abce9b8946e34ffb9f67c8
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < 39fc2742ca14f7fbc621ce9b43bcbd00248cb9a839fc2742ca14f7fbc621ce9b43bcbd00248cb9a8
linuxlinux>= 07120f1abdff80f3d1351f733661abe28d609535 < ae668cd567a6a7622bc813ee0bb61c42bed61ba7ae668cd567a6a7622bc813ee0bb61c42bed61ba7
linuxlinux_kernel
linuxlinux_kernel>= 0 < 5.10.244-15.10.244-1
linuxlinux_kernel>= 0 < 6.1.153-16.1.153-1
linuxlinux_kernel>= 0 < 6.12.48-16.12.48-1
linuxlinux_kernel>= 0 < 6.16.5-16.16.5-1
linuxlinux_kernel>= 0 < 5.15.0-163.1735.15.0-163.173
linuxlinux_kernel>= 0 < 6.8.0-106.1066.8.0-106.106
linuxlinux_kernel>= 5.11 < 5.15.1915.15.191
linuxlinux_kernel>= 5.16 < 6.1.1506.1.150
linuxlinux_kernel>= 5.9 < 5.10.2425.10.242
linuxlinux_kernel>= 6.13 < 6.16.56.16.5
linuxlinux_kernel>= 6.2 < 6.6.1046.6.104
linuxlinux_kernel>= 6.7 < 6.12.456.12.45
msrcazl3_kernel_6.6.96.2-2_on_azure_linux_3.0

CVSS provenance

nvdv3.17.8HIGHCVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
osv7.8HIGH