Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp1053146imm; Fri, 29 Jun 2018 10:32:56 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJdegRfVzi9wQpn859Xge1pC+EgD1BcTa5JIyl3d7JN0sbpCaLdqRtZ0g42j2x4gaUF8r1z X-Received: by 2002:a17:902:8ecb:: with SMTP id x11-v6mr16264082plo.308.1530293576206; Fri, 29 Jun 2018 10:32:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530293576; cv=none; d=google.com; s=arc-20160816; b=BkH6uDOcWWnpZ2K8hwfEzJ+4qoUjE8aGDr4/tjBTGUuCAq5M1SShtohMRNnw7I7Zth tvfoLOZq5KNP2tF/SHG9f8ikeSCnfwa6KQxEsuxTa5O6lXV/3mhSGms7B/GA+RSA7hvb fV3X+8/nVA7M2nPGas/hKRCsGl5GRIjwQnAfnXo1LkYJCx9xxNSqtN7I5uF0bZlABDB8 84NelgzjVZ4O0FwCkP6dlaNLEB1/or+PG9UKAePeqSIZu1QyuuKqCGLzD1zul/6qKxiF 8ADfjMmZzmQDV85VlvsPrNVwm0rZ2Oen/4wPLhJQOG6oNQ7SZPTq2h3jBY9tdfMKoFOE CBtw== 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=wGdZ1SZqJ7lwgVpAb7Oh+8z7GgMJWIzNqUb+2Q9Z0lw=; b=w6i5zzHQwXMVcVSwVVQrXmS/hEhkBgIpohli94LiJEB172uv2CghXOCFKIDbl5iEhi N40+ke+40cbgXYEfznQL9F6p9VfffA7VmeSfBc9ZsZSrr66HS/vRm+3lwLAL7q4q9Ubc Vtx7+HZH8XoQN+NsliZ+65sMtCAinzDoTeIXrfOJ59Gzlz0BRG3BUXpCZM2KUpUfKiel iz/3NLvZnaketppgDaAE2JFLGOgtY8gr2q/eJIwfGy3dOO6wZRQz5j8maWzAIoJaKlua baVP5q7Ujg6ZmleAYhXCFha3LSDyswaP+vjtZwX7fUWIc1DqmR5n1+uZAYHMwk5CeAZd 1BLg== 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 x70-v6si9662789pfa.108.2018.06.29.10.32.41; Fri, 29 Jun 2018 10:32:56 -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 S1755173AbeF2QUg (ORCPT + 99 others); Fri, 29 Jun 2018 12:20:36 -0400 Received: from mga03.intel.com ([134.134.136.65]:57838 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752260AbeF2QUf (ORCPT ); Fri, 29 Jun 2018 12:20:35 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by orsmga103.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 29 Jun 2018 09:20:34 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,285,1526367600"; d="scan'208";a="53928484" Received: from smile.fi.intel.com (HELO smile) ([10.237.72.86]) by orsmga006.jf.intel.com with ESMTP; 29 Jun 2018 09:20:14 -0700 Message-ID: Subject: Re: [PATCH] fbcon: introduce for_each_registered_fb() helper From: Andy Shevchenko To: Yisheng Xie , b.zolnierkie@samsung.com, keescook@chromium.org, j.w.r.degoede@gmail.com, david@lechnology.com Cc: dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org Date: Fri, 29 Jun 2018 19:20:13 +0300 In-Reply-To: <1530202809-24105-1-git-send-email-ysxie@foxmail.com> References: <1530202809-24105-1-git-send-email-ysxie@foxmail.com> 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 Fri, 2018-06-29 at 00:20 +0800, Yisheng Xie wrote: > Following pattern is often used: > > for (i = 0; i < FB_MAX; i++) { > if (registered_fb[i]) { > ... > } > } > > Therefore, as Andy's suggestion, for_each_registered_fb() helper can Suggested-by then ? > be introduced to make the code easier to read and write by reducing > indentation level. It also saves few lines of code in each occurrence. > > This patch convert all part here at the same time. LGTM except macro implementation. That's why I have mentioned for_each_pci_bridge() to look at. > +#define for_each_registered_fb(i) \ > + for (i = 0; i < FB_MAX; i++) \ > + if (registered_fb[i]) > + This needs to be protected against nested conditionals. Otherwise compiler issues a warning and even may generate wrong code. -- Andy Shevchenko Intel Finland Oy