Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp4545216ybz; Tue, 21 Apr 2020 02:32:44 -0700 (PDT) X-Google-Smtp-Source: APiQypJiRVe3q0PLDJgA4vRxQyDJiTA2NnqQKuSzZVnwkUFo29G4q+KK29qOMu87qPGM91tVgtZ+ X-Received: by 2002:a50:d0d5:: with SMTP id g21mr18550939edf.92.1587461564658; Tue, 21 Apr 2020 02:32:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587461564; cv=none; d=google.com; s=arc-20160816; b=GOczYMq3df48bNOwOTa+5Q0aNEB8aPW/8/X5/KBsALgS9ruf9aV1ML6lwbXmmvhFsU /GPr18uaJf6qzQkGmXeoeiUjBsjyGTjfSKgDAIV38pEbE5f9D/DG4idpbhcu9EOslaif R0PddMk68YpenBbe0qb9RM+anjV5TY5fBPeVegzaVbod94j2NQU8FZUrsuzbFzI++BgU rsAeBEpj6XiOwJ0pQ7jXjzirJMhIFE6aZ/OEQ98KXrGBKFlam5FimMvTzFIUcE+8qTVj 1MiHBFbVW1zt/IOX4mo2piSGo9YOApaojpJN8g1r7H1J06J4FiGvo3KhxOOsjr1Ahni9 c/mw== 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:mime-version :references:subject:cc:to:from:date:user-agent:message-id; bh=KzV9qsGI2cfwDDZd+l8hxozyEp6agU3AiZ8s2YOpEIg=; b=ZkDBpQP6m7o3sVlXb9XIeZkVrNZuRBLlg+2jORpTrdK8I1mN1Gpu6i15A24X11CH6H YZrCZ6E4uNg4R0Succp/kjQMzJfUOicsaBpTddYJM5M8sNSafy78trIY8djfXNIw9NMo 0ix98KfxJrb+vHyv0JF/U2MUzOlskHfhhFBbycWlT+OXf0HN1ojNajRAgVk3SqNIIGgd ZzeMOUnK/HBQO1r/eKpG6Ix034cxeh83BxRcJ6kvUYSghCks5iDDQrlO467aH0g0qTOn r8xYvXFtrG2AEwFu5brXjtDI5wCRKqnTDl4Z60TXImo98Vxy0gOCHW9Wu+wXjrWi5jIW 8U9g== 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 d11si1440721edo.105.2020.04.21.02.32.12; Tue, 21 Apr 2020 02:32:44 -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 S1728529AbgDUJ1B (ORCPT + 99 others); Tue, 21 Apr 2020 05:27:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58290 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1728335AbgDUJ1A (ORCPT ); Tue, 21 Apr 2020 05:27:00 -0400 Received: from Galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4F77DC061A0F for ; Tue, 21 Apr 2020 02:27:00 -0700 (PDT) Received: from p5de0bf0b.dip0.t-ipconnect.de ([93.224.191.11] helo=nanos.tec.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1jQpB5-0007xo-O1; Tue, 21 Apr 2020 11:26:51 +0200 Received: from nanos.tec.linutronix.de (localhost [IPv6:::1]) by nanos.tec.linutronix.de (Postfix) with ESMTP id E90ED1002EE; Tue, 21 Apr 2020 11:26:50 +0200 (CEST) Message-Id: <20200421092558.848064318@linutronix.de> User-Agent: quilt/0.65 Date: Tue, 21 Apr 2020 11:20:28 +0200 From: Thomas Gleixner To: LKML Cc: x86@kernel.org, Christoph Hellwig , Kees Cook , Alexandre Chartre , "Peter Zijlstra (Intel)" , Thomas Lendacky , Juergen Gross , Boris Ostrovsky Subject: [patch V2 01/16] x86/tlb: Uninline __get_current_cr3_fast() References: <20200421092027.591582014@linutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-transfer-encoding: 8-bit X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org cpu_tlbstate is exported because various TLB related functions need access to it, but cpu_tlbstate is sensitive information which should only be accessed by well contained kernel functions and not be directly exposed to modules. In preparation of unexporting cpu_tlbstate move __get_current_cr3_fast() into the x86 TLB management code. No functional change. Signed-off-by: Thomas Gleixner Reviewed-by: Alexandre Chartre Acked-by: Peter Zijlstra (Intel) --- arch/x86/include/asm/mmu_context.h | 19 +------------------ arch/x86/mm/tlb.c | 20 ++++++++++++++++++++ 2 files changed, 21 insertions(+), 18 deletions(-) --- a/arch/x86/include/asm/mmu_context.h +++ b/arch/x86/include/asm/mmu_context.h @@ -225,24 +225,7 @@ static inline bool arch_vma_access_permi return __pkru_allows_pkey(vma_pkey(vma), write); } -/* - * This can be used from process context to figure out what the value of - * CR3 is without needing to do a (slow) __read_cr3(). - * - * It's intended to be used for code like KVM that sneakily changes CR3 - * and needs to restore it. It needs to be used very carefully. - */ -static inline unsigned long __get_current_cr3_fast(void) -{ - unsigned long cr3 = build_cr3(this_cpu_read(cpu_tlbstate.loaded_mm)->pgd, - this_cpu_read(cpu_tlbstate.loaded_mm_asid)); - - /* For now, be very restrictive about when this can be called. */ - VM_WARN_ON(in_nmi() || preemptible()); - - VM_BUG_ON(cr3 != __read_cr3()); - return cr3; -} +unsigned long __get_current_cr3_fast(void); typedef struct { struct mm_struct *mm; --- a/arch/x86/mm/tlb.c +++ b/arch/x86/mm/tlb.c @@ -844,6 +844,26 @@ void flush_tlb_kernel_range(unsigned lon } /* + * This can be used from process context to figure out what the value of + * CR3 is without needing to do a (slow) __read_cr3(). + * + * It's intended to be used for code like KVM that sneakily changes CR3 + * and needs to restore it. It needs to be used very carefully. + */ +unsigned long __get_current_cr3_fast(void) +{ + unsigned long cr3 = build_cr3(this_cpu_read(cpu_tlbstate.loaded_mm)->pgd, + this_cpu_read(cpu_tlbstate.loaded_mm_asid)); + + /* For now, be very restrictive about when this can be called. */ + VM_WARN_ON(in_nmi() || preemptible()); + + VM_BUG_ON(cr3 != __read_cr3()); + return cr3; +} +EXPORT_SYMBOL_GPL(__get_current_cr3_fast); + +/* * arch_tlbbatch_flush() performs a full TLB flush regardless of the active mm. * This means that the 'struct flush_tlb_info' that describes which mappings to * flush is actually fixed. We therefore set a single fixed struct and use it in