-
CVE-2026-43492
- EPSS 0.02%
- Veröffentlicht 19.05.2026 10:44:24
- Zuletzt bearbeitet 19.05.2026 12:16:18
- Quelle 416baaa9-dc9f-4396-8d5f-8c081f
- CVE-Watchlists
- Unerledigt
lib/crypto: mpi: Fix integer underflow in mpi_read_raw_from_sgl()
In the Linux kernel, the following vulnerability has been resolved:
lib/crypto: mpi: Fix integer underflow in mpi_read_raw_from_sgl()
Yiming reports an integer underflow in mpi_read_raw_from_sgl() when
subtracting "lzeros" from the unsigned "nbytes".
For this to happen, the scatterlist "sgl" needs to occupy more bytes
than the "nbytes" parameter and the first "nbytes + 1" bytes of the
scatterlist must be zero. Under these conditions, the while loop
iterating over the scatterlist will count more zeroes than "nbytes",
subtract the number of zeroes from "nbytes" and cause the underflow.
When commit 2d4d1eea540b ("lib/mpi: Add mpi sgl helpers") originally
introduced the bug, it couldn't be triggered because all callers of
mpi_read_raw_from_sgl() passed a scatterlist whose length was equal to
"nbytes".
However since commit 63ba4d67594a ("KEYS: asymmetric: Use new crypto
interface without scatterlists"), the underflow can now actually be
triggered. When invoking a KEYCTL_PKEY_ENCRYPT system call with a
larger "out_len" than "in_len" and filling the "in" buffer with zeroes,
crypto_akcipher_sync_prep() will create an all-zero scatterlist used for
both the "src" and "dst" member of struct akcipher_request and thereby
fulfil the conditions to trigger the bug:
sys_keyctl()
keyctl_pkey_e_d_s()
asymmetric_key_eds_op()
software_key_eds_op()
crypto_akcipher_sync_encrypt()
crypto_akcipher_sync_prep()
crypto_akcipher_encrypt()
rsa_enc()
mpi_read_raw_from_sgl()
To the user this will be visible as a DoS as the kernel spins forever,
causing soft lockup splats as a side effect.
Fix it.Daten sind bereitgestellt durch das CVE Programm von einer CVE Numbering Authority (CNA) (Unstrukturiert).
HerstellerLinux
≫
Produkt
Linux
Default Statusunaffected
Version
2d4d1eea540b27c72488fd1914674c42473d53df
Version <
2aa77a18dc7f2670497fe3ee5acbeda0b57659e5
Status
affected
Version
2d4d1eea540b27c72488fd1914674c42473d53df
Version <
26d3a97ad46c7a9226ec04d4bf35bd4998a97d16
Status
affected
Version
2d4d1eea540b27c72488fd1914674c42473d53df
Version <
8637dfb4c1d8a7026ef681f2477c6de8b71c4003
Status
affected
Version
2d4d1eea540b27c72488fd1914674c42473d53df
Version <
30e513e755bb381afce6fb57cdc8694136193f22
Status
affected
Version
2d4d1eea540b27c72488fd1914674c42473d53df
Version <
8c2f1288250a90a4b5cabed5d888d7e3aeed4035
Status
affected
HerstellerLinux
≫
Produkt
Linux
Default Statusaffected
Version
4.4
Status
affected
Version
0
Version <
4.4
Status
unaffected
Version <=
6.6.*
Version
6.6.140
Status
unaffected
Version <=
6.12.*
Version
6.12.88
Status
unaffected
Version <=
6.18.*
Version
6.18.30
Status
unaffected
Version <=
7.0.*
Version
7.0.7
Status
unaffected
Version <=
*
Version
7.1-rc1
Status
unaffected
VulnDex Vulnerability Enrichment
| Typ | Quelle | Score | Percentile |
|---|---|---|---|
| EPSS | FIRST.org | 0.02% | 0.069 |
| Quelle | Base Score | Exploit Score | Impact Score | Vector String |
|---|