[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 19/33] linux-user: Split out mmap_end
From: |
Richard Henderson |
Subject: |
[PATCH 19/33] linux-user: Split out mmap_end |
Date: |
Fri, 18 Aug 2023 10:12:13 -0700 |
Use a subroutine instead of a goto within target_mmap__locked.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
linux-user/mmap.c | 69 +++++++++++++++++++++++++++--------------------
1 file changed, 40 insertions(+), 29 deletions(-)
diff --git a/linux-user/mmap.c b/linux-user/mmap.c
index e905b1b8f2..caa76eb11a 100644
--- a/linux-user/mmap.c
+++ b/linux-user/mmap.c
@@ -446,6 +446,42 @@ abi_ulong mmap_find_vma(abi_ulong start, abi_ulong size,
abi_ulong align)
}
}
+/*
+ * Record a successful mmap within the user-exec interval tree.
+ */
+static abi_long mmap_end(abi_ulong start, abi_ulong last,
+ abi_ulong passthrough_start,
+ abi_ulong passthrough_last,
+ int flags, int page_flags)
+{
+ if (flags & MAP_ANONYMOUS) {
+ page_flags |= PAGE_ANON;
+ }
+ page_flags |= PAGE_RESET;
+ if (passthrough_start > passthrough_last) {
+ page_set_flags(start, last, page_flags);
+ } else {
+ if (start < passthrough_start) {
+ page_set_flags(start, passthrough_start - 1, page_flags);
+ }
+ page_set_flags(passthrough_start, passthrough_last,
+ page_flags | PAGE_PASSTHROUGH);
+ if (passthrough_last < last) {
+ page_set_flags(passthrough_last + 1, last, page_flags);
+ }
+ }
+ trace_target_mmap_complete(start);
+ if (qemu_loglevel_mask(CPU_LOG_PAGE)) {
+ FILE *f = qemu_log_trylock();
+ if (f) {
+ fprintf(f, "page layout changed following mmap\n");
+ page_dump(f);
+ qemu_log_unlock(f);
+ }
+ }
+ return start;
+}
+
static abi_long target_mmap__locked(abi_ulong start, abi_ulong len,
int target_prot, int flags, int page_flags,
int fd, off_t offset)
@@ -588,7 +624,7 @@ static abi_long target_mmap__locked(abi_ulong start,
abi_ulong len,
ret = target_mprotect(start, len, target_prot);
assert(ret == 0);
}
- goto the_end;
+ return mmap_end(start, last, -1, 0, flags, page_flags);
}
/* handle the start of the mapping */
@@ -599,7 +635,7 @@ static abi_long target_mmap__locked(abi_ulong start,
abi_ulong len,
target_prot, flags, fd, offset)) {
return -1;
}
- goto the_end;
+ return mmap_end(start, last, -1, 0, flags, page_flags);
}
if (!mmap_frag(real_start, start,
real_start + host_page_size - 1,
@@ -646,33 +682,8 @@ static abi_long target_mmap__locked(abi_ulong start,
abi_ulong len,
passthrough_last = real_last;
}
}
- the_end:
- if (flags & MAP_ANONYMOUS) {
- page_flags |= PAGE_ANON;
- }
- page_flags |= PAGE_RESET;
- if (passthrough_start > passthrough_last) {
- page_set_flags(start, last, page_flags);
- } else {
- if (start < passthrough_start) {
- page_set_flags(start, passthrough_start - 1, page_flags);
- }
- page_set_flags(passthrough_start, passthrough_last,
- page_flags | PAGE_PASSTHROUGH);
- if (passthrough_last < last) {
- page_set_flags(passthrough_last + 1, last, page_flags);
- }
- }
- trace_target_mmap_complete(start);
- if (qemu_loglevel_mask(CPU_LOG_PAGE)) {
- FILE *f = qemu_log_trylock();
- if (f) {
- fprintf(f, "page layout changed following mmap\n");
- page_dump(f);
- qemu_log_unlock(f);
- }
- }
- return start;
+ return mmap_end(start, last, passthrough_start, passthrough_last,
+ flags, page_flags);
}
/* NOTE: all the constants are the HOST ones */
--
2.34.1
- [PATCH 13/33] softmmu/physmem: Remove qemu_host_page_size, (continued)
- [PATCH 13/33] softmmu/physmem: Remove qemu_host_page_size, Richard Henderson, 2023/08/18
- [PATCH 14/33] softmmu/physmem: Remove HOST_PAGE_ALIGN, Richard Henderson, 2023/08/18
- [PATCH 15/33] linux-user: Remove qemu_host_page_size from main, Richard Henderson, 2023/08/18
- [PATCH 17/33] linux-user: Move some mmap checks outside the lock, Richard Henderson, 2023/08/18
- [PATCH 16/33] linux-user: Split out target_mmap__locked, Richard Henderson, 2023/08/18
- [PATCH 18/33] linux-user: Fix sub-host-page mmap, Richard Henderson, 2023/08/18
- [PATCH 20/33] linux-user: Do early mmap placement only for reserved_va, Richard Henderson, 2023/08/18
- [PATCH 21/33] linux-user: Split out mmap_h_eq_g, Richard Henderson, 2023/08/18
- [PATCH 19/33] linux-user: Split out mmap_end,
Richard Henderson <=
- [PATCH 26/33] linux-user: Deprecate and disable -p pagesize, Richard Henderson, 2023/08/18
- [PATCH 27/33] cpu: Remove page_size_init, Richard Henderson, 2023/08/18
- [PATCH 22/33] linux-user: Split out mmap_h_lt_g, Richard Henderson, 2023/08/18
- [PATCH 25/33] tests/tcg: Extend file in linux-madvise.c, Richard Henderson, 2023/08/18
- [PATCH 24/33] tests/tcg: Remove run-test-mmap-*, Richard Henderson, 2023/08/18
- [PATCH 29/33] linux-user: Allow TARGET_PAGE_BITS_VARY, Richard Henderson, 2023/08/18