- hw/misc/mos6522: Fix bad class definition of the MOS6522 device - target/i386: Fix minor typo in NO_NESTED_DATA_BP feature bit - cpu: ensure we don't call start_exclusive from cpu_exec - Avoid unaligned fetch in ladr_match() - audio/audio.c: remove trailing newline in error_setg - acpi/tests/avocado/bits: wait for 200 seconds for SHUTDOWN event from bits VM - linux-user: Tolerate CONFIG_LSM_MMAP_MIN_ADDR - accel/tcg: Fix user-only probe_access_internal plugin - linux-user: Honor elf alignment when placing images - Reserve address for MSI mapping in the CVM scenario. Signed-off-by: Jiabo Feng <fengjiabo1@huawei.com> (cherry picked from commit 3ab56c27fe6b593be9a24f27b52b2730efa05304)
53 lines
2.0 KiB
Diff
53 lines
2.0 KiB
Diff
From 6d4db685ae8b4cbffab80c61c01ef56c57b67eb4 Mon Sep 17 00:00:00 2001
|
|
From: guping <guping_yewu@cmss.chinamobile.com>
|
|
Date: Mon, 18 Nov 2024 03:09:59 +0000
|
|
Subject: [PATCH] linux-user: Tolerate CONFIG_LSM_MMAP_MIN_ADDR cherry-pick
|
|
from fb7f3572b111ffb6c2dd2c7f6c5b4dc57dd8a3f5
|
|
|
|
Running qemu-i386 on a system running with SELinux in enforcing mode
|
|
(more precisely: s390x trixie container on Fedora 40) fails with:
|
|
|
|
qemu-i386: tests/tcg/i386-linux-user/sigreturn-sigmask: Unable to find a guest_base to satisfy all guest address mapping requirements
|
|
00000000-ffffffff
|
|
|
|
The reason is that main() determines mmap_min_addr from
|
|
/proc/sys/vm/mmap_min_addr, but SELinux additionally defines
|
|
CONFIG_LSM_MMAP_MIN_ADDR, which is normally larger: 32K or 64K, but,
|
|
in general, can be anything. There is no portable way to query its
|
|
value: /boot/config, /proc/config and /proc/config.gz are distro- and
|
|
environment-specific.
|
|
|
|
Once the identity map fails, the magnitude of guest_base does not
|
|
matter, so fix by starting the search from 1M or 1G.
|
|
|
|
Cc: qemu-stable@nongnu.org
|
|
Resolves: #2598
|
|
|
|
|
|
Suggested-by: default avatarRichard Henderson <richard.henderson@linaro.org>
|
|
Signed-off-by: default avatarIlya Leoshkevich <iii@linux.ibm.com>
|
|
Message-ID: <20241023002558.34589-1-iii@linux.ibm.com>
|
|
Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
|
|
|
|
Signed-off-by: guping <guping_yewu@cmss.chinamobile.com>
|
|
---
|
|
linux-user/elfload.c | 2 +-
|
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
|
|
diff --git a/linux-user/elfload.c b/linux-user/elfload.c
|
|
index cf9e74468b..0df64c6442 100644
|
|
--- a/linux-user/elfload.c
|
|
+++ b/linux-user/elfload.c
|
|
@@ -2980,7 +2980,7 @@ static uintptr_t pgb_try_itree(const PGBAddrs *ga, uintptr_t base,
|
|
static uintptr_t pgb_find_itree(const PGBAddrs *ga, IntervalTreeRoot *root,
|
|
uintptr_t align, uintptr_t brk)
|
|
{
|
|
- uintptr_t last = mmap_min_addr;
|
|
+ uintptr_t last = sizeof(uintptr_t) == 4 ? MiB : GiB;
|
|
uintptr_t base, skip;
|
|
|
|
while (true) {
|
|
--
|
|
2.41.0.windows.1
|
|
|