From patchwork Thu Apr 9 21:15:19 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185320 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2319122ilr; Thu, 9 Apr 2020 14:16:05 -0700 (PDT) X-Google-Smtp-Source: APiQypIQPm+WH82ZUQfqO14Wfdxs/Qobgnc3tlhGLwExily1pT+GEfPKoJRuy2qYIazdPCa5ICSp X-Received: by 2002:a37:b95:: with SMTP id 143mr921687qkl.412.1586466965581; Thu, 09 Apr 2020 14:16:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586466965; cv=none; d=google.com; s=arc-20160816; b=W3YYAYQUjczUhQj71m1a+IfzNqOG8MaG2UOhrYAqsqn2bxWR4ROnyau20H4QSSi7km desVPEELFfXrN5bRCNsexPjAo1B4ptcr8mB6qXmjMOCWWgd70E/ieo2mUid6HBxPpgaU IE5SWX1j2nn2kOwzkR7fVpP+q3bA72a7Ol4ZXGn8rQbwVtQ7VFbjFcyIVqXnzx5rmtu3 UDzOsNf3hqOIdvobPCHLIPbNCUTW69RhnucQAAiSU/TBov42dW45fhirml7hqfYc9qS7 dI8vEJZbFxJ5/7zAm9xmcCwitH3vDFgo1b8SWY7kqnUUYe0Y2MZUI+5cKEDBtB1CAhFd zY5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=ITHp/kEolbZdKkPDRbNKDAnTtqhWxFt1FMIeHrkT1Fo=; b=SPARsdX5rN1Kk24bl7lEN1juboKF7vAk/WeyUISDDEPk8qbsx/g6fuw9G+fJDZD2hO 6B95lshxreQoTLJUy4qicweTpRRTPW/WkyvMRJollIW6aVaPLmAEIRFD1sm6dMYgyNMq GSusG6dha+J8jzXOd5FQRcDJRQS7okJ6aKeleJ30YOq2sfM5QMVFYsdGrZ5XQ2FTPK5W ZMrGtgZKnctEdVFzlWi57vs6Qw9m7QHcwL/gMjHwYdLgTtp/V/pw0FyKer7C8k2+TRRd n4h2S0Mz9r3X7ehFUhiE+fZwsjdYfeOmhyYiOeirqt12E4/Cem0D1rQfKyI3e6mKnUEg gRFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=EIjH0pA8; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id d20si112985qko.362.2020.04.09.14.16.05 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:16:05 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=EIjH0pA8; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55564 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWr-00029Q-3Z for patch@linaro.org; Thu, 09 Apr 2020 17:16:05 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42311) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWQ-00022R-Qb for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:41 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWN-0005dc-SE for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:38 -0400 Received: from mail-wm1-x335.google.com ([2a00:1450:4864:20::335]:54758) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWN-0005cm-Hs for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:35 -0400 Received: by mail-wm1-x335.google.com with SMTP id h2so265712wmb.4 for ; Thu, 09 Apr 2020 14:15:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=ITHp/kEolbZdKkPDRbNKDAnTtqhWxFt1FMIeHrkT1Fo=; b=EIjH0pA8pRF3CNcxE03g2+5nGHDowHA39kZWdTjM91Kzzaw1U1G1u+s0gKRYWOo11H s1HjkmXEOUorKI/gNKyP6V2zco1sl0GItYVdAsTVCCaMo4tmx/kEV09bs8rufKb2FRSl nap6IfIVU8OrusxITIVo6TxLXJEPaTBbRTuOpRTknPw0kOE/tZxtFvvg7lbuMXfkspNn d54oPH+1K9Bg3LJMR0ZJjiJUiHuFNhsSxUo0i2dcMCijbwcJlX7dQk0GSpd4LwFuW9el DG/yetckzKTpN0hBBvgdIIBWOSH5gFdidgZaGgvaOFYHiy0afVBmMCsrP1l72RRC63MO g7Tw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ITHp/kEolbZdKkPDRbNKDAnTtqhWxFt1FMIeHrkT1Fo=; b=JEeKOotHduOeLrSjBH8kC2VcI1LO0pj0I7zG4yNNYKxed2tk9wUgzjrmjAkwzrutai SrYyoX6KT2h/d+lXsNvIp5Whob2FAa2IyDTpFyzIozgUyhyqVYSJs1/TEKIL5tkece3T BArL0tcee3JmAoWTq1431eq+VtUkhq5sz2J5/s2P6D1JmgislUvuDdtmKV/+iqajAh1k G+l4xwuZJHg8iq1no3vSTGIWld9PTthilQFKyKTqHYgaqwGRcQcuyz0Oa798AkW+MyuV M78FhcogLiZRVwufSQHdhT2jkGYGVV9tFNzd6ih5+yLmmlDRZG9WAaR3rkTf9IRwA8ud TTVw== X-Gm-Message-State: AGi0PuZDWToxtS3eXP+3vUDGJktB2w+4ko7MnLUaLDd9SnXakxI0ZR55 QNyeYjsOcBZRONGHKkYAkX4faDjhfPU= X-Received: by 2002:a7b:cd07:: with SMTP id f7mr1775219wmj.30.1586466933990; Thu, 09 Apr 2020 14:15:33 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id x11sm40545386wru.62.2020.04.09.14.15.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:31 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 211EA1FF87; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 01/11] linux-user: completely re-write init_guest_space Date: Thu, 9 Apr 2020 22:15:19 +0100 Message-Id: <20200409211529.5269-2-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::335 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Riku Voipio , =?utf-8?q?Alex_Benn=C3=A9e?= , Laurent Vivier Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" First we ensure all guest space initialisation logic comes through probe_guest_base once we understand the nature of the binary we are loading. The convoluted init_guest_space routine is removed and replaced with a number of pgb_* helpers which are called depending on what requirements we have when loading the binary. We first try to do what is requested by the host. Failing that we try and satisfy the guest requested base address. If all those options fail we fall back to finding a space in the memory map using our recently written read_self_maps() helper. There are some additional complications we try and take into account when looking for holes in the address space. We try not to go directly after the system brk() space so there is space for a little growth. We also don't want to have to use negative offsets which would result in slightly less efficient code on x86 when it's unable to use the segment offset register. Less mind-binding gotos and hopefully clearer logic throughout. Signed-off-by: Alex Bennée --- v3 - include rth updates that - split probe_guest_base into multiple functions - more heuristics on gap finding --- linux-user/qemu.h | 31 ++- linux-user/elfload.c | 503 +++++++++++++++++++++--------------------- linux-user/flatload.c | 6 + linux-user/main.c | 23 +- 4 files changed, 277 insertions(+), 286 deletions(-) -- 2.20.1 diff --git a/linux-user/qemu.h b/linux-user/qemu.h index 792c74290f8..e1febb88cf5 100644 --- a/linux-user/qemu.h +++ b/linux-user/qemu.h @@ -219,18 +219,27 @@ void init_qemu_uname_release(void); void fork_start(void); void fork_end(int child); -/* Creates the initial guest address space in the host memory space using - * the given host start address hint and size. The guest_start parameter - * specifies the start address of the guest space. guest_base will be the - * difference between the host start address computed by this function and - * guest_start. If fixed is specified, then the mapped address space must - * start at host_start. The real start address of the mapped memory space is - * returned or -1 if there was an error. +/** + * probe_guest_base: + * @image_name: the executable being loaded + * @loaddr: the lowest fixed address in the executable + * @hiaddr: the highest fixed address in the executable + * + * Creates the initial guest address space in the host memory space. + * + * If @loaddr == 0, then no address in the executable is fixed, + * i.e. it is fully relocatable. In that case @hiaddr is the size + * of the executable. + * + * This function will not return if a valid value for guest_base + * cannot be chosen. On return, the executable loader can expect + * + * target_mmap(loaddr, hiaddr - loaddr, ...) + * + * to succeed. */ -unsigned long init_guest_space(unsigned long host_start, - unsigned long host_size, - unsigned long guest_start, - bool fixed); +void probe_guest_base(const char *image_name, + abi_ulong loaddr, abi_ulong hiaddr); #include "qemu/log.h" diff --git a/linux-user/elfload.c b/linux-user/elfload.c index 619c054cc48..01a9323a637 100644 --- a/linux-user/elfload.c +++ b/linux-user/elfload.c @@ -11,6 +11,7 @@ #include "qemu/queue.h" #include "qemu/guest-random.h" #include "qemu/units.h" +#include "qemu/selfmap.h" #ifdef _ARCH_PPC64 #undef ARCH_DLINFO @@ -382,68 +383,30 @@ enum { /* The commpage only exists for 32 bit kernels */ -/* Return 1 if the proposed guest space is suitable for the guest. - * Return 0 if the proposed guest space isn't suitable, but another - * address space should be tried. - * Return -1 if there is no way the proposed guest space can be - * valid regardless of the base. - * The guest code may leave a page mapped and populate it if the - * address is suitable. - */ -static int init_guest_commpage(unsigned long guest_base, - unsigned long guest_size) -{ - unsigned long real_start, test_page_addr; - - /* We need to check that we can force a fault on access to the - * commpage at 0xffff0fxx - */ - test_page_addr = guest_base + (0xffff0f00 & qemu_host_page_mask); - - /* If the commpage lies within the already allocated guest space, - * then there is no way we can allocate it. - * - * You may be thinking that that this check is redundant because - * we already validated the guest size against MAX_RESERVED_VA; - * but if qemu_host_page_mask is unusually large, then - * test_page_addr may be lower. - */ - if (test_page_addr >= guest_base - && test_page_addr < (guest_base + guest_size)) { - return -1; - } +#define ARM_COMMPAGE (intptr_t)0xffff0f00u - /* Note it needs to be writeable to let us initialise it */ - real_start = (unsigned long) - mmap((void *)test_page_addr, qemu_host_page_size, - PROT_READ | PROT_WRITE, - MAP_ANONYMOUS | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); +static bool init_guest_commpage(void) +{ + void *want = g2h(ARM_COMMPAGE & -qemu_host_page_size); + void *addr = mmap(want, qemu_host_page_size, PROT_READ | PROT_WRITE, + MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); - /* If we can't map it then try another address */ - if (real_start == -1ul) { - return 0; + if (addr == MAP_FAILED) { + perror("Allocating guest commpage"); + exit(EXIT_FAILURE); } - - if (real_start != test_page_addr) { - /* OS didn't put the page where we asked - unmap and reject */ - munmap((void *)real_start, qemu_host_page_size); - return 0; + if (addr != want) { + return false; } - /* Leave the page mapped - * Populate it (mmap should have left it all 0'd) - */ - - /* Kernel helper versions */ - __put_user(5, (uint32_t *)g2h(0xffff0ffcul)); + /* Set kernel helper versions; rest of page is 0. */ + __put_user(5, (uint32_t *)g2h(0xffff0ffcu)); - /* Now it's populated make it RO */ - if (mprotect((void *)test_page_addr, qemu_host_page_size, PROT_READ)) { + if (mprotect(addr, qemu_host_page_size, PROT_READ)) { perror("Protecting guest commpage"); - exit(-1); + exit(EXIT_FAILURE); } - - return 1; /* All good */ + return true; } #define ELF_HWCAP get_elf_hwcap() @@ -2075,239 +2038,267 @@ static abi_ulong create_elf_tables(abi_ulong p, int argc, int envc, return sp; } -unsigned long init_guest_space(unsigned long host_start, - unsigned long host_size, - unsigned long guest_start, - bool fixed) -{ - /* In order to use host shmat, we must be able to honor SHMLBA. */ - unsigned long align = MAX(SHMLBA, qemu_host_page_size); - unsigned long current_start, aligned_start; - int flags; - - assert(host_start || host_size); - - /* If just a starting address is given, then just verify that - * address. */ - if (host_start && !host_size) { -#if defined(TARGET_ARM) && !defined(TARGET_AARCH64) - if (init_guest_commpage(host_start, host_size) != 1) { - return (unsigned long)-1; - } +#ifndef ARM_COMMPAGE +#define ARM_COMMPAGE 0 +#define init_guest_commpage() true #endif - return host_start; - } - /* Setup the initial flags and start address. */ - current_start = host_start & -align; - flags = MAP_ANONYMOUS | MAP_PRIVATE | MAP_NORESERVE; - if (fixed) { - flags |= MAP_FIXED; - } +static void pgb_fail_in_use(const char *image_name) +{ + error_report("%s: requires virtual address space that is in use " + "(omit the -B option or choose a different value)", + image_name); + exit(EXIT_FAILURE); +} - /* Otherwise, a non-zero size region of memory needs to be mapped - * and validated. */ +static void pgb_have_guest_base(const char *image_name, abi_ulong guest_loaddr, + abi_ulong guest_hiaddr, long align) +{ + const int flags = MAP_ANONYMOUS | MAP_PRIVATE | MAP_NORESERVE; + void *addr, *test; -#if defined(TARGET_ARM) && !defined(TARGET_AARCH64) - /* On 32-bit ARM, we need to map not just the usable memory, but - * also the commpage. Try to find a suitable place by allocating - * a big chunk for all of it. If host_start, then the naive - * strategy probably does good enough. - */ - if (!host_start) { - unsigned long guest_full_size, host_full_size, real_start; - - guest_full_size = - (0xffff0f00 & qemu_host_page_mask) + qemu_host_page_size; - host_full_size = guest_full_size - guest_start; - real_start = (unsigned long) - mmap(NULL, host_full_size, PROT_NONE, flags, -1, 0); - if (real_start == (unsigned long)-1) { - if (host_size < host_full_size - qemu_host_page_size) { - /* We failed to map a continous segment, but we're - * allowed to have a gap between the usable memory and - * the commpage where other things can be mapped. - * This sparseness gives us more flexibility to find - * an address range. - */ - goto naive; - } - return (unsigned long)-1; + if (!QEMU_IS_ALIGNED(guest_base, align)) { + fprintf(stderr, "Requested guest base 0x%lx does not satisfy " + "host minimum alignment (0x%lx)\n", + guest_base, align); + exit(EXIT_FAILURE); + } + + /* Sanity check the guest binary. */ + if (reserved_va) { + if (guest_hiaddr > reserved_va) { + error_report("%s: requires more than reserved virtual " + "address space (0x%" PRIx64 " > 0x%lx)", + image_name, (uint64_t)guest_hiaddr, reserved_va); + exit(EXIT_FAILURE); } - munmap((void *)real_start, host_full_size); - if (real_start & (align - 1)) { - /* The same thing again, but with extra - * so that we can shift around alignment. - */ - unsigned long real_size = host_full_size + qemu_host_page_size; - real_start = (unsigned long) - mmap(NULL, real_size, PROT_NONE, flags, -1, 0); - if (real_start == (unsigned long)-1) { - if (host_size < host_full_size - qemu_host_page_size) { - goto naive; - } - return (unsigned long)-1; - } - munmap((void *)real_start, real_size); - real_start = ROUND_UP(real_start, align); + } else { + if ((guest_hiaddr - guest_base) > ~(uintptr_t)0) { + error_report("%s: requires more virtual address space " + "than the host can provide (0x%" PRIx64 ")", + image_name, (uint64_t)guest_hiaddr - guest_base); + exit(EXIT_FAILURE); } - current_start = real_start; } - naive: -#endif - while (1) { - unsigned long real_start, real_size, aligned_size; - aligned_size = real_size = host_size; + /* + * Expand the allocation to the entire reserved_va. + * Exclude the mmap_min_addr hole. + */ + if (reserved_va) { + guest_loaddr = (guest_base >= mmap_min_addr ? 0 + : mmap_min_addr - guest_base); + guest_hiaddr = reserved_va; + } - /* Do not use mmap_find_vma here because that is limited to the - * guest address space. We are going to make the - * guest address space fit whatever we're given. - */ - real_start = (unsigned long) - mmap((void *)current_start, host_size, PROT_NONE, flags, -1, 0); - if (real_start == (unsigned long)-1) { - return (unsigned long)-1; - } + /* Reserve the address space for the binary, or reserved_va. */ + test = g2h(guest_loaddr); + addr = mmap(test, guest_hiaddr - guest_loaddr, PROT_NONE, flags, -1, 0); + if (test != addr) { + pgb_fail_in_use(image_name); + } +} - /* Check to see if the address is valid. */ - if (host_start && real_start != current_start) { - qemu_log_mask(CPU_LOG_PAGE, "invalid %lx && %lx != %lx\n", - host_start, real_start, current_start); - goto try_again; +/* Return value for guest_base, or -1 if no hole found. */ +static uintptr_t pgb_find_hole(uintptr_t guest_loaddr, uintptr_t guest_size, + long align) +{ + GSList *maps, *iter; + uintptr_t this_start, this_end, next_start, brk; + intptr_t ret = -1; + + assert(QEMU_IS_ALIGNED(guest_loaddr, align)); + + maps = read_self_maps(); + + /* Read brk after we've read the maps, which will malloc. */ + brk = (uintptr_t)sbrk(0); + + /* The first hole is before the first map entry. */ + this_start = mmap_min_addr; + + for (iter = maps; iter; + this_start = next_start, iter = g_slist_next(iter)) { + uintptr_t align_start, hole_size; + + this_end = ((MapInfo *)iter->data)->start; + next_start = ((MapInfo *)iter->data)->end; + align_start = ROUND_UP(this_start, align); + + /* Skip holes that are too small. */ + if (align_start >= this_end) { + continue; + } + hole_size = this_end - align_start; + if (hole_size < guest_size) { + continue; } - /* Ensure the address is properly aligned. */ - if (real_start & (align - 1)) { - /* Ideally, we adjust like - * - * pages: [ ][ ][ ][ ][ ] - * old: [ real ] - * [ aligned ] - * new: [ real ] - * [ aligned ] - * - * But if there is something else mapped right after it, - * then obviously it won't have room to grow, and the - * kernel will put the new larger real someplace else with - * unknown alignment (if we made it to here, then - * fixed=false). Which is why we grow real by a full page - * size, instead of by part of one; so that even if we get - * moved, we can still guarantee alignment. But this does - * mean that there is a padding of < 1 page both before - * and after the aligned range; the "after" could could - * cause problems for ARM emulation where it could butt in - * to where we need to put the commpage. - */ - munmap((void *)real_start, host_size); - real_size = aligned_size + align; - real_start = (unsigned long) - mmap((void *)real_start, real_size, PROT_NONE, flags, -1, 0); - if (real_start == (unsigned long)-1) { - return (unsigned long)-1; + /* If this hole contains brk, give ourselves some room to grow. */ + if (this_start <= brk && brk < this_end) { + hole_size -= guest_size; + if (sizeof(uintptr_t) == 8 && hole_size >= 1 * GiB) { + align_start += 1 * GiB; + } else if (hole_size >= 16 * MiB) { + align_start += 16 * MiB; + } else { + align_start = (this_end - guest_size) & -align; + if (align_start < this_start) { + continue; + } } - aligned_start = ROUND_UP(real_start, align); - } else { - aligned_start = real_start; } -#if defined(TARGET_ARM) && !defined(TARGET_AARCH64) - /* On 32-bit ARM, we need to also be able to map the commpage. */ - int valid = init_guest_commpage(aligned_start - guest_start, - aligned_size + guest_start); - if (valid == -1) { - munmap((void *)real_start, real_size); - return (unsigned long)-1; - } else if (valid == 0) { - goto try_again; + /* Record the lowest successful match. */ + if (ret < 0) { + ret = align_start - guest_loaddr; } -#endif - - /* If nothing has said `return -1` or `goto try_again` yet, - * then the address we have is good. - */ - break; - - try_again: - /* That address didn't work. Unmap and try a different one. - * The address the host picked because is typically right at - * the top of the host address space and leaves the guest with - * no usable address space. Resort to a linear search. We - * already compensated for mmap_min_addr, so this should not - * happen often. Probably means we got unlucky and host - * address space randomization put a shared library somewhere - * inconvenient. - * - * This is probably a good strategy if host_start, but is - * probably a bad strategy if not, which means we got here - * because of trouble with ARM commpage setup. - */ - if (munmap((void *)real_start, real_size) != 0) { - error_report("%s: failed to unmap %lx:%lx (%s)", __func__, - real_start, real_size, strerror(errno)); - abort(); + /* If this hole contains the identity map, select it. */ + if (align_start <= guest_loaddr && + guest_loaddr + guest_size <= this_end) { + ret = 0; } - current_start += align; - if (host_start == current_start) { - /* Theoretically possible if host doesn't have any suitably - * aligned areas. Normally the first mmap will fail. - */ - return (unsigned long)-1; + /* If this hole ends above the identity map, stop looking. */ + if (this_end >= guest_loaddr) { + break; } } + free_self_maps(maps); - qemu_log_mask(CPU_LOG_PAGE, "Reserved 0x%lx bytes of guest address space\n", host_size); - - return aligned_start; + return ret; } -static void probe_guest_base(const char *image_name, - abi_ulong loaddr, abi_ulong hiaddr) +static void pgb_static(const char *image_name, abi_ulong orig_loaddr, + abi_ulong orig_hiaddr, long align) { - /* Probe for a suitable guest base address, if the user has not set - * it explicitly, and set guest_base appropriately. - * In case of error we will print a suitable message and exit. - */ - const char *errmsg; - if (!have_guest_base && !reserved_va) { - unsigned long host_start, real_start, host_size; + uintptr_t loaddr = orig_loaddr; + uintptr_t hiaddr = orig_hiaddr; + uintptr_t addr; - /* Round addresses to page boundaries. */ - loaddr &= qemu_host_page_mask; - hiaddr = HOST_PAGE_ALIGN(hiaddr); + if (hiaddr != orig_hiaddr) { + error_report("%s: requires virtual address space that the " + "host cannot provide (0x%" PRIx64 ")", + image_name, (uint64_t)orig_hiaddr); + exit(EXIT_FAILURE); + } - if (loaddr < mmap_min_addr) { - host_start = HOST_PAGE_ALIGN(mmap_min_addr); + loaddr &= -align; + if (ARM_COMMPAGE) { + /* + * Extend the allocation to include the commpage. + * For a 64-bit host, this is just 4GiB; for a 32-bit host, + * the address arithmetic will wrap around, but the difference + * will produce the correct allocation size. + */ + if (sizeof(uintptr_t) == 8 || loaddr >= 0x80000000u) { + hiaddr = (uintptr_t)4 << 30; } else { - host_start = loaddr; - if (host_start != loaddr) { - errmsg = "Address overflow loading ELF binary"; - goto exit_errmsg; - } + loaddr = ARM_COMMPAGE & -align; } - host_size = hiaddr - loaddr; + } - /* Setup the initial guest memory space with ranges gleaned from - * the ELF image that is being loaded. + addr = pgb_find_hole(loaddr, hiaddr - loaddr, align); + if (addr == -1) { + /* + * If ARM_COMMPAGE, there *might* be a non-consecutive allocation + * that can satisfy both. But as the normal arm32 link base address + * is ~32k, and we extend down to include the commpage, making the + * overhead only ~96k, this is unlikely. */ - real_start = init_guest_space(host_start, host_size, loaddr, false); - if (real_start == (unsigned long)-1) { - errmsg = "Unable to find space for application"; - goto exit_errmsg; - } - guest_base = real_start - loaddr; + error_report("%s: Unable to allocate %#zx bytes of " + "virtual address space", image_name, + (size_t)(hiaddr - loaddr)); + exit(EXIT_FAILURE); + } + + guest_base = addr; +} + +static void pgb_dynamic(const char *image_name, long align) +{ + /* + * The executable is dynamic and does not require a fixed address. + * All we need is a commpage that satisfies align. + * If we do not need a commpage, leave guest_base == 0. + */ + if (ARM_COMMPAGE) { + uintptr_t addr, commpage; - qemu_log_mask(CPU_LOG_PAGE, "Relocating guest address space from 0x" - TARGET_ABI_FMT_lx " to 0x%lx\n", - loaddr, real_start); + /* 64-bit hosts should have used reserved_va. */ + assert(sizeof(uintptr_t) == 4); + + /* + * By putting the commpage at the first hole, that puts guest_base + * just above that, and maximises the positive guest addresses. + */ + commpage = ARM_COMMPAGE & -align; + addr = pgb_find_hole(commpage, -commpage, align); + assert(addr != -1); + guest_base = addr; } - return; +} -exit_errmsg: - fprintf(stderr, "%s: %s\n", image_name, errmsg); - exit(-1); +static void pgb_reserved_va(const char *image_name, abi_ulong guest_loaddr, + abi_ulong guest_hiaddr, long align) +{ + const int flags = MAP_ANONYMOUS | MAP_PRIVATE | MAP_NORESERVE; + void *addr, *test; + + if (guest_hiaddr > reserved_va) { + error_report("%s: requires more than reserved virtual " + "address space (0x%" PRIx64 " > 0x%lx)", + image_name, (uint64_t)guest_hiaddr, reserved_va); + exit(EXIT_FAILURE); + } + + /* Widen the "image" to the entire reserved address space. */ + pgb_static(image_name, 0, reserved_va, align); + + /* Reserve the memory on the host. */ + assert(guest_base != 0); + test = g2h(0); + addr = mmap(test, reserved_va, PROT_NONE, flags, -1, 0); + if (addr == MAP_FAILED) { + error_report("Unable to reserve 0x%lx bytes of virtual address " + "space for use as guest address space (check your " + "virtual memory ulimit setting or reserve less " + "using -R option)", reserved_va); + exit(EXIT_FAILURE); + } + assert(addr == test); } +void probe_guest_base(const char *image_name, abi_ulong guest_loaddr, + abi_ulong guest_hiaddr) +{ + /* In order to use host shmat, we must be able to honor SHMLBA. */ + uintptr_t align = MAX(SHMLBA, qemu_host_page_size); + + if (have_guest_base) { + pgb_have_guest_base(image_name, guest_loaddr, guest_hiaddr, align); + } else if (reserved_va) { + pgb_reserved_va(image_name, guest_loaddr, guest_hiaddr, align); + } else if (guest_loaddr) { + pgb_static(image_name, guest_loaddr, guest_hiaddr, align); + } else { + pgb_dynamic(image_name, align); + } + + /* Reserve and initialize the commpage. */ + if (!init_guest_commpage()) { + /* + * With have_guest_base, the user has selected the address and + * we are trying to work with that. Otherwise, we have selected + * free space and init_guest_commpage must succeeded. + */ + assert(have_guest_base); + pgb_fail_in_use(image_name); + } + + assert(QEMU_IS_ALIGNED(guest_base, align)); + qemu_log_mask(CPU_LOG_PAGE, "Locating guest address space " + "@ 0x%" PRIx64 "\n", (uint64_t)guest_base); +} /* Load an ELF image into the address space. @@ -2399,6 +2390,12 @@ static void load_elf_image(const char *image_name, int image_fd, * MMAP_MIN_ADDR or the QEMU application itself. */ probe_guest_base(image_name, loaddr, hiaddr); + } else { + /* + * The binary is dynamic, but we still need to + * select guest_base. In this case we pass a size. + */ + probe_guest_base(image_name, 0, hiaddr - loaddr); } } diff --git a/linux-user/flatload.c b/linux-user/flatload.c index 0122ab3afe6..952b4cb26d8 100644 --- a/linux-user/flatload.c +++ b/linux-user/flatload.c @@ -441,6 +441,12 @@ static int load_flat_file(struct linux_binprm * bprm, indx_len = MAX_SHARED_LIBS * sizeof(abi_ulong); indx_len = (indx_len + 15) & ~(abi_ulong)15; + /* + * Alloate the address space. + */ + probe_guest_base(bprm->filename, 0, + text_len + data_len + extra + indx_len); + /* * there are a couple of cases here, the separate code/data * case, and then the fully copied to RAM case which lumps diff --git a/linux-user/main.c b/linux-user/main.c index 22578b16336..1d20a83d4e8 100644 --- a/linux-user/main.c +++ b/linux-user/main.c @@ -24,6 +24,7 @@ #include "qemu-version.h" #include #include +#include #include "qapi/error.h" #include "qemu.h" @@ -747,28 +748,6 @@ int main(int argc, char **argv, char **envp) target_environ = envlist_to_environ(envlist, NULL); envlist_free(envlist); - /* - * Now that page sizes are configured in tcg_exec_init() we can do - * proper page alignment for guest_base. - */ - guest_base = HOST_PAGE_ALIGN(guest_base); - - if (reserved_va || have_guest_base) { - guest_base = init_guest_space(guest_base, reserved_va, 0, - have_guest_base); - if (guest_base == (unsigned long)-1) { - fprintf(stderr, "Unable to reserve 0x%lx bytes of virtual address " - "space for use as guest address space (check your virtual " - "memory ulimit setting or reserve less using -R option)\n", - reserved_va); - exit(EXIT_FAILURE); - } - - if (reserved_va) { - mmap_next_start = reserved_va; - } - } - /* * Read in mmap_min_addr kernel parameter. This value is used * When loading the ELF image to determine whether guest_base From patchwork Thu Apr 9 21:15:20 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185324 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2320951ilr; Thu, 9 Apr 2020 14:17:58 -0700 (PDT) X-Google-Smtp-Source: APiQypLtJyea0AcvbrsiWfIW8BXDRjYbTC/SMGYvd0XMLpo9upLF98ComEdR4CJ/Q1iq5rBb6CnE X-Received: by 2002:ac8:3805:: with SMTP id q5mr1478044qtb.46.1586467078762; Thu, 09 Apr 2020 14:17:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467078; cv=none; d=google.com; s=arc-20160816; b=qN62etzcNhBL+97Wq76NJLGgikSmBM/mdpRFgOrhx6JYqQoAK5Y4Qrivz/cW/63qcd fyw2YlDHS7gjiJFALnarcq2M85YWb/9RPdpHY9dRIXt70BreTLZOlW8SDG6STi5hjRWa GA9GdwWz99aLTtAyqZz9m2r5KF5krh4jcEUqE6r2xqBrgii7pkubTUHONsq4Pg0yqn6M fmJmTDNA3cqAVOhtYhDSvZK6ei00k9dPRhNsptlePWDct7HG3ky1BeWOUrL3yLerkady urE2oTD3/pRYlqY6STijtge64Yh+P18v5vpGceeQE+usVUIAKTSKrldvfHLrc5oLDcHl Ctxw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=L3oo5e13KKY97yaceKpUyQX6w7q5mwKsED5f0rgFBwI=; b=Imrq/z74I20PnYpZoMvyX+XRjhl5H3wgAu8rAMbJNSscL0pGQT1rADbkKepy+soEzr tVEyZX8jvgSDbVbWmIfYdyBuCKASWXQsNu6TrU06A7hJxU19ldSkjtWs9WV38u/unvRL H38bC0/6pdkyEAQ4mxP7J2sTfo0fpNIkpAGMtsVzAvyEgNcSwUSfge7xh1Cju/hJ7niV KNNHgqjaupP6fFA5FhAObEOoBJEerUvz0WmNC4khwMbzaVlY7/nCulSFPJNxNHiO8Xkm NaDdTrbfENPG328vYnXJqM9zflWJDuhSZLNkKogHszMds6DnJyOgflneSYFJwHG/6ud6 PgFQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=EZ9x65bB; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id i1si1429952qtp.217.2020.04.09.14.17.58 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:17:58 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=EZ9x65bB; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55616 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeYg-0005aL-7i for patch@linaro.org; Thu, 09 Apr 2020 17:17:58 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42266) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWN-00020d-FZ for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:36 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWM-0005cE-B8 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:35 -0400 Received: from mail-wr1-x444.google.com ([2a00:1450:4864:20::444]:46568) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWM-0005bp-5V for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:34 -0400 Received: by mail-wr1-x444.google.com with SMTP id f13so7119339wrm.13 for ; Thu, 09 Apr 2020 14:15:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=L3oo5e13KKY97yaceKpUyQX6w7q5mwKsED5f0rgFBwI=; b=EZ9x65bBr9LDMxcvIuXSUbh89pfWZKhTgBH478avcUIAU1K6WbB8Dn0AWPoHlx2Nxo aQP+qZrjNSOYdgdGuN8422Uvpnc8ApzX9nPonIU7S+JpRWFHxgXMSBblHNmE79hpW1CY FVzbQ+LuFzgo1LlLoKW+EAWa4++8sguttc98lfFSQbjt796IuX6soG9WkhtWiswu53IV qawawKKfX+g3Q0aKtT8ievfa+v3KYFYb/LC9jWvt+ANsKIG6ckYX59aQM/b3DesJVXcL sAqPNFEpCqZO9mSKz74vXPlwmcWTxulJk9i5IaBjKRIDcaI+dUNG96oBdLFfAYFXSlnr L0Kg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=L3oo5e13KKY97yaceKpUyQX6w7q5mwKsED5f0rgFBwI=; b=Slh69rrLFQXZEbfAXfvNnT5MJi3HZMficzW+m3U15w6Md11vbvLMZIhw2lUxnweHsz fqcysS1gC/SLz/OeZwovVe7a18yIdvSK1HO0koI5hiLRG66oLMzVgyiyEEpL1p8c60H5 laPEU/7ym7+lkfwZZB22Sj3FmwI9QzXVUEec+iathd39ml9DOidyEQ/7wGIyu2k+Q4Xk Nj7j9vykdjvvHx8Q8ZhGQrkwgeyJNzYrYmwROLLHiP082e+CB7ehff+ML9mIwl0gjMZi VtVhvetrXot6Rz7hs6sT4ic45+fOpzsQj0OEPcHHcLFy8+F+xJyKP/ZnNe4tFEEkrnwH tEkQ== X-Gm-Message-State: AGi0PuZ6w7qSpKUQp3FNyjQ2gH0zBUhSfT1vhFvk6tFPArXLNAhdqIfg HIkyAjSpjmu4jPY3PuJrNpz2og== X-Received: by 2002:adf:afe4:: with SMTP id y36mr1103433wrd.205.1586466932969; Thu, 09 Apr 2020 14:15:32 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id i8sm44602522wrb.41.2020.04.09.14.15.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:30 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 391D11FF8C; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 02/11] exec/cpu-all: Use bool for have_guest_base Date: Thu, 9 Apr 2020 22:15:20 +0100 Message-Id: <20200409211529.5269-3-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::444 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Riku Voipio , Richard Henderson , Laurent Vivier , Paolo Bonzini , =?utf-8?q?Alex_Benn=C3=A9e?= , Richard Henderson Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Richard Henderson Signed-off-by: Richard Henderson Signed-off-by: Alex Bennée --- include/exec/cpu-all.h | 2 +- bsd-user/main.c | 4 ++-- linux-user/main.c | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) -- 2.20.1 Reviewed-by: Philippe Mathieu-Daudé diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h index 49384bb66a5..b4fb5832c4a 100644 --- a/include/exec/cpu-all.h +++ b/include/exec/cpu-all.h @@ -159,7 +159,7 @@ static inline void tswap64s(uint64_t *s) * This allows the guest address space to be offset to a convenient location. */ extern unsigned long guest_base; -extern int have_guest_base; +extern bool have_guest_base; extern unsigned long reserved_va; #if HOST_LONG_BITS <= TARGET_VIRT_ADDR_SPACE_BITS diff --git a/bsd-user/main.c b/bsd-user/main.c index 770c2b267ad..aef5531628a 100644 --- a/bsd-user/main.c +++ b/bsd-user/main.c @@ -42,7 +42,7 @@ int singlestep; unsigned long mmap_min_addr; unsigned long guest_base; -int have_guest_base; +bool have_guest_base; unsigned long reserved_va; static const char *interp_prefix = CONFIG_QEMU_INTERP_PREFIX; @@ -828,7 +828,7 @@ int main(int argc, char **argv) } } else if (!strcmp(r, "B")) { guest_base = strtol(argv[optind++], NULL, 0); - have_guest_base = 1; + have_guest_base = true; } else if (!strcmp(r, "drop-ld-preload")) { (void) envlist_unsetenv(envlist, "LD_PRELOAD"); } else if (!strcmp(r, "bsd")) { diff --git a/linux-user/main.c b/linux-user/main.c index 1d20a83d4e8..90ad365b439 100644 --- a/linux-user/main.c +++ b/linux-user/main.c @@ -59,7 +59,7 @@ static const char *cpu_type; static const char *seed_optarg; unsigned long mmap_min_addr; unsigned long guest_base; -int have_guest_base; +bool have_guest_base; /* * Used to implement backwards-compatibility for the `-strace`, and @@ -334,7 +334,7 @@ static void handle_arg_cpu(const char *arg) static void handle_arg_guest_base(const char *arg) { guest_base = strtol(arg, NULL, 0); - have_guest_base = 1; + have_guest_base = true; } static void handle_arg_reserved_va(const char *arg) From patchwork Thu Apr 9 21:15:21 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185329 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2323431ilr; Thu, 9 Apr 2020 14:20:36 -0700 (PDT) X-Google-Smtp-Source: APiQypIZzrNpXM/NdZlgGyIkL9MxMl/Nt0hmnk7mWApEOE1yU9LU9s7dNPlBvwYLPn44rGFjN1uZ X-Received: by 2002:a37:c403:: with SMTP id d3mr878862qki.448.1586467236023; Thu, 09 Apr 2020 14:20:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467236; cv=none; d=google.com; s=arc-20160816; b=jCX3z/weswINtNc6EfD8KMxa6tPsXeYJcV6MffD/AKayp2mYWMdsBq+h3Llf2O7cnE fl/f4bsWL8JtOZoRFSyr7Oht1wbX98M+NrQAlHyDS0yi/bFePhfwapxnn0Z3M4uUgl3J 2vHE3QHD922ijke0Euo6gE87CYqq3cv8SOABoGecJK+Qz/U8Rf9CTh7dRhnbim8hBdrz H2Mhn+ZX6TSZByI155i4VlEM1HQllDg8cOlaX8A9EVmxzDxSYHFvnq5cdQZ2ngP6aJ85 LBmZ0IjKL/HgnJJZ57kWBxnxJTjmEmpGtNKezElk5aB9JqZvS85FXjOXeB/ZboYiorbg N6Fw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=NOU8+nMEIGED2iJZhktWL6KnvYhctO6T5v6pR87w3Mo=; b=kRXsZxGoa2Er1ebYk4ucKEOi3AwPOKuU66TjuGbXh8Odk+xoCeYyPws9/gsIFLMoAj Jm443pyDwfrkAYpUZoo6aiS5LUONxd9E0agIzhr37I5y651IBxqMzPGDHQZiY3OnmmR7 a8a1xjzNes/13cVPrD4Angm9XPryvwtpjSDBCHQ1TQog8M50z4GfDaXKjQquiMsxMbx2 XtRlM2XPBfXrkMrJlmb9KQHXl8k/h/inQsCdRDG8+pyMD5fr65CIiymDvxlSUqgDVXom gpaCP0VtwerGDknMaopvZHB5nQfMnKkJTKtC8N5jTyPpa3tufU2a5w89NZ6Yb8qx4euL 7xcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=V9d0Bu6R; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id 67si155563qkm.91.2020.04.09.14.20.35 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:20:36 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=V9d0Bu6R; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55670 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMebD-0000nF-Gq for patch@linaro.org; Thu, 09 Apr 2020 17:20:35 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42303) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWQ-00021K-3J for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:39 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWO-0005ee-M7 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:38 -0400 Received: from mail-wr1-x443.google.com ([2a00:1450:4864:20::443]:43715) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWO-0005da-FX for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:36 -0400 Received: by mail-wr1-x443.google.com with SMTP id i10so7401679wrv.10 for ; Thu, 09 Apr 2020 14:15:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=NOU8+nMEIGED2iJZhktWL6KnvYhctO6T5v6pR87w3Mo=; b=V9d0Bu6RvtTqDxTr5JqOE/cxlRXXhnHirbzdTgm0jEO+mH6BsThkbzhFLQF8NmTiid fLhQNdmKv/C2Yzbfd3ONdqUFWtpkqX6iJTH0nmiRNYWcQryA+7sZUzWUb14ZWiqCn35c daaLWDjn0awL2E4uBgKqTtXHmzKrakVaQY0GC/dbv0shfnAYVOkAk8rEhy28hg/sWYPu vVHXy8M4Opshvjjqt2PvdwLV7B9lfJr8zWBz4StWyzkdo2W1SVsfcN++8Nb4JjrvqrFX pTiBipjTAvPdC7QIPVdQGUzZC/XTTVkbGK52jhAh/8bxTmgygFYSAwEmROcQ/lBoUzGy qVnQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=NOU8+nMEIGED2iJZhktWL6KnvYhctO6T5v6pR87w3Mo=; b=D2XQce8APiXFJ7eD0wjm+VcKldEEwI3Z30REjEAKhfAKyz+BFyk4BSGJeBvT6mrVlq 19PfRfdJtu3fpzqtg2wCe+73SZMOqpY7nm0rF2yjTTxqTNsPJE5jqvdznwVJ3Cx7qZbs X+2uKeWexrggNjlnGIBQ0pVCJdDItr8X7Ke/rwX7AxA/zDtZ7bkQ5FN9uN2WlhxpwG47 NBkzBM5aRaJgVW7wmnWL1ryKNOcolov3w8jZAgevAmKApKQHqxRJbyUU5NLNWFJRvD5N 9RDktl4dZsnHsdjsPBUYuD6OyLXzHoCV5gRbuW9du9LeMmm56BoLCf8qM00lehupybux e51g== X-Gm-Message-State: AGi0Pua20hrWgMhCF1KftvZh57LAX3Zll2iBR79Ej8r+8L/x4b53O2nF qV85++6nUR3T5wz3R+zyQ28Sjw== X-Received: by 2002:a5d:4a11:: with SMTP id m17mr1055726wrq.125.1586466935348; Thu, 09 Apr 2020 14:15:35 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id c11sm16635780wrt.24.2020.04.09.14.15.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:32 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 50D8B1FF8F; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 03/11] accel/tcg: Relax va restrictions on 64-bit guests Date: Thu, 9 Apr 2020 22:15:21 +0100 Message-Id: <20200409211529.5269-4-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::443 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?utf-8?q?Alex_Benn=C3=A9e?= , Paolo Bonzini , Richard Henderson , Richard Henderson Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Richard Henderson We cannot at present limit a 64-bit guest to a virtual address space smaller than the host. It will mostly work to ignore this limitation, except if the guest uses high bits of the address space for tags. But it will certainly work better, as presently we can wind up failing to allocate the guest stack. Widen our user-only page tree to the host or abi pointer width. Remove the workaround for this problem from target/alpha. Always validate guest addresses vs reserved_va, as there we control allocation ourselves. Signed-off-by: Richard Henderson Signed-off-by: Alex Bennée --- include/exec/cpu-all.h | 23 +++++++++++++++++++---- target/alpha/cpu-param.h | 15 ++------------- accel/tcg/translate-all.c | 15 +++++++++------ 3 files changed, 30 insertions(+), 23 deletions(-) -- 2.20.1 diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h index b4fb5832c4a..c0c2fa3cc56 100644 --- a/include/exec/cpu-all.h +++ b/include/exec/cpu-all.h @@ -162,12 +162,27 @@ extern unsigned long guest_base; extern bool have_guest_base; extern unsigned long reserved_va; -#if HOST_LONG_BITS <= TARGET_VIRT_ADDR_SPACE_BITS -#define GUEST_ADDR_MAX (~0ul) +/* + * Limit the guest addresses as best we can. + * + * When not using -R reserved_va, we cannot really limit the guest + * to less address space than the host. For 32-bit guests, this + * acts as a sanity check that we're not giving the guest an address + * that it cannot even represent. For 64-bit guests... the address + * might not be what the real kernel would give, but it is at least + * representable in the guest. + * + * TODO: Improve address allocation to avoid this problem, and to + * avoid setting bits at the top of guest addresses that might need + * to be used for tags. + */ +#if MIN(TARGET_VIRT_ADDR_SPACE_BITS, TARGET_ABI_BITS) <= 32 +# define GUEST_ADDR_MAX_ UINT32_MAX #else -#define GUEST_ADDR_MAX (reserved_va ? reserved_va - 1 : \ - (1ul << TARGET_VIRT_ADDR_SPACE_BITS) - 1) +# define GUEST_ADDR_MAX_ ~0ul #endif +#define GUEST_ADDR_MAX (reserved_va ? reserved_va - 1 : GUEST_ADDR_MAX_) + #else #include "exec/hwaddr.h" diff --git a/target/alpha/cpu-param.h b/target/alpha/cpu-param.h index 692aee27ca9..1153992e42a 100644 --- a/target/alpha/cpu-param.h +++ b/target/alpha/cpu-param.h @@ -10,22 +10,11 @@ #define TARGET_LONG_BITS 64 #define TARGET_PAGE_BITS 13 -#ifdef CONFIG_USER_ONLY -/* - * ??? The kernel likes to give addresses in high memory. If the host has - * more virtual address space than the guest, this can lead to impossible - * allocations. Honor the long-standing assumption that only kernel addrs - * are negative, but otherwise allow allocations anywhere. This could lead - * to tricky emulation problems for programs doing tagged addressing, but - * that's far fewer than encounter the impossible allocation problem. - */ -#define TARGET_PHYS_ADDR_SPACE_BITS 63 -#define TARGET_VIRT_ADDR_SPACE_BITS 63 -#else + /* ??? EV4 has 34 phys addr bits, EV5 has 40, EV6 has 44. */ #define TARGET_PHYS_ADDR_SPACE_BITS 44 #define TARGET_VIRT_ADDR_SPACE_BITS (30 + TARGET_PAGE_BITS) -#endif + #define NB_MMU_MODES 3 #endif diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c index 9924e66d1f7..e4f703a7e6d 100644 --- a/accel/tcg/translate-all.c +++ b/accel/tcg/translate-all.c @@ -173,8 +173,13 @@ struct page_collection { #define TB_FOR_EACH_JMP(head_tb, tb, n) \ TB_FOR_EACH_TAGGED((head_tb)->jmp_list_head, tb, n, jmp_list_next) -/* In system mode we want L1_MAP to be based on ram offsets, - while in user mode we want it to be based on virtual addresses. */ +/* + * In system mode we want L1_MAP to be based on ram offsets, + * while in user mode we want it to be based on virtual addresses. + * + * TODO: For user mode, see the caveat re host vs guest virtual + * address spaces near GUEST_ADDR_MAX. + */ #if !defined(CONFIG_USER_ONLY) #if HOST_LONG_BITS < TARGET_PHYS_ADDR_SPACE_BITS # define L1_MAP_ADDR_SPACE_BITS HOST_LONG_BITS @@ -182,7 +187,7 @@ struct page_collection { # define L1_MAP_ADDR_SPACE_BITS TARGET_PHYS_ADDR_SPACE_BITS #endif #else -# define L1_MAP_ADDR_SPACE_BITS TARGET_VIRT_ADDR_SPACE_BITS +# define L1_MAP_ADDR_SPACE_BITS MIN(HOST_LONG_BITS, TARGET_ABI_BITS) #endif /* Size of the L2 (and L3, etc) page tables. */ @@ -2497,9 +2502,7 @@ void page_set_flags(target_ulong start, target_ulong end, int flags) /* This function should never be called with addresses outside the guest address space. If this assert fires, it probably indicates a missing call to h2g_valid. */ -#if TARGET_ABI_BITS > L1_MAP_ADDR_SPACE_BITS - assert(end <= ((target_ulong)1 << L1_MAP_ADDR_SPACE_BITS)); -#endif + assert(end - 1 <= GUEST_ADDR_MAX); assert(start < end); assert_memory_lock(); From patchwork Thu Apr 9 21:15:22 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185322 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2319615ilr; Thu, 9 Apr 2020 14:16:35 -0700 (PDT) X-Google-Smtp-Source: APiQypLlFwoCCgAed6YEUP9iXxXiMqm/I8eX/n8tdTtBRNcH0jXnjtoVwtYVf0p0AE18n3xwIRuV X-Received: by 2002:ad4:46a7:: with SMTP id br7mr2177332qvb.165.1586466995539; Thu, 09 Apr 2020 14:16:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586466995; cv=none; d=google.com; s=arc-20160816; b=x+1K7EwyWaSfIHWiUEZTg118XYiJuIqOZ8U/JxxxB3C83jefq0DY4Z5TvU9C5oeLoy eNlwgpNAe0MI3XWEJdXXACiGZktxc3C0mmHsYCtQx+ZTSerk7TJUgpYtg2JPhwlnxWkk o/FJkLlg1hDi8sHWl5fw6J3e4+3wDJ2NVJaeyAM6uOL34ZlWuGigJGeJMS8zyyPj6dzN gYgrj/W1VsoqkMQ4HIp/ppEceVU5g6JYvdh4iXOM7ELwk5wAk5fIrO+CEoY8sXC/nflN aBzva1cfiknjLz9avom7srMKQsfgxDBDg4b0Y2gPsDuvqjbBa6EpNGCKM9+ScjqCbRML PLkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=en3XxeI0kUhj1g+8oDCU8qm2/eo411eCLElDQvibSv4=; b=qxzn8LsAu1RwbqnxJ+yP46z0J0Dv9pIYpgksdJerByHjRycWOnMURaRr73sArNCjGl rBbrdDS8E3XGClwwymvGJKEl+Vf969lyJ1SlRLyquKSjYV84GHskaVkhcyMGi4TE3jvE NI3GKhlHt+wi8aVKHSn2rkZJmDQEntzX/sfc5pVg1s7dcrVBBFGy8JcYi4OnIf9aEr/w MrB66co9xVWjoY4YSFBnCBEOo+p6WMux6gPCYqxRq62qnDHLWptuMRPt3hfteycI5E31 sYBnPdQHugR/KLTKrevjbGur3UIbR0HX7GlxYqXfj1bPue/cSjx98G0k58TzQS58OeQ5 mmng== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=BtY+6NkZ; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id b32si6127444qtk.203.2020.04.09.14.16.35 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:16:35 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=BtY+6NkZ; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55554 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeXL-000266-0B for patch@linaro.org; Thu, 09 Apr 2020 17:16:35 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42323) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWR-00023d-Pq for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:41 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWQ-0005fi-3p for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:39 -0400 Received: from mail-wr1-x441.google.com ([2a00:1450:4864:20::441]:36112) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWP-0005f7-T7 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:38 -0400 Received: by mail-wr1-x441.google.com with SMTP id k1so13758971wrm.3 for ; Thu, 09 Apr 2020 14:15:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=en3XxeI0kUhj1g+8oDCU8qm2/eo411eCLElDQvibSv4=; b=BtY+6NkZh9PztFPJFQVkCw1KsCuP9tB6Y+bYElEu4HoHvspxU6FY3nHsdQI+Q72tmw XIvbp0MFW8Ht4+9JAf00flsqFo+E8Tpy3BO/NxrXdU36u1TIUa5tF/GhNI8YYjSnEy6S AaHxaXaAUXXW3JfjpVNbxnbjK9trUB0otAVUEqwub1dSTWybW67ybc4W9mNTuyB7IbWq XA36fymyQ14hlZlnkw9VDWQTeJkCBXdo6s0v+V6UJN0HCFA7x8nFLsAVBKrz9lcMFzDK cSPIvY7TOikXFgnij2FLBXVUvK4vz8XlI4XinRHTTBskKHIaIc6l9qhvpH6DFFd1fKaO Oz1w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=en3XxeI0kUhj1g+8oDCU8qm2/eo411eCLElDQvibSv4=; b=RewR8Th6qI0vcgfwtRRcpeG3XoHHixy6d4ABL1h+Yv969ohxcPhHf8d+FsNdUU6vNa p2Fn4Ctokls8I/3U8/aTmFyv9ZEU9ObpD5F6c3edltPk8xs2c57nkFFaiAR6SeEvWXQk vvXZ9QAKClOvywsFdXmT+2BYK4FHOgntxPWQOr6CIXKm94W9p/mi6TmEHIFYNOBkmHuw a7YW2K5BIBGa+CTX6ia4Y8Yw+CMtTusUgshGP7SKVSpaxw7iZ1q/u0Vq+QOEM6OEa97K HkwuDbSdVYOW/YWYgZOKDCY6RNkcYOQcjHb2+J3S25RHzvbABAD1qd8SEGbstDKKtu5Q nQpg== X-Gm-Message-State: AGi0PuZJAgbZDWr/xbOuBE2Cqthea+KJ3ZbWGNYtTCkrIbLpjfNXFnwD YJ7Udz+1uEUz/Lr+Kh/U8JpCTw== X-Received: by 2002:a5d:6a4e:: with SMTP id t14mr1152493wrw.101.1586466936785; Thu, 09 Apr 2020 14:15:36 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id v7sm4408633wmg.3.2020.04.09.14.15.31 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:34 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 656131FF90; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 04/11] linux-user/ppc: Fix padding in mcontext_t for ppc64 Date: Thu, 9 Apr 2020 22:15:22 +0100 Message-Id: <20200409211529.5269-5-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::441 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?utf-8?q?Alex_Benn=C3=A9e?= , Riku Voipio , Richard Henderson , Laurent Vivier Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Richard Henderson The padding that was added in 95cda4c44ee was added to a union, and so it had no effect. This fixes misalignment errors detected by clang sanitizers for ppc64 and ppc64le. In addition, only ppc64 allocates space for VSX registers, so do not save them for ppc32. The kernel only has references to CONFIG_SPE in signal_32.c, so do not attempt to save them for ppc64. Fixes: 95cda4c44ee Signed-off-by: Richard Henderson Signed-off-by: Alex Bennée --- linux-user/ppc/signal.c | 69 +++++++++++++++++------------------------ 1 file changed, 29 insertions(+), 40 deletions(-) -- 2.20.1 diff --git a/linux-user/ppc/signal.c b/linux-user/ppc/signal.c index ecd99736b7e..20a02c197cb 100644 --- a/linux-user/ppc/signal.c +++ b/linux-user/ppc/signal.c @@ -35,12 +35,26 @@ struct target_mcontext { target_ulong mc_gregs[48]; /* Includes fpscr. */ uint64_t mc_fregs[33]; + #if defined(TARGET_PPC64) /* Pointer to the vector regs */ target_ulong v_regs; + /* + * On ppc64, this mcontext structure is naturally *unaligned*, + * or rather it is aligned on a 8 bytes boundary but not on + * a 16 byte boundary. This pad fixes it up. This is why we + * cannot use ppc_avr_t, which would force alignment. This is + * also why the vector regs are referenced in the ABI by the + * v_regs pointer above so any amount of padding can be added here. + */ + target_ulong pad; + /* VSCR and VRSAVE are saved separately. Also reserve space for VSX. */ + struct { + uint64_t altivec[34 + 16][2]; + } mc_vregs; #else target_ulong mc_pad[2]; -#endif + /* We need to handle Altivec and SPE at the same time, which no kernel needs to do. Fortunately, the kernel defines this bit to be Altivec-register-large all the time, rather than trying to @@ -48,32 +62,14 @@ struct target_mcontext { union { /* SPE vector registers. One extra for SPEFSCR. */ uint32_t spe[33]; - /* Altivec vector registers. The packing of VSCR and VRSAVE - varies depending on whether we're PPC64 or not: PPC64 splits - them apart; PPC32 stuffs them together. - We also need to account for the VSX registers on PPC64 - */ -#if defined(TARGET_PPC64) -#define QEMU_NVRREG (34 + 16) - /* On ppc64, this mcontext structure is naturally *unaligned*, - * or rather it is aligned on a 8 bytes boundary but not on - * a 16 bytes one. This pad fixes it up. This is also why the - * vector regs are referenced by the v_regs pointer above so - * any amount of padding can be added here - */ - target_ulong pad; -#else - /* On ppc32, we are already aligned to 16 bytes */ -#define QEMU_NVRREG 33 -#endif - /* We cannot use ppc_avr_t here as we do *not* want the implied - * 16-bytes alignment that would result from it. This would have - * the effect of making the whole struct target_mcontext aligned - * which breaks the layout of struct target_ucontext on ppc64. + /* + * Altivec vector registers. One extra for VRSAVE. + * On ppc32, we are already aligned to 16 bytes. We could + * use ppc_avr_t, but choose to share the same type as ppc64. */ - uint64_t altivec[QEMU_NVRREG][2]; -#undef QEMU_NVRREG + uint64_t altivec[33][2]; } mc_vregs; +#endif }; /* See arch/powerpc/include/asm/sigcontext.h. */ @@ -278,6 +274,7 @@ static void save_user_regs(CPUPPCState *env, struct target_mcontext *frame) __put_user((uint32_t)env->spr[SPR_VRSAVE], vrsave); } +#if defined(TARGET_PPC64) /* Save VSX second halves */ if (env->insns_flags2 & PPC2_VSX) { uint64_t *vsregs = (uint64_t *)&frame->mc_vregs.altivec[34]; @@ -286,6 +283,7 @@ static void save_user_regs(CPUPPCState *env, struct target_mcontext *frame) __put_user(*vsrl, &vsregs[i]); } } +#endif /* Save floating point registers. */ if (env->insns_flags & PPC_FLOAT) { @@ -296,22 +294,18 @@ static void save_user_regs(CPUPPCState *env, struct target_mcontext *frame) __put_user((uint64_t) env->fpscr, &frame->mc_fregs[32]); } +#if !defined(TARGET_PPC64) /* Save SPE registers. The kernel only saves the high half. */ if (env->insns_flags & PPC_SPE) { -#if defined(TARGET_PPC64) - for (i = 0; i < ARRAY_SIZE(env->gpr); i++) { - __put_user(env->gpr[i] >> 32, &frame->mc_vregs.spe[i]); - } -#else for (i = 0; i < ARRAY_SIZE(env->gprh); i++) { __put_user(env->gprh[i], &frame->mc_vregs.spe[i]); } -#endif /* Set MSR_SPE in the saved MSR value to indicate that frame->mc_vregs contains valid data. */ msr |= MSR_SPE; __put_user(env->spe_fscr, &frame->mc_vregs.spe[32]); } +#endif /* Store MSR. */ __put_user(msr, &frame->mc_gregs[TARGET_PT_MSR]); @@ -392,6 +386,7 @@ static void restore_user_regs(CPUPPCState *env, __get_user(env->spr[SPR_VRSAVE], vrsave); } +#if defined(TARGET_PPC64) /* Restore VSX second halves */ if (env->insns_flags2 & PPC2_VSX) { uint64_t *vsregs = (uint64_t *)&frame->mc_vregs.altivec[34]; @@ -400,6 +395,7 @@ static void restore_user_regs(CPUPPCState *env, __get_user(*vsrl, &vsregs[i]); } } +#endif /* Restore floating point registers. */ if (env->insns_flags & PPC_FLOAT) { @@ -412,22 +408,15 @@ static void restore_user_regs(CPUPPCState *env, env->fpscr = (uint32_t) fpscr; } +#if !defined(TARGET_PPC64) /* Save SPE registers. The kernel only saves the high half. */ if (env->insns_flags & PPC_SPE) { -#if defined(TARGET_PPC64) - for (i = 0; i < ARRAY_SIZE(env->gpr); i++) { - uint32_t hi; - - __get_user(hi, &frame->mc_vregs.spe[i]); - env->gpr[i] = ((uint64_t)hi << 32) | ((uint32_t) env->gpr[i]); - } -#else for (i = 0; i < ARRAY_SIZE(env->gprh); i++) { __get_user(env->gprh[i], &frame->mc_vregs.spe[i]); } -#endif __get_user(env->spe_fscr, &frame->mc_vregs.spe[32]); } +#endif } #if !defined(TARGET_PPC64) From patchwork Thu Apr 9 21:15:23 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185325 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2321871ilr; Thu, 9 Apr 2020 14:18:59 -0700 (PDT) X-Google-Smtp-Source: APiQypLTYVG1ssZL/oloSAWayMAscu3fEYyOfdvcrNBKPPSXrKZQUeI1d7Qq4ZurrvxjGpjLGoh7 X-Received: by 2002:a37:4ac2:: with SMTP id x185mr905665qka.413.1586467139813; Thu, 09 Apr 2020 14:18:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467139; cv=none; d=google.com; s=arc-20160816; b=KL3tvWgweY/1Cs6JAfa72cFoO/0vhUlGWGhlBvaOXYeS7brfiGxDZTUm4d5qSrDVyw IZxVfxPufbic6bsVHNolFR3yPWYH18QVVQD97PDhQj6IklP6HSfLY0wCiR3iiBjIrX7/ /2+/gCTzylR9WSvSm01RL9LcLD/bPEcygpclDjxHK5BNWY29uR8GPcBVFTE/+GUngCQr xOt8miVdTu3syKmT4yVHFm7bkZHir5ijY6ib2T0Y2rxFGAGyN0DeGtXowRTpY1U+cEUd QvpO/uWyOqOwePglmfZf7kYIE1S30x/IUXS5f7xIUI7uUwTvSGTaBUofSpo0WxIpbXL7 Yx0A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=8kQXViYqUTZuPa2IrzFhn8UbNVNyk6FZ2Gjm7NSMqNs=; b=HDrulGUrHHQwaisj26t4WgvcljrPoHkUR5ozCTlCV6Lf2hw+3I6SdfnEEr22GlfLH9 EL5XUyt4XIp7oMwGSdT9RADDn2Dr3rAnumCv3CyfPWzRHQ9siSteIEfF7y/U1FglwyWq I7Plg6xfbR6pQvvRoiE9buaDwlBS7E/ZAmMerU7g+f1VagHoHFFYSPCwFNwqV0Sdlth5 a0mce2hmaCvEPQrOyKmA0K7yI+LkHN0CGmzhNenr7kSolpSq7plHbgch1UkLkDIsYoBe PyHNu1jrypOl6y+ZaVir4RukxAGNRfExtdQb32nWNu/mV9B/wgIBDioDOvicy6uujiIZ 0XAw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b="Nus5r/PB"; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id h1si123625qkc.288.2020.04.09.14.18.59 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:18:59 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b="Nus5r/PB"; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55624 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeZf-0005ot-Af for patch@linaro.org; Thu, 09 Apr 2020 17:18:59 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42336) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWS-000252-Op for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:42 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWR-0005gi-8S for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:40 -0400 Received: from mail-wm1-x32e.google.com ([2a00:1450:4864:20::32e]:50675) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWR-0005g3-2J for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:39 -0400 Received: by mail-wm1-x32e.google.com with SMTP id x25so294470wmc.0 for ; Thu, 09 Apr 2020 14:15:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=8kQXViYqUTZuPa2IrzFhn8UbNVNyk6FZ2Gjm7NSMqNs=; b=Nus5r/PBUtysXeNOzCbziBtjB2uborn+ThW7eupuqD/2pQJvPDsYIKnWlJnDVRBxaE sglav2nIVP9iwmP96Znw1zBwDaUTWM6+c20xnmRj9BGIsnIAszo06Tf+qrCGR028z6Ma mwCGOIFuhLzhx22Q5Gyz7tZs/sj8FO5MzcFMWnAoAyrZSkDtLWn/C81tQbGPeu7hyTrX NNFYWTZsARklMZDgZFBuENY2j7kVBhzJAbJWpI9NkKTJONaDjZWfAGb+Jg2VpvbkI5OB i9i1c6zRPoZwn0qLc6gL+xOa7Ya8WED3sbIfjW/ya9NoUQ5jzoYA3RNl00NkZhYmdR3y gvCg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=8kQXViYqUTZuPa2IrzFhn8UbNVNyk6FZ2Gjm7NSMqNs=; b=hmNDHPjRWqt3w7tjywpoQ+cLVXvnMU4OlMdVL6HxwmY7rprMFZx//xB3/jJpLtCEqZ I++OulBuC2Vpk8gVkAZ+gYJHUfMVWU7y3wdPsujZgu/FrSD43wOAjzUaLsEkxLn3nRj5 ULTe9D1ijscw3QfB1P9uLnwG+00wCjujxbcPw0EzUsfihFQhj4OCIRPhOxIbiq54/6qM oTIqh8oxZPX5/B5g8irB5bKX05gogyeU5CYbcuCNBJ+D6/zIIlzvjuKO25BDMsuAi2vs 87F3IXxdo/A044ciD97hbJRJm9irv7U4iUKpbtbUG2NkUmYuTJ9+VRiVR86osi1XqPPY 01ew== X-Gm-Message-State: AGi0PuY8b7D+xIWaXnvRc66mp90kHlDUv/vH6rOA9qb1FOiZaOuu95MB jMXwSMknBUEoGP+C7wN7rHq3oA== X-Received: by 2002:a1c:9c47:: with SMTP id f68mr1709909wme.148.1586466937998; Thu, 09 Apr 2020 14:15:37 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id j10sm24038122wru.85.2020.04.09.14.15.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:35 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 830BE1FF91; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 05/11] tests/docker: add docs FEATURE flag and use for test-misc Date: Thu, 9 Apr 2020 22:15:23 +0100 Message-Id: <20200409211529.5269-6-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::32e X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Fam Zheng , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= , =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" The test-misc docker test fails on a number of images which don't have the prerequisites to build the docs. Use the FEATURES flag so we can skip those tests. As the sphinx test fails to detect whatever feature we need to get hxtool to work we drop them from debian9 so the windows build doesn't attempt to build the docs. Signed-off-by: Alex Bennée --- tests/docker/dockerfiles/debian10.docker | 2 ++ tests/docker/dockerfiles/debian9.docker | 2 -- tests/docker/dockerfiles/fedora.docker | 2 +- tests/docker/dockerfiles/travis.docker | 2 +- tests/docker/dockerfiles/ubuntu.docker | 2 +- tests/docker/dockerfiles/ubuntu1804.docker | 2 +- tests/docker/test-misc | 2 ++ 7 files changed, 8 insertions(+), 6 deletions(-) -- 2.20.1 Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson diff --git a/tests/docker/dockerfiles/debian10.docker b/tests/docker/dockerfiles/debian10.docker index 2fcdc406e83..0769700a416 100644 --- a/tests/docker/dockerfiles/debian10.docker +++ b/tests/docker/dockerfiles/debian10.docker @@ -34,3 +34,5 @@ RUN apt update && \ python3-sphinx \ texinfo \ $(apt-get -s build-dep qemu | egrep ^Inst | fgrep '[all]' | cut -d\ -f2) + +ENV FEATURES docs diff --git a/tests/docker/dockerfiles/debian9.docker b/tests/docker/dockerfiles/debian9.docker index 92edbbf0f48..08cc970feb1 100644 --- a/tests/docker/dockerfiles/debian9.docker +++ b/tests/docker/dockerfiles/debian9.docker @@ -30,6 +30,4 @@ RUN apt update && \ pkg-config \ psmisc \ python3 \ - python3-sphinx \ - texinfo \ $(apt-get -s build-dep qemu | egrep ^Inst | fgrep '[all]' | cut -d\ -f2) diff --git a/tests/docker/dockerfiles/fedora.docker b/tests/docker/dockerfiles/fedora.docker index 4bd2c953af8..179575ecaaa 100644 --- a/tests/docker/dockerfiles/fedora.docker +++ b/tests/docker/dockerfiles/fedora.docker @@ -103,4 +103,4 @@ ENV QEMU_CONFIGURE_OPTS --python=/usr/bin/python3 RUN dnf install -y $PACKAGES RUN rpm -q $PACKAGES | sort > /packages.txt ENV PATH $PATH:/usr/libexec/python3-sphinx/ -ENV FEATURES mingw clang pyyaml asan +ENV FEATURES mingw clang pyyaml asan docs diff --git a/tests/docker/dockerfiles/travis.docker b/tests/docker/dockerfiles/travis.docker index e8eb48dccfd..591282561bc 100644 --- a/tests/docker/dockerfiles/travis.docker +++ b/tests/docker/dockerfiles/travis.docker @@ -13,5 +13,5 @@ RUN apt-get -y install device-tree-compiler python3 python3-yaml dh-autoreconf g # Travis tools require PhantomJS / Neo4j / Maven accessible # in their PATH (QEMU build won't access them). ENV PATH /usr/local/phantomjs/bin:/usr/local/phantomjs:/usr/local/neo4j-3.2.7/bin:/usr/local/maven-3.5.2/bin:/usr/local/cmake-3.9.2/bin:/usr/local/clang-5.0.0/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin -ENV FEATURES clang pyyaml +ENV FEATURES clang pyyaml docs USER travis diff --git a/tests/docker/dockerfiles/ubuntu.docker b/tests/docker/dockerfiles/ubuntu.docker index b6c7b41dddd..eeb3b22bf20 100644 --- a/tests/docker/dockerfiles/ubuntu.docker +++ b/tests/docker/dockerfiles/ubuntu.docker @@ -68,4 +68,4 @@ ENV PACKAGES flex bison \ RUN apt-get update && \ DEBIAN_FRONTEND=noninteractive apt-get -y install $PACKAGES RUN dpkg -l $PACKAGES | sort > /packages.txt -ENV FEATURES clang pyyaml sdl2 +ENV FEATURES clang pyyaml sdl2 docs diff --git a/tests/docker/dockerfiles/ubuntu1804.docker b/tests/docker/dockerfiles/ubuntu1804.docker index 1efedeef995..f66b06f4cff 100644 --- a/tests/docker/dockerfiles/ubuntu1804.docker +++ b/tests/docker/dockerfiles/ubuntu1804.docker @@ -54,7 +54,7 @@ ENV PACKAGES flex bison \ RUN apt-get update && \ DEBIAN_FRONTEND=noninteractive apt-get -y install $PACKAGES RUN dpkg -l $PACKAGES | sort > /packages.txt -ENV FEATURES clang pyyaml sdl2 +ENV FEATURES clang pyyaml sdl2 docs # https://bugs.launchpad.net/qemu/+bug/1838763 ENV QEMU_CONFIGURE_OPTS --disable-libssh diff --git a/tests/docker/test-misc b/tests/docker/test-misc index d480afedca7..cc94a738dd0 100755 --- a/tests/docker/test-misc +++ b/tests/docker/test-misc @@ -14,6 +14,8 @@ . common.rc +requires docs + cd "$BUILD_DIR" # build everything else but QEMU From patchwork Thu Apr 9 21:15:24 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185328 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2322843ilr; Thu, 9 Apr 2020 14:20:00 -0700 (PDT) X-Google-Smtp-Source: APiQypJzPHIj7azKpQ25uYBWdrt6xL/JFIsbi16XBTlCVry7NGLS6Bh4qy3n6/+k5Kve18z+hRc3 X-Received: by 2002:ac8:72ca:: with SMTP id o10mr1418469qtp.320.1586467200480; Thu, 09 Apr 2020 14:20:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467200; cv=none; d=google.com; s=arc-20160816; b=KiAR7Ag/O3vr+AFhmnglWiKRYXqUxehpEqAn46UPjwbFe2AixCwVWn5m7i6YVbI8e0 pxUb/2sUko9oC2qg4hUHeYJrqx+TZa3oSsOeNm3XgGryiPjhtno6Ryvz1xFEUQeZhhAi KVRyRgcnTlmlFSQGCO+iPB7HJ0FKd8bFzp+RcypJRGxlWdWj6/zLObHRMW0ABcgaWzcR xUkRWwWgJVnbTfJXu88BtyUEv5RjK+ANgbmbcREwnL6RfgkuiugayH/xMEvIrqIrInjK r5MnW+1UOTIN3anV5SXgj/xvONQnLTOM2kWWy7GcFlnW//HeXSJf1ni9gffbCU+jc5Yi 6h0w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=BdeCn4+10IAGnxWmwrkvRB49uZrWTVunuxiT/Jj8P3k=; b=rrARkFgLqutgbjUPjcVAogFI6EMsP7uk8w1CDevapTfkm8CbJ5vrjhYoVd9PQ+2VpJ gGmDNuMQ3Cl8UAy5PxHMsLWeo5KjdbI+vGbcfLFGJNwp/BCNUpS/RBb6TBvQFoRBbzaH iedrr1tTcy5ieHB6gWhMCAdd0KT+1jm5Q1CoFsARa6YHuIGin33mxbQFUwNk+ZWhvv3A u9xBgxKsq6IwBt3Gjh9cAJtxHOEPldQinG0hgUooi6LpBNYK10Da8qd4qvS2K/pzb3cI kgsdBcxUhgATLp6c9EYdKf+vbfspI+qUZqFYKNsOodT7qGZuqu8tuAc8lCUTFQxZuf6i Vkug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=c1tIiXID; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id c12si6749490qtq.97.2020.04.09.14.20.00 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:20:00 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=c1tIiXID; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55674 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeae-0000q5-1j for patch@linaro.org; Thu, 09 Apr 2020 17:20:00 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42349) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWU-00025x-6o for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:43 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWS-0005hh-Ah for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:42 -0400 Received: from mail-wm1-x335.google.com ([2a00:1450:4864:20::335]:34130) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWS-0005h1-5I for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:40 -0400 Received: by mail-wm1-x335.google.com with SMTP id c195so3416623wme.1 for ; Thu, 09 Apr 2020 14:15:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=BdeCn4+10IAGnxWmwrkvRB49uZrWTVunuxiT/Jj8P3k=; b=c1tIiXIDvJBh4Eg+6dYhPcprRYOKl0gTIA+tOK6kkmyV2UDcoPbXFzKujxwNqvvm7T dHOSaOHKMbicZu+Gaes1roDlsxRbG6gjBC/4IZfy3aQVrBpeK+/NvcIPo07bd5gAH4Q9 F1sciZTvpgMMvuEi59jNbPl42CFaRf6z59Lo7LY7Eu6aGI9YWxI1Y5Pn5+Bq57F+QWRU XZ2YiDv1334obufMCg2uKXmRAaGl54ajveewnBeH7XB85HvzzX64rv4KEkIyTAvvSEEF fJ530c/YPRKtyLdvxnytz4mPX8x4/29eJzaNx9bfkVdbEusdohr7JLs6Ggqakg6S809N 3fKw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=BdeCn4+10IAGnxWmwrkvRB49uZrWTVunuxiT/Jj8P3k=; b=e3jRnnzwvWnaW15tyaKIvTn3THdoWqiMEW6zvSKE7HYZf6nDyf67KO9A8VBGfif/dE Rtu/p3vdtkiqTwla+XBUI9O3QvO/dVF2HCTMQzAYe2+nRaL75ViZx1LATxQX+Bulabim 5FtTT9raT2XopaY0JM9aqZDEM0tW4wHWm9e4Vjc+cbuStt3xcZx+KVRwigEKoSRthf/x 8VRWnIu9vaAdOiAycukz2Ws2AOmXJZrlFp7Z/K2xydF8yk+XYYPg48Bsp3ARZiHXFZ5F MhHzctCtlipoFO306RHz8+jVcPDrIdFdrMMUhz9f82oqK4Yt3b6x8r4U/r8s5vDBgL5p VvVQ== X-Gm-Message-State: AGi0PubNOB3IJUbZoKqPk7KmnVyxOcS6e/sJh0yPRt0iJjZfvK3OWXkG Undp2iW3GoCeO6Eiz6wW0T5G5A== X-Received: by 2002:a1c:7415:: with SMTP id p21mr1720225wmc.93.1586466939240; Thu, 09 Apr 2020 14:15:39 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id s6sm5167430wmh.17.2020.04.09.14.15.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:35 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 967B61FF92; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 06/11] configure: redirect sphinx-build check to config.log Date: Thu, 9 Apr 2020 22:15:24 +0100 Message-Id: <20200409211529.5269-7-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::335 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" Otherwise it's hard to debug whats going on. Signed-off-by: Alex Bennée --- configure | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) -- 2.20.1 Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson diff --git a/configure b/configure index 233c671aaa9..a207cce82bc 100755 --- a/configure +++ b/configure @@ -4936,7 +4936,7 @@ has_sphinx_build() { # sphinx-build doesn't exist at all or if it is too old. mkdir -p "$TMPDIR1/sphinx" touch "$TMPDIR1/sphinx/index.rst" - "$sphinx_build" -c "$source_path/docs" -b html "$TMPDIR1/sphinx" "$TMPDIR1/sphinx/out" >/dev/null 2>&1 + "$sphinx_build" -c "$source_path/docs" -b html "$TMPDIR1/sphinx" "$TMPDIR1/sphinx/out" >> config.log 2>&1 } # Check if tools are available to build documentation. From patchwork Thu Apr 9 21:15:25 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185327 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2322366ilr; Thu, 9 Apr 2020 14:19:31 -0700 (PDT) X-Google-Smtp-Source: APiQypI+EXR0s5blMHMVvGjfHipkCp2OytaMBHoN+oLrPyckIeRqU/hu6bIHuX7DeEyHm+pLYDHB X-Received: by 2002:aed:3f1d:: with SMTP id p29mr1468049qtf.14.1586467171587; Thu, 09 Apr 2020 14:19:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467171; cv=none; d=google.com; s=arc-20160816; b=hOVG9R5ulrOI0k19tXI14RWhJraC05s4IKH2CSnnqEUlcj6xqrEiEanpTK/57JHyXm WmKT0D8SyOLTY5J3fJW3qZ25ol6kaV+kxchM8x5Zd2TLB6eNcjftWwHRfJlglGxmdHWl EiWuIgx343RDJjcJ2MszHFBwMupXYI+hOxbUqJzqlbyS+GuzdR1OWh8PVW5a155byjTw zSisoj6cdiUo6v+MXNnjlYRaC6d0o+IzWczLbO+RWsItGd8mtyhWx8xwhcsgZiSKgO6+ 040s979c6Lhyy5ae3/PJS9pZjdiSDRcza/MeiLsl2VLvvUQWIldg76Go51NZSvlmeggS phnQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=ziNKYsZMVifuVbLWk94SRoJmjJXfnyU9uE+FhQ5jb/Q=; b=jcd9NkK5ZL8zwt7YrJCNGP6q/jYvyB1Ac+cqKEIYmwBXgs0zvg0Y0ZuclGHXPaeC6n PnPJh7XFdZD2mCjnPYiJUIAiHHzHfwCu/GRsvqTlZFjgiXcJI0qXqEzbAtb443hB/nww oOjEkLoMDkKafgQ+v7jLcL++SjanSH7mYRdRKQJIceJoUtcJ3meTy83ehABG/cO6Hnm4 MBH4XiyBcbgISrUI8oMp35i/+N1p3PUg0FPK/zoyL55Rlsh+eIHahV0zKWyUTWFRIne6 0lzZ/zIy9761pZsLqXQtDq83fZxAOKy0iJgNPKHVPA7971grHDjLoJs6HRLr2JCzUM+n VBNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=ao5c+AdF; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id a5si143514qkn.149.2020.04.09.14.19.31 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:19:31 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=ao5c+AdF; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55636 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeaB-000781-33 for patch@linaro.org; Thu, 09 Apr 2020 17:19:31 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42372) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWV-00028t-Tt for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:45 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWU-0005md-PS for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:43 -0400 Received: from mail-wm1-x334.google.com ([2a00:1450:4864:20::334]:38275) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWU-0005i7-JH for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:42 -0400 Received: by mail-wm1-x334.google.com with SMTP id f20so329796wmh.3 for ; Thu, 09 Apr 2020 14:15:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=ziNKYsZMVifuVbLWk94SRoJmjJXfnyU9uE+FhQ5jb/Q=; b=ao5c+AdFy4Z91r5753lr0175eqQlPTmo3VUHIzu5J6q9Kuj/3+6zx+SYCh7twi0D01 rQ/vjcw8AePtlkPVvvc2vr9iiSkIJq456ONd3hU8JcZlwvh1jWrNloqWqm5PYdK38p/v oir2d26AXKTN8NPaJX1Of77L2f6za/ghfpk8+Qfru10qTToQVxGZCsMZe5RZI40iRfp1 l5FOzFt5MPluP2Ob7Vc/OcM825HP2/cgi8cTz5+8T1hof1neIVNWgFn4BT9RQF8qHTPl 0/gvt1wmo1i7DfvVoBhf0Q2vbfeNLi8jckhtF9J823NMfsFiJsiUd3hJvLYROhMyHGf7 XohA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ziNKYsZMVifuVbLWk94SRoJmjJXfnyU9uE+FhQ5jb/Q=; b=CvrOR8EP5Rw3uNkRoQ5uJYS54Zm5gjEkUomaKNA73VW8LP7KnwottX6ppHmzmhOMn+ mJRC1HSo/C8WHZ4KLouiPFAwh+RQfAaeTk8urDXDApZNuOoe8U9JvmS0/q1jYAXt785v hONyAdmBpwIqfCkDzVhAvIIVNzmmC5CSUJhYZwah/IMcTeWFKsFGEdS1zWf6/qnVR9Fs sdGIFzfJsbU1aqo8ym6NLJ9hCiODVr4uwINRdrnmcZl3ZqMMELHdKEGh8yTyvma84svK 2ytaOOybr2qy+HpnTMqFNl6qJkpgM9j2vITIqKro2MvdLblJ6SO5uFvS6FXI2lrhhQ7a /Qew== X-Gm-Message-State: AGi0PuaTZ8l7pgG2uysTkhhyAhxPqCV+A5Pa/BM6MBUM4TrD4MWHV51/ L4yhphRzWbUmjcr5JMcdILEK3Q== X-Received: by 2002:a7b:cdf7:: with SMTP id p23mr1790328wmj.33.1586466940416; Thu, 09 Apr 2020 14:15:40 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id b85sm5443767wmb.21.2020.04.09.14.15.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:35 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id AA03F1FF93; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 07/11] configure: disable PIE for Windows builds Date: Thu, 9 Apr 2020 22:15:25 +0100 Message-Id: <20200409211529.5269-8-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::334 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Bug 1871798 <1871798@bugs.launchpad.net>, James Le Cuirot , =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" It seems on some compilers the test can pass but still give you broken binaries. [AJB untested - please could windows users test] Fixes: d2cd29e30736 Fixes: https://bugs.launchpad.net/qemu/+bug/1871798 Cc: Bug 1871798 <1871798@bugs.launchpad.net> Cc: James Le Cuirot Signed-off-by: Alex Bennée --- configure | 1 + 1 file changed, 1 insertion(+) -- 2.20.1 Tested-by: Howard Spoelstra Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson diff --git a/configure b/configure index a207cce82bc..e9c5f630c14 100755 --- a/configure +++ b/configure @@ -807,6 +807,7 @@ MINGW32*) audio_drv_list="" fi supported_os="yes" + pie="no" ;; GNU/kFreeBSD) bsd="yes" From patchwork Thu Apr 9 21:15:26 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185323 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2320631ilr; Thu, 9 Apr 2020 14:17:37 -0700 (PDT) X-Google-Smtp-Source: APiQypKgVvKjkY8ZayT4tol14r2Vi3LwXHFb///uhERjUPuXUDrsqzurYZnizpkrHAQa+tadMLTl X-Received: by 2002:a37:428a:: with SMTP id p132mr920362qka.267.1586467057556; Thu, 09 Apr 2020 14:17:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467057; cv=none; d=google.com; s=arc-20160816; b=qc9Sg81jfPGEcqFWtrBavtpY4Z++KBGSQPhFAVCFtP3+klQINhTN50q4V7dGUuUdZR sOvRoYmOxL5Nrf9ExnD1Y7BtBZCaiicJn4VDAAC+RsCm6LzNey7wGNRGvlJ29TN9kuAm xaHIpS4AOdEjxYgOO2WHvnDpyDCxhjXohBKIXDuHL5s8AJ6dCpKJxs4oSim38s2jA739 h5stM8IFMkrdyUxcgYa/CLpaeKm/Ro7KGEDHXus/lZgEEuL0TtT27ywahLp3D23wcUDI K4mXHrDBrf7/2zCWiHlqcZRgPDGS2HwlaXQYQ1i6HI/fVkSLuEpU0O05phoh8tO8tYAK DOVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=3Vwwp+7FgPCuWIPWypnjEryUlzyp/CqPviLpa6fHhzs=; b=jVMzeAljEDsWlKuh3eWJcwBCW1IpX5mScdES6gyhDYdRIZZtZFxXF4oEM7l5Z9VGsJ Az9V9okdSgl+PgSsJL1CUokSNk27zFxC1UePYKd3CPa8Mv1lAga90X9YD2vyLb4H4Bu0 BlCwR3tq9JgwXBYk6qNyMjb0/h1lQ5kBcxGTaFKj3KdAFAsx06jNQ0LO5uCSzsF9vR3H AhS/UlZrgNxMQBcNlMRvWJQjGqhF1NOiGJPWn1yi+nM6pIx6q9kT73Egc7m2W1Jj8Cgf 9JHLSuOZdJJJGv5rcdBTkRfgBQ06xb6Ygp6pcBC1B8EtHIUqZPbX/aNQ/R/43AchL07q o+iQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=QLTcE4Jh; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id o8si6375889qvu.87.2020.04.09.14.17.37 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:17:37 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=QLTcE4Jh; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55588 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeYL-0003P1-0M for patch@linaro.org; Thu, 09 Apr 2020 17:17:37 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42370) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWV-00028P-Kh for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:44 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWU-0005m5-H7 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:43 -0400 Received: from mail-wr1-x42b.google.com ([2a00:1450:4864:20::42b]:44954) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWU-0005jw-BT for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:42 -0400 Received: by mail-wr1-x42b.google.com with SMTP id c15so13649342wro.11 for ; Thu, 09 Apr 2020 14:15:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=3Vwwp+7FgPCuWIPWypnjEryUlzyp/CqPviLpa6fHhzs=; b=QLTcE4JhzphXKShNK4RN0Od/VFN09fkzpUqPAb+/skkecwnvkFLqeNWzN+ccJm+722 YBvnCpNbt8NT/baiYiMS2xMmlkbLLAENVQc2DUsJAPcF9q0UeAlos1j9QU9KHGFZ12Mp GP4r3d7ETBDH4TgcqqR2fyIC2OqVaMaVjOfg2RfduY0JLeUcrVtucQoHo0GtE6KuiAnN g7UljjawR0D8vLtThFNraHMNfn1tUuzlwxMhS9rDclGFzjC4WKL/yePErkx1LOxAEmlx 1ehVHPlQn1as3H8OO2kpP/E5Ckh6JDUxghN3lf3xGnMWlDKbrAdSleBJlNDKjYpSPYKV nFFw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=3Vwwp+7FgPCuWIPWypnjEryUlzyp/CqPviLpa6fHhzs=; b=c84DVYDUROJTmwen+fx2yH9ZYc0vLYtTlaKMDaMVvJ+isqy6xbEm1a93ieEwmXIFE9 dDCOjSs/aNmgaZ5Frd+2SbUn4Ysu/zZymYRMDOKuzvEzd2z3BQdzqDyYHCnAgvUeFlSs BQeWB1WnEpQkmYwelh1yNntE9S18uJ5g9aLrDaronEvqMj8mjEZ/9byYfGXGu8MYoY9P voeyxOx6lmH9rZBxouS7ih9BQAMRWzfgySar8Swiu5Gt4wNB7re7zr4X4tsUfmQIfMDr XmpM9YIpq8iCSpLBMytP9gEeicyk8BUChT82QY5AejVDXLS5bbr1ny5W/0XzgEsGX/Tc ufqQ== X-Gm-Message-State: AGi0PuZmmjHl537XeQ0QWiOicsbCWkNDI56PgE0t73rkgpeGkd0bH1WI QFMqtPwC6wtFv8PhRbzTChnC43DxRc4= X-Received: by 2002:a5d:69ce:: with SMTP id s14mr1075308wrw.413.1586466941366; Thu, 09 Apr 2020 14:15:41 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id 127sm5440743wmd.38.2020.04.09.14.15.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:35 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id C14B21FF96; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 08/11] target/m68k/helper: Fix m68k_fpu_gdb_get_reg() use of GByteArray Date: Thu, 9 Apr 2020 22:15:26 +0100 Message-Id: <20200409211529.5269-9-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::42b X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?utf-8?q?Alex_Benn=C3=A9e?= , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= , Laurent Vivier , Peter Xu Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Philippe Mathieu-Daudé Since a010bdbe719 the gdbstub API takes a GByteArray*. Unfortunately we forgot to update the gdb_get_reg*() calls. Do it now. Fixes: a010bdbe719 ("extend GByteArray to read register helpers") Reported-by: Peter Xu Signed-off-by: Philippe Mathieu-Daudé Reviewed-by: Laurent Vivier Reviewed-by: Peter Xu Signed-off-by: Alex Bennée Message-Id: <20200409172509.4078-1-philmd@redhat.com> --- target/m68k/helper.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) -- 2.20.1 Reviewed-by: Richard Henderson diff --git a/target/m68k/helper.c b/target/m68k/helper.c index 014657c6372..cad40838956 100644 --- a/target/m68k/helper.c +++ b/target/m68k/helper.c @@ -109,8 +109,8 @@ static int m68k_fpu_gdb_get_reg(CPUM68KState *env, GByteArray *mem_buf, int n) { if (n < 8) { int len = gdb_get_reg16(mem_buf, env->fregs[n].l.upper); - len += gdb_get_reg16(mem_buf + len, 0); - len += gdb_get_reg64(mem_buf + len, env->fregs[n].l.lower); + len += gdb_get_reg16(mem_buf, 0); + len += gdb_get_reg64(mem_buf, env->fregs[n].l.lower); return len; } switch (n) { From patchwork Thu Apr 9 21:15:27 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185330 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2324138ilr; Thu, 9 Apr 2020 14:21:22 -0700 (PDT) X-Google-Smtp-Source: APiQypIBppoi2p9+f0866mflk0x0RvmEErwvFzurJZXWhPUv1mi6lafBO1mFojtMK+fl3Dbhx4pY X-Received: by 2002:a05:620a:16c2:: with SMTP id a2mr911480qkn.245.1586467281937; Thu, 09 Apr 2020 14:21:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467281; cv=none; d=google.com; s=arc-20160816; b=pmf/FZbYovg7WOVOIq4mgyb9wxbr7C3VsZCui9G7mj9RZy0VYwRGx6DEZw/ijQhvJJ 3lScObxBE9BRmnAXFUSjumiwOYWCCl5Z6aNJ4qginPJtnclfNmppjhRPAVarOKKs/W/Z h+kI1OvEpftRxUMHYqjzDGZKwIAle+bKKmMG4b8hY4MSoYRqqq9InTKHuho7vZ+geFfq MhTfCXR3UEwyz4ZRyaB4x8m5mzjgCWBTMKxqrs4anD5aBxCiMGkk4MwtrOQne+H69PxL lF+bMA9hkqKVuXPsPNbyFsux93y2tV046im3RYJxrMkUGqrTVmplbQgmJT2s4iOxqAts le5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=nVauCqAe02ZVV85VxJmPfUpt8hQkj2V7/kcfJf/XgeM=; b=mGbMDUfloiPZMJmewCCvt+uw/9fudlktEzib71KR2ftr2UhtjI6rt1hFX2aF775tk3 Fa9NtNJP2Uz2IVlx3qLaMXhrljR2jrqvk8yDLfHm02cIXYEcejVNQYXhp4um++glKlsZ kvRuiVsDQFWSn4Rx5g9sFFWzjSC3eEfPhZc/m0yj6cORAcsne5gBDE4c5DcJ8HUMMaKv DJBuAhTgLZhhMFGdicLUCCNXdQG8R03pAL6Kb4qyrSLKEvJWqlT/jhXqK83u3iNU1qcq DlHdHjARrqXdOqLJqnVCSpXbZzYvlJDSqq8yWgXLnxJyLUY/P8Z/r8LPS2UBn8FonasP v/fg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=cC1P2vPJ; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id l203si154090qke.210.2020.04.09.14.21.21 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:21:21 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=cC1P2vPJ; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55708 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMebx-0001x5-FI for patch@linaro.org; Thu, 09 Apr 2020 17:21:21 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42394) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWY-0002CA-15 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:46 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWW-0005p8-1a for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:44 -0400 Received: from mail-wm1-x341.google.com ([2a00:1450:4864:20::341]:53436) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWV-0005nA-Rs for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:43 -0400 Received: by mail-wm1-x341.google.com with SMTP id d77so272869wmd.3 for ; Thu, 09 Apr 2020 14:15:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=nVauCqAe02ZVV85VxJmPfUpt8hQkj2V7/kcfJf/XgeM=; b=cC1P2vPJJVf9RW/DyIIR90z4563W7+d9n5a+q5sh2AmPheKzS/sbazYOi1eQ8q9CEI MSD0p5Zi2L/1pqUFdzrLP4LWOnbvMyFYmtBsge+KZ00wQHUhTwWv+rZdx9v5RbVm6hXt IYrJ0gU53DYYUg/WKuwJ/HyUXcHBwhahh+wo4R+2uWqa8ViAA59I34TS+fJ8CQxQ42Gk 77GLAiRdbECed+RPxh6VXq2UW+6R7cMNS++vOe9wEKJdCAZ7TkJjTybZefC93c5aMRe2 0tb041iYA5CAXqPOAyz2KvJ6owFJAngVxMfku/T7w0D9sDo06DLKVlno6YXfnkEDJY7T yn/g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=nVauCqAe02ZVV85VxJmPfUpt8hQkj2V7/kcfJf/XgeM=; b=T+dGWtm8mDAvu5Wxo8JPdKKqkupzbBybz8BB2HQvleBY/6t6KIdYu1X6l4UIuS+3ia 50X/TjsQI/YWGAmPykwRvozhX1bUZgj7MD5gJVWvpucYV0wIOTiMShXC5CdWvO8qlfEs DLPiXfpcDUJTA3bsxlnBE4IEaGSKCkaPoYtAZTzcqlBIE598g1he3zfAEY99MpHM86pX 7TFdEBjW5os8Bm7UrL4cQdhpFR9eovy1Rq45xhlJsRQ6JsZiT/D+FxDzq8R+1Mq9kzMA oAGAIpL6qqBtOJUwYn3ymajUOmLuSNWXbIQxkWMjevi6gIAerf2ZkDcu0o5M4VaJettt PUZw== X-Gm-Message-State: AGi0PubzkEuN6Mov1ZEuudUE0tT+hktxesVo1/Y0DdgpBie/wObzBipt 5aTevF1vLEnTJsl11n2DGauh8Q== X-Received: by 2002:a1c:6787:: with SMTP id b129mr1822353wmc.165.1586466942652; Thu, 09 Apr 2020 14:15:42 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id a15sm4914213wme.17.2020.04.09.14.15.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:37 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id D6EF61FF98; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 09/11] gdbstub: i386: Fix gdb_get_reg16() parameter to unbreak gdb Date: Thu, 9 Apr 2020 22:15:27 +0100 Message-Id: <20200409211529.5269-10-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::341 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Eduardo Habkost , =?utf-8?q?Philippe_Mathieu-Daud?= =?utf-8?b?w6k=?= , Peter Xu , Paolo Bonzini , =?utf-8?q?Alex_Benn=C3=A9e?= , Richard Henderson Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Peter Xu We should only pass in gdb_get_reg16() with the GByteArray* object itself, no need to shift. Without this patch, gdb remote attach will crash QEMU. Fixes: a010bdbe719 ("extend GByteArray to read register helpers") Signed-off-by: Peter Xu Reviewed-by: Philippe Mathieu-Daudé Signed-off-by: Alex Bennée Message-Id: <20200409164954.36902-3-peterx@redhat.com> --- target/i386/gdbstub.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) -- 2.20.1 Tested-by: Stefano Garzarella Reviewed-by: Richard Henderson diff --git a/target/i386/gdbstub.c b/target/i386/gdbstub.c index f3d23b614ee..b98a99500ae 100644 --- a/target/i386/gdbstub.c +++ b/target/i386/gdbstub.c @@ -106,7 +106,7 @@ int x86_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n) } else if (n >= IDX_FP_REGS && n < IDX_FP_REGS + 8) { floatx80 *fp = (floatx80 *) &env->fpregs[n - IDX_FP_REGS]; int len = gdb_get_reg64(mem_buf, cpu_to_le64(fp->low)); - len += gdb_get_reg16(mem_buf + len, cpu_to_le16(fp->high)); + len += gdb_get_reg16(mem_buf, cpu_to_le16(fp->high)); return len; } else if (n >= IDX_XMM_REGS && n < IDX_XMM_REGS + CPU_NB_REGS) { n -= IDX_XMM_REGS; From patchwork Thu Apr 9 21:15:28 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185331 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2325184ilr; Thu, 9 Apr 2020 14:22:30 -0700 (PDT) X-Google-Smtp-Source: APiQypIfEP2wF5h/6aBTrh4+kfuYIonZnewirSRSvDEjHiCp7M41EotMjZJ9YL7Z/qdtUS4wdjbA X-Received: by 2002:a05:620a:10b4:: with SMTP id h20mr993697qkk.85.1586467349438; Thu, 09 Apr 2020 14:22:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467349; cv=none; d=google.com; s=arc-20160816; b=Y2EqcbZuyhQizF/7WEpdKWvRU64N+8o06Zikkbs+A9lMHRxPGBLhpbD4vXyZZGeuSA +oRez8tab1NoH/Z6O34xbzBrwmn+UYlPjwJrhtzyx/Zsg3j8svQglvsT7ES8i1qyuYOE h4V+Wlz6A7PM8RLyhDb0tp4qGjA7Vxn4Rvix3TC+JbtkkYvzXJBBuoCMCJevUr542jh3 qt1xkFgSEg+84n1eMjRUerVmT5KLvSKDqJVUsuZ0eQBxTLlnE9yy8AzP5bDq7Qf9kkOL Hm2C0npQNkvyf/JidRZGNIVSBVxXb1l1ceFL7qTcsAnRwFzc28kmUblpZv9fkZo/KNWM aDUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=UOHKfqIKF1jCjy8KTE3gn1Ffb6t6apDQDsVpcDQdBmM=; b=fExwhAEDMv8YKGKyMwcur48tffyYbGfmD8lcqgw8tG6mniP3MCxVnU5Xwm6AK9on0f 4uBrS7rajS80xGrDaOrvzBQRreKyJtWKTtL5I90lHFwYgso+v8YAV5oqWv7L6Hw9ko+v 8wqDVtgwQ003Mp0jSTvj9sgZuQaxbJBDi6g4/f4SSK7cf/8hRkfmCApZPOAXcmykN2jv 5X9IsAtG2CM+zEV4ZiXV2ZQ8EVm/TPsupiV5gUQLn8jRwPD2kGG+17mdqaJ6m2BRZJM+ dpepfkbRFzT76O2Q8xC/1e0j6pEZEOjp/B33JuibhtloJM4C7ki7OOvVHQP5P2H3x0RP Ffag== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=zvkleqK5; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id f38si6048638qtb.307.2020.04.09.14.22.29 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:22:29 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=zvkleqK5; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55738 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMed2-0003nd-VE for patch@linaro.org; Thu, 09 Apr 2020 17:22:28 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42396) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWY-0002CU-6t for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:47 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWX-0005qF-2y for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:46 -0400 Received: from mail-wr1-x444.google.com ([2a00:1450:4864:20::444]:46569) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWW-0005pW-T2 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:45 -0400 Received: by mail-wr1-x444.google.com with SMTP id f13so7119751wrm.13 for ; Thu, 09 Apr 2020 14:15:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=UOHKfqIKF1jCjy8KTE3gn1Ffb6t6apDQDsVpcDQdBmM=; b=zvkleqK54b0q8+MePDP5WrH3YP8Drad0R5SwOyaUvXPWXJhLxfw6gqYrwoC5QPyBKY bP0RqyDQg1pjNqAOgTVKjJPFk/mnkD+8HJe296Kj3Ak4/3iMBh2eiY643dDWMKNQ3zzG CLoOvVAyz/9LRGM4RNX0nv3LNL3dzs/RONV7nlcjbMcpkhCMYYJKQP0oDeYErzfIlsFi WtFblGD5dH/qhcdpD3YKHZAMndOiQa6xDCBxNeQv6xaiL5bUJKxw7ZNXk7qzfo7SOUdn cvH1kK5WS7N/Siy18w3nszXNoJEfl3i5P+r/DFRqe07+nV0SK+/ixNbHXbrL9XTAr3Nh q/yg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=UOHKfqIKF1jCjy8KTE3gn1Ffb6t6apDQDsVpcDQdBmM=; b=L6RSb5i2Dn0cGMojWMbEMsJ50XloHPO+AIav1yJZH+Qa6CcESB6UcvoxYrzgNv7vZU J/G/fC5JMWevujOPKnxU0WehaZT+XZ25CGzQQ7Pa/wZKfdrliXthfN6rTSjXdKP0/fLl kAPSNT9Nxubu95ywbuy2NtbV2eoEDG+tj7WD8jya7offrqFO4CbMpiwGeZ07fTErqY7q DFy3bmV0nx27GdgUm0A8xplpMdaZrjvQPPBPkOsDDhtnB3IUMf1FhhitXaqWou9JNdf1 g2mkCZsdubv47YHc+5vPWdFB22liL28upQid8pKE/QhpVhT/GIo6uIlRDtvxqhvB8VUy le7A== X-Gm-Message-State: AGi0PuZ23H6uTwB+kzwq/cvC0EU/P8Cr7zaNG5Wld1rGDo7cdg/jb6qf CUr6MpWuoTr38DvoJ1yxn8hrCw== X-Received: by 2002:adf:d851:: with SMTP id k17mr1214694wrl.157.1586466943892; Thu, 09 Apr 2020 14:15:43 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id x18sm5045661wmi.29.2020.04.09.14.15.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:37 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id EE4091FF99; Thu, 9 Apr 2020 22:15:30 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 10/11] linux-user: fix /proc/self/stat handling Date: Thu, 9 Apr 2020 22:15:28 +0100 Message-Id: <20200409211529.5269-11-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::444 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?utf-8?q?Philippe=5FMathieu-Daud=C3=A9?= , Riku Voipio , =?utf-8?q?Alex_Benn=C3=A9e?= , Laurent Vivier , Brice Goglin Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" In the original bug report long files names in Guix caused /proc/self/stat be truncated without the trailing ") " as specified in proc manpage which says: (2) comm %s The filename of the executable, in parentheses. This is visible whether or not the executable is swapped out. Additionally it should only be reporting the executable name rather than the full path. Fix both these failings while cleaning up the code to use GString to build up the reported values. As the whole function is cleaned up also adjust the white space to the current coding style. Message-ID: Reported-by: Brice Goglin Cc: Philippe_Mathieu-Daudé Signed-off-by: Alex Bennée --- linux-user/syscall.c | 43 +++++++++++++++++++------------------------ 1 file changed, 19 insertions(+), 24 deletions(-) -- 2.20.1 Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson diff --git a/linux-user/syscall.c b/linux-user/syscall.c index 6495ddc4cda..674f70e70a5 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -7295,34 +7295,29 @@ static int open_self_stat(void *cpu_env, int fd) { CPUState *cpu = env_cpu((CPUArchState *)cpu_env); TaskState *ts = cpu->opaque; - abi_ulong start_stack = ts->info->start_stack; + g_autoptr(GString) buf = g_string_new(NULL); int i; for (i = 0; i < 44; i++) { - char buf[128]; - int len; - uint64_t val = 0; - - if (i == 0) { - /* pid */ - val = getpid(); - snprintf(buf, sizeof(buf), "%"PRId64 " ", val); - } else if (i == 1) { - /* app name */ - snprintf(buf, sizeof(buf), "(%s) ", ts->bprm->argv[0]); - } else if (i == 27) { - /* stack bottom */ - val = start_stack; - snprintf(buf, sizeof(buf), "%"PRId64 " ", val); - } else { - /* for the rest, there is MasterCard */ - snprintf(buf, sizeof(buf), "0%c", i == 43 ? '\n' : ' '); - } + if (i == 0) { + /* pid */ + g_string_printf(buf, FMT_pid " ", getpid()); + } else if (i == 1) { + /* app name */ + gchar *bin = g_strrstr(ts->bprm->argv[0], "/"); + bin = bin ? bin + 1 : ts->bprm->argv[0]; + g_string_printf(buf, "(%.15s) ", bin); + } else if (i == 27) { + /* stack bottom */ + g_string_printf(buf, TARGET_ABI_FMT_ld " ", ts->info->start_stack); + } else { + /* for the rest, there is MasterCard */ + g_string_printf(buf, "0%c", i == 43 ? '\n' : ' '); + } - len = strlen(buf); - if (write(fd, buf, len) != len) { - return -1; - } + if (write(fd, buf->str, buf->len) != buf->len) { + return -1; + } } return 0; From patchwork Thu Apr 9 21:15:29 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 185326 Delivered-To: patch@linaro.org Received: by 2002:a92:de47:0:0:0:0:0 with SMTP id e7csp2321875ilr; Thu, 9 Apr 2020 14:19:00 -0700 (PDT) X-Google-Smtp-Source: APiQypIgeYqJdaeD9Z8ciFTeWi+s5M17KDVDAO1TcUagOwqz/7xNmLKg1pLIo8Rk4nr21SR7hFVE X-Received: by 2002:a37:b285:: with SMTP id b127mr928504qkf.292.1586467140041; Thu, 09 Apr 2020 14:19:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586467140; cv=none; d=google.com; s=arc-20160816; b=yGYfdo0O1dydG9KjdbtgKuGVlKSapnZIhNZdE3MmMleAJqIE1rLBNgVlYKqXu47r2L Ey6lcCpICXls53hjIIBoUyJok5cCnwv9lkfX6NAZBdhbXtxeyPHGKOa4YvmikE8hJhuI SM6Eq3u9kTU+1nQeIqGKkFt96pBTHho3XqylwMPl1frZBpWakr5ycXJMM29h9ipkUwfu hck5zHzxrD8Lwxv18zefRXPAjg9mORyDJ74hAEa4m4pPyOIQhGY9wKevhge1B+tAbkqi P6IayXnPsHfEiEGtSZWYpPu2cBe8VHjdfMxL1S/AXm2+rOt/NVgq4P6TO40q5edYzV/Q s4Hw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=NsgGnaK6H7tXZSUowxzbNGfoZoXPun4GYcBXJ76FIg0=; b=H4xdSOXXjVAvArU9mORoTmQyElwRMVl2vL8di3bE5JOGLVGy4WH6ighNkFodjzJmoO vZgg0JMes392Ddqsm+sKQqM7UFkaSoIEFz2U76aSpygKIPFZdSoMmLIlo0VpuUvGrla4 9NNLl+GBhKqSDt23KVTO3SfBpvTD1QfIVwlR8cLh1M6+Bl28BYLkVm3Qay3WPtQXLauy jYy4SmRgGduK1djz1XDBLiKov0bJ31LZQu5tnEVLQnJT5oB9BIS0YpQhFLisNl57vp1A GWKoy46XBf53sKNaY5T2TeGJ3A5HYm0I61Y0omJ++XE/MW899Be7A2blO9+Ap7WI21pl BdQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=iokV08AR; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id l15si6628004qtb.61.2020.04.09.14.18.59 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 09 Apr 2020 14:19:00 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=iokV08AR; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:55628 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeZf-0005qb-FX for patch@linaro.org; Thu, 09 Apr 2020 17:18:59 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:42413) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jMeWZ-0002G5-GQ for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:48 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jMeWY-0005rQ-9n for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:47 -0400 Received: from mail-wr1-x433.google.com ([2a00:1450:4864:20::433]:47076) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jMeWY-0005qa-46 for qemu-devel@nongnu.org; Thu, 09 Apr 2020 17:15:46 -0400 Received: by mail-wr1-x433.google.com with SMTP id f13so7119786wrm.13 for ; Thu, 09 Apr 2020 14:15:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=NsgGnaK6H7tXZSUowxzbNGfoZoXPun4GYcBXJ76FIg0=; b=iokV08ARsSiWllJ9cOA3WSv7O7YlPfESa/gnZ4Jr2a14wQsD5Mju2H6CgmQnJwU2iW b5zuJTJk7+PJ137KF9mgQ1QQhiReONIFhcd/iCVjQRLo9kWeyYw+6HurYjHLvHofSGPc af6EnETKMHmGLkZZwDEKxtC/e0E+lUCAKM465sZhnde7FZ4H/gRHcWu2wXBllMxb97Am 22DzvRGM7sxdvoDUmwFIU2OTJF5vKzMMR0WoSYdKJj4r/D69Nc1c7b0pWjgJitgeqV6m lLK0/KiW0XEmmnpg1GNsffZbQiTykkj/xz408UGAOpXFFJzR5XaiuhgMukAKIWHgLkxn JMfw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=NsgGnaK6H7tXZSUowxzbNGfoZoXPun4GYcBXJ76FIg0=; b=fOtwgNaBosP5xHT00ghex701f6s1qAh1UyQ7DtJFvqs4r8rKWfFoybs3vxQ28zRPDZ VFHVvHqiVzRKLqSZs7jYEmCJZwyxD45zpgVeZRcHDQ8Rf9Ay41TJGJ4Xh/AC7w8BP0Qv 7pYezF3/ejpEpGPuuNLJ7uB4SasO2+nqEXeasAgFQImjbtnxA36tyqFCD6jTkbpQcqts WXl3FiqAEMQPPTwBCGPodXykuN7vCEv4fMrVVMnB2J142xhMHBltIHaPhuGRQqnzBoZ8 czSCc9PIYVUF9sLAWrc3FXHLMFx6ikWUPmlxKkue9evDemQSMHG9viVlb4nD44RsN+1e 7rmA== X-Gm-Message-State: AGi0PuarxtZFEeACruNd6L+r65bcXNn9M9r1jPw3tets3MqoBkGwY7JJ 7ImJOx5e2RFOTZRZxXMowGgr4w== X-Received: by 2002:adf:e94a:: with SMTP id m10mr1130808wrn.324.1586466945102; Thu, 09 Apr 2020 14:15:45 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id o9sm36693010wru.29.2020.04.09.14.15.35 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 09 Apr 2020 14:15:41 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 0FA191FF9A; Thu, 9 Apr 2020 22:15:31 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 11/11] .travis.yml: Build OSX 10.14 with Xcode 10.0 Date: Thu, 9 Apr 2020 22:15:29 +0100 Message-Id: <20200409211529.5269-12-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200409211529.5269-1-alex.bennee@linaro.org> References: <20200409211529.5269-1-alex.bennee@linaro.org> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::433 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?utf-8?q?Alex_Benn=C3=A9e?= , =?utf-8?q?Daniel_P_=2E_Berrang=C3=A9?= , Fam Zheng , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Philippe Mathieu-Daudé Travis recently made a change which generates various warnings such [*]: CC utils.o In file included from cs.c:11: In file included from /Library/Developer/CommandLineTools/SDKs/MacOSX10.14.sdk/usr/include/stdio.h:64: /Library/Developer/CommandLineTools/SDKs/MacOSX10.14.sdk/usr/include/_stdio.h:93:16: warning: pointer is missing a nullability type specifier (_Nonnull, _Nullable, or _Null_unspecified) [-Wnullability-completeness] unsigned char *_base; ^ /Library/Developer/CommandLineTools/SDKs/MacOSX10.14.sdk/usr/include/_stdio.h:93:16: note: insert '_Nullable' if the pointer may be null unsigned char *_base; ^ _Nullable We only aim to support MacOS 10.14 and 10.15. 10.14 comes with Xcode 10.0. These warnings are not emitted with this Xcode version, so switch back to it. [*] https://travis-ci.org/github/qemu/qemu/jobs/673000302#L1387 Reported-by: Daniel P. Berrangé Signed-off-by: Philippe Mathieu-Daudé Signed-off-by: Alex Bennée Message-Id: <20200409190618.7402-1-philmd@redhat.com> --- .travis.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) -- 2.20.1 diff --git a/.travis.yml b/.travis.yml index 2fd63eceaac..7c92206ea33 100644 --- a/.travis.yml +++ b/.travis.yml @@ -272,12 +272,12 @@ jobs: # MacOSX builds - cirrus.yml also tests some MacOS builds including latest Xcode - - name: "OSX Xcode 10.3" + - name: "OSX 10.14 (Xcode 10.0)" env: - BASE_CONFIG="--disable-docs --enable-tools" - CONFIG="--target-list=i386-softmmu,ppc-softmmu,ppc64-softmmu,m68k-softmmu,x86_64-softmmu" os: osx - osx_image: xcode10.3 + osx_image: xcode10 compiler: clang addons: homebrew: