CVE-2022-49350

Source
https://cve.org/CVERecord?id=CVE-2022-49350
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-49350.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-49350
Downstream
Related
Published
2025-02-26T02:11:03.514Z
Modified
2026-03-20T12:22:22.382588Z
Summary
net: mdio: unexport __init-annotated mdio_bus_init()
Details

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

net: mdio: unexport __init-annotated mdiobusinit()

EXPORT_SYMBOL and __init is a bad combination because the .init.text section is freed up after the initialization. Hence, modules cannot use symbols annotated __init. The access to a freed symbol may end up with kernel panic.

modpost used to detect it, but it has been broken for a decade.

Recently, I fixed modpost so it started to warn it again, then this showed up in linux-next builds.

There are two ways to fix it:

  • Remove __init
  • Remove EXPORT_SYMBOL

I chose the latter for this case because the only in-tree call-site, drivers/net/phy/phydevice.c is never compiled as modular. (CONFIGPHYLIB is boolean)

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/49xxx/CVE-2022-49350.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
90eff9096c01ba90cdae504a6b95ee87fe2556a3
Fixed
ab64ec2c75683f30ccde9eaaf0761002f901aa12
Fixed
5534bcd7c40299862237c4a8fd9c5031b3db1538
Fixed
6a90a44d53428a3bf01bd80df9ba78b19959270c
Fixed
7759c3222815b945a94b212bc0c6cdec475cfec2
Fixed
59fa94cddf9eef8d8dae587373eed8b8f4eb11d7
Fixed
f5c68137f1191ba3fcf6260ec71b30be2e2bf4c3
Fixed
f2f0f8c18b60ca64ff50892ed899cf1c77864755
Fixed
35b42dce619701f1300fb8498dae82c9bb1f0263

Database specific

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