linux-loader reading beyond EOF could lead to infinite loop
Description
Published to the GitHub Advisory Database
Dec 12, 2022
Reviewed
Dec 12, 2022
Published by the National Vulnerability Database
Dec 13, 2022
Last updated
Jan 31, 2023
Impact
The linux-loader crate used the offsets and sizes provided in the ELF headers to determine the offsets to read from. If those offsets pointed beyond the end of the file this could lead to an infinite loop. Virtual Machine Monitors using the
linux-loader
crate could enter an infinite loop if the ELF header of the kernel they are loading was modified in a malicious manner.Patches
The issue has been addressed in 0.8.1
Workarounds
The issue can be mitigated by ensuring that only trusted kernel images are loaded or by verifying that the headers to not point beyond the end of the file.
References
See: rust-vmm/linux-loader#125
References