From patchwork Tue Apr 14 20:06:15 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: 185445 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1834834ilf; Tue, 14 Apr 2020 13:10:45 -0700 (PDT) X-Google-Smtp-Source: APiQypKc/8KVC0FDNjhfRpozAl65lWkCtToZRLDsxcvvDJCXYAkJrsHxT2uFqyMi2kD+yioo++l8 X-Received: by 2002:ae9:ebc8:: with SMTP id b191mr21914694qkg.1.1586895045387; Tue, 14 Apr 2020 13:10:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895045; cv=none; d=google.com; s=arc-20160816; b=ekcpLZqdq+sSZ0QtDMPWtYzTUJCITwIH/OR7q6bhtKX+PXqaAgQOGr/yofo03Z+Z5S JU30LWNNW/5PvFY53avPdd2bc8jjhRBR6KHpQ0N2INgC8htmnYBbOH85l1A9HsDuU3Qa 0HO9KrYVtf4il9ZINyHdVj9bywIxGm3abAPSBzljNPFqyDif6sZJkg8QZ6oPpa67eeen uj2ciY3s+j2+RX6KdcoLEcFEqm13XBepvEWEyI7/Y3+PKJmCofHvhfPUs9/HdiqoF6SQ kfupABaVP66x2pwXRH6ekZpn2Kb8f5+8ZxOjSQT97gExd0+JEiKXG1uk3qWGzac2rb0W k5NQ== 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=TTjAvCpLg+iizZbAaS2I0hTe9cFREBgQw4ZC2om1lsY=; b=EkKwTxgNwSlRdrSK8qxcZ4PADEjST5IUkt6V25VLz+3Q4MsXqw/+eRdFQtBp4C1qil C40/XqaZTDtr17v/ny6Mo9W6IwbB1zRSHO7YP9dOPtS347ia2zMXGquoilyu/4vARCA/ RFWfg/oDQ+ckI8S86J7nLmnLlLYsF8xXQWkm/Zysczokj5lCopXQQke7GPHuXKi66l4P mePrDghlYg30dldCuTF1iPSdAqq96LonBBmJ5xdQTp7ZpE2GBOFM7Zf4mcmwN8SOWOjW OMgyzt2PcwkD940UNGrkJtLui7Ch6vZbqPeBZ9BwE/vWF+o1zxPd/2WA5wmEQCLAtMK6 gW/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=iUiaVCoC; 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 x21si6053872qta.215.2020.04.14.13.10.45 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:10:45 -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=iUiaVCoC; 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]:38430 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORtM-0004ec-TP for patch@linaro.org; Tue, 14 Apr 2020 16:10:44 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44457) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpR-0005wX-Kc for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:44 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpO-0005uI-OJ for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:41 -0400 Received: from mail-wm1-x332.google.com ([2a00:1450:4864:20::332]:55539) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpO-0005tx-De for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:38 -0400 Received: by mail-wm1-x332.google.com with SMTP id e26so14519014wmk.5 for ; Tue, 14 Apr 2020 13:06:38 -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=TTjAvCpLg+iizZbAaS2I0hTe9cFREBgQw4ZC2om1lsY=; b=iUiaVCoCUvH7jDIizaBqMbcIjps7k5eqfhxTzJpuBEy5sKbiWF1IA0g2u4wfaZ3tEe 0PsZkEvjj+P9N7b7tsV7LF6f7jwSJtzEp8FtJuAdaFOvzmJM6Zv8IeU6BwKaQvV0OnqM Pkniyxgu2vhsLV7FfBAcPwghj5tckuyOhhO5Z86CONclnxOwhL6dXGf5RlRPBQfIJOXI 6NcX2wkNT/x0gdsSTXvetkOSu6Z52ZFxtp5af9fkYhxyqcf7LbRmSB6k0DMec4vgwUsC qKP/roW0C6M2J0xBoZ4HLr8IBp0blz41kHoeN8rVEACG+O97QBhtVJCaLfNV566pOXyC cz8g== 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=TTjAvCpLg+iizZbAaS2I0hTe9cFREBgQw4ZC2om1lsY=; b=IZPSA/Pa8evmHCHo8tKOG5RG0Z9ViXobXhnFwQos05RcKUNHYdq6xQ/W7aaCgSX0Ek ewGIMD0PFrJf8gixtjrXcfPA7anGjaAtjZSl+XcRZbOucijEcHpkIwtVMiBvcwTRIX1T E+PVc+CSSM39dWxFVC/z3RS89U0q40XAV8wfKWeP+XWjoZRqaiF8U80MF2VDeuPgKSHs 9s0tvCN2CalSuG9qTrnixTTE9xwP+zqDcLfEhcUC27NxRXdO4JYkC5E1v40uPoSv1/vV Eh4pU2NJS/1kkLP/RYfi9FGWOJbe+EstMSdKuDyZ7nBTRl1M/h/fNZ0HUtPOyv34rpOB K/4w== X-Gm-Message-State: AGi0Pub7UNzVEoTEoB+Mm9qvfYK//WcAtq5tJuas4oKK5+mjgRSjp3Tt A5IKI4CZxHBBPSx4k209CceFuUDXbdI= X-Received: by 2002:a7b:c3c5:: with SMTP id t5mr1412623wmj.80.1586894796837; Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id k8sm18465750wrm.52.2020.04.14.13.06.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:32 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 87DB21FF87; Tue, 14 Apr 2020 21:06:31 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 01/17] linux-user: completely re-write init_guest_space Date: Tue, 14 Apr 2020 21:06:15 +0100 Message-Id: <20200414200631.12799-2-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::332 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 v4 - whitespace fix --- 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..ce902f5132a 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 66901f39cc5..8fb448f0bf0 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 Tue Apr 14 20:06:16 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: 185438 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1831707ilf; Tue, 14 Apr 2020 13:07:34 -0700 (PDT) X-Google-Smtp-Source: APiQypIx6BCKKIWxUncZbGz4dSw5oo0ftWgbUdQmK/HC4u4iSUOYmzmuAEHESwXVCliEpBa0b8DS X-Received: by 2002:ac8:748b:: with SMTP id v11mr5841052qtq.238.1586894854323; Tue, 14 Apr 2020 13:07:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894854; cv=none; d=google.com; s=arc-20160816; b=p3WzioWkPAQUokk/6IVhYoc5GU7tPESFpk+TAs8aT+WQT3gq27UadylL16ZU2dciWd 2kWoyvQFQoppELdMASn16FGkG6JC5onfeeHzfTr8t0melzssrzMdLoVX5zrNsTv6i/C6 Ahh0NDaSfQIie/wcW5ug1CDPgg9RtDBWy6UmdPZ5RfYxpSy8hG95bhLm3qp7AqOhsdXi 8+mKmiE2WGpD1xsCgW2zbffRiFyVmVNYE2n5SVzRcQ0W0m+vmXl5hmlZBXiSh82mYjw1 lG3CDI05aSKBBRBqwjQgf5y6z7cY7FgBnQ+LjMgbD1uWziu87AdAQ+I64/p9DypdKH5P /GPw== 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=LyYH1vUOROUp+ALOi+AoU+6fL4aHHF4lo5SZlCQc25A=; b=BwDIFeND4doqkop9Q+KQSxARwKoMThC/T8i6wy6EdpxeLkO1LoTym9d9vJripNtzq3 oA32XW84zQrl+zrkbKa7Rsd53NHv8aknfIiw5FWj4TrXPnVd0sMZeDP1iHvQZQTutGvd zll6FkD44P5fhhYrqdYeuoZyl535bhfoelV2gW0zXQvTwauuzAcPDVHaF6ggBGe062Up Uu87G16goSDXjK/HW0czNny/LFpHCKNjoMr0/gdxNkSAgoCHjho/md9A96EHtufuG+c1 O++jAAIPGgva/vM7wphvqHCQgiYOZ7QHZEwQNBJr/2cGzPdO8URYCgI2ozdlOvqrjBWN nFow== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=IvmSZCaf; 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 b11si8196452qvt.124.2020.04.14.13.07.34 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:07:34 -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=IvmSZCaf; 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]:38274 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORqH-0005tN-Q7 for patch@linaro.org; Tue, 14 Apr 2020 16:07:33 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44422) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpN-0005t7-Ft for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:38 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpM-0005tB-5K for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:37 -0400 Received: from mail-wm1-x341.google.com ([2a00:1450:4864:20::341]:53853) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpL-0005si-RP for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:36 -0400 Received: by mail-wm1-x341.google.com with SMTP id d77so14502776wmd.3 for ; Tue, 14 Apr 2020 13:06: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=LyYH1vUOROUp+ALOi+AoU+6fL4aHHF4lo5SZlCQc25A=; b=IvmSZCaf0yjtZb0gsBQFlbhTvILOEfY9/Da4cG8YJArjhfh8PFu+VvvGPNwWFmXngu nUAqz6JWGDzYetx0BdIs/hktD5qPK7yIJAPWw7Ym83EBvpgOBGH38W8400kKl46oFxud eJYdz5OGnaPSNiRcwtOVhH4VRa60dvbzommM1bJeEDfyfu7IMSTBmNKl+R0NSBesAo1/ VgSjf+giw6lzor5Kl4UcXufBev1A9diGflZkZRMu4ujfcuoofgum6dCM6Cfj3jGXm3vN 8C0fqeuBCWXqJQXnOeu3wRc04LkEY/eA83ae0z/xfFopbE3QuK+Ox6ylyPdcFNPx0zul Zy+Q== 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=LyYH1vUOROUp+ALOi+AoU+6fL4aHHF4lo5SZlCQc25A=; b=jcL7ZmFofyWNn+OwNkuFmqNW/sIXhSE93CAqrt4VPN/v9lcvjGslQzn8aqOQSehEd6 38CT1N6REJkKJ7aiZqGlw0wqTU1gRmHkTfmWIShe3pt3a+89YUsi9kovpM8rIJ1Mclha inkCepg4DfL1kN8YHkGVT7dHUrHTYZFQeXkZqgcegjwLlJhYYHojxfR3kz8R1aFYIQuw ZvPJXlg3KyP+JyXssFuY0wLiEsG+2K8s3PapZSrAcswgjhqqj1YWwuEH0IdLHNyPSXiF iGld4r52mRTih8WxloO71b0xNjUJhHFyliwl8wmfExq3LJwtsC022QgMGtzbmD3nHr6k W1Vw== X-Gm-Message-State: AGi0PuaFdMTYtkY8D83R83fKqBc2CExRANRW5WbDRcK73cYojPDqFHug 44JBse8hnx+Y3zeKPFEtAEUDFQ== X-Received: by 2002:a1c:7ed7:: with SMTP id z206mr1406655wmc.64.1586894794435; Tue, 14 Apr 2020 13:06:34 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id u30sm22636wru.13.2020.04.14.13.06.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:32 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id AE2271FF8C; Tue, 14 Apr 2020 21:06:31 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 02/17] exec/cpu-all: Use bool for have_guest_base Date: Tue, 14 Apr 2020 21:06:16 +0100 Message-Id: <20200414200631.12799-3-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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: =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= , 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 Reviewed-by: Philippe Mathieu-Daudé --- 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 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 Tue Apr 14 20:06:17 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: 185441 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1833155ilf; Tue, 14 Apr 2020 13:09:01 -0700 (PDT) X-Google-Smtp-Source: APiQypLG99tOT0X7v6l4tVyCRJUR43ODTbv/Aaa0L//wBt9cvAxTV9lcIi9InEQ9bivvLUuNHQUZ X-Received: by 2002:ac8:6642:: with SMTP id j2mr65419qtp.311.1586894941564; Tue, 14 Apr 2020 13:09:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894941; cv=none; d=google.com; s=arc-20160816; b=TprEAiGRv2vHuLe7W0sQ9LoECrz+jdQBxjauIxOvjyxisSmLWgiPj2YeLibLU+M4BG LtkVUOVc16qmtyiKdCb311BGP/C7TG2MZP7tACMhlPUqGON+/jeIHeW0eidIpVHyOBks A1xxgSrkY4Mr5wjtSiSgnaJ0zOKtmZRhDKx9cglxnEVt9x/0JiX3dPxt4D13tCuLTo6C tI5ftmRflPIDZZd/m7OHO2Gc1NI9cGlE0PcrDFhXp6uNStA+16wQ4zRi1bDMry+YHvcA QMtmjnVwM/FRm5MRqai6e/4sitO3XbOqPOjMMh4KdrJc2EQWGGUC8Nc4cpGgi/wevOS3 Ctcg== 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=wzu/OG9U35sHi+0BiHwq4WJg682OwSe6P/vrRAPloPjiKObZCA2JLf2aZf3uBRMLQx AFOznn/Tgh2cd9CJT4BSG2SjmHwEGm3YHmYSupJ4xsn+sdGLKt7+y725zR1adwMBHieG xCHOrNlyoyK3SMk2IBUmmV/X8oMlz7MciRAK58U5c8rvkjXi5/rGUjwm3EK4UUvbPBph 9T4sHPlVicd6jTrpckQH8Q2ivLNEagbFnjyVkeBCcd1/myqvmZI239tapQHygkgEzyyZ QVqNWMJVy1V5r7NTy72ypZZm25JNuV4n5NAySuTQqToAYvzhRWtWPYuxPkyawHQCzfDy TElQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=mjCsPmuo; 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 71si8347483qtb.177.2020.04.14.13.09.01 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:09:01 -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=mjCsPmuo; 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]:38376 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORrh-0000sa-0H for patch@linaro.org; Tue, 14 Apr 2020 16:09:01 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44444) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpQ-0005ut-R8 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:42 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpP-0005ue-GQ for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:40 -0400 Received: from mail-wr1-x443.google.com ([2a00:1450:4864:20::443]:42770) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpP-0005uF-AK for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:39 -0400 Received: by mail-wr1-x443.google.com with SMTP id j2so16014403wrs.9 for ; Tue, 14 Apr 2020 13:06: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=NOU8+nMEIGED2iJZhktWL6KnvYhctO6T5v6pR87w3Mo=; b=mjCsPmuoughxp2LFW8AqP6K9VjuIgM5qLtRrDGoyhOZ827z4tTBSm1EN6iMC/LrnUT SjW90UCu66krkF3TGUKx+Zqc/+AqSvmleQmIgr9MbU+S8OuvFkaywELX2NIwMWPESOJw RlyJrM3V8bZswbUY7JmLbDWaDYrTZxLaWk0PBPRONIvTqQt6WXvLLABXQDR63H/FNxwa NVaSaPEL9LBbPdeWSzWxvUyoLSrXljzGIo+TRLSmkS+AsQnP3k8Rs9wWwDJEUCWbA3uT +c1hNLk1x+BuzmXY4c3tQOdGODYc73xeeU3tZYM+6jD5sKCR5D+xXDrfWyia2T6Th6x3 c08Q== 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=NtOhGcTRaLcj9uQpmI1b0+vkYT/m0VEv9SdhzF6uyKH8Qb5g9rNoLWcUS1dR0d2E+x ODnwb3UuXeypHkQDAL0l4GJNrc6S2d6l/nKN8YCMX0QOH6MMNN+B4UF16f7QJYLwit2H ArwMhaH69OJsJfe5dPeUpmaC8MEQHgjd0XOtkeEwq4crnNP+zHXE86XO875J6M4XDn6E rQohsYddezZf4O+tXLI1ZmDhVipAnqjQ9X6kyLsvOx4fkTxT1OjExi2ePanieFOkXveM GtbBzDA/Aps3y+qTv6eFXF34x/YstHZlBMEkM/IUTY7v29iOHIBUiAXRYgDEpQKUHKvt LWGg== X-Gm-Message-State: AGi0PuYWQ3OfPm3pksZUebtFYKVvVT0oAewebAqLd+iZBYnFZ3f+Ew0e hzlzTVE6MpwjXvCipRJpLLoIGg== X-Received: by 2002:a5d:4404:: with SMTP id z4mr20300751wrq.316.1586894798275; Tue, 14 Apr 2020 13:06:38 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id v1sm15855007wrv.19.2020.04.14.13.06.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id E5C4E1FF8F; Tue, 14 Apr 2020 21:06:31 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 03/17] accel/tcg: Relax va restrictions on 64-bit guests Date: Tue, 14 Apr 2020 21:06:17 +0100 Message-Id: <20200414200631.12799-4-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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 Tue Apr 14 20:06:18 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: 185439 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1831762ilf; Tue, 14 Apr 2020 13:07:38 -0700 (PDT) X-Google-Smtp-Source: APiQypK9zEhKDbRmIxWbHk9/u6DpG7XzAgFLLNs5XCpQcI0FCt0nreZw5xGHqwWeQhneGoSXEZsk X-Received: by 2002:ad4:46e3:: with SMTP id h3mr1779718qvw.14.1586894858551; Tue, 14 Apr 2020 13:07:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894858; cv=none; d=google.com; s=arc-20160816; b=C5BD8cXHwXWeykTeO9AIKHvxkdBirRjy+geIRM620pSjn0UAIFQ+PNhOONzzPQCXq/ SHhw1+tPHUDXrcbuO1+F2QJTv2+DPf1lUrGeeCqVjNDtyD0xe/juCoM/0MUhtacvQW+P OcWS7pdkin6fPj3cACDFQ64AfRD1IbKK0MIWFFbCbMs8FsbQADFTVaAeNHMlDHWREzrV 5agPZ8SyKtQBunUlVF3Xm1JW2k+/Au4NjzEFqRh19kStCUslUN4R8vkwFoCzFVX8pG7f R4r/lReveHOgy2+a+0yGh5dODkHSwzUOM1K3ynhzI9gJiAV6W1/fsmjlxx4GGd6Ttr28 LCtA== 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=9ptCwd/BWCtSQi+ZJyFjq9rFc58i3OUw5zJJkXD91Vg=; b=XdXBrn0fybNMr1Kj/xvdKbn03FwsmBdJ4+GecuF8Ip5ZsCacDWiejnrn6CMSq8xYoe F4qLXIiO+qmNdsjgFSbQuPcLxYX+sbSWlD5+G23OGTeJg0Q1db2gY5WEiRUpLXbKVk5u ghCRP3FbClH3Yt1A5HwkP1Bf/Z4b8JF7R3mrk1D5FdyIMqVFJO5UfF1IjpJv2YuBEXdG kbK6hJCZSREjLYY/tvQ/o6pFmBgVfaWhF/LmC7QQqiWVE9p4r3VBO1/z7ntRslht8leK hjYOlIiUA0VxqrJ4hgkVXZEMuaYUx68JPaR0m6zBlLLe7FOwKiweeinqqpQufd/hF2Cb 38aQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=a4IWk+DZ; 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 x2si8040185qtr.400.2020.04.14.13.07.38 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:07:38 -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=a4IWk+DZ; 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]:38294 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORqM-00060p-1D for patch@linaro.org; Tue, 14 Apr 2020 16:07:38 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44460) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpR-0005wm-O1 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:42 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpQ-0005vD-Rh for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:41 -0400 Received: from mail-wm1-x329.google.com ([2a00:1450:4864:20::329]:55531) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpQ-0005uo-LI for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:40 -0400 Received: by mail-wm1-x329.google.com with SMTP id e26so14519210wmk.5 for ; Tue, 14 Apr 2020 13:06: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=9ptCwd/BWCtSQi+ZJyFjq9rFc58i3OUw5zJJkXD91Vg=; b=a4IWk+DZy2PglXYjno1snkpgc3RTKB4rcida2gYlPyIullfzGuxZgTgIv2yjAvnmpu gCea0wLVCVG2BXjPJ0asCN73JynyDO5Z25ZtA9egGHRkwD0x/Bw8fhKxJyoCuB3KfOO9 CuFtIq/D9aClq//VrRHrP61k/JAA90LMzICpGBP697qfWPHVbZngxeS9o777bUVj0Rwx fGt/CrvfdWG2n2DRoJ445ZuEteXOAzcc7G1JJ6GiP7RjHBSxqTTtxn53xtdYDQ3jZv8d 2VZuIH46vZ4Y2WgvMlTUS6ercjmXmtY9PTWA3EUG67Z+5n6I0zI0qTTby296cIL8jusf a6cg== 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=9ptCwd/BWCtSQi+ZJyFjq9rFc58i3OUw5zJJkXD91Vg=; b=f3SLgxBjGqidFv6vBaUNDsrICiHR5ooMyaoGBaA4vBDIoNzm7uXJY4dkDPPD+gUveL qUQ8wE0t22BlasVfp6vQPFa9DnjCQUzrOYj3m70+YY5OpAAqRusXyhVPcd62OpQzqCHG Ddi7aIt5Kbl0VziEhTaU+pDZaA42FhVIPxPnoRYKN9Y7o+B9bSk607gp+beA3q9dqEBh 0uZWB4OEJ80VrkqpqFuhdxBox/BSMze6ttOCtKp22V24GDLlWR/rBZKZkGHR7tC/S/qu aP33THDtPPZeqxSHhySF3FSQyzihjMzqHiEeTrNz4puq7zV7ru2GyAhjxAD/ajAsYuHO 7ZAg== X-Gm-Message-State: AGi0PuZ6o9vhkoYgzgzZSUPnjfU7mDMLXovD6nlG3KMvvAi7tbennlkt P/df55MS6Ft2YFJlLeL2eAPaCHfTgdw= X-Received: by 2002:a1c:a553:: with SMTP id o80mr1627354wme.154.1586894799652; Tue, 14 Apr 2020 13:06:39 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id q4sm21416156wmj.1.2020.04.14.13.06.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 173811FF90; Tue, 14 Apr 2020 21:06:32 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 04/17] .gitignore: include common build sub-directories Date: Tue, 14 Apr 2020 21:06:18 +0100 Message-Id: <20200414200631.12799-5-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::329 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?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" As out-of-tree builds become more common (or rather building in a subdir) we can add a lot of load to "git ls-files" as it hunts down sub-directories that are irrelevant to the source tree. This is especially annoying if you have a prompt that attempts to summarise the current git status on command completion. Signed-off-by: Alex Bennée Reviewed-by: Eric Blake Reviewed-by: Philippe Mathieu-Daudé --- v2 - use build*/ to capture build and it's variants --- .gitignore | 1 + 1 file changed, 1 insertion(+) -- 2.20.1 diff --git a/.gitignore b/.gitignore index 0c5af83aa74..8dccb61a44e 100644 --- a/.gitignore +++ b/.gitignore @@ -141,6 +141,7 @@ cscope.* tags TAGS docker-src.* +build*/ *~ *.ast_raw *.depend_raw From patchwork Tue Apr 14 20:06: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: 185447 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1837762ilf; Tue, 14 Apr 2020 13:13:51 -0700 (PDT) X-Google-Smtp-Source: APiQypJNqZXH46i78SNl3BcfPs6tdu9/DmE+ZZKqMXnuItHVqKj/CjQdvgldb91RdrfRCoRRjX1o X-Received: by 2002:ac8:528d:: with SMTP id s13mr7908609qtn.160.1586895231228; Tue, 14 Apr 2020 13:13:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895231; cv=none; d=google.com; s=arc-20160816; b=LtY9fdWXZEUh8M+LgNH7V6IwT4wIRF7/EIb9piPmS0/51DMg427IDMjRc7luENvTAE YsdRzTjx4+vI7YBGpCEDdMB+z8UAHnN6uox8e2Ig1Aqv6ReLBiBCQJTLGWKwtL68vqZ/ GtqyH68hRM3MO05uVJ9WpBBNRhySrivqdQQlj8oaX15B+RvBS249brDdK6g/Maub51XP kT0n7A6dFPQNZA7SGKKrVDK/yAr+D58cr+z2Y6FiSaZ7hzaZj304Ff2RON8qn9aw9Ion DwHe3pPwEbtQhEY4x3xnUUNxqHC1tpuaGTAkjeGfY5CrNmHGwL0+v4PbA0/jU9umSzIN ArMQ== 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=xB6V3ABxp9YU0UYxtl8uOcAgDS3Er/bVqvGQrZsGlPV5grIZpJ66VyzHxnJajU/Hj+ xUCqjreIYmXvPWn1OVONPbSRYwu4f+kbsT/sQs2V1GASIoWlLz599ZOtROsqrkJvqvKn iPgAAGoFUrM8+53arFxKHU5gxCZT8f/s6W3bzfrNJ9EiZX3/nDjGR+xJvV1M4y2w15PA 6iAqHz/hKcbrVlahLpaDKwykDlMAhw8CGjc/z1+1haJqMTWf6rfIM6MzHljBz8Lx5W37 ZV1z1ctZNmeeFbNt+UWSU8xVvOHmaRS1nu1Lob3luwQGk5lhjf8c143K5saGloMxOyBY Wi9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=A7BCqQq3; 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 n82si8673799qkn.80.2020.04.14.13.13.51 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:13:51 -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=A7BCqQq3; 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]:38494 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORwM-0000MO-P8 for patch@linaro.org; Tue, 14 Apr 2020 16:13:50 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44492) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpU-000617-Kp for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:46 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpT-0005wW-6u for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:44 -0400 Received: from mail-wm1-x341.google.com ([2a00:1450:4864:20::341]:39755) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpT-0005wK-0U for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:43 -0400 Received: by mail-wm1-x341.google.com with SMTP id y24so15737876wma.4 for ; Tue, 14 Apr 2020 13:06: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=en3XxeI0kUhj1g+8oDCU8qm2/eo411eCLElDQvibSv4=; b=A7BCqQq3N+Wg72bkKjkAjNpf8sRBALo3rR1DHkl0MeO1HpWECTMdvIR4BgVqeLVY2M S9/ZFG2WHFHiaQ+rBEUzzd/H4jjOboS5wq/nAgDZSNXzeAziS/Cd/PMq+LQMd/mJVh9u vk1LBwC20ovfwekRoiMuYt85RGZ9tlsbo2x/zu/NbnMIvFy3Bb3GbFPw8O+oWuKfyjLY JpqAH2gv2efRDNNvdTa4C/dSyJ8auSM3qhFSdZC3qeXQLGs/WkIh4lJsrobSENQvB0uG ZQDuHxL5CJdCT5pSddpvx1I4UJlCUiWC1RHIfM9TKPvnaP03E2pW/AKIPfUy/FyVuyf0 Hxww== 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=WruGjUiYP/De4EYNKY+Z8CVLfm/r3dDmE6VMxMUyOXGIIy1L/f4pCMVI1dHRiVosEI Z2hWuXcKx2D2A+JOUaVZZRrrwFPO5AkUBQOZqCJTxMeZTvr/+tdbxIcNQKT+hzEb2D02 yM4k4idjqa8VPBTyDHaipv0cCsRU8awwVbyzlqtRnjSzhQ25Or54rd2Lpwyy8t6BToxT 35iVQD4vTseJ2mshUqFBMHsB8lYg0Ax2uhYHgyGEo6DaI0ruP616ikjFU5nkbnQFUZZh HDGlSSdmLG9ImCq3IJdJ5Z5gqQkM9gRmhmzn2yFRdNvSZlS0qeqyFft4pFEpKy5Tk9Ot FBzA== X-Gm-Message-State: AGi0PuZNWgRfNlr7Qg8Y1s2I4x8GDBs7GC2uhoqLLYwD2O0URkbs65Ew f+vgT0WMmwyqkf2rjtASylG+mA== X-Received: by 2002:a1c:e187:: with SMTP id y129mr1574429wmg.133.1586894802006; Tue, 14 Apr 2020 13:06:42 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id y9sm19405924wmm.26.2020.04.14.13.06.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 3AD241FF91; Tue, 14 Apr 2020 21:06:32 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 05/17] linux-user/ppc: Fix padding in mcontext_t for ppc64 Date: Tue, 14 Apr 2020 21:06:19 +0100 Message-Id: <20200414200631.12799-6-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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: =?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 Tue Apr 14 20:06: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: 185446 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1835618ilf; Tue, 14 Apr 2020 13:11:40 -0700 (PDT) X-Google-Smtp-Source: APiQypKwB40VT4uo+Zk9NeYb6VctJx4sYWc3LSxKBl1aluKHeLtRNo5L6dUzQqS7s/MzN2A+UF1M X-Received: by 2002:a37:61cf:: with SMTP id v198mr21658561qkb.485.1586895100038; Tue, 14 Apr 2020 13:11:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895100; cv=none; d=google.com; s=arc-20160816; b=PGhlmdLESHdlpiZnK+nm9CD/RhBLgRZCAaVwKTKGzrubWe9aCz4NaxxBuPaJbUuqzB EisoXc09p7MzMUz3qx8v8QxR1bB/DkP5hHxNC33zbRQHTdQSgIpQ/+faubpKsTXNiGJB /xEiWI82gvIqmsxPWeTmMji4OmKOx54iZkBP4mygLwEmLCkVaCsHKyNXqi4WXn1MZQss y6xA6bP0dR8cHCJlnF8z1WWxIFevq8YSBmjVQz93VcTipUjE1kGvPuZNmdhOTjACNPE7 oCdBqgXOIkFvgImRW4IHAjzQaZWtLEqUJ1OJa1rqan6jLnpv/JYMZpDIHUDVSvTf92vY BRfw== 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=MKNqRiBPCPZs1Nb8xQ+iMkO9ECJezVjcKyg7f8B8t6U=; b=P2BsNuUfxR+V20RD01EEFY7kRPYRDkf4AKhdT117sxrIImn71FYxWyUOhyWBbHtWPK ZR66/oSRCsAKfbEBQRwm/C6/R4LmyEN93NitjgFPvdUhZvRezmtx6RkpaVvaSZdBssvx UbtiMknexVTmWxfb9YssqefL0zVifpm/8bZNEAwC5vXFVfc5L323urJTSSsiTtsgL+YV 8TKXh0q8gdprQOWrD2eJlWKNcscrPvC8WuVrp75bwEL4V8DjLBrmhK2U+hYwnwxtn0ca 0+6db0qVlXUlWTPeRQZVHIg3Ykk6xG7yWBotCKnVz31kN20Siy6sTbI9CJJKE2mvpLUZ LZAg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b="l5x/H0Fz"; 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 w70si8981102qkb.180.2020.04.14.13.11.39 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:11:40 -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="l5x/H0Fz"; 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]:38480 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORuF-0006zC-Js for patch@linaro.org; Tue, 14 Apr 2020 16:11:39 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44478) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpT-0005zL-QN for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:45 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpS-0005w7-8Z for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:43 -0400 Received: from mail-wm1-x330.google.com ([2a00:1450:4864:20::330]:50380) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpS-0005vX-23 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:42 -0400 Received: by mail-wm1-x330.google.com with SMTP id x25so14524468wmc.0 for ; Tue, 14 Apr 2020 13:06: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=MKNqRiBPCPZs1Nb8xQ+iMkO9ECJezVjcKyg7f8B8t6U=; b=l5x/H0FzNGEL47GRnzCGTQS6UHX8GrWNGh8RgaP/OSqthAsQt7FUL+Hfr1dMv6rWEO EZ6+Zc/5uKFNU6G9VKyq7C8cFPZ8SWm8jkjAqU8wLI+/JR02HjKCjLqFN1avOR/W+dAa S3gh/De7w+cjua5rPeZloCg0DrNKMKjTnuUStGSaQJTqOuM+e8W4hx7NvHJ9wAnyCXBu Bm2aZgY16Kz1RcCv2QTbsDTYt8jvz6szJmH1DjfdlxWLDvOfvcPVtmr+nJunHvDZz+Iq ydEEZFe2DjuSsRq2K8cnzdx0EK5gAa0MwggbZRSTT59Jor6eUbK/A6tYu8h7Ph1dF9Zm 0sNg== 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=MKNqRiBPCPZs1Nb8xQ+iMkO9ECJezVjcKyg7f8B8t6U=; b=TAQumhpec74LCIGG2g4AWKX9B+dFBzcW8du7CDjRUToJubtPVxB60bhP4h6wvVG2JJ A4H1BU58GhBP56STc+CDdAB3p9W2Q+GI6avZxTUq5ibj/BtnsrzQ6MWOvHZK/KQuTmBo nOAL+sRkaG10cRxRMVPWf8+VNyi8dPd+CFMrrLApcRK+rH+URnGK+JB7ZoXGPr07xGkC FSW8oh5LgYDprQP4h+rQNPGgOrZLjY1aJdrBD/F677LOkdCj9hJwTuZsosfU4rkTeVor 5+bFdudDlp9APEiP23K14VywEPX5sr2tvWo517I0kmZdKqsna8/ocB2jF/2Jct5KVmyi fFQg== X-Gm-Message-State: AGi0PubNMiYbuohRkz5AYUShKXE3MjJ36g3j4QiqKaXugr7TQNf0Tq2K 8pJW69oaG7v9iy+TTfDHf0pUYlVHlGg= X-Received: by 2002:a1c:e242:: with SMTP id z63mr1586134wmg.72.1586894800990; Tue, 14 Apr 2020 13:06:40 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id q8sm19482844wmg.22.2020.04.14.13.06.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 85FC81FF92; Tue, 14 Apr 2020 21:06:32 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 06/17] tests/docker: add docs FEATURE flag and use for test-misc Date: Tue, 14 Apr 2020 21:06:20 +0100 Message-Id: <20200414200631.12799-7-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::330 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?= , Richard Henderson , =?utf-8?q?Alex_Benn?= =?utf-8?b?w6ll?= 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 Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson --- 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 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 Tue Apr 14 20:06: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: 185437 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1831370ilf; Tue, 14 Apr 2020 13:07:12 -0700 (PDT) X-Google-Smtp-Source: APiQypKt+lMISRkKVdTfFq0E1IJNJnSbLj4dl824ivYr9iKPZD1MsYomFjVyoTWr1pOneuakfjZR X-Received: by 2002:a37:5c46:: with SMTP id q67mr11764859qkb.210.1586894832621; Tue, 14 Apr 2020 13:07:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894832; cv=none; d=google.com; s=arc-20160816; b=o05L6VQMi0OUu6kPACAsbJdlbpKGBQkI1vfVM4ncgnT5PA4VMZW9bPkcHxfpe+bt8M ablwXH60JwHk7rXneAKQBdsivHvJKy3/WsC9jR3eEJaW1syQhwtu/hSsALF7++s8HKp1 PI1Nd+lgtcSdEJwgepANA2L4OetElWPLr3SvnvTOLtVeYWjt00CVm3+GHL8c603T4iCq 2imb7tovGtNom2Fz7tNbh1qGRuWezJLCLnO9YfPrb3vv7tdJQzG0o3Cn5bdDYlcWcXPW uKpz7jt1d8jWEiReuTidODJv5T+hy8xKJfFVjHKCkcFZYCuzmr3n6bEyn063Guftd1i1 eiFQ== 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=Stc4FSJiUzlY3FsuzLYHemmHJ45cRRBL4YVh1lfAAYo=; b=gDIrMIUMH6blMkJhWnvxZYgUE+5teN3+oafuuOHLhZQR8Xdxl6GoTcITFGmsguoJXZ L5R1PqiI9dOB9MMOVBSXEU2xoy55bnM5S7d9AUP9n2A9tgqeqICoeiYsosdere9Jc3l/ t0rWXXrWCnPNeoM0rwfw+XjLardtPao6oy7r8EGx3/1o34l0O8LDm8BGy6+Vfav8uws3 fpDoacmAbkRheWRBH20lSQyJgQZgKkkxXMiArXC0U2gsSRWI3ilRsDMstmwuEllz62c4 oUKeogyASPOFnL9/guZ2O+cgNSqw5dgZYdc82M3slBxQ8Qmnky1oZBK5rhABN1eiyyg4 59mw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=W8jcJe78; 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 k10si4479748qvq.24.2020.04.14.13.07.12 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:07:12 -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=W8jcJe78; 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]:38316 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpv-00068X-WD for patch@linaro.org; Tue, 14 Apr 2020 16:07:12 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44510) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpV-00062m-NP for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:46 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpU-0005x1-LP for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:45 -0400 Received: from mail-wm1-x32b.google.com ([2a00:1450:4864:20::32b]:35777) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpU-0005wl-FG for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:44 -0400 Received: by mail-wm1-x32b.google.com with SMTP id r26so15788406wmh.0 for ; Tue, 14 Apr 2020 13:06: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=Stc4FSJiUzlY3FsuzLYHemmHJ45cRRBL4YVh1lfAAYo=; b=W8jcJe78mqjkvE6H+bdu8ofUq0cSwVmy6RU/hV5ucrYJUQjdhYExE1UkzzL8C6U4lk ORctGtC8la1fk29F9VFeOX8DNakh0o/HgD5vjlU2FAQdLBKyugjZfjGpsQbJsZ08Xkqy 9pT5FOgez7s6W3ozydc5zEadWEAL8gDTKkfLjqOrHildDpNZwYGTe6yA1WOQ4ee02DpJ 52YqE/KjUog3hMh9vttq+wRR4y4osAfxMksh0Ad98YVUL54tNLAA+Vc9d3839lOPgugp Tuj1R/MtvGLC2mHqO9d9gFvIx6bldpKB46hwORedIazkKNJS8HnolFykJ+NknNgNWlDQ k62w== 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=Stc4FSJiUzlY3FsuzLYHemmHJ45cRRBL4YVh1lfAAYo=; b=aNdQ7X6dUZGSjuqX9qOimVTGbUSilZjNgf7gTEM86/TYR37EpjrL25HcemldhapMk9 G7u+wTvK2931JMjDn+0K8ECAu5ax5OkY3hNnUjctHfely4UBAjTrIqXjdQ7b7Ddu4pBM eq3asBhnGwnj3qFy7oHQ5LWRQ7tVwuGFkHyZbJzE5PdpdBMCZ84MdMtOaHA9L2r2V2yO /Ef2LEjCW4iKxL/Fb2wF8zxcWvfXXpxLyQfnZ+V7eiCfUWfZ5jg7n9n3LM3e68B8YeSK LkjqPV+mlNaR8hYlPLSMx82bV6+Qo7+lE0BtevTv6O5Yo3BoifnNg627pNNddO14afqy 52HA== X-Gm-Message-State: AGi0PuZT7wy8Xqow7uwXGq1v7Tlr2VG543cIBnCYutukZJYH3Jd4csey 1u4e8EoIgiJ1FSbq2ALjwQMH56RnTLI= X-Received: by 2002:a1c:41d7:: with SMTP id o206mr1506122wma.89.1586894803480; Tue, 14 Apr 2020 13:06:43 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id y20sm21130075wra.79.2020.04.14.13.06.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id AA7FC1FF93; Tue, 14 Apr 2020 21:06:32 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 07/17] configure: redirect sphinx-build check to config.log Date: Tue, 14 Apr 2020 21:06:21 +0100 Message-Id: <20200414200631.12799-8-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::32b 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_Mathieu-Daud=C3=A9?= , Richard Henderson , =?utf-8?q?Alex_Benn?= =?utf-8?b?w6ll?= 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 Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson --- configure | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) -- 2.20.1 diff --git a/configure b/configure index 9b1f5b33e45..25f7d915720 100755 --- a/configure +++ b/configure @@ -4942,7 +4942,9 @@ 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" $sphinx_werror -c "$source_path/docs" -b html "$TMPDIR1/sphinx" "$TMPDIR1/sphinx/out" >/dev/null 2>&1 + "$sphinx_build" $sphinx_werror -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 Tue Apr 14 20:06: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: 185442 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1833196ilf; Tue, 14 Apr 2020 13:09:03 -0700 (PDT) X-Google-Smtp-Source: APiQypL4/ZiYHcfrlY2cPqx/XKD38cK2Otkqel0UT0V4WV+XkOKjQJLlqfr9VdhZ5kp5CNTBete1 X-Received: by 2002:a05:6214:8d3:: with SMTP id da19mr1768967qvb.49.1586894943728; Tue, 14 Apr 2020 13:09:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894943; cv=none; d=google.com; s=arc-20160816; b=FtQOh7c//fGwaLl85uQwKNKhPKZVJxffJkfTOOZFk3arh3IdHcfcrJVsXKiLyxqw1K z+Mjnrum0X/qou8GQnjDO5b+WKqVWCT/ziMrvT1gdTfAd/c3zbAIJfzWM7ZY5BHjc+jO +h3Ngqf5idjq8XU78/udzMhjtAh7ZEcvFsgHml2QSb535z5NdnemqC3HCHwSMJEG59tp lhMiW21U1BoqUzvH939cQHjZQrtkyBbO8uIxWmXSK9kVBUO7z3KX3NnJWFPKxmFWV84B hszmuLe0HIuC7I0vgKocxPR8Kw7+wTWKqOOGxwUTpIO2k2AdAfiiLVbn6vwda1oyGcWe YagA== 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=+FYvvrpeRy/LpnKiPLY9U4dRrQSytS7+4553ef7RHis=; b=VsWOCgaW31XrLx81aiktKKXLxR3+Rn3knr5q3CMoUsQWZKoa9cs5fVOxZa0l0DDhiH 5nUNtDohKd/jJI4nTYGMdz9F9bEnAb6GOnncl/WFzeZFGFpXp5br8n2+wQgj0MtHq2k/ 7wGp+TCeW1l5zh+wG1wTkCvnD66F8mezuzYP2guS1dQ4JmaSvS0VuXHIYjCc2WpArQQv DeK32R5AjD16WtwmR7XJZCc+TR7626CCpv0z+E8oxeQfdvL9I90Ki+lCEfVihw4QZRYE zbpXUGUqp8ynCmdHineyDmGIt/19KJdUGuwbLI5x0+eExyQcLKQIS7zq/yGbNgq01lr4 c2eQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=a5FhvHPS; 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 q14si3743670qkc.256.2020.04.14.13.09.03 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:09:03 -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=a5FhvHPS; 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]:38385 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORrj-00014b-8m for patch@linaro.org; Tue, 14 Apr 2020 16:09:03 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44522) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpW-00064A-KY for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:47 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpV-0005xT-MO for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:46 -0400 Received: from mail-wm1-x335.google.com ([2a00:1450:4864:20::335]:39582) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpV-0005x7-G5 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:45 -0400 Received: by mail-wm1-x335.google.com with SMTP id y24so15738120wma.4 for ; Tue, 14 Apr 2020 13:06:45 -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=+FYvvrpeRy/LpnKiPLY9U4dRrQSytS7+4553ef7RHis=; b=a5FhvHPSnbz49vwvqN6tg0HjcRVazxSCvzlxcb2fT5PfmNhJ01yiF/0YSJE9araXze g/JrrvOAHvsGA5RM7weOKqHY8eSwUN8vC/wSp4soJJJusOWVYvqlL7JvRoqfvFZiAVSM hxgK02WJa2TsSXm5ohzqopiTnj9wSxjL5qQUVC8FsEDk5ydc4MlSd+32NILb0tAPiBlT ULFOwAJGZlqaWETvzWI1QnkXqkenbUEhD7+sgauJxS9+NusEugSzburpKDpeStb+CE+1 SMTUQCJos1KABaGitA0Humma4cGqqQunPMmxsDIE9xFX/NCvXUaJVdRWv4K2MZ3NP5p7 SCBA== 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=+FYvvrpeRy/LpnKiPLY9U4dRrQSytS7+4553ef7RHis=; b=LEo9iI92Frapdjg4mz0foaJ+t007w9sWtaI+U9qADDDqKIQJTtB5+kUoYfvd3BbvjC NC8ZywYKwNn0lJbpkac5MakK6E8P/a9PgoYRGa8O0xJGAwlcacP/FnUg9TPJuocXx5GU giE++DlZM47JvGSllNixYBvg5YTH0rgrIOETZH0b41yG0Pneaxh7TKE2/KdOf26X3uCo f903qy1OWKaUTrwlkayvPNBlJrlzyt+taXwLaj53vmuLC9O67lR2tbrJtKGDEF4LTUq/ 8o0MivI2Qu4nJqfnN1ldmGxbrf7fDNGy/Jbb5rmV28IQkeSUyTEcQIQJe8gEz8p9sD4H REtQ== X-Gm-Message-State: AGi0PuaMwxb0SWlm2047rxiQyoT27y/eWwIFaqNtD6iERqFInlTxTu/U Q5N8+s8Pk/A7uDs2+wJ3ql2h5g== X-Received: by 2002:a1c:bc02:: with SMTP id m2mr1485187wmf.60.1586894804495; Tue, 14 Apr 2020 13:06:44 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id d133sm21285043wmc.27.2020.04.14.13.06.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:36 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id D53081FF96; Tue, 14 Apr 2020 21:06:32 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 08/17] configure: disable PIE for Windows builds Date: Tue, 14 Apr 2020 21:06:22 +0100 Message-Id: <20200414200631.12799-9-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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: Bug 1871798 <1871798@bugs.launchpad.net>, Richard Henderson , =?utf-8?q?Alex_Benn=C3=A9e?= , James Le Cuirot , Howard Spoelstra , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= 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. Fixes: d2cd29e30736 Fixes: https://bugs.launchpad.net/qemu/+bug/1871798 Cc: Bug 1871798 <1871798@bugs.launchpad.net> Signed-off-by: Alex Bennée Tested-by: Howard Spoelstra Tested-by: James Le Cuirot Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson --- configure | 1 + 1 file changed, 1 insertion(+) -- 2.20.1 diff --git a/configure b/configure index 25f7d915720..23b5e93752b 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 Tue Apr 14 20:06: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: 185443 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1833236ilf; Tue, 14 Apr 2020 13:09:06 -0700 (PDT) X-Google-Smtp-Source: APiQypLlgsGw24cK32HUuXkcL6nHfMOmuIHuCNElxesM+KFLH1UNgYdoPv0OysSzCTeqO55A2Vsi X-Received: by 2002:ac8:19dd:: with SMTP id s29mr12171000qtk.164.1586894946644; Tue, 14 Apr 2020 13:09:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894946; cv=none; d=google.com; s=arc-20160816; b=eTXjX1PXvLB+eXrjcxdc7V440/fGZxYnDQH5KHYICwjktBW8hFFqRQaVZLUgpFHxX4 ge/QItia+XnUTpTLeIbnGK6rRPobIgmVl68fZQG1RmQGIP3PVcgD6zU8ZZ8PGm43X4LN xtcLAeE4g8p0qzxf2vmHt6iplxigkrQQJiZrJpPfwRTuAEXI4Phzx4gSRwEzJ4NmP/hO fsQVP1oejoK/QU1RV7ApEXA6qWF5KgJ2MgnmkLDr5Saqyhn3OEwD3yv1/zlbIA8uXtAb PIh+HZQHRoFofdjQSVWmKwQFLJ3tGsQRun7DEQlL9ha5SezLHubr9tyin5jj4cGiRxkM idKw== 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=9Tb6fI3tVBkHUd/y7Zo+dSFehRr8QpWy7fD+f4ic+ig=; b=F0vJAt/Q0X95vZeCZ4rNu+uXFiLnE+ivIOA9FRn/Z0lox+3iINO0IMbYHtejOzIAKk qPZzsm+3RSRKqQTkGF3HN+w6FJOaoxkAEdXTaGbHXggc8kIWGpYbFl7135SipzKQU7nk j5w4z/4d90bIpJZ+QKFZHee1JbUZniP5NpTKQJZqGgTdynmEbcLzy518eCJgaDM1PEGu lTq74ogP5cHB5QVXuQ0kMy9HDhuwEuP0+7RoSToQd0h+dsJwW0dlY61xwVZSi1azLaRT dATRyT4+9InRBVx6GBYc3sm7m99lf8CCqIbyu56YTl411ltMgsVxCD776cfwR8dENFjp JBUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=wttuBit2; 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 g5si7997797qvs.207.2020.04.14.13.09.06 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:09:06 -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=wttuBit2; 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]:38388 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORrm-0001C3-3a for patch@linaro.org; Tue, 14 Apr 2020 16:09:06 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44564) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpa-0006BS-1h for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:53 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpY-0005z4-Ts for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:49 -0400 Received: from mail-wr1-x441.google.com ([2a00:1450:4864:20::441]:36153) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpY-0005yf-N6 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:48 -0400 Received: by mail-wr1-x441.google.com with SMTP id u13so15521559wrp.3 for ; Tue, 14 Apr 2020 13:06:48 -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=9Tb6fI3tVBkHUd/y7Zo+dSFehRr8QpWy7fD+f4ic+ig=; b=wttuBit2rudWSw4TCjpzebO7LSNobJFxOG3lmzE6092o9UW39mKyyA6MWVc90M9t41 gu/bsMymQ+RVAyJXqyb6BqIs1JzECzshdqlSo/EmFdM4Ktbt2H+Rjsp4DEWFCmFN92oB ko3wIVlQ/dMRRK7/eu0RN77b6UJVAkG3lWOw5vdZoQw6umLE41FaHlzcAstlCnNmzHw0 w7jjfu1L4gHmZMXgaAzRxuh+z+RcCRxV0sagbb9WhsbwxkQRrDi/8/xhE5dn71aD3gKj 2jWlZCoqYdoMfCXUiHWYPOglrUxB7EnQziqIhglIUuEJYz+zDhlc/IIAa/eP91eG6ill N8VA== 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=9Tb6fI3tVBkHUd/y7Zo+dSFehRr8QpWy7fD+f4ic+ig=; b=Ul21illD1mxwBWhwW3606Pm14XDCGxjhdGB59kB5F1TjwbOcBdVXh4aItD2Ke0cXbD kNQzt7T2uDlINqp1uGStNlZNcdAob14oS5kdwjP0DBomeQ9ykpaq+PjBbcQh6sVFKrFH HqqcT8yKw4Ht0ZOUnmp+N+REhniInN6UH/4+QjlPFA97N9MqOheOQDdBizAYXLjwLjpI 18jQzUFyHx64HtvXFt3ZR5sp4BXxZ+nMbUcaVwKzOuq+IOhquvf5K6J4yXm2tGeJI7sx WihOJvmcOnBhQYN3iWbfxURyCJ7iSQBcuOchBQKCjLIqa7dqmgR21PFRUw4oFv48kMmP ogjg== X-Gm-Message-State: AGi0Pub28TF2PuOgtzmX5HaaQQNzIikMiIIbVMBkCjpbm7qG788kKcu4 9oaLUHUEIjj51nO56CavYF5l/w== X-Received: by 2002:adf:d087:: with SMTP id y7mr4275303wrh.321.1586894807624; Tue, 14 Apr 2020 13:06:47 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id p10sm19781721wrm.6.2020.04.14.13.06.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:44 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 080751FF98; Tue, 14 Apr 2020 21:06:33 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 09/17] linux-user: fix /proc/self/stat handling Date: Tue, 14 Apr 2020 21:06:23 +0100 Message-Id: <20200414200631.12799-10-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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 , Brice Goglin , =?utf-8?q?Philippe_Mathieu-Daud?= =?utf-8?b?w6k=?= 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. In the kernel this is currently done by do_task_stat calling proc_task_name() which uses a structure limited by TASK_COMM_LEN (16). 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 Signed-off-by: Alex Bennée Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Richard Henderson --- linux-user/syscall.c | 43 +++++++++++++++++++------------------------ 1 file changed, 19 insertions(+), 24 deletions(-) -- 2.20.1 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 Tue Apr 14 20:06: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: 185440 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1832900ilf; Tue, 14 Apr 2020 13:08:45 -0700 (PDT) X-Google-Smtp-Source: APiQypJ/RVRW7TNKwv0hz/4I3+hZ9kbguqmaxonGfJLYQx8wRTtCi+W3b/bxoL26Q9NElPee0oYc X-Received: by 2002:ad4:5a01:: with SMTP id ei1mr1789218qvb.63.1586894925438; Tue, 14 Apr 2020 13:08:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586894925; cv=none; d=google.com; s=arc-20160816; b=ac78Bw21E/3YQl4/TWD/N+06Xmph+0+M/w+Fzgc/fKHvo+zdH4dP7hUvl7oIygecHQ LSBuSLSxfOliOQ4ax3zfL2zT+5xp4UWBOEoaODTY9ZhCnDy3+zLExrtIqminWh19/06J 7xEpTVa6EPhzf8yqTSAO4xe8pI/RWQ6lk0PTpVA8V0J6nZpDFYogXMN99gXINwXw7LZC WDjlv+4nrTjqebguiyReOoclhuVbyj5xKCBSRTb/alAhRRwlDRVja8zKYXnHFTAIcKU1 Tlv9q47H32UOsGj+BpUizolCcfmTX9EtfJifbG4LPQgVJS47Uiv7lyqAuM+3/6KKpatM 9zaA== 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=+h4qF34NYYCpNnzawIFaWBfnQi1AWYOeOfS8Oq1wtAU=; b=usVUx28G5ob7Eluyo9vb7OrCgnYhjvVV3uw1TgoDirptuHEhOXrdGn6RaVavQCKfIV 1cdV8ZCOk+RczkjWFOGkl0vwQzjUq/yoojR5RZO8PlLROIuRkuB2jDGdjn9TXl30NS/y UvdiVlQ1DHSStJQX5KqKbF6s1n4gBcBMQSvgOGv3sjhZ32d0c8KmOzqeTXDfx/YSKKNC uskiqeQaQI/I/Ft+0KbrCYoAzK6lkxU/zaBwU0hnJnJIAoLZhfvJn1tOe5R+LA6tpGjC 0wOcEJR6x2lreMywl10evP5xs1ac23nKhpECFqGD3dxU1cBAnSCXnr8W2qpBkkACmD9R 2kMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=f1fjPHNH; 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 q9si8637712qkn.374.2020.04.14.13.08.45 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:08:45 -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=f1fjPHNH; 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]:38392 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORrQ-0001CR-Rc for patch@linaro.org; Tue, 14 Apr 2020 16:08:44 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44595) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpe-0006Et-UW for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:56 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpd-00061w-Si for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:54 -0400 Received: from mail-wr1-x42c.google.com ([2a00:1450:4864:20::42c]:33193) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpc-0005zw-Dx for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:53 -0400 Received: by mail-wr1-x42c.google.com with SMTP id a25so16027305wrd.0 for ; Tue, 14 Apr 2020 13:06:51 -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=+h4qF34NYYCpNnzawIFaWBfnQi1AWYOeOfS8Oq1wtAU=; b=f1fjPHNHeO6rBOZGjTKY+PgSL6eLEcjGILOtdR0k3GHYzmpRjCOh56QA1C7sSz2pue KR8STw3ri3yZp/eM9FKs88g/KYL8FLhqckZFTcKsKRM04Dj2u4Ts5Vbg4CtVdgTqYFcn q6xQiKgP8wuSWcBV3gZ2u6sebhhFi2iRH2u48a2z1At46fwxCCZw2nH6+tOu/v+jSskn gLLyY77aOeZ2Tk0atiBGxUJ1hp6o92LLgEZEHL48ta9+MRdMDAyemjh31r7kXCR1JBm5 uXgtI0+y3WjVPKEGuLCHKaIYuZ8h6rjMxlVnnwmcvTeD43GhuKLna+mAPPQId3FYCLmL SS7A== 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=+h4qF34NYYCpNnzawIFaWBfnQi1AWYOeOfS8Oq1wtAU=; b=dAGujLH3RMEimKKgiTI9F+c9b1nLyqST/8ibTcjEyvPhHa1x6h93b0EtZnGQ89aFqf eaePwtZMcOfvu7FJStuQikkkNZaT0MwSy1swXl+krPEvlM43aHZGPvnQ1nksIOUnR/Tg UqPnoIqIRNM3oM6KjurLyhZBoRvIsnpElORUpFBTn4fYjlCJg569u0HjoAhPmL3QmUEx zkUwyvY0BZj9tY6Jdag5JV6c697WaYQ2eRqq8jisLvFlY/2XUQVLyl+lwRgaogKW7Jvc zZuTQtKr7Edz3dDW8khJqr1wblENdMFsNJcmYWm6sJ8+PtMyvz5M7qIyWco1Atky8PG5 jMZQ== X-Gm-Message-State: AGi0PuaLNYgJuzslCErzhduOqvNIw08Z4foiPYRIE+L7St5ncC4URqBz UJOFTJiZMG3AlefSik3qwoFg2A== X-Received: by 2002:adf:82b1:: with SMTP id 46mr18098277wrc.44.1586894810142; Tue, 14 Apr 2020 13:06:50 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id u16sm20153720wro.23.2020.04.14.13.06.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:44 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 2ABF91FF99; Tue, 14 Apr 2020 21:06:33 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 10/17] target/m68k/helper: Fix m68k_fpu_gdb_get_reg() use of GByteArray Date: Tue, 14 Apr 2020 21:06:24 +0100 Message-Id: <20200414200631.12799-11-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::42c 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?= , Richard Henderson , =?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 Reviewed-by: Richard Henderson Message-Id: <20200409172509.4078-1-philmd@redhat.com> --- target/m68k/helper.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) -- 2.20.1 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 Tue Apr 14 20:06: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: 185448 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1838759ilf; Tue, 14 Apr 2020 13:14:58 -0700 (PDT) X-Google-Smtp-Source: APiQypKqzyZtjPQaa7WlZEEtEA6akzGoAbSkQ9Dby/QdO5L151y7zLC469UtLqx8NxPrJwsXvdeU X-Received: by 2002:a05:6214:17c5:: with SMTP id cu5mr1668967qvb.135.1586895298302; Tue, 14 Apr 2020 13:14:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895298; cv=none; d=google.com; s=arc-20160816; b=tjDtHbViEIMuvAAGI+K/VOvW0nJOxOlEM+uYwYKxVW53zn4W7oByKysWsLwCmS+38L FXYZ/CsbhGERWR7FPtZ7nSZoCWkn7b6/bK1cW5ED52Iq8eiQQRf/Tby9fdV3H7YaO79a mSu67pDIm45CC7J/NdkwQxBBO+I4Ant/bcK6gQ4OQhiDyA44TRyJPVKraLBRYNcTcaHC gpK64D2pTRUHwb1nPZUMDSj6/WWgrGvrRY9OBRtCj6w4Em/9BFfCsTkNZyKhERDJlOzl q7ZQ0huGpn/d2S2Ymnf0zZnjgY0IKlX1LP7p7/IgaInTCf4uPN9+8KjJwDtw0fXTJYpC wOQA== 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=bPwQhRdvGibSgM9jwxm8brESu2WKcPxrBlyVkpOMlqE=; b=yYNmW2CSS9n0opIi8YPik4ogZFTDZqLOJEJKMryWcQhnu2lLpYgnKeDeJwQcrNA/7C fhHXMNxrhgD/35JEU/NW3jm8NfPss8dXDC1lVJ/UxRi2zPSz2FfYoou7EqEgtABxrCDr j3BPPOT29DCsfq34PKumDQkhuOcuSOM8v1fbqFHjGGwXtkrAQmwlgVQnfRvQm5qJI/fn inqRDGPWN6l97RnE3SAqqT11AWoicK1lt1dHZC8kiiBM5l9tnh3TgiouU9aWYS4D9xq/ d2bW5zaTDvXPdPPeyTvA5Gjo63ba5i48cjshwc/Qw0xu2eOOyx/31/uPAok/Wl72x9Uo ohcg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=ZHs6+T8P; 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 c9si8107760qtd.28.2020.04.14.13.14.58 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:14: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=ZHs6+T8P; 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]:38506 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORxR-0001Gd-Sw for patch@linaro.org; Tue, 14 Apr 2020 16:14:57 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44578) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpd-0006CK-LK for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:55 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpa-0005zn-4N for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:52 -0400 Received: from mail-wm1-x32e.google.com ([2a00:1450:4864:20::32e]:38787) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpZ-0005zK-UZ for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:50 -0400 Received: by mail-wm1-x32e.google.com with SMTP id g12so7907648wmh.3 for ; Tue, 14 Apr 2020 13:06:49 -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=bPwQhRdvGibSgM9jwxm8brESu2WKcPxrBlyVkpOMlqE=; b=ZHs6+T8P2V4NE5qGEv4Tz+U6rxgh9AG50KbjQDc/JCEXQbcKQXxH74p/9wXdbq8m3T FJqr+Ntsr+W9Wp1O/3HZMOkrHunP0sjl97W0fX9FqMQpNKgc7ikz2v5Jp1NScH1JHb6K mI/gYrdv4geJ/PKpUiF0A5uIGp5esL/iKB5aFfBYFJH0Ntm9hdyRGns69F84B8yK0Uj7 00eGNVDPH0/8avgkOUI3SWrQPvAuDwfqQ9kxAe2rcHWCy2w9WxCzWyPKGul2+vo/SYhN nwzez2xyveo79KiD+9qkXK+s+R9qDILnrHhQAOiub5u1K+BCtzvu3THlwhz4GTGRVW4C xPYA== 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=bPwQhRdvGibSgM9jwxm8brESu2WKcPxrBlyVkpOMlqE=; b=RPT2sncdYeHZO10O0lwzXZNKrOcQau1d5c04GHq6M29x3pfQAsamp3ZOaXpuFNXASZ EC8tcDR0hMUs3ZVVT4RP+zSkuet8R18Ca28dhO0RzLEK4hZy3wTrDVbiD2BkyCQoA/i/ GKI9eKHx3QG0l/cUWoyrssLVPSlQ7OrtVO+Zrb3gtJlV7ar2Vm080Co7pzT7iScIMIY4 0Ow0ugLnYI+ARjijs36KOk6a2ilQvJf4rcz9oTmzoWnIOpo3Bvcby8bg0NepRmQrh9lX ncQIrKGiuxWhxj8dLr+qaEAJo3YopK4sWAgJ63o7hVFby05zrBJj7zelCFfz2QCetOZM GiNA== X-Gm-Message-State: AGi0PuYGa/q6TuWH0CVyDHxXE8bs1J9iwoE+j+B6pwutREiK29MJ8zlB d9vdpZSRWTQcAd49wL4T6nqW5A== X-Received: by 2002:a1c:dfc2:: with SMTP id w185mr1427740wmg.1.1586894808896; Tue, 14 Apr 2020 13:06:48 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id a205sm15483375wmh.29.2020.04.14.13.06.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:44 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 585D81FF9A; Tue, 14 Apr 2020 21:06:33 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 11/17] gdbstub: i386: Fix gdb_get_reg16() parameter to unbreak gdb Date: Tue, 14 Apr 2020 21:06:25 +0100 Message-Id: <20200414200631.12799-12-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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: Eduardo Habkost , =?utf-8?q?Philippe_Mathieu-Daud?= =?utf-8?b?w6k=?= , Richard Henderson , Peter Xu , Paolo Bonzini , Richard Henderson , =?utf-8?q?Alex_Benn=C3=A9e?= , Stefano Garzarella 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: (gdb) target remote :1234 Remote debugging using :1234 Remote communication error. Target disconnected.: Connection reset by peer. $ qemu-system-x86_64 -m 1G -smp 4 ... -s ERROR:qemu/gdbstub.c:1843:handle_read_all_regs: assertion failed: (len == gdbserver_state.mem_buf->len) Bail out! ERROR:qemu/gdbstub.c:1843:handle_read_all_regs: assertion failed: (len == gdbserver_state.mem_buf->len) Fixes: a010bdbe719 ("extend GByteArray to read register helpers") Signed-off-by: Peter Xu Reviewed-by: Philippe Mathieu-Daudé Signed-off-by: Alex Bennée Tested-by: Stefano Garzarella Reviewed-by: Richard Henderson Message-Id: <20200409164954.36902-3-peterx@redhat.com> --- v2 - tags and expand comment --- target/i386/gdbstub.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) -- 2.20.1 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 Tue Apr 14 20:06: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: 185444 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1834812ilf; Tue, 14 Apr 2020 13:10:43 -0700 (PDT) X-Google-Smtp-Source: APiQypILOjg7w1u5N0ZtVgUEcKjNy7a3zhS0IvVIIgc1uKwGtwo0B2zvMlfGV3KQgFGBPyiK+/HB X-Received: by 2002:a37:a049:: with SMTP id j70mr7787740qke.193.1586895043549; Tue, 14 Apr 2020 13:10:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895043; cv=none; d=google.com; s=arc-20160816; b=wCzwkTSXsY2iRs2se/28HSJkMAMd0jDhIQt/3XLxaa74kOXTYfS8ielDOy6uKzThqU SiAaCpDxisqE8pg3KBG0FId/KHjlCDw4/a1Cg1o3B2ZjtXDGhCndXTchHx4/kOkFDxZN +pliMphTd0fk1036IBPMFKfh2AjEt86SHN6hZAJFM5hhi93C62HFQaxSXmtTdZS78IjD lbzcpHmhEMLkTPcYt1xLj0C0XQR8FkYMzITBCO9uE0UcfGMgjCOEIpJIqMnLpD9vMbAN 6ujhWKaMCRvbTPnSR9zR52l04zPzMWIZBq5pHOfgBNN2PWf0KWrSqhrPwVwCqDNVIztB Nr0Q== 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=aZ6FKx87IIsaQ+fv9HHif36FthP5pDUoqk2AxtvgmQ8=; b=0+LLbynU8opkDX5b2qAlyS+SfP2FxUdXil4+2vKjPN9Qvtr0++I9NCPex+hZZb1M3x DWr84NsN8yVWYzqgk2BfX4Eos2VvCZWow+kEHAyhFX1XpYvTR0PosnKyd9nfLe6WtU6x EuhwfwQ1r2a1Qx32FtFTqw6dL9brjouc1vkK/lNjYu4TDrUUIpotD9F1gZlj18+L4+Xl iqAaSMEIYR5mJclwm0IpZfJAWJnSKDtQ2oyDcZQ4EnRY6wBqPDAIZHdCXzpj7mJBHsVV PK/r81Msay880ECRhYoEXNjFulZFEhbEq6UNVal9jLkt54OwgTpoj6DvPNJgLlKRF+92 3B3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=eUXplBNY; 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 f11si8437279qtm.12.2020.04.14.13.10.43 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:10:43 -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=eUXplBNY; 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]:38428 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORtL-0004eW-2W for patch@linaro.org; Tue, 14 Apr 2020 16:10:43 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44542) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpY-0006Ag-OG for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:49 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpX-0005yQ-JD for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:48 -0400 Received: from mail-wm1-x332.google.com ([2a00:1450:4864:20::332]:54470) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpX-0005xz-CK for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:47 -0400 Received: by mail-wm1-x332.google.com with SMTP id h2so14492110wmb.4 for ; Tue, 14 Apr 2020 13:06:47 -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=aZ6FKx87IIsaQ+fv9HHif36FthP5pDUoqk2AxtvgmQ8=; b=eUXplBNYodG6JvFBONo8L2tEaI/kp6eZoywXUqbyebmAcDcuCDcAeR0YJYW95D5TaH 0RNJJwZpd3ggMQ/YHnfJGW72P1lZk0wVjw7RWju1wmk/LB2XZtag/CxNHYbBpDDcqYyq 1hlP7oX7jJxTMPnELJTdLeg3hkiyyFtsBeuttFJT5tuIk86jyxkVhgNjv4saKw+uRsfn F007fJBxomr6EKdpnxoRpIjjnAmQsOFKEaU3/lnOR8p3lGjven6DckXymUNTdqDz610z 8X35a5na7Rav/ANxVFULQgDnsw55VRFt6+KfllhSogx72uBa5fR3gbQT4JDnxlwfCOh9 t6bA== 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=aZ6FKx87IIsaQ+fv9HHif36FthP5pDUoqk2AxtvgmQ8=; b=b4NDhEZnHBO25iBElobheZm0ggRpAlM3SfUIc+cfwznOI3LrwRmqyPacr/z+TuZ3wO t8/eE304Ko2g4jyabb3bYna+AVHayChut/9+f75cARVYelQBnYv1hyf5JV8ee6PnGTvH bAp6OwVz+zDrMmRuLkXQeTkVWqFLbCl3egta08p0tYpE7UB9gOLSuQQXDjhCUU0W4DIZ P6GwhXLSutLcGstW13xPUR/u93H0hhkPRLitBMrfmQ6SXpnx66uK4q0dGjkouh8GV3/p sxebk5xG2aOlZS+wBwsaxMPb1GbFHIntt3J0+9fDjbrxWOp8kOwHEoGtXbkz2m9uvUrj 2K+Q== X-Gm-Message-State: AGi0PuZsTXPUut4DWGqYFi4Yd49f6TUlcejK1C/S9F+azTfQDkDU/6Rw mI1erRPgPfaUuce1sMuwc2PKOQ== X-Received: by 2002:a1c:4b0a:: with SMTP id y10mr1472289wma.24.1586894806418; Tue, 14 Apr 2020 13:06:46 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id q17sm11836553wmj.45.2020.04.14.13.06.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:44 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 87CFB1FF9B; Tue, 14 Apr 2020 21:06:33 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 12/17] gdbstub: Do not use memset() on GByteArray Date: Tue, 14 Apr 2020 21:06:26 +0100 Message-Id: <20200414200631.12799-13-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::332 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: Max Filippov , =?utf-8?q?Alex_Benn=C3=A9e?= , "open list:ARM TCG CPUs" , =?utf-8?q?Philippe_Ma?= =?utf-8?q?thieu-Daud=C3=A9?= , Peter Maydell Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Philippe Mathieu-Daudé Introduce gdb_get_zeroes() to fill a GByteArray with zeroes. Fixes: a010bdbe719 ("extend GByteArray to read register helpers") Signed-off-by: Philippe Mathieu-Daudé Message-Id: <20200414102427.7459-1-philmd@redhat.com> [AJB: used slightly more gliby set_size approach] Signed-off-by: Alex Bennée --- include/exec/gdbstub.h | 9 +++++++++ target/arm/gdbstub.c | 3 +-- target/xtensa/gdbstub.c | 6 ++---- 3 files changed, 12 insertions(+), 6 deletions(-) -- 2.20.1 diff --git a/include/exec/gdbstub.h b/include/exec/gdbstub.h index 30b909ebd27..3c452fc50c0 100644 --- a/include/exec/gdbstub.h +++ b/include/exec/gdbstub.h @@ -125,6 +125,15 @@ static inline int gdb_get_reg128(GByteArray *buf, uint64_t val_hi, return 16; } +static inline int gdb_get_zeroes(GByteArray *array, size_t len) +{ + guint oldlen = array->len; + g_byte_array_set_size(array, oldlen + len); + memset(array->data + oldlen, 0, len); + + return len; +} + /** * gdb_get_reg_ptr: get pointer to start of last element * @len: length of element diff --git a/target/arm/gdbstub.c b/target/arm/gdbstub.c index 8efc535f2a0..063551df234 100644 --- a/target/arm/gdbstub.c +++ b/target/arm/gdbstub.c @@ -47,8 +47,7 @@ int arm_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n) if (gdb_has_xml) { return 0; } - memset(mem_buf, 0, 12); - return 12; + return gdb_get_zeroes(mem_buf, 12); } switch (n) { case 24: diff --git a/target/xtensa/gdbstub.c b/target/xtensa/gdbstub.c index 0ee3feabe54..4d43f1340ae 100644 --- a/target/xtensa/gdbstub.c +++ b/target/xtensa/gdbstub.c @@ -105,8 +105,7 @@ int xtensa_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n) default: qemu_log_mask(LOG_UNIMP, "%s from reg %d of unsupported size %d\n", __func__, n, reg->size); - memset(mem_buf, 0, reg->size); - return reg->size; + return gdb_get_zeroes(mem_buf, reg->size); } case xtRegisterTypeWindow: /*a*/ @@ -115,8 +114,7 @@ int xtensa_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n) default: qemu_log_mask(LOG_UNIMP, "%s from reg %d of unsupported type %d\n", __func__, n, reg->type); - memset(mem_buf, 0, reg->size); - return reg->size; + return gdb_get_zeroes(mem_buf, reg->size); } } From patchwork Tue Apr 14 20:06: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: 185450 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1840373ilf; Tue, 14 Apr 2020 13:16:40 -0700 (PDT) X-Google-Smtp-Source: APiQypKyxN9ERJzkexYPt8DLNGkB5210qxJmlwHYrlC6nRhWrkTvnpVYO99jMTtJXKkpeNoUjhS1 X-Received: by 2002:ac8:c84:: with SMTP id n4mr18137369qti.24.1586895400161; Tue, 14 Apr 2020 13:16:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895400; cv=none; d=google.com; s=arc-20160816; b=pPE0EoAfGbAcZgSwUhqqIYDGGQlcniZheAlRKEfpfRHVikkEBMQO3mREVLEBG0uX7K qVQPSAgVO+bHie9Lf7idc/t6TS5XUDpXLFnML1/Y/fAEnMMkl4+rG8JNWlG34n/c3NjO tZaetADJtHKspsl1He6MrE9if/tp0cXZ0818ck0XJongcCP2dxoqmndztFmRJVWSCGdR Y514snI/YqfAjZ77cWjAnWKThf5uDD54Gauxj84JzJeUNdtLiDeNMjZqsHDzw3iFFHrh eTCiLOltnE+XzI6NqF+svMMaO715jQn7H+y3S3jhG6yOSxg1oX/pBmaaxX8woWuiwE5e 5Y5g== 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=Y41oariPSirC8NfMhDAA8Vm62k5I1+y4ZRfI3cHl76k=; b=yMs3I6Ze/dcIlCQeb8zzwpdNEfthyqu90hbRT8OSve5l4iTGOuZdxoMLnIai8eMURR dv4y3Mqr0VnN67yS3C+ZjlyjikvcAEt2RWxSkQ5FSyG80jbzf6aNG/Iw9BL7caIidDr4 BLSe+ux8PAIWk1IyohUxo3s5Qf8wdKwzOZ3MRw1cegs0Wbd0+gaNPHdPv5Hr+20FO0dm YXAT88XB9UnEchuanoFp3pS3P2sWem/fqQvnVBcbjUZEdFjbVvZiE58+9XVVDk+/bfXY JFB9NjDUyRbg57J63Vh4Z/HVeHLD2uU8ztmfsJdN6GU2Y18sJUDvVWEL5JxmIV/k55QQ d77w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=YgfGVdkf; 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 y16si8993544qtn.345.2020.04.14.13.16.40 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:16:40 -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=YgfGVdkf; 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]:38560 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORz4-0003Ym-KA for patch@linaro.org; Tue, 14 Apr 2020 16:16:38 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:44597) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORpf-0006Eu-4b for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:56 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORpe-000627-3a for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:55 -0400 Received: from mail-wr1-x42f.google.com ([2a00:1450:4864:20::42f]:44212) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORpd-00060K-Rk for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:06:54 -0400 Received: by mail-wr1-x42f.google.com with SMTP id d17so9089172wrg.11 for ; Tue, 14 Apr 2020 13:06:52 -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=Y41oariPSirC8NfMhDAA8Vm62k5I1+y4ZRfI3cHl76k=; b=YgfGVdkf//l7U+mJ+B5Z6iAPJUBTw6O2mNuPpXLZEA29xfYTZ+OcqUyigRwqEXLUAD YZRUmM9/fbl1DhPgfD+pYoX7x0TErvieLRGlVhJtOtj9HAmu7lDtILdp9Fh907bqD2wT 11VaE4LcsxutGRAEp38Z1BooO4y9oky49ENLw8OuIaGPtwYdyCqGFVjXlIlsvvKCC/EG jHUZOTe1KPGA/3Z932uOpZ+wYNScmq40cDeIc5wBo/Q6fEE0gfzXhbV6+PSOdUD99p40 E7fi9Yf5NwHkZs7TpneG5q6UWNuJKxSrounIi5KfAkhNMjC2xhJsVpNoLftZjJJZ5SJI jyAQ== 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=Y41oariPSirC8NfMhDAA8Vm62k5I1+y4ZRfI3cHl76k=; b=hnTnRle6ADKvp5C5X+bDM3Lt3xBH99pv/vyEjLeWE9nBDFozrhD9tTv8oIhKeSVj5T a1RljSqVEeELlY8gFwUJ/6wxQQmNh1GOyEbCbgXRzHQkM7DeV/2oFL6eZeJ1TtrMtM8O VqEXP/zPijHQO52u1xeb3FDzaOaCheCeGHHtei31QpbUQmoAal1C9JPuPyDOihPIQaUu kCVSC6GJBFQ0TmvO1JF+FlBUyQOMC0HXW1gOOJfNxuN1HDyB78NLARlDlTgZNo6gxOiL 2bDlu8ZvHfUNgtUAAIa/9ipIhfX0RH4fZ7XAABqjm9TXLIJh9pBQzls2vF4mgawJpk43 6MtA== X-Gm-Message-State: AGi0PuZtOMiEliouCXdHYd8QykeL0YalrB1L9ExRcLaPZfJD0tO9ebGZ K+DZ0JTiDPkVbg3uSMnP80hEZQ== X-Received: by 2002:a5d:4a42:: with SMTP id v2mr24248547wrs.333.1586894811402; Tue, 14 Apr 2020 13:06:51 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id t2sm13394364wmt.15.2020.04.14.13.06.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:06:44 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id AF3781FF7E; Tue, 14 Apr 2020 21:06:33 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 13/17] gdbstub: Introduce gdb_get_float32() to get 32-bit float registers Date: Tue, 14 Apr 2020 21:06:27 +0100 Message-Id: <20200414200631.12799-14-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::42f 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?= , Aurelien Jarno Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Philippe Mathieu-Daudé Since we now use a GByteArray, we can not use stfl_p() directly. Introduce the gdb_get_float32() helper to load a float32 register. Fixes: a010bdbe719 ("extend GByteArray to read register helpers") Signed-off-by: Philippe Mathieu-Daudé Signed-off-by: Alex Bennée Message-Id: <20200414163853.12164-2-philmd@redhat.com> --- include/exec/gdbstub.h | 9 +++++++++ target/sh4/gdbstub.c | 6 ++---- 2 files changed, 11 insertions(+), 4 deletions(-) -- 2.20.1 Reviewed-by: Richard Henderson diff --git a/include/exec/gdbstub.h b/include/exec/gdbstub.h index 3c452fc50c0..20e10726929 100644 --- a/include/exec/gdbstub.h +++ b/include/exec/gdbstub.h @@ -125,6 +125,15 @@ static inline int gdb_get_reg128(GByteArray *buf, uint64_t val_hi, return 16; } +static inline int gdb_get_float32(GByteArray *array, float32 val) +{ + uint8_t buf[sizeof(CPU_FloatU)]; + + stfl_p(buf, val); + g_byte_array_append(array, buf, sizeof(buf)); + + return sizeof(buf); +} static inline int gdb_get_zeroes(GByteArray *array, size_t len) { guint oldlen = array->len; diff --git a/target/sh4/gdbstub.c b/target/sh4/gdbstub.c index 49fc4a0cc69..34ad3ca0508 100644 --- a/target/sh4/gdbstub.c +++ b/target/sh4/gdbstub.c @@ -58,11 +58,9 @@ int superh_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n) return gdb_get_regl(mem_buf, env->fpscr); case 25 ... 40: if (env->fpscr & FPSCR_FR) { - stfl_p(mem_buf, env->fregs[n - 9]); - } else { - stfl_p(mem_buf, env->fregs[n - 25]); + return gdb_get_float32(mem_buf, env->fregs[n - 9]); } - return 4; + return gdb_get_float32(mem_buf, env->fregs[n - 25]); case 41: return gdb_get_regl(mem_buf, env->ssr); case 42: From patchwork Tue Apr 14 20:06: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: 185453 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1845853ilf; Tue, 14 Apr 2020 13:22:53 -0700 (PDT) X-Google-Smtp-Source: APiQypJnorLT/Gc9LXgRyFy48f0hz68vw83/i9QQg/vla1PS863eWhgvE9KHGoYevNkYK1oPSBrv X-Received: by 2002:a37:48a:: with SMTP id 132mr23610994qke.390.1586895773640; Tue, 14 Apr 2020 13:22:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895773; cv=none; d=google.com; s=arc-20160816; b=rus0gp91oUH1wANTBHHBx4pmz8ESHeaV2AV1TzgWKXCFSN7BHt6Z2dI7xbnm/oCCP3 w8oDK+Ca5NdJWBK6BUTV0kZiRvQ3C2vzU9+jro0P3QQoEKYAyEBSF6PhGPFWe7Q/VfW1 ndSX53t+j7TPFqoKqDtkFDp1gi6RnFM+ZGF8oASjzuNYcxd78dZPlSGcIdXYY6c3F8HD XDbKlk8BUOBensYUC63rdKr0ctfpo2YDecfOj5vAILz5NwSq6eYRt5/ozVrzuKKI+ApH /mNU/Y+UxggXOzZcbe3cgN06vZYsxQBsLKEZnBmiU/Zy56tFmH5nup7YNbFie8u29RLP PoZA== 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=3UWknvv+wdPtsXv26OjYUAVxV8/wuy9nynu7HohmC0w=; b=TieWl2Oad7kM0z+hlCIBg0rR7i5j7AzPtSfT4k3ivDD8ve5NQbvsD2Y2bZyOTv6OM/ dGn9mjHs7AG8X9mmWbwQ96m2R1k2vzCgv+6acRABpYHFEy5EcbDM2CicZmQXZ5uah35/ WNu3ekZECVzWvdlk4e9/7QFNcE/v1sjaeg8YImMefy4ZDKXLWj2b/5eUzPf/alj/05yB GYJYIYcThbYaAlSGoLnhOYmRzg7ihM2HRPCIpKii+vDUC8l8lwA+Q6AdH9KHlhPXX5TN v8gaAZ77ToGlSskrnUikty39HA9RVQJJhTGfHitgauE7JtdWTEScTyHDBUfwwKezQ5dj vyiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=PHCviFKd; 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 h21si7924806qve.56.2020.04.14.13.22.53 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:22:53 -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=PHCviFKd; 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]:38720 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jOS57-0003a4-6N for patch@linaro.org; Tue, 14 Apr 2020 16:22:53 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:45924) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORyj-00042g-IN for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:18 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORyi-0001jM-Bh for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:17 -0400 Received: from mail-wm1-x332.google.com ([2a00:1450:4864:20::332]:52681) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORyi-0001ik-4v for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:16 -0400 Received: by mail-wm1-x332.google.com with SMTP id o81so8958236wmo.2 for ; Tue, 14 Apr 2020 13:16:16 -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=3UWknvv+wdPtsXv26OjYUAVxV8/wuy9nynu7HohmC0w=; b=PHCviFKd1hV0AsvNdCAwXWgDWrWM8XIaHkCpvzTa5wp7ih6mgcaiHoPqewJfOuTfZ6 hEaLhALhRKBTz7k7/fUtV0M9spzMOFsZX7Z99FZqjk8MXz2BLEmlxXsiOkG4zZ92PE19 9BAnhPz+Gl7JQzcvpN+L130pii2DI3n+650ZBJuQNs0c5NMh27xx+NyFyRHqjbF3qCqT dPESQiY4+5DSxxYXxrz20457bN+wmGMFLTCMv+jIKc9uB61Xb5bGHrZXcnMv0ULw9Oir 7yH/LpSYiVNr/Inl2leKT6137CRB9VSP2HmXOylEpsDwyN1IONMI8MNRPtjw4/OWGf5Z bapA== 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=3UWknvv+wdPtsXv26OjYUAVxV8/wuy9nynu7HohmC0w=; b=rlxYTXdqmNucbYGxyvVouLUaLkNC1LSeG4MNGTg+EdrBzGhZp78JmSGq4W++wJoUSr jQ2bLQdl3z1oFfNJWIvmgMQTES3K0Ez9X0+QKeDqvle0orn1he3FTZST/o6SS5qLwU6+ QDTCPNLW0834cbXY0rRUeOgh6dh2GpCWaHT23f/x8tRzqXEID+91BywMLir+lSm2v0ZX WBEJELo3PWotsnkZ65zmS5zCEXzbZD2hQHgaZy6CkdMBLWloCjThfY4OHxSKOdu7a3rJ yyjXo8uurfIPczzNnzDlYE239hGKYib59FYR+ACpN/zUS8P7LmaVBZ6IDogfbp4+7ob9 SLUg== X-Gm-Message-State: AGi0PuZWmzedRMOVpYLDD8Iv0+7dZfrWOoqgeX+nFlZwtvK7Bc1oIzKa qISV3eU9qkVpvn6DrfV6fQra5w== X-Received: by 2002:a05:600c:2112:: with SMTP id u18mr1627424wml.112.1586895375103; Tue, 14 Apr 2020 13:16:15 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id i17sm20105226wml.23.2020.04.14.13.16.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:16:11 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id DACC01FF9C; Tue, 14 Apr 2020 21:06:33 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 14/17] gdbstub: Introduce gdb_get_float64() to get 64-bit float registers Date: Tue, 14 Apr 2020 21:06:28 +0100 Message-Id: <20200414200631.12799-15-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::332 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: "open list:PowerPC TCG CPUs" , =?utf-8?q?Alex_Ben?= =?utf-8?q?n=C3=A9e?= , =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= , Laurent Vivier , David Gibson Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Philippe Mathieu-Daudé When converted to use GByteArray in commits 462474d760c and a010bdbe719, the call to stfq_p() was removed. This call serialize a float. Since we now use a GByteArray, we can not use stfq_p() directly. Introduce the gdb_get_float64() helper to load a float64 register. Fixes: 462474d760c ("target/m68k: use gdb_get_reg helpers") Fixes: a010bdbe719 ("extend GByteArray to read register helpers") Signed-off-by: Philippe Mathieu-Daudé Signed-off-by: Alex Bennée Message-Id: <20200414163853.12164-3-philmd@redhat.com> --- include/exec/gdbstub.h | 11 +++++++++++ target/m68k/helper.c | 3 ++- target/ppc/gdbstub.c | 4 ++-- target/ppc/translate_init.inc.c | 2 +- 4 files changed, 16 insertions(+), 4 deletions(-) -- 2.20.1 diff --git a/include/exec/gdbstub.h b/include/exec/gdbstub.h index 20e10726929..4a2b8e30893 100644 --- a/include/exec/gdbstub.h +++ b/include/exec/gdbstub.h @@ -134,6 +134,17 @@ static inline int gdb_get_float32(GByteArray *array, float32 val) return sizeof(buf); } + +static inline int gdb_get_float64(GByteArray *array, float64 val) +{ + uint8_t buf[sizeof(CPU_DoubleU)]; + + stfq_p(buf, val); + g_byte_array_append(array, buf, sizeof(buf)); + + return sizeof(buf); +} + static inline int gdb_get_zeroes(GByteArray *array, size_t len) { guint oldlen = array->len; diff --git a/target/m68k/helper.c b/target/m68k/helper.c index cad40838956..79b0b10ea9b 100644 --- a/target/m68k/helper.c +++ b/target/m68k/helper.c @@ -72,7 +72,8 @@ static int cf_fpu_gdb_get_reg(CPUM68KState *env, GByteArray *mem_buf, int n) { if (n < 8) { float_status s; - return gdb_get_reg64(mem_buf, floatx80_to_float64(env->fregs[n].d, &s)); + return gdb_get_float64(mem_buf, + floatx80_to_float64(env->fregs[n].d, &s)); } switch (n) { case 8: /* fpcontrol */ diff --git a/target/ppc/gdbstub.c b/target/ppc/gdbstub.c index eb362dd9aec..5c11c88b2a8 100644 --- a/target/ppc/gdbstub.c +++ b/target/ppc/gdbstub.c @@ -130,7 +130,7 @@ int ppc_cpu_gdb_read_register(CPUState *cs, GByteArray *buf, int n) gdb_get_regl(buf, env->gpr[n]); } else if (n < 64) { /* fprs */ - gdb_get_reg64(buf, *cpu_fpr_ptr(env, n - 32)); + gdb_get_float64(buf, *cpu_fpr_ptr(env, n - 32)); } else { switch (n) { case 64: @@ -184,7 +184,7 @@ int ppc_cpu_gdb_read_register_apple(CPUState *cs, GByteArray *buf, int n) gdb_get_reg64(buf, env->gpr[n]); } else if (n < 64) { /* fprs */ - gdb_get_reg64(buf, *cpu_fpr_ptr(env, n - 32)); + gdb_get_float64(buf, *cpu_fpr_ptr(env, n - 32)); } else if (n < 96) { /* Altivec */ gdb_get_reg64(buf, n - 64); diff --git a/target/ppc/translate_init.inc.c b/target/ppc/translate_init.inc.c index e853164a865..d825cb59758 100644 --- a/target/ppc/translate_init.inc.c +++ b/target/ppc/translate_init.inc.c @@ -9881,7 +9881,7 @@ static int gdb_get_float_reg(CPUPPCState *env, GByteArray *buf, int n) { uint8_t *mem_buf; if (n < 32) { - gdb_get_reg64(buf, *cpu_fpr_ptr(env, n)); + gdb_get_float64(buf, *cpu_fpr_ptr(env, n)); mem_buf = gdb_get_reg_ptr(buf, 8); ppc_maybe_bswap_register(env, mem_buf, 8); return 8; From patchwork Tue Apr 14 20:06: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: 185449 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1840265ilf; Tue, 14 Apr 2020 13:16:33 -0700 (PDT) X-Google-Smtp-Source: APiQypJIV/GC3QVJByYjyt/rPct0YEfbmUi5cehNypjWYXH4ecyTNrIBsA6XHmC8irH98MVKqjtj X-Received: by 2002:a37:a603:: with SMTP id p3mr22283767qke.109.1586895392987; Tue, 14 Apr 2020 13:16:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895392; cv=none; d=google.com; s=arc-20160816; b=Mk4bsocCauElOGEbZgZBvqXQ1bCSWlJyFQAQuHQV3UOd2HPfaNYThpNpnuBlhNOrIu eLsAJJt8XY8+/6kDG5sxrDCkl+LwaCyR24ll8s7jdfEPBAwBe3xHDLFHtI6ZwjkdQq6f Bg0F6+GjqOSVzEgJFBqPfU0LoVuzKV6Saasv4MNpGiJIxLszxueld1ooR6tIbRiYGhYF I59bUyms3e63msspdJb1dFIqBA9bxMHod9vfsswSSdWzkTqJZOmvpIpHXQmsyjBaSn/h IscmbYzZaKqXAIHdOzpJNIB2W/Ww65EHRf18NKOIMnz29GXQyk8iKekEhea19f0odN8f 1/fg== 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=U0GHkMxjV1uSRYh2+mG4n9m1cHTJmvyky0OeonmCsaU=; b=qCSp7zCxLQlcUQCmB2NQ4eicxZlHNJPcko6Q8l34h2DFFpcpo126vpfmkZORv2XCUl A4nur8T+JF+0pgkU4Z0JN7iz4LZ/A7UwkIiC19+QLgdhuLVaoxp0B7z1ZfXFJqaWDoze brMqZ4qtaBZ5KovHUY3M6eG/bd4NlrFYMaKa0geLIQv0527vZaD5abD0hAaa1b2AyFq2 Y3bBYEV3gHzvMgJlnJwlJqNb4y0UsTfp5LJpKgxW7mCXjzhm9da3gP3INVmeUR/Ag0Gd Ux0Jb9ZfspNjDG6UnvGAU6pfRZGGDF01IlNdITwQ2QcDav+ZIcBdXwW8dl+VfF6pxVny ZyyQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=zDyVX+eG; 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 o2si2812028qkm.81.2020.04.14.13.16.32 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:16:32 -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=zDyVX+eG; 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]:38592 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORyy-0004AW-Db for patch@linaro.org; Tue, 14 Apr 2020 16:16:32 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:45913) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORyi-00040S-Lm for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:17 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORyh-0001iV-BM for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:16 -0400 Received: from mail-wm1-x342.google.com ([2a00:1450:4864:20::342]:40511) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORyh-0001hw-4e for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:15 -0400 Received: by mail-wm1-x342.google.com with SMTP id a81so15773847wmf.5 for ; Tue, 14 Apr 2020 13:16:15 -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=U0GHkMxjV1uSRYh2+mG4n9m1cHTJmvyky0OeonmCsaU=; b=zDyVX+eGLidywceNh4TJT/ZYZU5Sl8GDbcntFEUGG5+KT3G5Rp02Ky9cQbxUpfbefN MQq8fa1MP/TzuzOq3BesyNCGzQIhS1w01JPNnmjJZ/gaYLiYfTrDiDdrK0zEwNjNzbKb UWLiqqrX9WVcYop2mp08FcL3LqKt04r69IWfcx+5UyhTWHbU1PSdLKNBg5cV58rW5N6B lZiInQtKv7errpITUoT5XmBZwzKMx+hVVn1pQMCzYjD4ephmZUvxx6tTy6ZBbWWA/d+b GyB3HSD+M4CHp9CyN9p5hIUpNRTjp1d5mBC63geazmVR/BvS0Vb+v3pJh4yHWRKz4Air nnmA== 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=U0GHkMxjV1uSRYh2+mG4n9m1cHTJmvyky0OeonmCsaU=; b=UYOR36MEIJvFMh20UINTjdzggLfCzNc2Z+7P7gpyrfkB03o7TevlTjbID1KSEgkzjE IVbN+7bGd4OadXLRmshO4IT5YS464YwoG5FiMQdWzVxYulI6sNJBP3psOg8YWQ4H/HhW JPIykLsLoAssmttOwsYMAFipNRdn5twRct2nq24wlhBlOgzVxM+998PQraQshT5Pi0gw QCNnVd4rCqoTQLnIYzhX2PXhuAVU88nv1N2kDif+SVZFQSd0Q7P3MJtg00gcytR0jsKI prxI6NmbyK9ZkvFMym07DPlFdPxwA6Q5RYIwm7XbSUxp3lc369NLq4WNGYR64hREL5Wk 88Pg== X-Gm-Message-State: AGi0PubOnOG75oH9iKQRsIGqzOTCZabA10n2/VgFgC9EdhllundIqlkI +fVcvg21OK3SQ4FrBEBmnhdoYs64EUA= X-Received: by 2002:a1c:808c:: with SMTP id b134mr1587510wmd.131.1586895374113; Tue, 14 Apr 2020 13:16:14 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id w12sm5778068wrk.56.2020.04.14.13.16.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:16:11 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 09FA11FF9D; Tue, 14 Apr 2020 21:06:34 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 15/17] target/m68k: hack around the FPU register support (HACK!) Date: Tue, 14 Apr 2020 21:06:29 +0100 Message-Id: <20200414200631.12799-16-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::342 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_Mathieu-Daud=C3=A9?= , =?utf-8?q?Alex_Benn=C3=A9e?= , Laurent Vivier Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" Attempting to attach to the gdbstub causes GDB to complain: warning: Register "fp0" has an unsupported size (80 bits) warning: Register "fp1" has an unsupported size (80 bits) warning: Register "fp2" has an unsupported size (80 bits) warning: Register "fp3" has an unsupported size (80 bits) warning: Register "fp4" has an unsupported size (80 bits) warning: Register "fp5" has an unsupported size (80 bits) warning: Register "fp6" has an unsupported size (80 bits) warning: Register "fp7" has an unsupported size (80 bits) Remote 'g' packet reply is too long (expected 148 bytes, got 164 bytes): 000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000$ 00000000000000000000408009f000000000800003407fffffffffffffffffff7fffffffffffffffffff7fffffffffffffffffff7fffffffffffffffffff7fffffffffffffffffff7fffffffffffffffffff7fffffff$ fffffffffff7fffffffffffffffffff000000000000000000000000 and then subsequently fail. The root problem seems to be this is an undefined size register for the target description. There does exist a floatformats_m68881_ext in GDB but setting "m68881_ext" also fails as the only "weird" tdesc types gdb seems to understand are: { "arm_fpa_ext", TDESC_TYPE_ARM_FPA_EXT }, { "i387_ext", TDESC_TYPE_I387_EXT } So present the register as a i386_ext as some sort of hack. The values are garbage but at least we can continue to connect. Perhaps we should just delete the code because I don't think this ever worked with upstream tools. Signed-off-by: Alex Bennée Cc: Laurent Vivier --- target/m68k/helper.c | 11 +++++------ gdb-xml/m68k-fp.xml | 16 ++++++++-------- 2 files changed, 13 insertions(+), 14 deletions(-) -- 2.20.1 diff --git a/target/m68k/helper.c b/target/m68k/helper.c index 79b0b10ea9b..80069adb8cc 100644 --- a/target/m68k/helper.c +++ b/target/m68k/helper.c @@ -109,9 +109,8 @@ static int cf_fpu_gdb_set_reg(CPUM68KState *env, uint8_t *mem_buf, int n) 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, 0); - len += gdb_get_reg64(mem_buf, env->fregs[n].l.lower); + int len = gdb_get_reg64(mem_buf, cpu_to_le64(env->fregs[n].l.lower)); + len += gdb_get_reg16(mem_buf, cpu_to_le16(env->fregs[n].l.upper)); return len; } switch (n) { @@ -128,9 +127,9 @@ static int m68k_fpu_gdb_get_reg(CPUM68KState *env, GByteArray *mem_buf, int n) static int m68k_fpu_gdb_set_reg(CPUM68KState *env, uint8_t *mem_buf, int n) { if (n < 8) { - env->fregs[n].l.upper = lduw_be_p(mem_buf); - env->fregs[n].l.lower = ldq_be_p(mem_buf + 4); - return 12; + env->fregs[n].l.lower = le64_to_cpu(* (uint64_t *) mem_buf); + env->fregs[n].l.upper = le16_to_cpu(* (uint16_t *) (mem_buf + 8)); + return 10; } switch (n) { case 8: /* fpcontrol */ diff --git a/gdb-xml/m68k-fp.xml b/gdb-xml/m68k-fp.xml index 64290d16306..8eb55af2860 100644 --- a/gdb-xml/m68k-fp.xml +++ b/gdb-xml/m68k-fp.xml @@ -6,14 +6,14 @@ notice and this notice are preserved. --> - - - - - - - - + + + + + + + + , From patchwork Tue Apr 14 20:06:30 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: 185452 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1844725ilf; Tue, 14 Apr 2020 13:21:43 -0700 (PDT) X-Google-Smtp-Source: APiQypIz2n5q4G+LleW2MZqvDd6mtCExig7Qi7ZjCqHPYEAr30sDi3aSHzm3UFRxKhhpmWn3vOyL X-Received: by 2002:a37:61d3:: with SMTP id v202mr13567qkb.142.1586895703573; Tue, 14 Apr 2020 13:21:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895703; cv=none; d=google.com; s=arc-20160816; b=G+IRbynFrKJ7SDpOrBBkTmZq41JM8OEBL6u+ghvh29T2CjNkj75V8vP8KayvNezwPv T+u15PcjtcL69J6bNIF8e0LOXAPLNAEHq5aPPd0tCr4oJctIC/7rQzM48LUEdCyuotGm x7EWjrKqHyl2RlxZeEVHFAxdbOVbFHLbGKa9W+vOYOM4Oojlwsyxmh1l1+TZ/kNehOt0 Vlz/ljMEsxMV7OMhgxTucG32rPOltdfVbjCLA2Rwj8919NaQAOlO3QbvBpfSPWmZr6Ut SkhGMCGbtjYukVjdXWG1U7EXFUU0/OUMflOtxh8CGqSQi6+iZausoeLFc/ftGxXeJktE kGag== 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=NPiyUCAjRop3t1WgPzKfTIoYlwAGqnRWW17Y8kgOmss=; b=0zsHT0EyApwgBA/C5J5z/PZXIyNEFf5Zy+JrmF0azPU7gZgEEJaznPxU99iWCYzci4 tayPUDl1jilaiWHBvadM0NL+gSKK+2WYirO5gPXFEUHk5WQgJsM+sRPPRLidRcahR2HZ F6N9clvaJSlMBkmX5Ci7l3DMsHDb9PZABwuYOxGqdVmqPRWND2rdasSYcklxkZ8vm87M v+UhmqnWOpYZS9pqrZ86PDUxofYdWHue664rk0OKIQLdVhO6jVRUbSwJE0Duor6dGArC lEdN3Guzsl9DmgO+8mlPIoooSsD582Ft5WvRFAesJFfpmNl+2PplukksBElI68kxdJ+h ADuQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b="v/dySJqP"; 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 x10si7969929qts.9.2020.04.14.13.21.43 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:21:43 -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="v/dySJqP"; 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]:38692 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jOS3z-0002Fr-58 for patch@linaro.org; Tue, 14 Apr 2020 16:21:43 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:45874) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORyh-0003xD-5O for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:16 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORyf-0001hV-RL for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:14 -0400 Received: from mail-wm1-x32f.google.com ([2a00:1450:4864:20::32f]:53640) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORyf-0001gg-H3 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:13 -0400 Received: by mail-wm1-x32f.google.com with SMTP id d77so14538532wmd.3 for ; Tue, 14 Apr 2020 13:16:13 -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=NPiyUCAjRop3t1WgPzKfTIoYlwAGqnRWW17Y8kgOmss=; b=v/dySJqPPNf/T7mPWN0oYESPDypKjKp5xHxSiMfxPfnUaVxMuqEsH5gzYWcLoLrxYq a3CVyLt9+uKeI1c7khVD0y/QJW+6KUYUQXLxl1ElA4SZ+8slq/cgJ9bSwsiQmDHNfNa4 oc6V9EB3gALg5DM9nzmcuTg0ZRToKyXhlAzJGqzz8byKWyMHGd7AebTuVNj0PHTdUnPU gvyFKDd/pnkoIty0RhzU7/cq6JgRpNqRwTIoZuucI996R9lzfY++cnYi+r7x7Ui1319t kZ0q9uphLiPTEIp/S9VuWNnorDCbZcV2Z2ibe9rAaV1bXnIfTF0kvj01hVjoa118ChyX 7gGQ== 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=NPiyUCAjRop3t1WgPzKfTIoYlwAGqnRWW17Y8kgOmss=; b=O2sy9qvLwf1kzD8ry4R4UoOQmUwpgzQw8nc+Vg5AG0e35RRGLMOmbyXU81O5dpA2R/ ogbgzI8wFpxg3PR8sirJA0WFyfS9WmYLlZjBLbt9nzK+/W4FmGjO7wupNyQmwMCXrJGp qz4lPt3SrJRx2bMAim6omdg2RZto6YDuRVmKBS04xx3N3fU3nC5gB7kBLtLVX1vaM+Qn mz7c4rd0JzfC8RtJPGZT0ctXkprSHRJH0wSj3PtCIcybA04DbKtxGAeZNtROwpGf5ERz qLmrsPiaRzkWhTGNE0HTbpVIDXAVn0KKYeFU3W8lfO+YlI6mAbUjRcxZo7kE5cErevo1 6CQg== X-Gm-Message-State: AGi0PuZqmN/LlIBNaG5tf6+EikWD+nx3W1rhckI6/2X4kauSHRkgFFcn e6iqPULgBeZPlZm47pMq0vKwEQ== X-Received: by 2002:a1c:a7c4:: with SMTP id q187mr1677166wme.56.1586895372176; Tue, 14 Apr 2020 13:16:12 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id y9sm19434556wmm.26.2020.04.14.13.16.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:16:11 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 31E541FF9E; Tue, 14 Apr 2020 21:06:34 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 16/17] tests/tcg: drop inferior.was_attached() test Date: Tue, 14 Apr 2020 21:06:30 +0100 Message-Id: <20200414200631.12799-17-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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::32f 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: Peter Maydell , "open list:ARM TCG CPUs" , =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" This test seems flaky and reports attachment even when we failed to negotiate the architecture. However the fetching of the guest architecture will fail tripping up the gdb AttributeError which will trigger our early no error status exit from the test Signed-off-by: Alex Bennée --- tests/tcg/aarch64/gdbstub/test-sve-ioctl.py | 3 --- tests/tcg/aarch64/gdbstub/test-sve.py | 3 --- 2 files changed, 6 deletions(-) -- 2.20.1 diff --git a/tests/tcg/aarch64/gdbstub/test-sve-ioctl.py b/tests/tcg/aarch64/gdbstub/test-sve-ioctl.py index 984fbeb277e..5824abe09ac 100644 --- a/tests/tcg/aarch64/gdbstub/test-sve-ioctl.py +++ b/tests/tcg/aarch64/gdbstub/test-sve-ioctl.py @@ -58,9 +58,6 @@ def run_test(): # try: inferior = gdb.selected_inferior() - if inferior.was_attached == False: - print("SKIPPING (failed to attach)", file=sys.stderr) - exit(0) arch = inferior.architecture() report(arch.name() == "aarch64", "connected to aarch64") except (gdb.error, AttributeError): diff --git a/tests/tcg/aarch64/gdbstub/test-sve.py b/tests/tcg/aarch64/gdbstub/test-sve.py index dbe7f2aa932..90201d80094 100644 --- a/tests/tcg/aarch64/gdbstub/test-sve.py +++ b/tests/tcg/aarch64/gdbstub/test-sve.py @@ -59,9 +59,6 @@ def run_test(): # try: inferior = gdb.selected_inferior() - if inferior.was_attached == False: - print("SKIPPING (failed to attach)", file=sys.stderr) - exit(0) arch = inferior.architecture() report(arch.name() == "aarch64", "connected to aarch64") except (gdb.error, AttributeError): From patchwork Tue Apr 14 20:06:31 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: 185451 Delivered-To: patch@linaro.org Received: by 2002:a92:3d9a:0:0:0:0:0 with SMTP id k26csp1840914ilf; Tue, 14 Apr 2020 13:17:15 -0700 (PDT) X-Google-Smtp-Source: APiQypKdM1X9Aj4TMbqckOLMd/4+nE5nqUwsySHuXJPBium969uiRXpa6L2cqa4xVowx3NLmnwXS X-Received: by 2002:ad4:56e3:: with SMTP id cr3mr1809291qvb.119.1586895435236; Tue, 14 Apr 2020 13:17:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586895435; cv=none; d=google.com; s=arc-20160816; b=u3nsjBFAM3SSG0CGA+JsRIlZ7Uk0SKmvnvtKqjMsSnNFvOlUOb5zt039g2ETFPEB+V RfA6WYxTGI4fb81828rxHm7TcULHRe3j9FA+zfhqZstJDt6Rl0C1MEdHe4eGM5eK253T 3oeLm6N2thpESVetIdKR2UW8PL5mtJpsdaXDJrj0/1LfN3jdaTryypsvJzyDvFBfy4he wPMiZ/F4tmF1EQwfHNvjBrh1al8xrD2LTpFFhxQkCH3pbuX9HLRrS321rDGaafzWUqOG OPO0zq4AN8uIVLwc0kTSApwSkBPzU3stFlk2fa75qh0Z9SwP9zBUCGnBueDBYFUxFaYy tJ6w== 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=pXOAgjF0MzY5dkIyjyLAmatYK5vlyk1VB17UWTeSYLg=; b=QjqXqMsmQKhOaavWZc8yOrcT9WPCTHQnsVsJl4DNUzI08E0isk8dp0tyOt0LZ5nqe5 KlOC7UCIfoKaP6GBQWE18zahOzgHGo5ImK3A7zDFoiT6M+QuxY1KlDFOObOq9eKe0Z0r uwb74rundndvGKQAyN4gsdW9ot+rvs6FrxYhfLMAL9jG/RTCEjyQ8iNx37hwK74bn58k 5Qvdc7lCmdU/WMIRhoVfC3wwo/GkjCRN712Afk7qHuHTQttmqH+SxZFbEiqpvdTUtClk 488fLh6uh7SVDlB0SssY6BI7aZhoMI8DZeh5VH7b+6VmAa6cDwyr7hLuw1VPW+GAz1hR Mm5w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=l3SJYTvE; 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 d4si8360231qkk.353.2020.04.14.13.17.15 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 14 Apr 2020 13:17:15 -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=l3SJYTvE; 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]:38606 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORze-00059I-H4 for patch@linaro.org; Tue, 14 Apr 2020 16:17:14 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:45892) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jORyh-0003yT-Nc for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:16 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jORyg-0001hs-GI for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:15 -0400 Received: from mail-wr1-x441.google.com ([2a00:1450:4864:20::441]:47053) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jORyg-0001h9-A7 for qemu-devel@nongnu.org; Tue, 14 Apr 2020 16:16:14 -0400 Received: by mail-wr1-x441.google.com with SMTP id f13so16028450wrm.13 for ; Tue, 14 Apr 2020 13:16:14 -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=pXOAgjF0MzY5dkIyjyLAmatYK5vlyk1VB17UWTeSYLg=; b=l3SJYTvEgPDRkSatLR4hF7MJ5Msw6QnVdjtiVi20VWWZ/2NEtk2cZuDWDkP0maoeQi /htFWipTBa7ExaFfx+BSNLxZmAawvkiskTaJE8mF9aYyi6eM3jWe23IHnpbTxXH/5K30 2x1qntg5N8Ho0VyWYIrKSas+gqg1L+dQ0nQjDNfzh1Pa5EmnQvAl/GpW4luueidC5X9M LfUv19Yjd0oX8OAlN2isV+h2Ea38wjMTL29JjxnMuwk6xkdlPQHbsN66azMtqlHbjYTN Zf8rXDm9NdUdaCiEipH/2O+tzKIjHJxkch8jCgzfHeTSvLt/fPwZd76BmP94BT8a/kB+ K6jw== 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=pXOAgjF0MzY5dkIyjyLAmatYK5vlyk1VB17UWTeSYLg=; b=azXnwoB2lT4uFWzWefGKJbCLggypFpgb6zd20POvMKPFx47cmeOAmiUSoUR0canvDP wiIKd6QFgMgJSkXOWtGalft1yc02U2KER+1S+AUdffnjqIu11pxgDVcEpP9jOpgeFwhW Vixa4ZA0JPQbcjpcX/jW8pFIcPxbWbYlnTiR47pcoso4DlSamm7DVKYQ9tmwhBOA4M3d RxoJkq/cSA3c4NtGobQDb/A7AH+jEPPig14koYGRzKQTHI+f8qU6XzHMyQI8IhcLRPEb DcgWEQ6u3fyDHVO26bIIqdWTznaElvd25ttmFcT5OakiTbpparO5tR8my0Jx9iZ7aFwA X5Kw== X-Gm-Message-State: AGi0PubcaBjsJTG9ReCs9gQppZS0ubbIE0DOf2lwel2m2PAhF1vDp9yu 2UMKCy/cYEZdUWwzczypgfAF/Bo8D5U= X-Received: by 2002:adf:fe45:: with SMTP id m5mr17771336wrs.124.1586895373108; Tue, 14 Apr 2020 13:16:13 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id p6sm12977676wrt.3.2020.04.14.13.16.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Apr 2020 13:16:11 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 587BD1FF9F; Tue, 14 Apr 2020 21:06:34 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v2 17/17] tests/tcg: add a multiarch linux-user gdb test Date: Tue, 14 Apr 2020 21:06:31 +0100 Message-Id: <20200414200631.12799-18-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200414200631.12799-1-alex.bennee@linaro.org> References: <20200414200631.12799-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?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" When the gdbstub code was converted to the new API we missed a few snafus in the various guests. Add a simple gdb test script which can be used on all our linux-user guests to check for obvious failures. Signed-off-by: Alex Bennée --- tests/tcg/multiarch/Makefile.target | 15 ++++++ tests/tcg/multiarch/gdbstub/sha1.py | 81 +++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) create mode 100644 tests/tcg/multiarch/gdbstub/sha1.py -- 2.20.1 diff --git a/tests/tcg/multiarch/Makefile.target b/tests/tcg/multiarch/Makefile.target index 035b09c8533..47fd675aba5 100644 --- a/tests/tcg/multiarch/Makefile.target +++ b/tests/tcg/multiarch/Makefile.target @@ -42,5 +42,20 @@ run-test-mmap-%: test-mmap $(call run-test, test-mmap-$*, $(QEMU) -p $* $<,\ "$< ($* byte pages) on $(TARGET_NAME)") +ifneq ($(HAVE_GDB_BIN),) +GDB_SCRIPT=$(SRC_PATH)/tests/guest-debug/run-test.py + +MULTIARCH_TESTS += gdbstub-sha1 + +.PHONY: gdbstub-sha1 +run-gdbstub-sha1: sha1 + $(call run-test, $@, $(GDB_SCRIPT) \ + --gdb $(HAVE_GDB_BIN) \ + --qemu $(QEMU) --qargs "$(QEMU_OPTS)" \ + --bin $< --test $(MULTIARCH_SRC)/gdbstub/sha1.py, \ + "basic gdbstub support") +endif + + # Update TESTS TESTS += $(MULTIARCH_TESTS) diff --git a/tests/tcg/multiarch/gdbstub/sha1.py b/tests/tcg/multiarch/gdbstub/sha1.py new file mode 100644 index 00000000000..734553b98bb --- /dev/null +++ b/tests/tcg/multiarch/gdbstub/sha1.py @@ -0,0 +1,81 @@ +from __future__ import print_function +# +# A very simple smoke test for debugging the SHA1 userspace test on +# each target. +# +# This is launched via tests/guest-debug/run-test.py +# + +import gdb +import sys + +initial_vlen = 0 +failcount = 0 + +def report(cond, msg): + "Report success/fail of test" + if cond: + print("PASS: %s" % (msg)) + else: + print("FAIL: %s" % (msg)) + global failcount + failcount += 1 + +def check_break(sym_name): + "Setup breakpoint, continue and check we stopped." + sym, ok = gdb.lookup_symbol(sym_name) + bp = gdb.Breakpoint(sym_name) + + gdb.execute("c") + + # hopefully we came back + end_pc = gdb.parse_and_eval('$pc') + report(bp.hit_count == 1, + "break @ %s (%s %d hits)" % (end_pc, sym.value(), bp.hit_count)) + + bp.delete() + +def run_test(): + "Run through the tests one by one" + + check_break("SHA1Init") + + # check step and inspect values + gdb.execute("next") + val_ctx = gdb.parse_and_eval("context->state[0]") + exp_ctx = 0x67452301 + report(int(val_ctx) == exp_ctx, "context->state[0] == %x" % exp_ctx); + + gdb.execute("next") + val_ctx = gdb.parse_and_eval("context->state[1]") + exp_ctx = 0xEFCDAB89 + report(int(val_ctx) == exp_ctx, "context->state[1] == %x" % exp_ctx); + + # finally check we don't barf inspecting registers + gdb.execute("info registers") + +# +# This runs as the script it sourced (via -x, via run-test.py) +# +try: + inferior = gdb.selected_inferior() + arch = inferior.architecture() + print("ATTACHED: %s" % arch.name()) +except (gdb.error, AttributeError): + print("SKIPPING (not connected)", file=sys.stderr) + exit(0) + +try: + # These are not very useful in scripts + gdb.execute("set pagination off") + gdb.execute("set confirm off") + + # Run the actual tests + run_test() +except (gdb.error): + print ("GDB Exception: %s" % (sys.exc_info()[0])) + failcount += 1 + pass + +print("All tests complete: %d failures" % failcount) +exit(failcount)