cve/2025/CVE-2025-38377.md
2025-09-29 21:09:30 +02:00

1.9 KiB

CVE-2025-38377

Description

In the Linux kernel, the following vulnerability has been resolved🌹 fix dangling neighbour pointers in rose_rt_device_down()There are two bugs in rose_rt_device_down() that can causeuse-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 Ais 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_neighstructure has been freed. Code that accesses these entries assumes thatthe first count entries are valid pointers, causing a use-after-freewhen it accesses the dangling pointer.Fix both issues by iterating over the array in reverse order with a fixedloop bound. This ensures that all entries are examined and that the removalof an entry doesn't affect subsequent iterations.

POC

Reference

No PoCs from references.

Github