Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp442814imm; Mon, 9 Jul 2018 04:51:58 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcuKs1zmAj+vxtjThQME0UwxJI58kFcp3XU6PgcuBvM77+Rm5r2J90QiZ+ZpzlMBGfiXlTH X-Received: by 2002:a63:b505:: with SMTP id y5-v6mr18973278pge.213.1531137118207; Mon, 09 Jul 2018 04:51:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531137118; cv=none; d=google.com; s=arc-20160816; b=bZTQGIqsIs1R9w9m7A89wM+axTmcX88gJXhsJeYBFpSmmQLtr9ChY9m93MNk2hmsky p+wfhiOikD5f5VV5LTIs8cdnXXpv9RDnWFdf6BDXlLrLOggCGEJp5rNXcZJo+e4MHNYt yn83d/rLCWTho7HJxLpjO2mRuVB1gYahwbiDWC1+GbCJW4aOCsjMY7ZWRSP6mCdAzhkO GUVRFhRA1eQjm0djZ4mzyd7zsY47q/XMildYTiNl+CZwJi2oYNWiboXWiPt7SAGGPyTw OP7yR8RLXa5R2MmdbKTjHtYUsF8Weh7si52J+MyPtZbHMed4iaJAqN/X6Vpu1y1bOddT kgeA== 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 :organization:references:in-reply-to:date:cc:to:from:subject :message-id:arc-authentication-results; bh=u96QRSmgGWoxsEvkl9YxuN1D20i2xE6R2TBcg42IVHk=; b=t2JPv6DTP7HTpqs9gNatNiiUkxLyTcvzImkse6JRvj0TrycXKH4jQ1cZEVZFol/z7u jYNOUAEv9bm86lftvGz7sJQas8w3LpmVmfT79F1121AM3Y6Nd3yGQX0fbQ1nYZWn6v6F aYuPCGi/StxLSziG2xVll+AvobqEK/Wz1e/guRz9ck/aXKBwCG0zdRQS1Fh9nbAci2yc DU235V+GwMf60dp6jEuPhFh4btsLWJ7Q6tlozTGEkk4BlUeGqxwfrL9dLj26phP4CeCe O4wxNAZ1XhuU9CPlp6CgkG8giXeiw3JCPYZVZoyfVqkxt1Uiupqr9oLitNwtxVBNpS9n bRPQ== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k18-v6si14202851pll.404.2018.07.09.04.51.37; Mon, 09 Jul 2018 04:51:58 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932789AbeGILu7 (ORCPT + 99 others); Mon, 9 Jul 2018 07:50:59 -0400 Received: from mga14.intel.com ([192.55.52.115]:41178 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932707AbeGILu6 (ORCPT ); Mon, 9 Jul 2018 07:50:58 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 09 Jul 2018 04:50:57 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,330,1526367600"; d="scan'208";a="55452862" Received: from smile.fi.intel.com (HELO smile) ([10.237.72.86]) by orsmga008.jf.intel.com with ESMTP; 09 Jul 2018 04:50:52 -0700 Message-ID: Subject: Re: [PATCH 01/12] kernel.h: Add for_each_if() From: Andy Shevchenko To: Daniel Vetter , LKML Cc: DRI Development , Intel Graphics Development , Daniel Vetter , Gustavo Padovan , Maarten Lankhorst , Sean Paul , David Airlie , Andrew Morton , Kees Cook , Ingo Molnar , Greg Kroah-Hartman , NeilBrown , Wei Wang , Stefan Agner , Andrei Vagin , Randy Dunlap , Yisheng Xie Date: Mon, 09 Jul 2018 14:50:51 +0300 In-Reply-To: <20180709083650.23549-1-daniel.vetter@ffwll.ch> References: <20180709083650.23549-1-daniel.vetter@ffwll.ch> Organization: Intel Finland Oy Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.28.1-2 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2018-07-09 at 10:36 +0200, Daniel Vetter wrote: > To avoid compilers complainig about ambigious else blocks when putting > an if condition into a for_each macro one needs to invert the > condition and add a dummy else. We have a nice little convenience > macro for that in drm headers, let's move it out. Subsequent patches > will roll it out to other places. > > Motivated by a discussion with Andy and Yisheng, who want to add > another for_each_macro which would benefit from for_each_if() instead > of hand-rolling it. > Thanks, Daniel! Reviewed-by: Andy Shevchenko > Signed-off-by: Daniel Vetter > Cc: Gustavo Padovan > Cc: Maarten Lankhorst > Cc: Sean Paul > Cc: David Airlie > Cc: Andrew Morton > Cc: Kees Cook > Cc: Ingo Molnar > Cc: Greg Kroah-Hartman > Cc: NeilBrown > Cc: Wei Wang > Cc: Stefan Agner > Cc: Andrei Vagin > Cc: Randy Dunlap > Cc: Andy Shevchenko > Cc: Yisheng Xie > --- > include/drm/drmP.h | 3 --- > include/linux/kernel.h | 3 +++ > 2 files changed, 3 insertions(+), 3 deletions(-) > > diff --git a/include/drm/drmP.h b/include/drm/drmP.h > index f7a19c2a7a80..05350424a4d3 100644 > --- a/include/drm/drmP.h > +++ b/include/drm/drmP.h > @@ -110,7 +110,4 @@ static inline bool drm_can_sleep(void) > return true; > } > > -/* helper for handling conditionals in various for_each macros */ > -#define for_each_if(condition) if (!(condition)) {} else > - > #endif > diff --git a/include/linux/kernel.h b/include/linux/kernel.h > index 941dc0a5a877..4cb95ab9a5bc 100644 > --- a/include/linux/kernel.h > +++ b/include/linux/kernel.h > @@ -71,6 +71,9 @@ > */ > #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + > __must_be_array(arr)) > > +/* helper for handling conditionals in various for_each macros */ > +#define for_each_if(condition) if (!(condition)) {} else > + > #define u64_to_user_ptr(x) ( \ > { \ > typecheck(u64, x); \ -- Andy Shevchenko Intel Finland Oy