From: Richard Henderson <richard.henderson@linaro.org>
To: qemu-devel@nongnu.org
Subject: [PATCH 27/33] cpu: Remove page_size_init
Date: Fri, 18 Aug 2023 10:12:21 -0700 [thread overview]
Message-ID: <20230818171227.141728-28-richard.henderson@linaro.org> (raw)
In-Reply-To: <20230818171227.141728-1-richard.henderson@linaro.org>
Move qemu_host_page_{size,mask} and HOST_PAGE_ALIGN into bsd-user.
It should be removed from bsd-user as well, but defer that cleanup.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
bsd-user/qemu.h | 7 +++++++
include/exec/cpu-common.h | 7 -------
include/hw/core/cpu.h | 2 --
accel/tcg/translate-all.c | 1 -
bsd-user/main.c | 12 ++++++++++++
cpu.c | 13 -------------
softmmu/vl.c | 1 -
7 files changed, 19 insertions(+), 24 deletions(-)
diff --git a/bsd-user/qemu.h b/bsd-user/qemu.h
index 8f2d6a3c78..9fe4e70890 100644
--- a/bsd-user/qemu.h
+++ b/bsd-user/qemu.h
@@ -38,6 +38,13 @@ extern char **environ;
#include "exec/gdbstub.h"
#include "qemu/clang-tsa.h"
+/*
+ * TODO: Remove these and rely only on qemu_real_host_page_size().
+ */
+extern uintptr_t qemu_host_page_size;
+extern intptr_t qemu_host_page_mask;
+#define HOST_PAGE_ALIGN(addr) ROUND_UP((addr), qemu_host_page_size)
+
/*
* This struct is used to hold certain information about the image. Basically,
* it replicates in user space what would be certain task_struct fields in the
diff --git a/include/exec/cpu-common.h b/include/exec/cpu-common.h
index 87dc9a752c..1bf4616fa3 100644
--- a/include/exec/cpu-common.h
+++ b/include/exec/cpu-common.h
@@ -22,13 +22,6 @@ typedef uint64_t vaddr;
void cpu_exec_init_all(void);
void cpu_exec_step_atomic(CPUState *cpu);
-/* Using intptr_t ensures that qemu_*_page_mask is sign-extended even
- * when intptr_t is 32-bit and we are aligning a long long.
- */
-extern uintptr_t qemu_host_page_size;
-extern intptr_t qemu_host_page_mask;
-
-#define HOST_PAGE_ALIGN(addr) ROUND_UP((addr), qemu_host_page_size)
#define REAL_HOST_PAGE_ALIGN(addr) ROUND_UP((addr), qemu_real_host_page_size())
/* The CPU list lock nests outside page_(un)lock or mmap_(un)lock */
diff --git a/include/hw/core/cpu.h b/include/hw/core/cpu.h
index fdcbe87352..66575eec73 100644
--- a/include/hw/core/cpu.h
+++ b/include/hw/core/cpu.h
@@ -1025,8 +1025,6 @@ bool target_words_bigendian(void);
const char *target_name(void);
-void page_size_init(void);
-
#ifdef NEED_CPU_H
#ifndef CONFIG_USER_ONLY
diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c
index b2d4e22c17..d84558dd95 100644
--- a/accel/tcg/translate-all.c
+++ b/accel/tcg/translate-all.c
@@ -255,7 +255,6 @@ bool cpu_unwind_state_data(CPUState *cpu, uintptr_t host_pc, uint64_t *data)
void page_init(void)
{
- page_size_init();
page_table_config_init();
}
diff --git a/bsd-user/main.c b/bsd-user/main.c
index 381bb18df8..3cb2b5f43c 100644
--- a/bsd-user/main.c
+++ b/bsd-user/main.c
@@ -49,6 +49,13 @@
#include "host-os.h"
#include "target_arch_cpu.h"
+
+/*
+ * TODO: Remove these and rely only on qemu_real_host_page_size().
+ */
+uintptr_t qemu_host_page_size;
+intptr_t qemu_host_page_mask;
+
static bool opt_one_insn_per_tb;
uintptr_t guest_base;
bool have_guest_base;
@@ -308,6 +315,9 @@ int main(int argc, char **argv)
(void) envlist_setenv(envlist, *wrk);
}
+ qemu_host_page_size = getpagesize();
+ qemu_host_page_size = MAX(qemu_host_page_size, TARGET_PAGE_SIZE);
+
cpu_model = NULL;
qemu_add_opts(&qemu_trace_opts);
@@ -407,6 +417,8 @@ int main(int argc, char **argv)
}
}
+ qemu_host_page_mask = -qemu_host_page_size;
+
/* init debug */
{
int mask = 0;
diff --git a/cpu.c b/cpu.c
index 1c948d1161..743c889ece 100644
--- a/cpu.c
+++ b/cpu.c
@@ -431,16 +431,3 @@ const char *target_name(void)
{
return TARGET_NAME;
}
-
-void page_size_init(void)
-{
- /* NOTE: we can always suppose that qemu_host_page_size >=
- TARGET_PAGE_SIZE */
- if (qemu_host_page_size == 0) {
- qemu_host_page_size = qemu_real_host_page_size();
- }
- if (qemu_host_page_size < TARGET_PAGE_SIZE) {
- qemu_host_page_size = TARGET_PAGE_SIZE;
- }
- qemu_host_page_mask = -(intptr_t)qemu_host_page_size;
-}
diff --git a/softmmu/vl.c b/softmmu/vl.c
index b0b96f67fa..bc2aab9aaa 100644
--- a/softmmu/vl.c
+++ b/softmmu/vl.c
@@ -2049,7 +2049,6 @@ static void qemu_create_machine(QDict *qdict)
}
cpu_exec_init_all();
- page_size_init();
if (machine_class->hw_version) {
qemu_set_hw_version(machine_class->hw_version);
--
2.34.1
next prev parent reply other threads:[~2023-08-18 17:14 UTC|newest]
Thread overview: 44+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-08-18 17:11 [PATCH 00/33] linux-user: Improve host and guest page size handling Richard Henderson
2023-08-18 17:11 ` [PATCH 01/33] accel/tcg: Remove qemu_host_page_size from page_protect/page_unprotect Richard Henderson
2023-08-18 17:11 ` [PATCH 02/33] linux-user: Adjust SVr4 NULL page mapping Richard Henderson
2023-08-18 17:11 ` [PATCH 03/33] linux-user: Remove qemu_host_page_{size, mask} in probe_guest_base Richard Henderson
2023-08-18 17:11 ` [PATCH 04/33] linux-user: Remove qemu_host_page_size from create_elf_tables Richard Henderson
2023-08-18 17:11 ` [PATCH 05/33] linux-user/hppa: Simplify init_guest_commpage Richard Henderson
2023-08-18 17:12 ` [PATCH 06/33] linux-user/nios2: Remove qemu_host_page_size from init_guest_commpage Richard Henderson
2023-08-18 17:12 ` [PATCH 07/33] linux-user/arm: " Richard Henderson
2023-08-18 17:12 ` [PATCH 08/33] linux-user: Remove qemu_host_page_{size, mask} from mmap.c Richard Henderson
2023-08-18 17:12 ` [PATCH 09/33] linux-user: Remove REAL_HOST_PAGE_ALIGN " Richard Henderson
2023-08-21 7:08 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 10/33] linux-user: Remove HOST_PAGE_ALIGN " Richard Henderson
2023-08-18 17:12 ` [PATCH 11/33] migration: Remove qemu_host_page_size Richard Henderson
2023-08-18 17:12 ` [PATCH 12/33] hw/tpm: Remove HOST_PAGE_ALIGN from tpm_ppi_init Richard Henderson
2023-08-18 17:12 ` [PATCH 13/33] softmmu/physmem: Remove qemu_host_page_size Richard Henderson
2023-08-18 17:12 ` [PATCH 14/33] softmmu/physmem: Remove HOST_PAGE_ALIGN Richard Henderson
2023-08-18 17:12 ` [PATCH 15/33] linux-user: Remove qemu_host_page_size from main Richard Henderson
2023-08-18 17:12 ` [PATCH 16/33] linux-user: Split out target_mmap__locked Richard Henderson
2023-08-21 6:43 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 17/33] linux-user: Move some mmap checks outside the lock Richard Henderson
2023-08-21 6:47 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 18/33] linux-user: Fix sub-host-page mmap Richard Henderson
2023-08-18 17:12 ` [PATCH 19/33] linux-user: Split out mmap_end Richard Henderson
2023-08-21 6:49 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 20/33] linux-user: Do early mmap placement only for reserved_va Richard Henderson
2023-08-18 17:12 ` [PATCH 21/33] linux-user: Split out mmap_h_eq_g Richard Henderson
2023-08-18 17:12 ` [PATCH 22/33] linux-user: Split out mmap_h_lt_g Richard Henderson
2023-08-18 17:12 ` [PATCH 23/33] linux-user: Split out mmap_h_gt_g Richard Henderson
2023-08-18 17:12 ` [PATCH 24/33] tests/tcg: Remove run-test-mmap-* Richard Henderson
2023-08-18 17:12 ` [PATCH 25/33] tests/tcg: Extend file in linux-madvise.c Richard Henderson
2023-08-21 6:54 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 26/33] linux-user: Deprecate and disable -p pagesize Richard Henderson
2023-08-21 6:58 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` Richard Henderson [this message]
2023-08-21 7:00 ` [PATCH 27/33] cpu: Remove page_size_init Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 28/33] accel/tcg: Disconnect TargetPageDataNode from page size Richard Henderson
2023-08-21 7:03 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 29/33] linux-user: Allow TARGET_PAGE_BITS_VARY Richard Henderson
2023-08-18 17:12 ` [PATCH 30/33] target/arm: Enable TARGET_PAGE_BITS_VARY for AArch64 user-only Richard Henderson
2023-08-21 7:05 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 31/33] linux-user: Bound mmap_min_addr by host page size Richard Henderson
2023-08-18 17:12 ` [PATCH 32/33] target/ppc: Enable TARGET_PAGE_BITS_VARY for user-only Richard Henderson
2023-08-21 7:06 ` Philippe Mathieu-Daudé
2023-08-18 17:12 ` [PATCH 33/33] target/alpha: " Richard Henderson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230818171227.141728-28-richard.henderson@linaro.org \
--to=richard.henderson@linaro.org \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).