KernelScan.io

HIGH

net/mana ServiceWq UAF

CVE-2026-43276

CVSS 7.8 / 10.0 NVD

CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

KernelScan AI5.2MEDIUM

01

In the Linux kernel, the following vulnerability has been resolved: net: mana: Fix double destroy_workqueue on service rescan PCI path While testing corner cases in the driver, a use-after-free crash was found on the service rescan PCI path. When mana_serv_reset() calls mana_gd_suspend(), mana_gd_cleanup() destroys gc->service_wq. If the subsequent mana_gd_resume() fails with -ETIMEDOUT or -EPROTO, the code falls through to mana_serv_rescan() which triggers pci_stop_and_remove_bus_device(). This invokes the PCI .remove callback (mana_gd_remove), which calls mana_gd_cleanup() a second time, attempting to destroy the already- freed workqueue. Fix this by NULL-checking gc->service_wq in mana_gd_cleanup() and setting it to NULL after destruction. Call stack of issue for reference: [Sat Feb 21 18:53:48 2026] Call Trace: [Sat Feb 21 18:53:48 2026] <TASK> [Sat Feb 21 18:53:48 2026] mana_gd_cleanup+0x33/0x70 [mana] [Sat Feb 21 18:53:48 2026] mana_gd_remove+0x3a/0xc0 [mana] [Sat Feb 21 18:53:48 2026] pci_device_remove+0x41/0xb0 [Sat Feb 21 18:53:48 2026] device_remove+0x46/0x70 [Sat Feb 21 18:53:48 2026] device_release_driver_internal+0x1e3/0x250 [Sat Feb 21 18:53:48 2026] device_release_driver+0x12/0x20 [Sat Feb 21 18:53:48 2026] pci_stop_bus_device+0x6a/0x90 [Sat Feb 21 18:53:48 2026] pci_stop_and_remove_bus_device+0x13/0x30 [Sat Feb 21 18:53:48 2026] mana_do_service+0x180/0x290 [mana] [Sat Feb 21 18:53:48 2026] mana_serv_func+0x24/0x50 [mana] [Sat Feb 21 18:53:48 2026] process_one_work+0x190/0x3d0 [Sat Feb 21 18:53:48 2026] worker_thread+0x16e/0x2e0 [Sat Feb 21 18:53:48 2026] kthread+0xf7/0x130 [Sat Feb 21 18:53:48 2026] ? __pfx_worker_thread+0x10/0x10 [Sat Feb 21 18:53:48 2026] ? __pfx_kthread+0x10/0x10 [Sat Feb 21 18:53:48 2026] ret_from_fork+0x269/0x350 [Sat Feb 21 18:53:48 2026] ? __pfx_kthread+0x10/0x10 [Sat Feb 21 18:53:48 2026] ret_from_fork_asm+0x1a/0x30 [Sat Feb 21 18:53:48 2026] </TASK>

02

Engine v0.2.0

Risk summary

Systems using Microsoft Azure Network Adapter (MANA) hardware are at risk of kernel crashes or potential memory corruption during PCI device service reset operations. The vulnerability requires administrative privileges and specific error conditions during service reset. Because the bug is a use-after-free on a heap workqueue object, it can potentially leak kernel heap information or corrupt memory rather than causing a crash alone.

Affecteddrivers/net/ethernet/microsoft/mana/gdma_main.c (MANA network driver)

Vulnerability analysis

The MANA network driver contains a use-after-free vulnerability in its service rescan error path. When mana_gd_cleanup() destroys the service_wq workqueue during suspend, and the subsequent mana_gd_resume() fails with -ETIMEDOUT or -EPROTO, the error path triggers PCI device removal which calls mana_gd_cleanup() again, attempting to destroy the already-freed workqueue. The fix adds NULL-checking and pointer nullification to make the cleanup function idempotent. The double-free/use-after-free primitive can expose heap contents or enable limited memory corruption through the stale workqueue pointer, not only a denial-of-service crash.

03

BranchFixed inPatch commit
6.186.18.16fa3c2f8d9152
6.196.19.6a9a7c3203fdc
mainline7.0f975a0955276