From: Bingwu Zhang <[email protected]>
Fixes: 4c13048e02d9 ("linux-user: Use page_find_range_empty for
mmap_find_vma_reserved")
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/3310
Signed-off-by: Bingwu Zhang <[email protected]>
---
linux-user/mmap.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/linux-user/mmap.c b/linux-user/mmap.c
index 07175e11d576..76978a56a859 100644
--- a/linux-user/mmap.c
+++ b/linux-user/mmap.c
@@ -423,12 +423,15 @@ abi_ulong mmap_next_start;
static abi_ulong mmap_find_vma_reserved(abi_ulong start, abi_ulong size,
abi_ulong align)
{
- target_ulong ret;
+ target_ulong ret = -1;
- ret = page_find_range_empty(start, reserved_va, size, align);
+ if (start <= reserved_va) {
+ ret = page_find_range_empty(start, reserved_va, size, align);
+ }
if (ret == -1 && start > mmap_min_addr) {
/* Restart at the beginning of the address space. */
- ret = page_find_range_empty(mmap_min_addr, start - 1, size, align);
+ ret = page_find_range_empty(mmap_min_addr, MIN(start - 1, reserved_va),
+ size, align);
}
return ret;
--
2.52.0