From: "Alex Bennée" <alex.bennee@linaro.org> To: qemu-devel@nongnu.org Cc: "Alex Bennée" <alex.bennee@linaro.org>, "Laurent Vivier" <laurent@vivier.eu>, "Bug 1895080" <1895080@bugs.launchpad.net> Subject: [RFC PATCH] linux-user: test, don't assert addr != test in pgb_reserved_va Date: Fri, 11 Sep 2020 15:56:30 +0100 [thread overview] Message-ID: <20200911145630.6560-1-alex.bennee@linaro.org> (raw) On older kernels which don't implement MAP_FIXED_NOREPLACE the kernel may still fail to give us the address we asked for despite having already probed the map for a valid hole. Asserting isn't particularly useful to the user so let us move the check up and expand the error_report a little to give them a fighting chance of working around the problem. Ameliorates: ee94743034 Cc: Bug 1895080 <1895080@bugs.launchpad.net> Signed-off-by: Alex Bennée <alex.bennee@linaro.org> --- linux-user/elfload.c | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/linux-user/elfload.c b/linux-user/elfload.c index 4961e6119e2..f6022fd7049 100644 --- a/linux-user/elfload.c +++ b/linux-user/elfload.c @@ -2331,14 +2331,13 @@ static void pgb_reserved_va(const char *image_name, abi_ulong guest_loaddr, assert(guest_base != 0); test = g2h(0); addr = mmap(test, reserved_va, PROT_NONE, flags, -1, 0); - if (addr == MAP_FAILED) { + if (addr == MAP_FAILED || addr != test) { error_report("Unable to reserve 0x%lx bytes of virtual address " - "space (%s) for use as guest address space (check your " - "virtual memory ulimit setting or reserve less " - "using -R option)", reserved_va, strerror(errno)); + "space at %p (%s) for use as guest address space (check your" + "virtual memory ulimit setting, min_mmap_addr or reserve less " + "using -R option)", reserved_va, test, strerror(errno)); exit(EXIT_FAILURE); } - assert(addr == test); } void probe_guest_base(const char *image_name, abi_ulong guest_loaddr, -- 2.20.1
WARNING: multiple messages have this Message-ID (diff)
From: "Alex Bennée" <1895080@bugs.launchpad.net> To: qemu-devel@nongnu.org Subject: [Bug 1895080] Re: pgb_reserved_va: Assertion `addr == test' failed Date: Fri, 11 Sep 2020 14:56:30 -0000 [thread overview] Message-ID: <20200911145630.6560-1-alex.bennee@linaro.org> (raw) Message-ID: <20200911145630.Hr-vK7VbwjaNC_otWkcI8QG7c1g-r_F-A7NEuDIRD6g@z> (raw) In-Reply-To: 159970958159.31371.12301700684467003959.malonedeb@wampee.canonical.com On older kernels which don't implement MAP_FIXED_NOREPLACE the kernel may still fail to give us the address we asked for despite having already probed the map for a valid hole. Asserting isn't particularly useful to the user so let us move the check up and expand the error_report a little to give them a fighting chance of working around the problem. Ameliorates: ee94743034 Cc: Bug 1895080 <1895080@bugs.launchpad.net> Signed-off-by: Alex Bennée <alex.bennee@linaro.org> --- linux-user/elfload.c | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/linux-user/elfload.c b/linux-user/elfload.c index 4961e6119e2..f6022fd7049 100644 --- a/linux-user/elfload.c +++ b/linux-user/elfload.c @@ -2331,14 +2331,13 @@ static void pgb_reserved_va(const char *image_name, abi_ulong guest_loaddr, assert(guest_base != 0); test = g2h(0); addr = mmap(test, reserved_va, PROT_NONE, flags, -1, 0); - if (addr == MAP_FAILED) { + if (addr == MAP_FAILED || addr != test) { error_report("Unable to reserve 0x%lx bytes of virtual address " - "space (%s) for use as guest address space (check your " - "virtual memory ulimit setting or reserve less " - "using -R option)", reserved_va, strerror(errno)); + "space at %p (%s) for use as guest address space (check your" + "virtual memory ulimit setting, min_mmap_addr or reserve less " + "using -R option)", reserved_va, test, strerror(errno)); exit(EXIT_FAILURE); } - assert(addr == test); } void probe_guest_base(const char *image_name, abi_ulong guest_loaddr, -- 2.20.1 ** Tags added: mmap -- You received this bug notification because you are a member of qemu- devel-ml, which is subscribed to QEMU. https://bugs.launchpad.net/bugs/1895080 Title: pgb_reserved_va: Assertion `addr == test' failed Status in QEMU: New Bug description: This problem occurs on CentOS-7.5 (64-bit) with qemu-5.1.0, qemu head (commit 9435a8b3dd35f1f926f1b9127e8a906217a5518a) for riscv32-linux- user. Firstly, compile fails: Compiling C object libqemu-riscv32-linux-user.fa.p/linux-user_strace.c.o ../qemu.git/linux-user/strace.c:1210:18: error: ‘FALLOC_FL_KEEP_SIZE’ undeclared here (not in a function) FLAG_GENERIC(FALLOC_FL_KEEP_SIZE), I have to add below include to linux-user/strace.c diff --git a/linux-user/strace.c b/linux-user/strace.c index 11fea14fba..22e51d4a8a 100644 --- a/linux-user/strace.c +++ b/linux-user/strace.c @@ -7,6 +7,7 @@ #include <sys/mount.h> #include <arpa/inet.h> #include <netinet/tcp.h> +#include <linux/falloc.h> #include <linux/if_packet.h> #include <linux/netlink.h> #include <sched.h> Then trying qemu-riscv32 with a simple ELF, I get: linux-user/elfload.c:2341: pgb_reserved_va: Assertion `addr == test' failed. strace shows that: mmap(0x1000, 4294963200, PROT_NONE, MAP_PRIVATE|MAP_ANONYMOUS|MAP_NORESERVE, -1, 0) = 0x10000 write(2, "qemu-riscv32: ../qemu.git/linux-"..., 103qemu-riscv32: ../qemu.git/linux-user/elfload.c:2341: pgb_reserved_va: Assertion `addr == test' failed. ) = 103 The source code is in the function pgb_reserved_va (linux- user/elfload.c). I think mmap cannot guarantee that the returned pointer (test) equals to the parameter of addr. So is this a bug to assert (addr == test)? Attached configure script and test ELF file. Thanks. To manage notifications about this bug go to: https://bugs.launchpad.net/qemu/+bug/1895080/+subscriptions
next prev reply other threads:[~2020-09-11 14:57 UTC|newest] Thread overview: 73+ messages / expand[flat|nested] mbox.gz Atom feed top 2020-09-10 3:46 [Bug 1895080] [NEW] pgb_reserved_va: Assertion `addr == test' failed Hansni Bu 2020-09-10 6:18 ` [Bug 1895080] " Laurent Vivier 2020-09-10 19:04 ` [Bug 1895080] [NEW] " Laurent Vivier 2020-09-11 5:57 ` Hansni Bu 2020-09-11 9:34 ` Alex Bennée 2020-09-11 9:38 ` Alex Bennée 2020-09-11 10:18 ` Hansni Bu 2020-09-11 11:54 ` Alex Bennée 2020-09-11 11:54 ` Alex Bennée 2020-09-11 12:32 ` Hansni Bu 2020-09-11 14:47 ` Alex Bennée 2020-09-11 14:47 ` Alex Bennée 2020-09-11 8:30 ` [Bug 1895080] " Alex Bennée 2020-09-11 9:31 ` Hansni Bu 2020-09-11 14:56 ` Alex Bennée [this message] 2020-09-11 14:56 ` Alex Bennée 2020-09-15 2:09 ` Hansni Bu 2020-11-08 9:43 ` Thomas Huth 2020-12-10 9:17 ` Thomas Huth -- strict thread matches above, loose matches on Subject: below -- 2020-09-14 15:07 [PATCH v1 0/6] deprecation and linux-user tweaks (+test fix) Alex Bennée 2020-09-14 15:07 ` [PATCH v1 1/6] linux-user: test, don't assert addr != test in pgb_reserved_va Alex Bennée 2020-09-14 15:07 ` [Bug 1895080] " Alex Bennée 2020-09-14 15:07 ` [PATCH v1 2/6] configure: use add_to for tweaking deprecated_features Alex Bennée 2020-09-14 16:14 ` Thomas Huth 2020-09-14 15:07 ` [PATCH v1 3/6] configure: also skip deprecated targets with target-list-exclude Alex Bennée 2020-09-14 19:17 ` Peter Maydell 2020-09-15 9:22 ` Alex Bennée 2020-09-14 15:07 ` [PATCH v1 4/6] configure: include tilegx-linux-user in the auto-exclude logic Alex Bennée 2020-09-15 12:58 ` Philippe Mathieu-Daudé 2020-09-14 15:07 ` [PATCH v1 5/6] gitlab: create a build-deprecated target Alex Bennée 2020-09-14 15:15 ` Philippe Mathieu-Daudé 2020-09-14 16:16 ` Thomas Huth 2020-09-14 15:07 ` [PATCH v1 6/6] iotests: Work around failing readlink -f Alex Bennée 2020-09-15 13:43 [PATCH v2 0/8] configure deprecation, linux-user and iotest fixes Alex Bennée 2020-09-15 13:43 ` [PATCH v2 1/8] linux-user: test, don't assert addr != test in pgb_reserved_va Alex Bennée 2020-09-15 13:43 ` [Bug 1895080] " Alex Bennée 2020-09-15 15:58 ` Laurent Vivier 2020-09-15 15:58 ` [Bug 1895080] " Laurent Vivier 2020-09-15 17:13 ` Richard Henderson 2020-09-15 13:43 ` [PATCH v2 2/8] iotests: Drop readlink -f Alex Bennée 2020-09-15 17:14 ` Richard Henderson 2020-09-15 13:43 ` [PATCH v2 3/8] configure: move deprecated feature processing to supported_target Alex Bennée 2020-09-15 13:51 ` Michael Tokarev 2020-09-15 13:43 ` [PATCH v2 4/8] configure: also skip deprecated targets with target-list-exclude Alex Bennée 2020-09-15 17:16 ` Richard Henderson 2020-09-15 13:43 ` [PATCH v2 5/8] configure: clean-up the target-list-exclude logic Alex Bennée 2020-09-15 17:17 ` Richard Henderson 2020-09-15 13:43 ` [PATCH v2 6/8] configure: include tilegx-linux-user in the deprecation logic Alex Bennée 2020-09-15 17:17 ` Richard Henderson 2020-09-15 17:47 ` Philippe Mathieu-Daudé 2020-09-15 13:43 ` [PATCH v2 7/8] gitlab: create a build-deprecated target Alex Bennée 2020-09-15 13:43 ` [PATCH v2 8/8] configure: add [lm32|unicore32]-softmmu to deprecation logic Alex Bennée 2020-09-15 17:20 ` Richard Henderson 2020-10-29 12:25 ` Thomas Huth 2020-10-29 14:42 ` Alex Bennée 2020-10-29 15:28 ` Thomas Huth 2020-09-16 12:26 [PULL 0/8] configure deprecation, linux-user and test fix Alex Bennée 2020-09-16 12:26 ` [PULL 1/8] linux-user: test, don't assert addr != test in pgb_reserved_va Alex Bennée 2020-09-16 12:26 ` [Bug 1895080] " Alex Bennée 2020-09-16 12:26 ` [PULL 2/8] iotests: Drop readlink -f Alex Bennée 2020-09-16 12:26 ` [PULL 3/8] configure: move deprecated feature processing to supported_target Alex Bennée 2020-09-16 12:26 ` [PULL 4/8] configure: also skip deprecated targets with target-list-exclude Alex Bennée 2020-09-16 12:26 ` [PULL 5/8] configure: clean-up the target-list-exclude logic Alex Bennée 2020-09-16 12:26 ` [PULL 6/8] configure: include tilegx-linux-user in the deprecation logic Alex Bennée 2020-09-16 12:26 ` [PULL 7/8] gitlab: create a build-deprecated target Alex Bennée 2020-09-16 12:40 ` Peter Maydell 2020-09-16 13:23 ` Alex Bennée 2020-09-16 13:52 ` Philippe Mathieu-Daudé 2020-09-25 15:54 ` Peter Maydell 2020-09-25 18:34 ` Richard Henderson 2020-09-25 18:47 ` Peter Maydell 2020-09-16 12:26 ` [PULL 8/8] configure: add [lm32|unicore32]-softmmu to deprecation logic Alex Bennée 2020-09-17 19:40 ` [PULL 0/8] configure deprecation, linux-user and test fix Peter Maydell
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=20200911145630.6560-1-alex.bennee@linaro.org \ --to=alex.bennee@linaro.org \ --cc=1895080@bugs.launchpad.net \ --cc=laurent@vivier.eu \ --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: linkBe 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).