diff options
Diffstat (limited to 'meta/recipes-devtools/qemu/qemu/mmap2.patch')
-rw-r--r-- | meta/recipes-devtools/qemu/qemu/mmap2.patch | 39 |
1 files changed, 0 insertions, 39 deletions
diff --git a/meta/recipes-devtools/qemu/qemu/mmap2.patch b/meta/recipes-devtools/qemu/qemu/mmap2.patch deleted file mode 100644 index e115473b70..0000000000 --- a/meta/recipes-devtools/qemu/qemu/mmap2.patch +++ /dev/null @@ -1,39 +0,0 @@ -When using qemu-i386 to build qemux86 webkitgtk on musl, it sits in an -infinite loop of mremap calls of ever decreasing/increasing addresses. - -I suspect something in the musl memory allocation code loops indefinitely -if it only sees ENOMEM and only exits when it hits EFAULT. - -According to the docs, trying to mremap outside the address space -can/should return EFAULT and changing this allows the build to succeed. - -A better return value for the other cases of invalid addresses is EINVAL -rather than ENOMEM so adjust the other part of the test to this. - -Upstream-Status: Submitted [https://lists.gnu.org/archive/html/qemu-devel/2021-01/msg01355.html] -Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org - -Index: qemu-6.0.0/linux-user/mmap.c -=================================================================== ---- qemu-6.0.0.orig/linux-user/mmap.c -+++ qemu-6.0.0/linux-user/mmap.c -@@ -733,12 +733,16 @@ abi_long target_mremap(abi_ulong old_add - int prot; - void *host_addr; - -- if (!guest_range_valid_untagged(old_addr, old_size) || -- ((flags & MREMAP_FIXED) && -+ if (!guest_range_valid_untagged(old_addr, old_size)) { -+ errno = EFAULT; -+ return -1; -+ } -+ -+ if (((flags & MREMAP_FIXED) && - !guest_range_valid_untagged(new_addr, new_size)) || - ((flags & MREMAP_MAYMOVE) == 0 && - !guest_range_valid_untagged(old_addr, new_size))) { -- errno = ENOMEM; -+ errno = EINVAL; - return -1; - } - |