Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp155366imu; Wed, 2 Jan 2019 16:32:02 -0800 (PST) X-Google-Smtp-Source: ALg8bN5cafcS+DMaAmyQBkTfNv+xlWprYaNV2I9z9298WewnzEIbQ/3L3x+gL6X74Sgue5B2lfNE X-Received: by 2002:a17:902:7588:: with SMTP id j8mr45635417pll.215.1546475522891; Wed, 02 Jan 2019 16:32:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546475522; cv=none; d=google.com; s=arc-20160816; b=I6vOtvDb01zhHCOZXLZ8NZZyGiS6DDRl01zGUzDqAhxbQA0miIx9xH0Uz3yeUoMnEb rjpwBmFuhg82mwLNt9JXdK1nVsDJhIsYvu42yEvsyWllfJVqCZQICupEXJtr6oNhEFip sk34PZM2d/DBbRMGzHxzETmtWsx+BpPIXc5RobGAE5DWah5cBi/nw1jr8ZqLXn4tKeFE Sw7/NTwmYjYNJEr7y2Lcws4wAp2ZRNFAWAe/l6FWNLcGjprmhHY+9UqK3/Fc3O5wo6/B Mn7I0eyB03gIwS8o0Y+5qI//aM0b9aEvs0iVDSsTjvb+akx8l/pWTAOoW3w9lLlPD9JI VeIg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=wLIoSkD0lQ49naASOOz6N5O9IgM95XLhYQuPmsyMEDs=; b=GlKBnIwHPUa2KNvqEAEy3dyFzOURCuQaqtgQ9V7EuvaA5XPgPX7XWlU3Tok2EOSUqQ E6EpgGNp1UOmlGZmwvpt8pfRKZSspir0U/Il502ezFArdQ6ZdgrMBlgExHC+7P77Saie jry3+1/He6tPeVeM1kczaUQZnNSpjQz9/ilaH47Omx0WOA1hwW153FmIMzJ29wNKmRtq g042/8YQLMfksBBGnnW2tHXRCOfoP2VjQpXke+LbXWVRX4VTS08MFJ6sP2zG3X+njqRb oCcvKpjIYPLeUta8gZb/GD1R5WkVW+IpDwT11D2UD5DmUDZlvd+9JzEliChP7bjJDXlO vVgw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 3si19320218plq.138.2019.01.02.16.31.47; Wed, 02 Jan 2019 16:32:02 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728482AbfABU55 (ORCPT + 99 others); Wed, 2 Jan 2019 15:57:57 -0500 Received: from mx1.redhat.com ([209.132.183.28]:40882 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728327AbfABU5z (ORCPT ); Wed, 2 Jan 2019 15:57:55 -0500 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 95CA7C0259; Wed, 2 Jan 2019 20:57:54 +0000 (UTC) Received: from redhat.com (ovpn-120-148.rdu2.redhat.com [10.10.120.148]) by smtp.corp.redhat.com (Postfix) with SMTP id D93C960C69; Wed, 2 Jan 2019 20:57:49 +0000 (UTC) Date: Wed, 2 Jan 2019 15:57:49 -0500 From: "Michael S. Tsirkin" To: linux-kernel@vger.kernel.org Cc: Jason Wang , Alan Stern , Andrea Parri , Will Deacon , Peter Zijlstra , Boqun Feng , Nicholas Piggin , David Howells , Jade Alglave , Luc Maranget , "Paul E. McKenney" , Akira Yokosawa , Daniel Lustig , linux-arch@vger.kernel.org, netdev@vger.kernel.org, virtualization@lists.linux-foundation.org, Eli Friedman , Joe Perches , Nick Desaulniers , Linus Torvalds , Luc Van Oostenryck , linux-sparse@vger.kernel.org Subject: [PATCH RFC 1/4] include/linux/compiler*.h: fix OPTIMIZER_HIDE_VAR Message-ID: <20190102205715.14054-2-mst@redhat.com> References: <20190102205715.14054-1-mst@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190102205715.14054-1-mst@redhat.com> X-Mutt-Fcc: =sent X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.39]); Wed, 02 Jan 2019 20:57:55 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since commit 815f0ddb346c ("include/linux/compiler*.h: make compiler-*.h mutually exclusive") clang no longer reuses the OPTIMIZER_HIDE_VAR macro from compiler-gcc - instead it gets the version in include/linux/compiler.h. Unfortunately that version doesn't actually prevent compiler from optimizing out the variable. Fix up by moving the macro out from compiler-gcc.h to compiler.h. Compilers without incline asm support will keep working since it's protected by an ifdef. Also fix up comments to match reality since we are no longer overriding any macros. Build-tested with gcc and clang. Fixes: 815f0ddb346c ("include/linux/compiler*.h: make compiler-*.h mutually exclusive") Cc: Eli Friedman Cc: Joe Perches Cc: Nick Desaulniers Cc: Linus Torvalds Signed-off-by: Michael S. Tsirkin --- include/linux/compiler-clang.h | 5 ++--- include/linux/compiler-gcc.h | 4 ---- include/linux/compiler-intel.h | 4 +--- include/linux/compiler.h | 4 +++- 4 files changed, 6 insertions(+), 11 deletions(-) diff --git a/include/linux/compiler-clang.h b/include/linux/compiler-clang.h index 3e7dafb3ea80..7ddaeb5182e3 100644 --- a/include/linux/compiler-clang.h +++ b/include/linux/compiler-clang.h @@ -3,9 +3,8 @@ #error "Please don't include directly, include instead." #endif -/* Some compiler specific definitions are overwritten here - * for Clang compiler - */ +/* Compiler specific definitions for Clang compiler */ + #define uninitialized_var(x) x = *(&(x)) /* same as gcc, this was present in clang-2.6 so we can assume it works diff --git a/include/linux/compiler-gcc.h b/include/linux/compiler-gcc.h index 2010493e1040..72054d9f0eaa 100644 --- a/include/linux/compiler-gcc.h +++ b/include/linux/compiler-gcc.h @@ -58,10 +58,6 @@ (typeof(ptr)) (__ptr + (off)); \ }) -/* Make the optimizer believe the variable can be manipulated arbitrarily. */ -#define OPTIMIZER_HIDE_VAR(var) \ - __asm__ ("" : "=r" (var) : "0" (var)) - /* * A trick to suppress uninitialized variable warning without generating any * code diff --git a/include/linux/compiler-intel.h b/include/linux/compiler-intel.h index 517bd14e1222..b17f3cd18334 100644 --- a/include/linux/compiler-intel.h +++ b/include/linux/compiler-intel.h @@ -5,9 +5,7 @@ #ifdef __ECC -/* Some compiler specific definitions are overwritten here - * for Intel ECC compiler - */ +/* Compiler specific definitions for Intel ECC compiler */ #include diff --git a/include/linux/compiler.h b/include/linux/compiler.h index 06396c1cf127..1ad367b4cd8d 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h @@ -152,7 +152,9 @@ void ftrace_likely_update(struct ftrace_likely_data *f, int val, #endif #ifndef OPTIMIZER_HIDE_VAR -#define OPTIMIZER_HIDE_VAR(var) barrier() +/* Make the optimizer believe the variable can be manipulated arbitrarily. */ +#define OPTIMIZER_HIDE_VAR(var) \ + __asm__ ("" : "=r" (var) : "0" (var)) #endif /* Not-quite-unique ID. */ -- MST