Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3158346imm; Fri, 10 Aug 2018 04:54:40 -0700 (PDT) X-Google-Smtp-Source: AA+uWPxa5aFgQZCpPtnI2wBG6rH5wd6tr2wxjIRPPBlIjYh2nVBEq9nLSRbENs/LfxMF0JFdW+p7 X-Received: by 2002:a17:902:7587:: with SMTP id j7-v6mr5883752pll.256.1533902080740; Fri, 10 Aug 2018 04:54:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533902080; cv=none; d=google.com; s=arc-20160816; b=hZLKiTPBf27PBwNDFusb2IsAc1Qko3ikJjWsz5e3iMYbc3/14zqb74q677i4l/u1eg QTu0AFw9V2J2BrwZ7UntXNwDalwCNj/fRAdoGn7R4E+gedn3fIV6s+vhwEeqY56ubflZ DdGhXhQaqIUMKLPu9D5gwGmk9wbJq4eNx34uPaKiPzWHwtp3Fi6CdMD+DFHrjvye2Wss S41w3+DyjtehNfd8b0pklANAMqshzt9S8AInQ6B2kZ8cecLt4+o+GXHCRf+Ykzs7h/Mz YcYuEMOZDqHUtvnPhfImO/lJ7QkJVUUPpGpYbgie/SdOtjEcIvJD9Ywts8+bRcwPoPEd Qhig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=0UkleM/ykdsgtWrWBIFw16IvndrdZEJvvdf371W7SYM=; b=fG4Z8Xrzs1yxn4MiUeRLqmJhgINSmt2kvLR+zKxEJFnYen2HDqs8g6eXoVXFn6KzUN qHiAXJN+RQgrnldHtGqZF7murIhgcXIbGHeRRJm6xcAobz36kEk81YyiZqtSblvofJ9W nQBADt9ZCs6InrFVBXYHOs6PrjiigihzDgu0/Y5AsTUf8FZ3Ae7/Tbt3wWNx7NS+/JcR jKWbg3GSAYldykjkwenmP6bhGsGUfY6cQ3RoNqUZH1SkhyS7CPC5S18Nk+CtjSkINmsC JAYIDkEUJzkHAj2QpLXhTmK0sQFulGQi2atlZxifMle7cH1kVKBVKjhNOy4ywaMCdLvn ASjQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g15-v6si7852661plo.284.2018.08.10.04.54.26; Fri, 10 Aug 2018 04:54:40 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728085AbeHJOWi (ORCPT + 99 others); Fri, 10 Aug 2018 10:22:38 -0400 Received: from mx2.suse.de ([195.135.220.15]:38770 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727674AbeHJOWh (ORCPT ); Fri, 10 Aug 2018 10:22:37 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 91D03AEB4; Fri, 10 Aug 2018 11:52:58 +0000 (UTC) From: Juergen Gross To: linux-kernel@vger.kernel.org, xen-devel@lists.xenproject.org, x86@kernel.org, virtualization@lists.linux-foundation.org Cc: akataria@vmware.com, rusty@rustcorp.com.au, boris.ostrovsky@oracle.com, hpa@zytor.com, tglx@linutronix.de, mingo@redhat.com, Juergen Gross Subject: [PATCH 07/10] x86/paravirt: move items in pv_info under PARAVIRT_XXL umbrella Date: Fri, 10 Aug 2018 13:52:49 +0200 Message-Id: <20180810115252.18213-8-jgross@suse.com> X-Mailer: git-send-email 2.13.7 In-Reply-To: <20180810115252.18213-1-jgross@suse.com> References: <20180810115252.18213-1-jgross@suse.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org All items but name in pv_info are needed by Xen PV only. Define them with CONFIG_PARAVIRT_XXL set only. Signed-off-by: Juergen Gross --- arch/x86/include/asm/paravirt.h | 2 ++ arch/x86/include/asm/paravirt_types.h | 2 ++ arch/x86/include/asm/pgtable-3level_types.h | 2 +- arch/x86/include/asm/ptrace.h | 3 ++- arch/x86/include/asm/segment.h | 2 +- arch/x86/kernel/paravirt.c | 2 ++ 6 files changed, 10 insertions(+), 3 deletions(-) diff --git a/arch/x86/include/asm/paravirt.h b/arch/x86/include/asm/paravirt.h index 436d270e622b..afc0469979f7 100644 --- a/arch/x86/include/asm/paravirt.h +++ b/arch/x86/include/asm/paravirt.h @@ -104,7 +104,9 @@ static inline void wbinvd(void) PVOP_VCALL0(pv_cpu_ops.wbinvd); } +#ifdef CONFIG_PARAVIRT_XXL #define get_kernel_rpl() (pv_info.kernel_rpl) +#endif static inline u64 paravirt_read_msr(unsigned msr) { diff --git a/arch/x86/include/asm/paravirt_types.h b/arch/x86/include/asm/paravirt_types.h index ed024e90b863..f1bdc4c9ff4c 100644 --- a/arch/x86/include/asm/paravirt_types.h +++ b/arch/x86/include/asm/paravirt_types.h @@ -65,12 +65,14 @@ struct paravirt_callee_save { /* general info */ struct pv_info { +#ifdef CONFIG_PARAVIRT_XXL unsigned int kernel_rpl; int shared_kernel_pmd; #ifdef CONFIG_X86_64 u16 extra_user_64bit_cs; /* __USER_CS if none */ #endif +#endif const char *name; }; diff --git a/arch/x86/include/asm/pgtable-3level_types.h b/arch/x86/include/asm/pgtable-3level_types.h index 6a59a6d0cc50..1aa68ca1907c 100644 --- a/arch/x86/include/asm/pgtable-3level_types.h +++ b/arch/x86/include/asm/pgtable-3level_types.h @@ -20,7 +20,7 @@ typedef union { } pte_t; #endif /* !__ASSEMBLY__ */ -#ifdef CONFIG_PARAVIRT +#ifdef CONFIG_PARAVIRT_XXL #define SHARED_KERNEL_PMD (pv_info.shared_kernel_pmd) #else #define SHARED_KERNEL_PMD 1 diff --git a/arch/x86/include/asm/ptrace.h b/arch/x86/include/asm/ptrace.h index 6de1fd3d0097..c9ac6ff5f7d2 100644 --- a/arch/x86/include/asm/ptrace.h +++ b/arch/x86/include/asm/ptrace.h @@ -144,7 +144,8 @@ static inline int v8086_mode(struct pt_regs *regs) static inline bool user_64bit_mode(struct pt_regs *regs) { #ifdef CONFIG_X86_64 -#ifndef CONFIG_PARAVIRT +/* Early boot code has CONFIG_PARAVIRT undefined! */ +#if !defined(CONFIG_PARAVIRT) || !defined(CONFIG_PARAVIRT_XXL) /* * On non-paravirt systems, this is the only long mode CPL 3 * selector. We do not allow long mode selectors in the LDT. diff --git a/arch/x86/include/asm/segment.h b/arch/x86/include/asm/segment.h index e293c122d0d5..0ffbe9519e68 100644 --- a/arch/x86/include/asm/segment.h +++ b/arch/x86/include/asm/segment.h @@ -211,7 +211,7 @@ #endif -#ifndef CONFIG_PARAVIRT +#ifndef CONFIG_PARAVIRT_XXL # define get_kernel_rpl() 0 #endif diff --git a/arch/x86/kernel/paravirt.c b/arch/x86/kernel/paravirt.c index 40ec68135f7a..168901f4dc09 100644 --- a/arch/x86/kernel/paravirt.c +++ b/arch/x86/kernel/paravirt.c @@ -292,12 +292,14 @@ enum paravirt_lazy_mode paravirt_get_lazy_mode(void) struct pv_info pv_info = { .name = "bare hardware", +#ifdef CONFIG_PARAVIRT_XXL .kernel_rpl = 0, .shared_kernel_pmd = 1, /* Only used when CONFIG_X86_PAE is set */ #ifdef CONFIG_X86_64 .extra_user_64bit_cs = __USER_CS, #endif +#endif }; #if defined(CONFIG_X86_32) && !defined(CONFIG_X86_PAE) -- 2.13.7