From version 0.2.14 to 0.2.16 for Solana rBPF, function "relocate" in the file src/elf.rs has an integer overflow bug because the sym.st_value is read directly from ELF file without checking. If the sym.st_value is rather large, an integer overflow is triggered while calculating the variable "addr" via "addr = (sym.st_value + refd_pa) as u64";
References
Link | Resource |
---|---|
https://blocksecteam.medium.com/new-integer-overflow-bug-discovered-in-solana-rbpf-7729717159ee | Exploit Third Party Advisory |
https://github.com/solana-labs/rbpf/blob/c14764850f0b83b58aa013248eaf6d65836c1218/src/elf.rs#L609-L630 | Exploit Third Party Advisory |
https://github.com/solana-labs/rbpf/pull/200 | Patch Third Party Advisory |
https://github.com/solana-labs/rbpf/pull/236 | Patch Third Party Advisory |
Configurations
History
No history.
Information
Published : 2022-01-27 18:15
Updated : 2023-04-26 19:10
NVD link : CVE-2021-46102
Mitre link : CVE-2021-46102
CVE.ORG link : CVE-2021-46102
JSON object : View
Products Affected
solanalabs
- rbpf
CWE
CWE-190
Integer Overflow or Wraparound