CVE-2026-31581

HIGH

ALSA: 6fire: fix use-after-free on disconnect

Title source: cna
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: ALSA: 6fire: fix use-after-free on disconnect In usb6fire_chip_abort(), the chip struct is allocated as the card's private data (via snd_card_new with sizeof(struct sfire_chip)). When snd_card_free_when_closed() is called and no file handles are open, the card and embedded chip are freed synchronously. The subsequent chip->card = NULL write then hits freed slab memory. Call trace: usb6fire_chip_abort sound/usb/6fire/chip.c:59 [inline] usb6fire_chip_disconnect+0x348/0x358 sound/usb/6fire/chip.c:182 usb_unbind_interface+0x1a8/0x88c drivers/usb/core/driver.c:458 ... hub_event+0x1a04/0x4518 drivers/usb/core/hub.c:5953 Fix by moving the card lifecycle out of usb6fire_chip_abort() and into usb6fire_chip_disconnect(). The card pointer is saved in a local before any teardown, snd_card_disconnect() is called first to prevent new opens, URBs are aborted while chip is still valid, and snd_card_free_when_closed() is called last so chip is never accessed after the card may be freed.

Scores

CVSS v3 7.8
EPSS 0.0001
EPSS Percentile 2.4%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Details

CWE
CWE-416
Status published
Products (26)
Linux/Linux < 6.13
Linux/Linux 0df7f4b5cc10f5adf98be0845372e9eef7bb5b09
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - 3dc20d1981d6a67d8184498a5da272942dde1e65
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - 51f6532790b74ffdd6970bc848358a2838c1c185
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - af75b486f7e883e3422ece23c8d727e6815144a0
Linux/Linux 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 - d21e8a2af4869b5890b34e081d5aeadc93e9cd5c
Linux/Linux 273eec23467dfbfbd0e4c10302579ba441fb1e13
Linux/Linux 57860a80f03f9dc69a34a5c37b0941ad032a0a8c - af75b486f7e883e3422ece23c8d727e6815144a0
Linux/Linux 6.12.83 - 6.12.*
Linux/Linux 6.13
... and 16 more
Published Apr 24, 2026
Tracked Since Apr 24, 2026