[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v1 25/34] linux-user/elfload: add extra logging for hole finding
|
From: |
Alex Bennée |
|
Subject: |
[PATCH v1 25/34] linux-user/elfload: add extra logging for hole finding |
|
Date: |
Wed, 5 Jan 2022 13:50:00 +0000 |
The various approaches to finding memory holes are quite complicated
to follow especially at a distance. Improve the logging so we can see
exactly what method found the space for the guest memory.
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
---
linux-user/elfload.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
diff --git a/linux-user/elfload.c b/linux-user/elfload.c
index 767f54c76d..238979b8b6 100644
--- a/linux-user/elfload.c
+++ b/linux-user/elfload.c
@@ -2221,6 +2221,9 @@ static void pgb_have_guest_base(const char *image_name,
abi_ulong guest_loaddr,
if (test != addr) {
pgb_fail_in_use(image_name);
}
+ qemu_log_mask(CPU_LOG_PAGE,
+ "%s: base @ %p for " TARGET_ABI_FMT_ld " bytes\n",
+ __func__, addr, guest_hiaddr - guest_loaddr);
}
/**
@@ -2263,6 +2266,9 @@ static uintptr_t pgd_find_hole_fallback(uintptr_t
guest_size, uintptr_t brk,
if (mmap_start != MAP_FAILED) {
munmap(mmap_start, guest_size);
if (mmap_start == (void *) align_start) {
+ qemu_log_mask(CPU_LOG_PAGE,
+ "%s: base @ %p for %" PRIdPTR" bytes\n",
+ __func__, mmap_start + offset, guest_size);
return (uintptr_t) mmap_start + offset;
}
}
@@ -2342,6 +2348,12 @@ static uintptr_t pgb_find_hole(uintptr_t guest_loaddr,
uintptr_t guest_size,
}
free_self_maps(maps);
+ if (ret != -1) {
+ qemu_log_mask(CPU_LOG_PAGE, "%s: base @ %" PRIxPTR
+ " for %" PRIdPTR " bytes\n",
+ __func__, ret, guest_size);
+ }
+
return ret;
}
@@ -2391,6 +2403,9 @@ static void pgb_static(const char *image_name, abi_ulong
orig_loaddr,
}
guest_base = addr;
+
+ qemu_log_mask(CPU_LOG_PAGE, "%s: base @ %"PRIxPTR" for %" PRIdPTR"
bytes\n",
+ __func__, addr, hiaddr - loaddr);
}
static void pgb_dynamic(const char *image_name, long align)
@@ -2447,6 +2462,9 @@ static void pgb_reserved_va(const char *image_name,
abi_ulong guest_loaddr,
"using -R option)", reserved_va, test, strerror(errno));
exit(EXIT_FAILURE);
}
+
+ qemu_log_mask(CPU_LOG_PAGE, "%s: base @ %p for %ld bytes\n",
+ __func__, addr, reserved_va);
}
void probe_guest_base(const char *image_name, abi_ulong guest_loaddr,
--
2.30.2
- [PATCH v1 10/34] tests/docker: auto-generate ubuntu1804.docker with lcitool, (continued)
- [PATCH v1 10/34] tests/docker: auto-generate ubuntu1804.docker with lcitool, Alex Bennée, 2022/01/05
- [PATCH v1 32/34] gitlab-ci: Enable docs in the centos job, Alex Bennée, 2022/01/05
- [PATCH v1 21/34] hw/arm: add control knob to disable kaslr_seed via DTB, Alex Bennée, 2022/01/05
- [PATCH v1 20/34] tests/docker: add libfuse3 development headers, Alex Bennée, 2022/01/05
- [PATCH v1 18/34] tests/docker: auto-generate alpine.docker with lcitool, Alex Bennée, 2022/01/05
- [PATCH v1 13/34] tests/docker: remove ubuntu.docker container, Alex Bennée, 2022/01/05
- [PATCH v1 25/34] linux-user/elfload: add extra logging for hole finding,
Alex Bennée <=
- [PATCH v1 17/34] tests/docker: fully expand the alpine package list, Alex Bennée, 2022/01/05
- [PATCH v1 16/34] tests/docker: fix sorting of alpine image package lists, Alex Bennée, 2022/01/05
- [PATCH v1 26/34] linux-user: don't adjust base of found hole, Alex Bennée, 2022/01/05
- [PATCH v1 22/34] monitor: move x-query-profile into accel/tcg to fix build, Alex Bennée, 2022/01/05