Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3000122ybt; Mon, 29 Jun 2020 12:32:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyBz5BnPhBTXsrWb+QMr/MOk1KxbNi28kWMheRzqpgH5QzJJakMk2Ge/Ukxcq4OhMCUi/qG X-Received: by 2002:a17:906:2e83:: with SMTP id o3mr11798864eji.261.1593459143078; Mon, 29 Jun 2020 12:32:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593459143; cv=none; d=google.com; s=arc-20160816; b=rg7Tu5CxATQjtij4DQAZKjMLi6NtIrQlCRM/4S1WJ14RO9REX7XrHggLHA21Kle3F9 kkVlhMNqxgfAL8NTQVL6NCXeDGBkHgI04H0BA2rkzhbbRE1OGStjyybzdmcrhVIGK7Tg NQOQpnYoezpcEV4Ie1WmcJtSlBEEH+yNh4jL050zv+7eK6117sU9loRpeTUm2L4DI/nh DxYUp60u+D2QuQ2BRyqCguW4eH8mjkHbkQgSLYCoryMiI/7l4FHppxeM2B75s34aTZKj BaGBPBMuVBS+d4VBcavmxIkddP1U49i0HK3FbOhX9QHhKMHEMQDzvgveL+0VSthCbNxg KXlQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=jQx0z6+GVKrcjbXyF5nTz+c+VJ7f5gRav7z2QcorLgs=; b=Rv/4NZS1ig3leTcirbQ3aY3jX12p2kTr0XWj+LWLEzsQEMx8OqhO0pCGOHs+/VR3fd iJ0RKiopRW07TKPpO/Vby2yr3goYlfUNisU0mFFAlHwQYjeZHvCNYR2q4XEjPCys5hOm zX5zX59L9DnIAEiR+oohAFoU9Vc3cI6+YL1oW67MRaRhoVTp3/trk02mI08hmXhd0Jlr LZau7kQvzXO1zFuo1fIJokcMgKvtpk9AQP/m+sB4luzHnJGNlm41hXcO8ZF1iG6gGLTp JUOtD6+w1jaUwvivxKb0OdOTBCkLo3s7+6jeyRBbDJ41AdRYyWN9kiq/D8RX1rTOh8DG nQkQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y19si366152ejb.186.2020.06.29.12.31.58; Mon, 29 Jun 2020 12:32:23 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731689AbgF2Tb4 (ORCPT + 99 others); Mon, 29 Jun 2020 15:31:56 -0400 Received: from mx2.suse.de ([195.135.220.15]:36734 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732448AbgF2Tb2 (ORCPT ); Mon, 29 Jun 2020 15:31:28 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 326E3AD76; Mon, 29 Jun 2020 05:17:22 +0000 (UTC) Subject: Re: [PATCH fsgsbase v2 4/4] x86/fsgsbase: Fix Xen PV support To: Andy Lutomirski , x86@kernel.org Cc: Sasha Levin , linux-kernel@vger.kernel.org, Andrew Cooper , Boris Ostrovsky , Stefano Stabellini , xen-devel@lists.xenproject.org References: From: =?UTF-8?B?SsO8cmdlbiBHcm/Dnw==?= Message-ID: <714d4c04-5907-885f-e23b-baef662f1080@suse.com> Date: Mon, 29 Jun 2020 07:17:20 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 26.06.20 19:24, Andy Lutomirski wrote: > On Xen PV, SWAPGS doesn't work. Teach __rdfsbase_inactive() and > __wrgsbase_inactive() to use rdmsrl()/wrmsrl() on Xen PV. The Xen > pvop code will understand this and issue the correct hypercalls. > > Cc: Boris Ostrovsky > Cc: Juergen Gross > Cc: Stefano Stabellini > Cc: xen-devel@lists.xenproject.org > Signed-off-by: Andy Lutomirski > --- > arch/x86/kernel/process_64.c | 20 ++++++++++++++------ > 1 file changed, 14 insertions(+), 6 deletions(-) > > diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c > index cb8e37d3acaa..457d02aa10d8 100644 > --- a/arch/x86/kernel/process_64.c > +++ b/arch/x86/kernel/process_64.c > @@ -163,9 +163,13 @@ static noinstr unsigned long __rdgsbase_inactive(void) > > lockdep_assert_irqs_disabled(); > > - native_swapgs(); > - gsbase = rdgsbase(); > - native_swapgs(); > + if (!static_cpu_has(X86_FEATURE_XENPV)) { > + native_swapgs(); > + gsbase = rdgsbase(); > + native_swapgs(); > + } else { > + rdmsrl(MSR_KERNEL_GS_BASE, gsbase); > + } > > return gsbase; > } > @@ -182,9 +186,13 @@ static noinstr void __wrgsbase_inactive(unsigned long gsbase) > { > lockdep_assert_irqs_disabled(); > > - native_swapgs(); > - wrgsbase(gsbase); > - native_swapgs(); > + if (!static_cpu_has(X86_FEATURE_XENPV)) { > + native_swapgs(); > + wrgsbase(gsbase); > + native_swapgs(); > + } else { > + wrmsrl(MSR_KERNEL_GS_BASE, gsbase); > + } > } > > /* > Another possibility would be to just do (I'm fine either way): diff --git a/arch/x86/xen/enlighten_pv.c b/arch/x86/xen/enlighten_pv.c index acc49fa6a097..b78dd373adbf 100644 --- a/arch/x86/xen/enlighten_pv.c +++ b/arch/x86/xen/enlighten_pv.c @@ -318,6 +318,8 @@ static void __init xen_init_capabilities(void) setup_clear_cpu_cap(X86_FEATURE_XSAVE); setup_clear_cpu_cap(X86_FEATURE_OSXSAVE); } + + setup_clear_cpu_cap(X86_FEATURE_FSGSBASE); } static void xen_set_debugreg(int reg, unsigned long val) Juergen