Received: by 10.213.65.68 with SMTP id h4csp1664939imn; Mon, 19 Mar 2018 10:01:50 -0700 (PDT) X-Google-Smtp-Source: AG47ELvYiAvJ8h8MzC9GZJoOdc17Xscg5gJMh+IvDI18zCKg9caFmh2IXwJ5Rislq1VF4eihXqXB X-Received: by 2002:a17:902:6d0f:: with SMTP id s15-v6mr13422728plk.375.1521478910652; Mon, 19 Mar 2018 10:01:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521478910; cv=none; d=google.com; s=arc-20160816; b=nOxLedIuv3IETFnkD4wb616VnfHvOw2VigVluwu/hCDmmxKs7PQ7dhMoUvGDbou0q+ I3WyTXtEKTowFLvVa1Gxs0yxKcxj63+IFNIddpzlbWJ8MgPpgsiYR9y+PKdZvm/SsCar ldTZHdmhHQGz1RUKuxvjkuZXst7PEGtzNTxNXCCch5Gtf4frUJ4LcQ+Hp5vncLurH3Kc 3D8jb4Pnof69QiiyLzDchHkcpabJkj8eSaYh90iLuIF/is6LGhkGWYjgCs9cRVczjwWi XUkJJ3EOMiT/h2zmuHlBX3bTCGbpEGVpfEAYIBRjtUQetUYp3CCaTc1O9C15YNxWh31Z wopw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=I7f3rrp2I6YVCAw1hCsJGPmOYiDPTy3hG7ZLUvUC1A4=; b=vNt4aCcGxhn2AivNGdNGoQMBEjGdZkT8PS9/PbHcuObx+Laypmb9MhMb20JkAV0C2I 1ZfW63fGd6XxuIXLJe/SeRvoo37fSDvO2nXBDAwxhnxryq2JvG7wQc8+V6ZTRp6N4bwK ti6kG4faU7acsDVaSQcIT7sQt9+2qPb90BnQ76kT755EpS/NVud79ByFYRkD2Hq7RDGJ VNV+lnN0AJ8m63Zmi+jjxlBUFMEs2o+fQ/RjtN6Uf5IpG75yGqG67JjV5tVc1WWx5HSh 1KPCr74hxadQSJHu1hJcjJWMyUYYkYGaBRMxYq0w5tRPRaCqYC5JX9bED+ZAFUmoMxKI OpVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Opn2VLK3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w18-v6si206709plq.357.2018.03.19.10.01.32; Mon, 19 Mar 2018 10:01:50 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Opn2VLK3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935041AbeCSQ6f (ORCPT + 99 others); Mon, 19 Mar 2018 12:58:35 -0400 Received: from mail-qt0-f196.google.com ([209.85.216.196]:39404 "EHLO mail-qt0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935103AbeCSQ6S (ORCPT ); Mon, 19 Mar 2018 12:58:18 -0400 Received: by mail-qt0-f196.google.com with SMTP id v11so10770424qtj.6 for ; Mon, 19 Mar 2018 09:58:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=I7f3rrp2I6YVCAw1hCsJGPmOYiDPTy3hG7ZLUvUC1A4=; b=Opn2VLK3fXtfHEamkZkwa1tIjBcjdGI5VH8W8QMgmDiviKBsEr8spv0hAs48E7QOyW zOzeXT2m7mp9u/icGLmBmcBacXCc1VY3yOrt+SbxF4PBI+PFkUUJQymOrr7JOFraQQib qB0eEXpASbm7kVbomrf4vESaRCiiooo2p/GkU36vmMXR31mBEtr984Kw/Z51A8XqpDNu aj+K79jPiOORHchirbI/ef3IDO2SUFVqcJKJj1e4gvkfYAV/3XivvsHOkacpD0TR+Tnl 1QWAL00IQ9HEXIPVzOJjRTKpFFgNsJQVE5Rzl1B1c2OXYsYhQVNansxEETML1e2Xjjnb ZtLQ== 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; bh=I7f3rrp2I6YVCAw1hCsJGPmOYiDPTy3hG7ZLUvUC1A4=; b=YM+f1fl/mLaR2vtffildUYwA+wpaLopOyCsRTPBW/0MDCfQf7KQQinyaNgQUbxrujT 6BGM1PfY/pyMMg3wKbtlgHiJsheJZFn6CoYGfnF4lxplKBucJUZCf8yE7+mRKFm7J4fM WxbK1P4tpzVFQVk6b+/Ml9Uxmz5+xBjUsEPB9c9a1lcygKL2TSvbKxU26KvOp+ADkZHe Dze8JUuyuTjrYY4WUm4OKRTuB5XEtX55v6EtRFGxmDpniD2bIG2TKRZ2X6aH2s6/YQ4v MadPaeuKJWSVOvXZmbqxpqC/q4I3EViFd/ByCwoU6OU73F3uEmD9OyL6ZmGXTiXBIZCZ TS/A== X-Gm-Message-State: AElRT7FIYa/7rxKIH/jycW3TylZIDXNP/SGEmQYiN3x9RO1PzS5iMyve vVVZDrYpNaQScXQdxMvlCTg= X-Received: by 10.200.22.116 with SMTP id x49mr19402445qtk.326.1521478697733; Mon, 19 Mar 2018 09:58:17 -0700 (PDT) Received: from pm2-ws13.praxislan02.com ([2001:470:8:67e:256d:9ccd:7b56:7891]) by smtp.gmail.com with ESMTPSA id m127sm26386qkd.90.2018.03.19.09.58.16 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 19 Mar 2018 09:58:16 -0700 (PDT) From: Jason Andryuk To: Boris Ostrovsky , Juergen Gross Cc: Jason Andryuk , Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , x86@kernel.org, xen-devel@lists.xenproject.org, linux-kernel@vger.kernel.org Subject: [PATCH] x86/xen: Delay get_cpu_cap until stack canary is established Date: Mon, 19 Mar 2018 12:58:04 -0400 Message-Id: <20180319165804.10636-1-jandryuk@gmail.com> X-Mailer: git-send-email 2.14.3 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit 2cc42bac1c79 ("x86-64/Xen: eliminate W+X mappings") introduced a call to get_cpu_cap, which is fstack-protected. This is works on x86-64 as commit 4f277295e54c ("x86/xen: init %gs very early to avoid page faults with stack protector") ensures the stack protector is configured, but it it did not cover x86-32. Delay calling get_cpu_cap until after xen_setup_gdt has initialized the stack canary. Without this, a 32bit PV machine crashes early in boot. (XEN) Domain 0 (vcpu#0) crashed on cpu#0: (XEN) ----[ Xen-4.6.6-xc x86_64 debug=n Tainted: C ]---- (XEN) CPU: 0 (XEN) RIP: e019:[<00000000c10362f8>] And the PV kernel IP corresponds to init_scattered_cpuid_features 0xc10362f8 <+24>: mov %gs:0x14,%eax Fixes 2cc42bac1c79 ("x86-64/Xen: eliminate W+X mappings") Signed-off-by: Jason Andryuk --- arch/x86/xen/enlighten_pv.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/arch/x86/xen/enlighten_pv.c b/arch/x86/xen/enlighten_pv.c index 3c2c2530737e..c36d23aa6c35 100644 --- a/arch/x86/xen/enlighten_pv.c +++ b/arch/x86/xen/enlighten_pv.c @@ -1259,10 +1259,6 @@ asmlinkage __visible void __init xen_start_kernel(void) */ __userpte_alloc_gfp &= ~__GFP_HIGHMEM; - /* Work out if we support NX */ - get_cpu_cap(&boot_cpu_data); - x86_configure_nx(); - /* Get mfn list */ xen_build_dynamic_phys_to_machine(); @@ -1272,6 +1268,10 @@ asmlinkage __visible void __init xen_start_kernel(void) */ xen_setup_gdt(0); + /* Work out if we support NX */ + get_cpu_cap(&boot_cpu_data); + x86_configure_nx(); + xen_init_irq_ops(); /* Let's presume PV guests always boot on vCPU with id 0. */ -- 2.14.3