From patchwork Wed May 27 10:05:44 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: 187224 Delivered-To: patch@linaro.org Received: by 2002:a92:5b0a:0:0:0:0:0 with SMTP id p10csp974783ilb; Wed, 27 May 2020 03:06:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz6B/rmx5DfSsv1tfWU8eYnWrajEz5z11HE9giKtci5W2mPZKTFI5ZI3FqHIbSSt4DmMVMJ X-Received: by 2002:a25:b70b:: with SMTP id t11mr8821054ybj.171.1590573969101; Wed, 27 May 2020 03:06:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590573969; cv=none; d=google.com; s=arc-20160816; b=BQzLIBwtfDaJ+S7UfkDTCBG0K36KRfkpLj6ApZv7HZp1dMJmiRdTtdG+M5STXNIw5K H6m1K4wVDkA2ZtsSMQZyYqXh7S0Nj9A4dk5v4440YTiCpkBryeNLLiYf9IT229rmmHzA yN6GkBt91REOUNfG/23+SYLGZqvLXkZ+5tam0zLo0/KpdCMdue9uta1iP2diz6aRWhTI Kcfb1CGGeLG5Rj3j7RYjgTF2l9VD2tehTg7UQIZK92E2O+fOvPf/WlJs/anUrKRO/m6P Pd9yIjqMSZfKWOythxT1apckTZjWqOJZqgf2EVYzPpTQOcy5L5byvG4SINpfcYw7xUPT kG1A== 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=Q9g2hw1e4m0meDSSDGhsHzYZBM3E+e3OyOVzFlX36Xg=; b=HRusbVhGWMYLu6X8gR2Z3Ub0QVWjov1Ivw7sZ4x33d43Js7bhFRUVUs3P//FCyk8O4 yE+Ez3OmoD97qnvsm3KTOlqZuUEiHyxnpDs2fUYDvl/hABBNUrs7xHSlYWt87sdLkmja CcdjtytFQgmWU3MEgHNQXlUNtc/ps8X3WJwuLM9R9gV6EKAAj4uoMMpF7E2C26Aeuk4q ZIOzA4Mk8EwS4V45ps9I/6ai/mwvUlKoyKPl6qIQIH2cI3H2YktxgUH3RDRBcumvlH+u QLcESuxBuaR2pMyu19/gx6LSikKDvuxulnEN9Hp/3xsCY/H1sp4ArI/b0LKulImDyPQ4 P1Nw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=L8cIFL3j; 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 p9si2612789ybk.267.2020.05.27.03.06.09 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Wed, 27 May 2020 03:06:09 -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=L8cIFL3j; 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]:48606 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jdswq-0003S7-Im for patch@linaro.org; Wed, 27 May 2020 06:06:08 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:50240) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1jdswa-0003PH-Px for qemu-devel@nongnu.org; Wed, 27 May 2020 06:05:52 -0400 Received: from mail-wr1-x443.google.com ([2a00:1450:4864:20::443]:40712) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1jdswZ-0005C0-Pe for qemu-devel@nongnu.org; Wed, 27 May 2020 06:05:52 -0400 Received: by mail-wr1-x443.google.com with SMTP id j16so10962323wrb.7 for ; Wed, 27 May 2020 03:05: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=Q9g2hw1e4m0meDSSDGhsHzYZBM3E+e3OyOVzFlX36Xg=; b=L8cIFL3jvF31gFLNhZfKcVyUva/SJZkPMo8p6jMPrz9TKGGYK7oi99G/yVQs0l5rxB s2hyzXGbYuN9G3dGjjZ3siAMbUhWWeYgy0sa/IdrzBtzbtYu7DVCx8anPINCqdw6OqBX fQX0N2c90JujLRS0y7xAjIMNn1n7QzS2FmvcaZMbhjrHVWjCiU2bL2n7HJnMpyXvfJVu 6DQEJPA5oIU47rDGAwKPrywGhIL/wENg0u5SxES7ngwlayE3/OhW7e3M5uFI9htloRLg HtZv/DGwcnDddISMtMWQPJuM2FgTMWtxT1HgWSPlNty9edvvsW1yTw8xGxOOHgnqzKOi HEtw== 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=Q9g2hw1e4m0meDSSDGhsHzYZBM3E+e3OyOVzFlX36Xg=; b=J8M9ARb4IZbfnBAFjglodGoXAaT+0zuLB4nZkvpvGHlvG4C7mdFl1Qc9JSw594aLZN WIM3ikA4JvPufu5tOK3XDSb7oyM91FAa9BAR1rNTL1Lc2/0ioNgGJDS4K8pGfHiJXSRq 3TYQ6z/DrdlXfcYaa7uLoTMeF/ABR7lWu3A5/xYN3Y+KYJp5MqKItY53v4BfyQmDGBJ8 Mi9m8HMB+0h/5dDCaCSMkrHv0ejT4v8Zdzclnsem+fDMDHbe+h7E9XwDP/LSLFoIo2wZ zAaQbEDWoqBqraF8tKLH4P/IyTiELkECkBVRLWlPDVsQwDk24BC4nN0rsD3mUXsw1vZr iDmQ== X-Gm-Message-State: AOAM530xbcQxPNZmNrlTA+UUhTKWeyaKhlQZLM++BP8sXnBeWCv5L/Qy 1rof5x/cCbYwdQ7T6j8KjtjZZA== X-Received: by 2002:adf:aa97:: with SMTP id h23mr21461385wrc.251.1590573950239; Wed, 27 May 2020 03:05:50 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id m129sm1971380wmf.2.2020.05.27.03.05.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 May 2020 03:05:47 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id DADDD1FF87; Wed, 27 May 2020 11:05:46 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 1/3] linux-user: provide fallback pgd_find_hole for bare chroots Date: Wed, 27 May 2020 11:05:44 +0100 Message-Id: <20200527100546.29297-2-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200527100546.29297-1-alex.bennee@linaro.org> References: <20200527100546.29297-1-alex.bennee@linaro.org> MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::443; envelope-from=alex.bennee@linaro.org; helo=mail-wr1-x443.google.com X-detected-operating-system: by eggs.gnu.org: No matching host in p0f cache. That's all we know. X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001 autolearn=_AUTOLEARN X-Spam_action: no action 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 , Riku Voipio , qemu-arm@nongnu.org, =?utf-8?q?Alex?= =?utf-8?q?_Benn=C3=A9e?= , Laurent Vivier Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" When running QEMU out of a chroot environment we may not have access to /proc/self/maps. As there is no other "official" way to introspect our memory map we need to fall back to the original technique of repeatedly trying to mmap an address range until we find one that works. Fortunately it's not quite as ugly as the original code given we already re-factored the complications of dealing with the ARM_COMMPAGE. We do make an attempt to skip over brk() which is about the only concrete piece of information we have about the address map at this moment. Fixes: ee9474303 Reported-by: Peter Maydell Signed-off-by: Alex Bennée --- linux-user/elfload.c | 48 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) -- 2.20.1 diff --git a/linux-user/elfload.c b/linux-user/elfload.c index 01a9323a637..d6027867a1a 100644 --- a/linux-user/elfload.c +++ b/linux-user/elfload.c @@ -2099,6 +2099,50 @@ static void pgb_have_guest_base(const char *image_name, abi_ulong guest_loaddr, } } +/** + * pgd_find_hole_fallback: potential mmap address + * @guest_size: size of available space + * @brk: location of break + * @align: memory alignment + * + * This is a fallback method for finding a hole in the host address + * space if we don't have the benefit of being able to access + * /proc/self/map. It can potentially take a very long time as we can + * only dumbly iterate up the host address space seeing if the + * allocation would work. + */ +static uintptr_t pgd_find_hole_fallback(uintptr_t guest_size, uintptr_t brk, long align) +{ + uintptr_t base; + + /* Start at the bottom and work our way up */ + base = mmap_min_addr; + + while (true) { + uintptr_t align_start, end; + align_start = ROUND_UP(base, align); + end = align_start + guest_size; + + /* if brk is anywhere in the range give ourselves some room to grow. */ + if (align_start <= brk && brk < end) { + base += 16 * MiB; + continue; + } else if (align_start + guest_size < align_start) { + /* we have run out of space */ + return -1; + } else { + int flags = MAP_ANONYMOUS | MAP_PRIVATE | MAP_NORESERVE | MAP_FIXED; + void * mmap_start = mmap((void *) align_start, guest_size, + PROT_NONE, flags, -1, 0); + if (mmap_start != MAP_FAILED) { + munmap((void *) align_start, guest_size); + return (uintptr_t) mmap_start; + } + base += qemu_host_page_size; + } + } +} + /* 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) @@ -2114,6 +2158,10 @@ static uintptr_t pgb_find_hole(uintptr_t guest_loaddr, uintptr_t guest_size, /* Read brk after we've read the maps, which will malloc. */ brk = (uintptr_t)sbrk(0); + if (!maps) { + return pgd_find_hole_fallback(guest_size, brk, align); + } + /* The first hole is before the first map entry. */ this_start = mmap_min_addr; From patchwork Wed May 27 10:05:45 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: 187225 Delivered-To: patch@linaro.org Received: by 2002:a92:5b0a:0:0:0:0:0 with SMTP id p10csp975445ilb; Wed, 27 May 2020 03:07:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz7g6P9FTZ1b2XuDyCMhsG/6YPQbR1+3PzdL7RzxqmnwTu3KVblejmCprCYt3+pGyEHtxjm X-Received: by 2002:a25:76c5:: with SMTP id r188mr9568550ybc.71.1590574022638; Wed, 27 May 2020 03:07:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590574022; cv=none; d=google.com; s=arc-20160816; b=M3MhpuVkYctf8IW5pqXiNqJfAroDPIBtjJtbI9Cupy0NzRnNo+Xuz6sP9qgXjiJ/Ea 9RbgkElKHIydpuzAk0AKH01yAJgjlwDCQqpKzg6AJPrkGNMgXDs2zBy9uvVHG+E6ObmT BWJi2mG6kmxQ+6dfBM9+PCe5bYjgS3tJP9/1A7jaCtYhWKVFMihrhqTfTpHYHTTTb2EC 13KlxTr0NwOAfjgq2bwa6D+Q67J7tSZ8ZVDG1naOvWUmwRVTHvxoX5V6Vq8Ks9qwF/5h vZU6KezrEeLIs6ea0W+AI7CpwZaQqTyTbtclxA7zz3r0bbCNQDkK5fQII1T6PUasAjR0 Queg== 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=b1rnVPfR5Tx3kSg0YJymoHV+oJytl6k3F5aYs9rOE0Y=; b=d6GkC5f1yYBcFr1xUh6ClLIBFdKNVzs9AwD/wOOrU/Ib8Gp9bCqCetpGvNxLA3QB37 v0xht+1591jwPofxC5e8TW1455DurvV/Fo9VYaKNdbc4KWeO0G9YKgOZMFxI7J4RRnCe +yth1ib3PVR5a5fnZhDqsaZJS6XKmddcAbneIvjhLqQrSPOK+QSV7XqQLu4lp/9SIfzk 4xdOD3/30rwGIohN2Kb7rxxMIkPdZx1uYdsuJXGjRBC0PDSjm1Sx4CWMmnbLTAoz7ePE yYcMdx/M0xEZ+T7JMrEIDu8kHELEiAykvrZlXX3tjS0oXodpO7hd6Okl0A7rf9iZgKfJ rBLg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=HSvZhak5; 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 x124si2314429ybc.82.2020.05.27.03.07.02 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Wed, 27 May 2020 03:07:02 -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=HSvZhak5; 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]:50348 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jdsxi-00049q-51 for patch@linaro.org; Wed, 27 May 2020 06:07:02 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:50276) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1jdswd-0003UI-V3 for qemu-devel@nongnu.org; Wed, 27 May 2020 06:05:55 -0400 Received: from mail-wr1-x443.google.com ([2a00:1450:4864:20::443]:40713) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1jdswc-0005D2-F8 for qemu-devel@nongnu.org; Wed, 27 May 2020 06:05:55 -0400 Received: by mail-wr1-x443.google.com with SMTP id j16so10962462wrb.7 for ; Wed, 27 May 2020 03:05:54 -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=b1rnVPfR5Tx3kSg0YJymoHV+oJytl6k3F5aYs9rOE0Y=; b=HSvZhak5TuyQi5IWGcjjOMlGbsZjF0Y+Pnnp7jg47KH8u9bziJp1RV+tyAD8bqemmj sc/d231xp3cX+xmGHphArsopMn6lH4g2eue939MRJSO1nEtp6Jj3Tk3yPfrwMK56wjfo SFiRSetkMr+HF+8kY22xMxhxb0X6xfXRQPxEQ2ylQ7GYpvdWMhKA0qcdjWSA/bVumNaK NEdKLeLeXzvfLE3oBy7g5IRI3lYpBGvjdfhDcdfQzVt0Od5/5KikGl0x2tUv/SrHCz0A 5NkszQYUfLpf36LG+LhnfKdleLh4PIGeovJAB/N5J3ouDj3YeUsiA6H2/s5xdju4BbPR Ux1Q== 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=b1rnVPfR5Tx3kSg0YJymoHV+oJytl6k3F5aYs9rOE0Y=; b=luCWEfqqms3TYeP7ofYO8ivXWwXIh7ajuvf8gOsQB7LYMzhMWslKF9LlcFLWmXZSRn imf+39Tq2L8bGNcXRFTR/iiEY1qLhVzIxxet9AtJ8X6ILP5evIR50AZ1yy+a5oDrwUs9 6Kq1FOp4LqV6IfjmfcOuFbpSLA6L6Hye/hAsmjLoEf+a5Q9MtCJNck38aRsq8KuQrAGc wj3aGBI2DtS17sjTg7AoslyW4r45om6yl0DH9FZE9rQpFJ6yWNnqEo2RhZpnrTTG4e1q u+EH7/eOheboVEaqO+f6Tcy/BY62A2lpPxvmAC9zBUkHUbboQHMa22VkFDE8bmzcqY0I q7/g== X-Gm-Message-State: AOAM530r04wcHUbiRyEryaRxsxNNJTvFtB8xHIGuO9a2efu+Ik8FyTXt 22uEf3iCj9tGW/6blS9fPCgm7w== X-Received: by 2002:adf:814a:: with SMTP id 68mr24367324wrm.177.1590573952701; Wed, 27 May 2020 03:05:52 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id t6sm2202626wma.4.2020.05.27.03.05.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 May 2020 03:05:50 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 128271FF8C; Wed, 27 May 2020 11:05:47 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 2/3] linux-user: deal with address wrap for ARM_COMMPAGE on 32 bit Date: Wed, 27 May 2020 11:05:45 +0100 Message-Id: <20200527100546.29297-3-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200527100546.29297-1-alex.bennee@linaro.org> References: <20200527100546.29297-1-alex.bennee@linaro.org> MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::443; envelope-from=alex.bennee@linaro.org; helo=mail-wr1-x443.google.com X-detected-operating-system: by eggs.gnu.org: No matching host in p0f cache. That's all we know. X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001 autolearn=_AUTOLEARN X-Spam_action: no action 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 , Bug 1880225 <1880225@bugs.launchpad.net>, Riku Voipio , Richard Henderson , Laurent Vivier , qemu-arm@nongnu.org, =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" We rely on the pointer to wrap when accessing the high address of the COMMPAGE so it lands somewhere reasonable. However on 32 bit hosts we cannot afford just to map the entire 4gb address range. The old mmap trial and error code handled this by just checking we could map both the guest_base and the computed COMMPAGE address. We can't just manipulate loadaddr to get what we want so we introduce an offset which pgb_find_hole can apply when looking for a gap for guest_base that ensures there is space left to map the COMMPAGE afterwards. This is arguably a little inefficient for the one 32 bit value (kuser_helper_version) we need to keep there given all the actual code entries are picked up during the translation phase. Fixes: ee94743034b Bug: https://bugs.launchpad.net/qemu/+bug/1880225 Cc: Bug 1880225 <1880225@bugs.launchpad.net> Signed-off-by: Alex Bennée Cc: Richard Henderson Cc: Peter Maydell --- linux-user/elfload.c | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) -- 2.20.1 Tested-by: Aleksandar Markovic diff --git a/linux-user/elfload.c b/linux-user/elfload.c index d6027867a1a..31defce95b5 100644 --- a/linux-user/elfload.c +++ b/linux-user/elfload.c @@ -2145,7 +2145,7 @@ static uintptr_t pgd_find_hole_fallback(uintptr_t guest_size, uintptr_t brk, lon /* 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) + long align, uintptr_t offset) { GSList *maps, *iter; uintptr_t this_start, this_end, next_start, brk; @@ -2171,7 +2171,7 @@ static uintptr_t pgb_find_hole(uintptr_t guest_loaddr, uintptr_t guest_size, this_end = ((MapInfo *)iter->data)->start; next_start = ((MapInfo *)iter->data)->end; - align_start = ROUND_UP(this_start, align); + align_start = ROUND_UP(this_start + offset, align); /* Skip holes that are too small. */ if (align_start >= this_end) { @@ -2221,6 +2221,7 @@ static void pgb_static(const char *image_name, abi_ulong orig_loaddr, { uintptr_t loaddr = orig_loaddr; uintptr_t hiaddr = orig_hiaddr; + uintptr_t offset = 0; uintptr_t addr; if (hiaddr != orig_hiaddr) { @@ -2234,18 +2235,19 @@ static void pgb_static(const char *image_name, abi_ulong orig_loaddr, 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. + * For a 64-bit host, this is just 4GiB; for a 32-bit host we + * need to ensure there is space bellow the guest_base so we + * can map the commpage in the place needed when the address + * arithmetic wraps around. */ if (sizeof(uintptr_t) == 8 || loaddr >= 0x80000000u) { hiaddr = (uintptr_t)4 << 30; } else { - loaddr = ARM_COMMPAGE & -align; + offset = (128 * KiB); } } - addr = pgb_find_hole(loaddr, hiaddr - loaddr, align); + addr = pgb_find_hole(loaddr, hiaddr - loaddr, align, offset); if (addr == -1) { /* * If ARM_COMMPAGE, there *might* be a non-consecutive allocation @@ -2280,7 +2282,7 @@ static void pgb_dynamic(const char *image_name, long align) * just above that, and maximises the positive guest addresses. */ commpage = ARM_COMMPAGE & -align; - addr = pgb_find_hole(commpage, -commpage, align); + addr = pgb_find_hole(commpage, -commpage, align, 0); assert(addr != -1); guest_base = addr; } From patchwork Wed May 27 10:05:46 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: 187226 Delivered-To: patch@linaro.org Received: by 2002:a92:5b0a:0:0:0:0:0 with SMTP id p10csp975794ilb; Wed, 27 May 2020 03:07:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxOYOTG083EcCygtKnEhxjzXWRxAZFiDFm5O856Zlg5/44Fd5+mOUcvO1DLfle2ThJIYSTf X-Received: by 2002:a05:620a:22d0:: with SMTP id o16mr3001800qki.345.1590574053528; Wed, 27 May 2020 03:07:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590574053; cv=none; d=google.com; s=arc-20160816; b=zDhfrRY3AWGVWmmx0xYk7ydbiM6GX4mZQDGLhQo1F+acXYPqcpEvLJdv+SYbL2famt woEHoBghxmYaD0uMxsqk14JSK+vZQ8EPOIWYru5Cgs87QjvNg7xO3iOiNMtcbYt/A/T+ yhaQklfzwpdILw3icowbxIFDOUgFD0tzE4WkUnt/HyQO3LviRvlyLXV6I/OTsoucCB4a tWaO1GboO06jASusmxwL88dJyhShz5eBCzPvg0tKHQuK+0zezChctYc/V2VaczvWKGZB cyFjcpRcyIDWmgt9z5Sw3hkR6mAg0wLBdc2HhzVP0Tbrp7ZnLmbo4GUcvjk4nEdFdrv1 qy0Q== 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=7BwVQR+RWIzqLy1PIq/KCliSSJ727LeNTpr8QNS3EBg=; b=w714vC4qvseI6+Rf6qx2OlmCJ0OlUT0lkbVjdWjX4PJn8Jxyxybl4dX5zx+92iJkPz QL1lJQpb1fCUQAk8y9q6gC2gubWLdskBsPvrptiK7SKKN4XCZTtbMJWQ4o537lkAXbHr J2kJMNMvh0HewXGXboeEU3YrLrpBPiokLY5PrFuifQlR/ZwHzy+9HvBDU0Am+RI05zIp /Ye6ejN7mdl5YwVQhBBzpuAttdG6L9Qb7Wpaz1WWt2Yb022e1NurSQ0KG7Xe3EUZLoX4 2Eywky7GuxN6RAU3khUBv9DGb0v9lkTr7WClkxa2I+mFDaGPkgoIQ6moQqxEH77cvMfa u4WQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=OijwdnFo; 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 p16si1350248qtj.43.2020.05.27.03.07.33 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Wed, 27 May 2020 03:07:33 -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=OijwdnFo; 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]:55100 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jdsyD-0006WN-2K for patch@linaro.org; Wed, 27 May 2020 06:07:33 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:50278) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1jdswd-0003UU-UM for qemu-devel@nongnu.org; Wed, 27 May 2020 06:05:55 -0400 Received: from mail-wr1-x441.google.com ([2a00:1450:4864:20::441]:41529) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1jdswb-0005CZ-Cm for qemu-devel@nongnu.org; Wed, 27 May 2020 06:05:55 -0400 Received: by mail-wr1-x441.google.com with SMTP id j10so7799058wrw.8 for ; Wed, 27 May 2020 03:05: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=7BwVQR+RWIzqLy1PIq/KCliSSJ727LeNTpr8QNS3EBg=; b=OijwdnFog7MJOKgQXuIpzoT9zTo2dRa22snN1e8PLCTgtegtiufaLSHXf31GGRSzo5 i3EmIUqduEqP3s20UJIESHxq2Sy0zkU5gqtWbjJKOz6lqcH9VpTyX3iX4Zz+V++zEPbM nrWxXM6MVBIh9YyzSp12zYwLWdsWad/KhJAJMi29K+8Snk0AvjBPmvUVj3RPyduqeOGf yRRu5ZGGq/gO2hXnEAA2Vdp1PPdaAe0185NhbFZcH4TUfPbw3vSLf9CE7TqoWY2uGtPm Rt3OLk9viPuNE04H6uqTp/Y6NhiNGKB113jJejopfwxKOK0T1lrxS2uiwGQoHxT7VqfR Na7A== 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=7BwVQR+RWIzqLy1PIq/KCliSSJ727LeNTpr8QNS3EBg=; b=n9xBy2tdz3ssqYvdt7QBaMWtkRIsA4Ca69bo3zKtfEnqHlP3mJiKhjHxN7QZCS77/k oTaIRBVBbvyfNrg/sm2r8izx6TK9CDI9VQOCpCbppiQgaWW9y7vV9cz8FAifzPn0YCWV LSNHCXvvzkrHQg+aEbh0He6rZSqQ86HZZetvldJ2DG86aMhuiFJypk3PqCjHRnJGBKbK Ry/HPbZo9kyzCewBRFiXufnfob5NJCM+AR39jdlG1II4b6qco6W/mBDa7g+qiXMTwk5h pSmCG+14EGiLZcrk5z6nr9RAliQ+N7dnAoiGK1ZzhwpdBsGMIJBeeYA5wWpFY4vOuSGz 4qcQ== X-Gm-Message-State: AOAM5321Mra5RPHiL7jIovFA6i2Z4Q9PPuvO+rSSyMvVppbgOQAbadwZ 252NTATJR2c4YNk3Ax48D+akdg== X-Received: by 2002:adf:e38e:: with SMTP id e14mr25153823wrm.2.1590573951548; Wed, 27 May 2020 03:05:51 -0700 (PDT) Received: from zen.linaroharston ([51.148.130.216]) by smtp.gmail.com with ESMTPSA id t6sm2202636wma.4.2020.05.27.03.05.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 May 2020 03:05:50 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id 479B81FF8F; Wed, 27 May 2020 11:05:47 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Subject: [PATCH v1 3/3] tests/tcg: add simple commpage test case Date: Wed, 27 May 2020 11:05:46 +0100 Message-Id: <20200527100546.29297-4-alex.bennee@linaro.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200527100546.29297-1-alex.bennee@linaro.org> References: <20200527100546.29297-1-alex.bennee@linaro.org> MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::441; envelope-from=alex.bennee@linaro.org; helo=mail-wr1-x441.google.com X-detected-operating-system: by eggs.gnu.org: No matching host in p0f cache. That's all we know. X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001 autolearn=_AUTOLEARN X-Spam_action: no action 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 , qemu-arm@nongnu.org, =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" The COMMPAGE are a number of kernel provided user-space routines for 32 bit ARM systems. Add a basic series of smoke tests to ensure it is working as it should. Signed-off-by: Alex Bennée --- tests/tcg/arm/commpage.c | 61 +++++++++++++++++++++++++++++++++++ tests/tcg/arm/Makefile.target | 2 ++ 2 files changed, 63 insertions(+) create mode 100644 tests/tcg/arm/commpage.c -- 2.20.1 Reviewed-by: Richard Henderson diff --git a/tests/tcg/arm/commpage.c b/tests/tcg/arm/commpage.c new file mode 100644 index 00000000000..c76e70cb8bd --- /dev/null +++ b/tests/tcg/arm/commpage.c @@ -0,0 +1,61 @@ +/* + * Verify the COMMPAGE emulation + * + * The ARM commpage is a set of user space helper functions provided + * by the kernel in an effort to ease portability of user space code + * between different CPUs with potentially different capabilities. It + * is a 32 bit invention and similar to the vdso segment in many ways. + * + * The ABI is documented in the Linux kernel: + * Documentation/arm/kernel_userspace_helpers.rst + * + * Copyright (c) 2020 Linaro Ltd + * + * SPDX-License-Identifier: GPL-2.0-or-later + */ + +#include +#include +#include + +#define ARM_COMMPAGE (0xffff0f00u) +#define ARM_KUSER_VERSION (*(int32_t *)(ARM_COMMPAGE + 0xfc)) +typedef void * (get_tls_fn)(void); +#define ARM_KUSER_GET_TLS (*(get_tls_fn *)(ARM_COMMPAGE + 0xe0)) +typedef int (cmpxchg_fn)(int oldval, int newval, volatile int *ptr); +#define ARM_KUSER_CMPXCHG (*(cmpxchg_fn *)(ARM_COMMPAGE + 0xc0)) +typedef void (dmb_fn)(void); +#define ARM_KUSER_DMB (*(dmb_fn *)(ARM_COMMPAGE + 0xa0)) +typedef int (cmpxchg64_fn)(const int64_t *oldval, + const int64_t *newval, + volatile int64_t *ptr); +#define ARM_KUSER_CMPXCHG64 (*(cmpxchg64_fn *)(ARM_COMMPAGE + 0x60)) + +#define fail_unless(x) \ + do { \ + if (!(x)) { \ + fprintf(stderr, "FAILED at %s:%d\n", __FILE__, __LINE__); \ + exit(EXIT_FAILURE); \ + } \ + } while (0) + + +int main(int argc, char *argv[argc]) +{ + void *kuser_tls; + int val = 1; + const int64_t oldval = 1, newval = 2; + int64_t val64 = 1; + + fail_unless(ARM_KUSER_VERSION == 0x5); + kuser_tls = ARM_KUSER_GET_TLS(); + printf("TLS = %p\n", kuser_tls); + fail_unless(kuser_tls != 0); + fail_unless(ARM_KUSER_CMPXCHG(1, 2, &val) == 0); + printf("val = %d\n", val); + /* this is a crash test, not checking an actual barrier occurs */ + ARM_KUSER_DMB(); + fail_unless(ARM_KUSER_CMPXCHG64(&oldval, &newval, &val64) == 0); + printf("val64 = %lld\n", val64); + return 0; +} diff --git a/tests/tcg/arm/Makefile.target b/tests/tcg/arm/Makefile.target index 11c39c601ea..3da09a38be7 100644 --- a/tests/tcg/arm/Makefile.target +++ b/tests/tcg/arm/Makefile.target @@ -68,6 +68,8 @@ run-semiconsole-arm: semiconsole-arm run-plugin-semiconsole-arm-with-%: $(call skip-test, $<, "MANUAL ONLY") +ARM_TESTS += commpage + TESTS += $(ARM_TESTS) # On ARM Linux only supports 4k pages