CVE-2023-52740

Source
https://nvd.nist.gov/vuln/detail/CVE-2023-52740
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2023-52740.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2023-52740
Downstream
Related
Published
2024-05-21T15:23:03Z
Modified
2025-10-08T16:34:49.148847Z
Summary
powerpc/64s/interrupt: Fix interrupt exit race with security mitigation switch
Details

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

powerpc/64s/interrupt: Fix interrupt exit race with security mitigation switch

The RFI and STF security mitigation options can flip the interruptexitnot_reentrant static branch condition concurrently with the interrupt exit code which tests that branch.

Interrupt exit tests this condition to set MSR[EE|RI] for exit, then again in the case a soft-masked interrupt is found pending, to recover the MSR so the interrupt can be replayed before attempting to exit again. If the condition changes between these two tests, the MSR and irq soft-mask state will become corrupted, leading to warnings and possible crashes. For example, if the branch is initially true then false, MSR[EE] will be 0 but PACAIRQHARDDIS clear and EE may not get enabled, leading to warnings in irq64.c.

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
13799748b957bc5659f97c036224b0f4b42172e2
Fixed
86f7e423933608d536015a0f2eb9e0338c1227e0
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
13799748b957bc5659f97c036224b0f4b42172e2
Fixed
6f097c24815e67909a1fcc2c605586d02babd673
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
13799748b957bc5659f97c036224b0f4b42172e2
Fixed
2ea31e2e62bbc4d11c411eeb36f1b02841dbcab1

Affected versions

v5.*

v5.13
v5.13-rc3
v5.13-rc4
v5.13-rc5
v5.13-rc6
v5.13-rc7
v5.14
v5.14-rc1
v5.14-rc2
v5.14-rc3
v5.14-rc4
v5.14-rc5
v5.14-rc6
v5.14-rc7
v5.15
v5.15-rc1
v5.15-rc2
v5.15-rc3
v5.15-rc4
v5.15-rc5
v5.15-rc6
v5.15-rc7
v5.15.1
v5.15.10
v5.15.11
v5.15.12
v5.15.13
v5.15.14
v5.15.15
v5.15.16
v5.15.17
v5.15.18
v5.15.19
v5.15.2
v5.15.20
v5.15.21
v5.15.22
v5.15.23
v5.15.24
v5.15.25
v5.15.26
v5.15.27
v5.15.28
v5.15.29
v5.15.3
v5.15.30
v5.15.31
v5.15.32
v5.15.33
v5.15.34
v5.15.35
v5.15.36
v5.15.37
v5.15.38
v5.15.39
v5.15.4
v5.15.40
v5.15.41
v5.15.42
v5.15.43
v5.15.44
v5.15.45
v5.15.46
v5.15.47
v5.15.48
v5.15.49
v5.15.5
v5.15.50
v5.15.51
v5.15.52
v5.15.53
v5.15.54
v5.15.55
v5.15.56
v5.15.57
v5.15.58
v5.15.59
v5.15.6
v5.15.60
v5.15.61
v5.15.62
v5.15.63
v5.15.64
v5.15.65
v5.15.66
v5.15.67
v5.15.68
v5.15.69
v5.15.7
v5.15.70
v5.15.71
v5.15.72
v5.15.73
v5.15.74
v5.15.75
v5.15.76
v5.15.77
v5.15.78
v5.15.79
v5.15.8
v5.15.80
v5.15.81
v5.15.82
v5.15.83
v5.15.84
v5.15.85
v5.15.86
v5.15.87
v5.15.88
v5.15.89
v5.15.9
v5.15.90
v5.15.91
v5.15.92
v5.15.93
v5.16
v5.16-rc1
v5.16-rc2
v5.16-rc3
v5.16-rc4
v5.16-rc5
v5.16-rc6
v5.16-rc7
v5.16-rc8
v5.17
v5.17-rc1
v5.17-rc2
v5.17-rc3
v5.17-rc4
v5.17-rc5
v5.17-rc6
v5.17-rc7
v5.17-rc8
v5.18
v5.18-rc1
v5.18-rc2
v5.18-rc3
v5.18-rc4
v5.18-rc5
v5.18-rc6
v5.18-rc7
v5.19
v5.19-rc1
v5.19-rc2
v5.19-rc3
v5.19-rc4
v5.19-rc5
v5.19-rc6
v5.19-rc7
v5.19-rc8

