CVE-2026-23393 PUBLISHED

bridge: cfm: Fix race condition in peer_mep deletion

Assigner: Linux
Reserved: 13.01.2026 Published: 25.03.2026 Updated: 25.03.2026

In the Linux kernel, the following vulnerability has been resolved:

bridge: cfm: Fix race condition in peer_mep deletion

When a peer MEP is being deleted, cancel_delayed_work_sync() is called on ccm_rx_dwork before freeing. However, br_cfm_frame_rx() runs in softirq context under rcu_read_lock (without RTNL) and can re-schedule ccm_rx_dwork via ccm_rx_timer_start() between cancel_delayed_work_sync() returning and kfree_rcu() being called.

The following is a simple race scenario:

<pre> cpu0 cpu1 </pre>

mep_delete_implementation() cancel_delayed_work_sync(ccm_rx_dwork); br_cfm_frame_rx() // peer_mep still in hlist if (peer_mep->ccm_defect) ccm_rx_timer_start() queue_delayed_work(ccm_rx_dwork) hlist_del_rcu(&peer_mep->head); kfree_rcu(peer_mep, rcu); ccm_rx_work_expired() // on freed peer_mep

To prevent this, cancel_delayed_work_sync() is replaced with disable_delayed_work_sync() in both peer MEP deletion paths, so that subsequent queue_delayed_work() calls from br_cfm_frame_rx() are silently rejected.

The cc_peer_disable() helper retains cancel_delayed_work_sync() because it is also used for the CC enable/disable toggle path where the work must remain re-schedulable.

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from dc32cbb3dbd7da38c700d6e0fc6354df24920525 to e89dbd2736a45f0507949af4748cbbf3ff793146 (excl.)
  • affected from dc32cbb3dbd7da38c700d6e0fc6354df24920525 to d8f35767bacb3c7769d470a41cf161e3f3c07e70 (excl.)
  • affected from dc32cbb3dbd7da38c700d6e0fc6354df24920525 to 1fd81151f65927fd9edb8ecd12ad45527dbbe5ab (excl.)
  • affected from dc32cbb3dbd7da38c700d6e0fc6354df24920525 to 3715a00855316066cdda69d43648336367422127 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 5.11 is affected
  • unaffected from 0 to 5.11 (excl.)
  • unaffected from 6.12.78 to 6.12.* (incl.)
  • unaffected from 6.18.20 to 6.18.* (incl.)
  • unaffected from 6.19.10 to 6.19.* (incl.)
  • unaffected from 7.0-rc5 to * (incl.)

References