CVE-2022-50476

Source
https://cve.org/CVERecord?id=CVE-2022-50476
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-50476.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-50476
Downstream
Published
2025-10-04T15:16:36.895Z
Modified
2026-05-28T03:54:03.053351959Z
Summary
ntb_netdev: Use dev_kfree_skb_any() in interrupt context
Details

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

ntbnetdev: Use devkfreeskbany() in interrupt context

TX/RX callback handlers (ntbnetdevtxhandler(), ntbnetdevrxhandler()) can be called in interrupt context via the DMA framework when the respective DMA operations have completed. As such, any calls by these routines to free skb's, should use the interrupt context safe devkfreeskb_any() function.

Previously, these callback handlers would call the interrupt unsafe version of devkfreeskb(). This has not presented an issue on Intel IOAT DMA engines as that driver utilizes tasklets rather than a hard interrupt handler, like the AMD PTDMA DMA driver. On AMD systems, a kernel WARNING message is encountered, which is being issued from skbreleaseheadstate() due to inhardirq() being true.

Besides the user visible WARNING from the kernel, the other symptom of this bug was that TCP/IP performance across the ntbnetdev interface was very poor, i.e. approximately an order of magnitude below what was expected. With the repair to use devkfreeskbany(), kernel WARNINGs from skbreleasehead_state() ceased and TCP/IP performance, as measured by iperf, was on par with expected results, approximately 20 Gb/s on AMD Milan based server. Note that this performance is comparable with Intel based servers.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/50xxx/CVE-2022-50476.json",
    "cna_assigner": "Linux"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
548c237c0a9972df5d1afaca38aa733ee577128d
Fixed
d4460c82177899751975180c268f352893302221
Fixed
dd860b39aa7c7b82e6c99b6fdb99d4610ce49d67
Fixed
8b78493968ed3cef0326183ed059c55e42f24d5b
Fixed
a6b9e09403102bdf8402dae734800e4916c7ea58
Fixed
13286ad1c7c49c606fdcba4cf66f953a1a16c1ca
Fixed
21296a52caa6a6bad6debdfe40ad81d4f1a27e69
Fixed
14d245da57a11e80277ab455aa9b6dcc5ed38a19
Fixed
07e28a8f450217db679802ebd4de0915556ce846
Fixed
5f7d78b2b12a9d561f48fa00bab29b40f4616dad

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-50476.json"

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
3.9.0
Fixed
4.9.337
Type
ECOSYSTEM
Events
Introduced
4.10.0
Fixed
4.14.303
Type
ECOSYSTEM
Events
Introduced
4.15.0
Fixed
4.19.270
Type
ECOSYSTEM
Events
Introduced
4.20.0
Fixed
5.4.229
Type
ECOSYSTEM
Events
Introduced
5.5.0
Fixed
5.10.163
Type
ECOSYSTEM
Events
Introduced
5.11.0
Fixed
5.15.86
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.0.16
Type
ECOSYSTEM
Events
Introduced
6.1.0
Fixed
6.1.2

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-50476.json"