Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3538161imu; Wed, 7 Nov 2018 11:53:16 -0800 (PST) X-Google-Smtp-Source: AJdET5fEZIDWV9g89Gg458idVrdS68QAFM/9Q2gvemSA8jUDzRj9iyTMhMpCKJ3Nd9lHYhSmJXYj X-Received: by 2002:a17:902:6b4b:: with SMTP id g11-v6mr1594858plt.213.1541620396190; Wed, 07 Nov 2018 11:53:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541620396; cv=none; d=google.com; s=arc-20160816; b=VG0EQ4OHqmEamjZ7i0/4H80eiAypbh+1IgFTnIgVT+M9cx6RM1oLFir9HeKRMhVpDt 8tNR+KO7ZASfxkAy5oLv6yFvWHiI6NTPAJBaGBzqQGRpA5UyeUkreRzC0fLgXhQlJIak 7uMkNBxCfrlwNS+enpW4Aowhv4V4X0AARcrC2C4R91G/q+fqvFCZScQ2Ka1Obm1MUvKR i79nkraAUErOZrl3rMbuSNP4ysdfK6hnWr1BwE6kqcJuSOizpLM3NQOlY/qnsrrHDtj5 QLUpRSe1g2olnJ6V4ggIkUjJK59EbzvXx2cmSXRRsCCZAKKpbZTWVfJTpAjCWdeVtqye fzzg== 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:in-reply-to:message-id:date:subject:cc:to:from; bh=UqwrSJFn7yfO8XQVJwxU6XEnqlbwATHikGSLo3O9wTo=; b=UlQrmdTaACSFVQQAVNXFVC/0VKvt22AGBh4S9xfZmxH41ulB0SUx81Mw+CNXHAJLXI 5tyOnWPwz9oFsH5DeuwMtEW24oovuz2n2fEjijnTJVqx/X4AVCpDu6D8cidrtyJ0k8s1 OCMMafjQrBVOg+g5izPfWfGtKUtn0Rvh5ctAwVlml0q8jfhJ1YZvSwV3qOR8o0EQWOaV B0p0VOmPP6xox51hB3tZa+DTO/ZKn9CzZsvLjzjoG3wRPWR6vptF9OJiBWMGyUS8KD4g MpChUwegCP46eGVSdzXBXT7zixA6W27kXE4OMr8fO7tN1nD+Z8Dg0xJZ4bamLOGd+62n KdjA== 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 t23si1456041pgi.181.2018.11.07.11.53.01; Wed, 07 Nov 2018 11:53:16 -0800 (PST) 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 S1726801AbeKHFWa (ORCPT + 99 others); Thu, 8 Nov 2018 00:22:30 -0500 Received: from Galois.linutronix.de ([146.0.238.70]:41933 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727668AbeKHFVQ (ORCPT ); Thu, 8 Nov 2018 00:21:16 -0500 Received: from localhost ([127.0.0.1] helo=bazinga.breakpoint.cc) by Galois.linutronix.de with esmtp (Exim 4.80) (envelope-from ) id 1gKTpJ-00070Q-BI; Wed, 07 Nov 2018 20:49:21 +0100 From: Sebastian Andrzej Siewior To: linux-kernel@vger.kernel.org Cc: x86@kernel.org, Andy Lutomirski , Paolo Bonzini , =?UTF-8?q?Radim=20Kr=C4=8Dm=C3=A1=C5=99?= , kvm@vger.kernel.org, "Jason A. Donenfeld" , Rik van Riel , Dave Hansen , Sebastian Andrzej Siewior Subject: [PATCH 15/23] x86/fpu: Only write PKRU if it is different from current Date: Wed, 7 Nov 2018 20:48:50 +0100 Message-Id: <20181107194858.9380-16-bigeasy@linutronix.de> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181107194858.9380-1-bigeasy@linutronix.de> References: <20181107194858.9380-1-bigeasy@linutronix.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Dave Hansen says that the `wrpkru' is more expensive than `rdpkru'. It has a higher cycle cost and it's also practically a (light) speculation barrier. As an optimisation read the current PKRU value and only write the new one if it is different. Signed-off-by: Sebastian Andrzej Siewior --- arch/x86/include/asm/special_insns.h | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/arch/x86/include/asm/special_insns.h b/arch/x86/include/asm/special_insns.h index 43c029cdc3fe8..c2ccf71b22dd6 100644 --- a/arch/x86/include/asm/special_insns.h +++ b/arch/x86/include/asm/special_insns.h @@ -107,7 +107,7 @@ static inline u32 __read_pkru(void) return pkru; } -static inline void __write_pkru(u32 pkru) +static inline void __write_pkru_insn(u32 pkru) { u32 ecx = 0, edx = 0; @@ -118,6 +118,17 @@ static inline void __write_pkru(u32 pkru) asm volatile(".byte 0x0f,0x01,0xef\n\t" : : "a" (pkru), "c"(ecx), "d"(edx)); } + +static inline void __write_pkru(u32 pkru) +{ + /* + * Writting PKRU is expensive. Only write the PKRU value if it is + * different from the current one. + */ + if (pkru == __read_pkru()) + return; + __write_pkru_insn(pkru); +} #else static inline u32 __read_pkru(void) { -- 2.19.1