From patchwork Mon Mar 16 16:15:16 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Laurent Vivier X-Patchwork-Id: 184575 Delivered-To: patch@linaro.org Received: by 2002:a92:1f12:0:0:0:0:0 with SMTP id i18csp3096232ile; Mon, 16 Mar 2020 10:51:55 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtufVMxq22wWypvoPDFRVpKAAkTJxheAW9vj0Asqfiv5471toBXA36UBb/TEQxVKkUytE7G X-Received: by 2002:a37:6e84:: with SMTP id j126mr847448qkc.77.1584381115194; Mon, 16 Mar 2020 10:51:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584381115; cv=none; d=google.com; s=arc-20160816; b=aE3wUOCSQeC+qPb2ajIcmEPop4lWIs+Vj6JofD7mfgoEO5sUW16WNLe4kz13ydfVLB EYxu2WQcQYRIGKsmQWNSL5uYfYIoKfgIre3d7gZnbwASW9oO0pgtcBQTGSqHP0I6UM6x STRytebqkGT2RD9BciC/kwhusYTwiwnsYqlchukl4wPxcy8PYg9BwFZbXj3jwH5WLVtM CClsmJDWn1p97TM/Aq+jsBUhlFlFYRxsPbFFr3N0Akw7WX6h4eqStW9B3uHkzKg9gehe odqioAy1wBinjpthefqQwq8DnzFle3GSlzfAHqIGkyqoCFEY/d0Pc5dNBtJ9YdiD22wX KpGQ== 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; bh=/ZvV49OFsjmxWSbOxxoXySr5fzZgNd9AeTlb1UBAj0g=; b=etmlC3Yty0z12ZeOwqRe+llxrTltmAYBsRrtrzFuSmq8uIs2zfngdxrElGwUfc1RSI pW2mB04suMR5bVvs0QXGxZoVi8bsJxVSv5rKp66K4BHxuJiWc4GCEsdDgnxK9dGLRTpr wKjad8eFbR+ty6sdOXASkkD5PMSgfD+A1wB1t0BSmZdYqhwElwnmZxjF1CPtPL6iDgRd Kj1gqQmn5Xs0NN5OrSIdSF98kGg7XOczLA9v8IcXcD6E1ugo2UWyZaJVFihc5oeDcaIZ cY9F9w8bO7RTEUwHkW5SdxnieNhPjgYS6tGEVBbeeMJgzoSZ1ElC6OuG6NHYI1tAyv8w ZeSA== ARC-Authentication-Results: i=1; mx.google.com; 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" Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id k22si413882qkk.374.2020.03.16.10.51.55 for (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 16 Mar 2020 10:51:55 -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; 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" Received: from localhost ([::1]:44902 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jDtu6-0004wl-Lf for patch@linaro.org; Mon, 16 Mar 2020 13:51:54 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:40240) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1jDsPc-0007tf-6q for qemu-devel@nongnu.org; Mon, 16 Mar 2020 12:16:21 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1jDsPb-00081i-5V for qemu-devel@nongnu.org; Mon, 16 Mar 2020 12:16:20 -0400 Received: from mout.kundenserver.de ([212.227.126.131]:58519) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1jDsPa-0007qv-SE for qemu-devel@nongnu.org; Mon, 16 Mar 2020 12:16:19 -0400 Received: from localhost.localdomain ([82.252.135.106]) by mrelayeu.kundenserver.de (mreue012 [212.227.15.167]) with ESMTPSA (Nemesis) id 1MWR6x-1ioucO0HkJ-00Xvoy; Mon, 16 Mar 2020 17:16:07 +0100 From: Laurent Vivier To: qemu-devel@nongnu.org Subject: [PULL 04/38] linux-user: Add x86_64 vsyscall page to /proc/self/maps Date: Mon, 16 Mar 2020 17:15:16 +0100 Message-Id: <20200316161550.336150-5-laurent@vivier.eu> X-Mailer: git-send-email 2.24.1 In-Reply-To: <20200316161550.336150-1-laurent@vivier.eu> References: <20200316161550.336150-1-laurent@vivier.eu> MIME-Version: 1.0 X-Provags-ID: V03:K1:aZJhjr1SrOnsZQ0Eh7GbOh1xCz4COGGOOTZHp4QlnihexQ9KgAx OEI24kevWu/iirqAk5ty1OFeu53UcviEnp1PfguCVZp+MB/s8PSC8wHz4R1BYYRqn5+1NbE PDvMR40ZCB4qy58arwxydxR9er0qeCs3KOKOBim+wTOHAURPP58oGFH/IBx4nUnJbNC3ZKL nnCdQC5AIxJJjxKzMpJSA== X-UI-Out-Filterresults: notjunk:1; V03:K0:ksttNYJ3YiM=:RaSS9gfOnXm7Obg/KdtIYh /o2X0KsGwG+fnmVMVoTjd1cjpGfg97JaJ/Tei93aaKDhA+9quhMkOk5yqTavhnQLxiBYgcuVY SoT5X0lQKx0SaFzRxkLvWUfl7RUputVt7OqY9RefGOHnLA4UAZqdIZzG3hLIvpUV6NN21bR5S qH+ge423gqHd1tQ/KQ/iTih/1GK7Aq957Ls7NkXgauTtC4h8cXbaV+BJkKEGKlOe4FRsujaUv Ekxv2VT71kfLd0nRZIDHEJaQIAdtDQBNjaGziEoZshcFLUDpuy5NHrGZn8fnXEcKZiBf9PD+H 8PcnNe8Cop38psjdLXynSLSn0yEIVsCz5dpmAkSKOfBMMk0whOn19jPQ7zH/GPClb5cXurpY0 DUV6BbEkbq4Uf59WdYlOc1CQBRUsIsDp+8kFZyFbf4MyFl2nldER/CkTkQ80KebzVvi5bd2IM SiVbjm+2J+ufAEz8+AMn0cMMLwBZ4ytQv6jYKJXd17fbodoIhIQV9f0+k/6SNDiU+UcpNI6wY 0p8M8B9vfB3hA4bUctTrHzjnlg+DSUIlyLM6I6YmjSCRh/3GE6n3YE6iarGnU4ycEzrnFaIHN DwmtKpHMN8BhzN5AMB0Cb2J0rlvNdlEFvYd6cLpuUVPFGdRhXcPiGutlBq6SbKEKE9IPuGwGK nSiZKtwjbnKWNurQZ0YTpaIRbCiAIcBz9zzI6NNQa+gjt5PAnIS+mv9kivhI4x+6QqpcZ/kMx JJk3zmYTIV73WSDutgellKeoK7IX44VD7MgjN+oE9QJhwvptUU+i+C8lTIKn2cfZC+4Ro96iI y75aRBDf0z7so6mPrISjNhDBrNhOSGRbX3sFRNUtzuE84ZdJ01AT/GEeOs+0ggmqNzYXkNW X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 212.227.126.131 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Riku Voipio , Richard Henderson , Laurent Vivier Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Richard Henderson The page isn't (necessarily) present in the host /proc/self/maps, and even if it might be it isn't present in page_flags, and even if it was it might not have the same set of page permissions. The easiest thing to do, particularly when it comes to the "[vsyscall]" note at the end of line, is to special case it. Signed-off-by: Richard Henderson Message-Id: <20200213032223.14643-5-richard.henderson@linaro.org> [lv: remove trailing whitespace] Signed-off-by: Laurent Vivier --- linux-user/syscall.c | 10 ++++++++++ 1 file changed, 10 insertions(+) -- 2.24.1 diff --git a/linux-user/syscall.c b/linux-user/syscall.c index 8d27d1080752..5479d67a10be 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -7079,6 +7079,16 @@ static int open_self_maps(void *cpu_env, int fd) } } +#ifdef TARGET_VSYSCALL_PAGE + /* + * We only support execution from the vsyscall page. + * This is as if CONFIG_LEGACY_VSYSCALL_XONLY=y from v5.3. + */ + dprintf(fd, TARGET_FMT_lx "-" TARGET_FMT_lx + " --xp 00000000 00:00 0 [vsyscall]\n", + TARGET_VSYSCALL_PAGE, TARGET_VSYSCALL_PAGE + TARGET_PAGE_SIZE); +#endif + free(line); fclose(fp);