mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-27 21:40:49 +00:00
kvmvapic: Prevent reading beyond the end of guest RAM
rom_state_paddr is guest provided (caller address of outw(VAPIC_PORT) + writen 16-bit value) and can be influenced to point beyond the end of the host memory backing the guest's RAM. Make sure we do not use this pointer to actually read beyond the limits. Reading arbitrary guest bytes is harmless, the guest kernel has to manage access to this I/O port anyway. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Gleb Natapov <gleb@redhat.com>
This commit is contained in:
parent
2560f19f42
commit
7174e54cf1
@ -596,6 +596,9 @@ static int vapic_map_rom_writable(VAPICROMState *s)
|
||||
section = memory_region_find(as, 0, 1);
|
||||
|
||||
/* read ROM size from RAM region */
|
||||
if (rom_paddr + 2 >= memory_region_size(section.mr)) {
|
||||
return -1;
|
||||
}
|
||||
ram = memory_region_get_ram_ptr(section.mr);
|
||||
rom_size = ram[rom_paddr + 2] * ROM_BLOCK_SIZE;
|
||||
if (rom_size == 0) {
|
||||
|
Loading…
Reference in New Issue
Block a user