v6.*

v6.0
v6.0-rc1
v6.0-rc2
v6.0-rc3
v6.0-rc4
v6.0-rc5
v6.0-rc6
v6.0-rc7
v6.1
v6.1-rc1
v6.1-rc2
v6.1-rc3
v6.1-rc4
v6.1-rc5
v6.1-rc6
v6.1-rc7
v6.1-rc8
v6.1.1
v6.1.10
v6.1.11
v6.1.2
v6.1.3
v6.1.4
v6.1.5
v6.1.6
v6.1.7
v6.1.8
v6.1.9
v6.2-rc1
v6.2-rc2

Database specific

{
    "vanir_signatures": [
        {
            "signature_type": "Function",
            "deprecated": false,
            "target": {
                "file": "arch/powerpc/kernel/interrupt.c",
                "function": "prep_irq_for_enabled_exit"
            },
            "signature_version": "v1",
            "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@86f7e423933608d536015a0f2eb9e0338c1227e0",
            "id": "CVE-2023-52740-6978d110",
            "digest": {
                "function_hash": "14755381371384451172135814783765883689",
                "length": 312.0
            }
        },
        {
            "signature_type": "Function",
            "deprecated": false,
            "target": {
                "file": "arch/powerpc/kernel/interrupt.c",
                "function": "prep_irq_for_enabled_exit"
            },
            "signature_version": "v1",
            "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@2ea31e2e62bbc4d11c411eeb36f1b02841dbcab1",
            "id": "CVE-2023-52740-829b405d",
            "digest": {
                "function_hash": "14755381371384451172135814783765883689",
                "length": 312.0
            }
        },
        {
            "signature_type": "Line",
            "deprecated": false,
            "target": {
                "file": "arch/powerpc/kernel/interrupt.c"
            },
            "signature_version": "v1",
            "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@2ea31e2e62bbc4d11c411eeb36f1b02841dbcab1",
            "id": "CVE-2023-52740-d04597c7",
            "digest": {
                "line_hashes": [
                    "181015050594272128054391241345300389985",
                    "248841789086289620683798903616317638945",
                    "228243961922735735254268736994429951629",
                    "139211545796595301064398272437576608545",
                    "118271080607588173279003953355135553333",
                    "160366292653392477499011517484859967583",
                    "288325439941582034365472368971291963194",
                    "297717701434195722646612041695843927258",
                    "178669960365343878482645450941443728424",
                    "312625212229005743173933021237944966457"
                ],
                "threshold": 0.9
            }
        },
        {
            "signature_type": "Line",
            "deprecated": false,
            "target": {
                "file": "arch/powerpc/kernel/interrupt.c"
            },
            "signature_version": "v1",
            "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@86f7e423933608d536015a0f2eb9e0338c1227e0",
            "id": "CVE-2023-52740-fc02e379",
            "digest": {
                "line_hashes": [
                    "181015050594272128054391241345300389985",
                    "248841789086289620683798903616317638945",
                    "228243961922735735254268736994429951629",
                    "139211545796595301064398272437576608545",
                    "118271080607588173279003953355135553333",
                    "160366292653392477499011517484859967583",
                    "288325439941582034365472368971291963194",
                    "297717701434195722646612041695843927258",
                    "178669960365343878482645450941443728424",
                    "312625212229005743173933021237944966457"
                ],
                "threshold": 0.9
            }
        }
    ]
}

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
5.14.0
Fixed
5.15.94
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.12