Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp2923395ybk; Mon, 18 May 2020 11:12:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy0gQ4M81+QwZNkgh+uvOGSn7LN16qa+JUj5p/lT2V5Gt0hu1OP1JhL9dxmFSDytdjbaixB X-Received: by 2002:a17:906:8304:: with SMTP id j4mr16189663ejx.200.1589825567502; Mon, 18 May 2020 11:12:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589825567; cv=none; d=google.com; s=arc-20160816; b=Y+rRgnfueV4HhogV4F+6rKjcMRjC8e/QLx8TyI19Xl0VOhiBF5vSCQgSXlzdgXTYhX c6XigEKJNrI6NmnUffg40Xc5+JU0cO/HC483NyerI+i493WREwnsnOTXQxEuk2K0keRg K9JuRKWUJfe18z7ByfdlcjL1afyYHx9a6zsOtFmpJ2LPEGdjfSniRiJWDkYvFQSFHXiB QUK7zg12MY/9c92IfO0Naf6CGk6eiwnZNKCPXODyQMg+l04tn3dOkef5CscLf8j9NJpH 97N2nNJB1qoXXRRnuBfmsBzAcRh/5+UqxwFBkcnS6o4lbWFEAzdRRjzcfR04w63hVTlf aQqw== 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 :robot-unsubscribe:robot-id:message-id:mime-version:references :in-reply-to:cc:subject:to:reply-to:from:date; bh=0gfa5t4IRtcZTPthZnywWXKTJIUX4liW67oB+EOLfUk=; b=cyXmccU6fqPdSumKuPtISKhHRRBla7CNRmWXlEV5+xed/jy73Cveal5lvlAQOcWSfY F+DJHM+xYqXNHRrP8PYpBkciPbT1wz1kwn0aP4gqUNBAEocUZEQBZU8YmmIUFW0sQcW7 udhzRLUwfgOCbOUBgFjcnpjaqeeFa1g5Dda4mR4JeTNvpo8vD4bb23CunID6PbOoA2yo weJf7kIQRv9+/AVB/+4ilYXGFV9gT7ke9451OJFwBMIEJFyG66LQxXdZ3+JgbfNflTaS LCEU2Djg/5RXYnGl1jZDt3YQSQGB4Zd1TZOj/83k6V+SLL2w1tZ8ns0bXpFOiPG/VzYZ 7UMA== 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 bd6si2733006edb.305.2020.05.18.11.12.23; Mon, 18 May 2020 11:12:47 -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 S2387535AbgERSJs (ORCPT + 99 others); Mon, 18 May 2020 14:09:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35388 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733125AbgERSGN (ORCPT ); Mon, 18 May 2020 14:06:13 -0400 Received: from Galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 09211C061A0C; Mon, 18 May 2020 11:06:13 -0700 (PDT) Received: from [5.158.153.53] (helo=tip-bot2.lab.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1jak9O-00008n-KX; Mon, 18 May 2020 20:06:06 +0200 Received: from [127.0.1.1] (localhost [IPv6:::1]) by tip-bot2.lab.linutronix.de (Postfix) with ESMTP id 2A2751C009C; Mon, 18 May 2020 20:06:06 +0200 (CEST) Date: Mon, 18 May 2020 18:06:06 -0000 From: "tip-bot2 for Uros Bizjak" Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: x86/cpu] x86/cpu: Use RDRAND and RDSEED mnemonics in archrandom.h Cc: Uros Bizjak , Borislav Petkov , "H. Peter Anvin (Intel)" , "Peter Zijlstra (Intel)" , x86 , LKML In-Reply-To: <20200508105817.207887-1-ubizjak@gmail.com> References: <20200508105817.207887-1-ubizjak@gmail.com> MIME-Version: 1.0 Message-ID: <158982516602.17951.15035547991791218308.tip-bot2@tip-bot2> X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit 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 The following commit has been merged into the x86/cpu branch of tip: Commit-ID: 3d81b3d1e55a518837c3d1f722c6d93abe34aa85 Gitweb: https://git.kernel.org/tip/3d81b3d1e55a518837c3d1f722c6d93abe34aa85 Author: Uros Bizjak AuthorDate: Fri, 08 May 2020 12:58:17 +02:00 Committer: Borislav Petkov CommitterDate: Mon, 18 May 2020 19:50:47 +02:00 x86/cpu: Use RDRAND and RDSEED mnemonics in archrandom.h Current minimum required version of binutils is 2.23, which supports RDRAND and RDSEED instruction mnemonics. Replace the byte-wise specification of RDRAND and RDSEED with these proper mnemonics. Signed-off-by: Uros Bizjak Signed-off-by: Borislav Petkov Reviewed-by: H. Peter Anvin (Intel) Acked-by: Peter Zijlstra (Intel) Link: https://lkml.kernel.org/r/20200508105817.207887-1-ubizjak@gmail.com --- arch/x86/include/asm/archrandom.h | 26 ++++++++------------------ 1 file changed, 8 insertions(+), 18 deletions(-) diff --git a/arch/x86/include/asm/archrandom.h b/arch/x86/include/asm/archrandom.h index 7a4bb1b..ebc248e 100644 --- a/arch/x86/include/asm/archrandom.h +++ b/arch/x86/include/asm/archrandom.h @@ -15,16 +15,6 @@ #define RDRAND_RETRY_LOOPS 10 -#define RDRAND_INT ".byte 0x0f,0xc7,0xf0" -#define RDSEED_INT ".byte 0x0f,0xc7,0xf8" -#ifdef CONFIG_X86_64 -# define RDRAND_LONG ".byte 0x48,0x0f,0xc7,0xf0" -# define RDSEED_LONG ".byte 0x48,0x0f,0xc7,0xf8" -#else -# define RDRAND_LONG RDRAND_INT -# define RDSEED_LONG RDSEED_INT -#endif - /* Unconditional execution of RDRAND and RDSEED */ static inline bool __must_check rdrand_long(unsigned long *v) @@ -32,9 +22,9 @@ static inline bool __must_check rdrand_long(unsigned long *v) bool ok; unsigned int retry = RDRAND_RETRY_LOOPS; do { - asm volatile(RDRAND_LONG + asm volatile("rdrand %[out]" CC_SET(c) - : CC_OUT(c) (ok), "=a" (*v)); + : CC_OUT(c) (ok), [out] "=r" (*v)); if (ok) return true; } while (--retry); @@ -46,9 +36,9 @@ static inline bool __must_check rdrand_int(unsigned int *v) bool ok; unsigned int retry = RDRAND_RETRY_LOOPS; do { - asm volatile(RDRAND_INT + asm volatile("rdrand %[out]" CC_SET(c) - : CC_OUT(c) (ok), "=a" (*v)); + : CC_OUT(c) (ok), [out] "=r" (*v)); if (ok) return true; } while (--retry); @@ -58,18 +48,18 @@ static inline bool __must_check rdrand_int(unsigned int *v) static inline bool __must_check rdseed_long(unsigned long *v) { bool ok; - asm volatile(RDSEED_LONG + asm volatile("rdseed %[out]" CC_SET(c) - : CC_OUT(c) (ok), "=a" (*v)); + : CC_OUT(c) (ok), [out] "=r" (*v)); return ok; } static inline bool __must_check rdseed_int(unsigned int *v) { bool ok; - asm volatile(RDSEED_INT + asm volatile("rdseed %[out]" CC_SET(c) - : CC_OUT(c) (ok), "=a" (*v)); + : CC_OUT(c) (ok), [out] "=r" (*v)); return ok; }