CVE-2022-49661

medium

Description

In the Linux kernel, the following vulnerability has been resolved: can: gs_usb: gs_usb_open/close(): fix memory leak The gs_usb driver appears to suffer from a malady common to many USB CAN adapter drivers in that it performs usb_alloc_coherent() to allocate a number of USB request blocks (URBs) for RX, and then later relies on usb_kill_anchored_urbs() to free them, but this doesn't actually free them. As a result, this may be leaking DMA memory that's been used by the driver. This commit is an adaptation of the techniques found in the esd_usb2 driver where a similar design pattern led to a memory leak. It explicitly frees the RX URBs and their DMA memory via a call to usb_free_coherent(). Since the RX URBs were allocated in the gs_can_open(), we remove them in gs_can_close() rather than in the disconnect function as was done in esd_usb2. For more information, see the 928150fad41b ("can: esd_usb2: fix memory leak").

References

https://git.kernel.org/stable/c/ffb6cc6601ec7c8fa963dcf76025df4a02f2cf5c

https://git.kernel.org/stable/c/d91492638b054f4a359621ef216242be5973ed6b

https://git.kernel.org/stable/c/d0b8e223998866b3e7b2895927d4e9689b0a80d8

https://git.kernel.org/stable/c/c1d806bc29ff7ffe0e2a023583c8720ed96cb0b0

https://git.kernel.org/stable/c/6f655b5e13fa4b27e915b6c209ac0da74fd75963

https://git.kernel.org/stable/c/339fa9f80d3b94177a7a459c6d115d3b56007d5a

https://git.kernel.org/stable/c/2bda24ef95c0311ab93bda00db40486acf30bd0a

https://git.kernel.org/stable/c/0e60230bc64355c80abe993d1719fdb318094e20

Details

Source: Mitre, NVD

Published: 2025-02-26

Updated: 2025-02-26

Risk Information

CVSS v2

Base Score: 4.9

Vector: CVSS2#AV:L/AC:L/Au:N/C:N/I:N/A:C

Severity: Medium

CVSS v3

Base Score: 5.5

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

Severity: Medium