cbcvebase.
CVE-2025-38377
published 2025-07-25

CVE-2025-38377: In the Linux kernel, the following vulnerability has been resolved: rose: fix dangling neighbour pointers in rose_rt_device_down() There are two bugs in…

high7.8CVSS 3.1
AVLACLPRLUINSUCHIHAH
In the Linux kernel, the following vulnerability has been resolved: rose: fix dangling neighbour pointers in rose_rt_device_down() There are two bugs in rose_rt_device_down() that can cause use-after-free: 1. The loop bound `t->count` is modified within the loop, which can cause the loop to terminate early and miss some entries. 2. When removing an entry from the neighbour array, the subsequent entries are moved up to fill the gap, but the loop index `i` is still incremented, causing the next entry to be skipped. For example, if a node has three neighbours (A, A, B) with count=3 and A is being removed, the second A is not checked. i=0: (A, A, B) -> (A, B) with count=2 ^ checked i=1: (A, B) -> (A, B) with count=2 ^ checked (B, not A!) i=2: (doesn't occur because i < count is false) This leaves the second A in the array with count=2, but the rose_neigh structure has been freed. Code that accesses these entries assumes that the first `count` entries are valid pointers, causing a use-after-free when it accesses the dangling pointer. Fix both issues by iterating over the array in reverse order with a fixed loop bound. This ensures that all entries are examined and that the removal of an entry doesn't affect subsequent iterations.

Affected

38 ranges· showing 25
VendorProductVersion rangeFixed in
debiandebian_linux
debianlinux< linux 6.1.147-1 (bookworm)linux 6.1.147-1 (bookworm)
debianlinux-6.1< linux 6.1.147-1 (bookworm)linux 6.1.147-1 (bookworm)
linuxlinux
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 94e0918e39039c47ddceb609500817f7266be75694e0918e39039c47ddceb609500817f7266be756
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < fe62a35fb1f77f494ed534fc69a9043dc5a30ce1fe62a35fb1f77f494ed534fc69a9043dc5a30ce1
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 2b952dbb32fef835756f07ff0cd77efbb836dfea2b952dbb32fef835756f07ff0cd77efbb836dfea
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < b6b232e16e08c6dc120672b4753392df0d28c1b4b6b232e16e08c6dc120672b4753392df0d28c1b4
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 7a1841c9609377e989ec41c16551309ce79c39e47a1841c9609377e989ec41c16551309ce79c39e4
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 446ac00b86be1670838e513b643933d78837d8db446ac00b86be1670838e513b643933d78837d8db
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 2c6c82ee074bfcfd1bc978ec45bfea37703d840a2c6c82ee074bfcfd1bc978ec45bfea37703d840a
linuxlinux>= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 34a500caf48c47d5171f4aa1f237da39b07c615734a500caf48c47d5171f4aa1f237da39b07c6157
linuxlinux_kernel
linuxlinux_kernel
linuxlinux_kernel>= 0 < 5.10.244-15.10.244-1
linuxlinux_kernel>= 0 < 6.1.147-16.1.147-1
linuxlinux_kernel>= 0 < 6.12.37-16.12.37-1
linuxlinux_kernel>= 0 < 6.12.37-16.12.37-1
linuxlinux_kernel>= 0 < 5.15.0-156.1665.15.0-156.166
linuxlinux_kernel>= 0 < 6.8.0-100.1006.8.0-100.100
linuxlinux_kernel>= 2.6.13 < 5.4.2965.4.296
linuxlinux_kernel>= 5.11 < 5.15.1875.15.187
linuxlinux_kernel>= 5.16 < 6.1.1446.1.144
linuxlinux_kernel>= 5.5 < 5.10.2405.10.240
linuxlinux_kernel>= 6.13 < 6.15.66.15.6

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