Received: by 10.213.65.68 with SMTP id h4csp941980imn; Wed, 14 Mar 2018 05:04:38 -0700 (PDT) X-Google-Smtp-Source: AG47ELthc/7sSo72jM6Y7Ul8oSBpB7YFMFM3qMUI0HCRMfOeH5ttiXhA/gs40uMbzQ0gGZJUingi X-Received: by 10.99.143.66 with SMTP id r2mr3386966pgn.397.1521029078178; Wed, 14 Mar 2018 05:04:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521029078; cv=none; d=google.com; s=arc-20160816; b=TNTcB7vdyuXZW2tTAS9tR90A4HP9P+0aGSkLrMBIV8b73BCz5IRivDCfmKXRNju/qo WSYU+HOpKenpJPQ5EAwhmCergNdi7y+wUDQ9Sd3zCMa1rgyIqA8MgU5BkMfdgg+OeLQ2 yJNVE8aMbduDrzi+Z/FpJ8cYNywG5PeQqLeI97bti1XUNRTujJelGeVYMQ40won7Xijl tgnsTEq6roITmHpQFPUTafWYB78W+Z2CBq2Pwc3iQ/FJR+vA1kh9Mtj3FUUlcoV3O8Hy w2FLEZBwn+cGy0XUZIV+FigkSG51fYqS9fzbbb8hKKKbhdMkVDwclKYVSj73RVuejkQm scbw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=B9AhewtcIxc1Uui7AgRoeqXCrVbcmx5OEQjW2xwgVmE=; b=GHReia4RFvFPNdwYx2rvRZH30SQ05u0JJC80rBLVgW/X2xoLlK7+jGcFd3n/1Tnpn5 EmxAglSoNXehVQAVmh8CFPzSTy1sJjzM0C8zta/VAypOyzEoD0ulL0XZy9ZpcLud3hHQ xhHh1XAT8GbXomjBDYHrXQfEKEBWnC7Z+3bmEfCodoO0pe5NTIEggSLo6xTGGSJX6DEO 2zQ5z8KyFaSOWixTJ5JZgwABvi+LQNH72nEL616ej3s1QDihUWcJnYhpktdwaw8B0MSf x72iuhnNnEEj+MvlzWy27JvrZ+ac1KNARz2xWn41WTOISyFtpaA/+8fptGlkLYFjrM8e U3sw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=QdjKkGaD; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k11-v6si1925442pln.257.2018.03.14.05.04.05; Wed, 14 Mar 2018 05:04:38 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=QdjKkGaD; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751420AbeCNMCS (ORCPT + 99 others); Wed, 14 Mar 2018 08:02:18 -0400 Received: from mail-wm0-f52.google.com ([74.125.82.52]:37270 "EHLO mail-wm0-f52.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750855AbeCNMCQ (ORCPT ); Wed, 14 Mar 2018 08:02:16 -0400 Received: by mail-wm0-f52.google.com with SMTP id 139so3545684wmn.2 for ; Wed, 14 Mar 2018 05:02:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=B9AhewtcIxc1Uui7AgRoeqXCrVbcmx5OEQjW2xwgVmE=; b=QdjKkGaDAp/12dWz7xKxLSuZHQFHLekc4QNHhT746d/Dg3+tGBMkbKgcEZSJS6I/TC Fw51l3qi3sBJWIwnDdGm2hPI1cwMUqRyB2D1nwcI9euRTsDRGi3zU6ih49zs8hIduaR4 OHKojhZHlyLs3Gkulbh4kaR+p61f+yXJMT7L+m7tmqSC8JtCZ/P1fKSQBqSE/TV+oh2t WYeButThvSh5esGARhYLH9eDgvFeEzJ2VnTojdyfj8UxIw8KWceVbUDcjKNh/Ir5ADXP GwRmMmaibYZIulTA2VMRb3QRhl7fknRG5vNA0N1tF4tgRWZtXpb693CYLShnXbZEH2Ts DAyw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=B9AhewtcIxc1Uui7AgRoeqXCrVbcmx5OEQjW2xwgVmE=; b=r97faUO5cOEUWJZQL0QrImhy5J26O2UMAyy2ICvIYuuP82sVgEfX7tlAtqCGeIDM3g Kq52FD7JIKV+SNibzBup70i634MvaBEY4TGktDDLPD2ltUKpHYjUFcAJlrebgSLEutl8 l2G2uWJNuTF511intTDGjsJIep9WjGiRsMi14JhJPu/2DzYKjFvoDsDH53bJIp2bZiq7 54NxAiB4GEqfMjwDgDxkVTiysJ0wplT0Wd93h1p8pKIfDv5DRSWQ0sONxxlmQCpmt6AP g/YvNhKInHu1omxXx/db3rl3dVI7xrgcZgSTx0jGI1tmJ6mJuNYQaYAJztc0A+XDjuzO JOvw== X-Gm-Message-State: AElRT7GDYBUjrb7O7GEWi2qHNlXH4l6xzSWIkv3fMy+6BjEvV8c/cnpe rIPWQ1OAXnHa5GTh/T9gq8DlSw/RUYd3rQjyZi0= X-Received: by 10.28.224.135 with SMTP id x129mr1554924wmg.57.1521028934939; Wed, 14 Mar 2018 05:02:14 -0700 (PDT) MIME-Version: 1.0 Received: by 10.28.179.86 with HTTP; Wed, 14 Mar 2018 05:02:13 -0700 (PDT) In-Reply-To: <1521018736-20980-1-git-send-email-hl@rock-chips.com> References: <1521018736-20980-1-git-send-email-hl@rock-chips.com> From: Emil Velikov Date: Wed, 14 Mar 2018 12:02:13 +0000 Message-ID: Subject: Re: [PATCH v4 1/3] drm/panel: refactor INNOLUX P079ZCA panel driver To: Lin Huang Cc: Thierry Reding , Brian Norris , Rob Herring , Sean Paul , David Airlie , "Linux-Kernel@Vger. Kernel. Org" , ML dri-devel Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Lin, On 14 March 2018 at 09:12, Lin Huang wrote: > From: huang lin > > Refactor Innolux P079ZCA panel driver, let it support > multi panel. > > Change-Id: If89be5e56dba8cb498e2d50c1bbeb0e8016123a2 > Signed-off-by: Lin Huang > --- > Changes in v2: > - Change regulator property name to meet the panel datasheet > Changes in v3: > - this patch only refactor P079ZCA panel to support multi panel, support P097PFG panel in another patch > Changes in v4: > - Modify the patch which suggest by Thierry > Thanks for splitting this up. I think there's another piece that fell through the cracks. I'm not deeply familiar with the driver, so just sharing some quick notes. > struct innolux_panel { > struct drm_panel base; > struct mipi_dsi_device *link; > + const struct panel_desc *desc; > > struct backlight_device *backlight; > - struct regulator *supply; > + struct regulator *vddi; > + struct regulator *avdd; > + struct regulator *avee; These two seem are new addition, as opposed to a dummy refactor. Are they optional, does one need them for the existing panel (separate patch?) or only for the new one (squash with the new panel code)? > struct gpio_desc *enable_gpio; > > bool prepared; > @@ -77,9 +93,9 @@ static int innolux_panel_unprepare(struct drm_panel *panel) > /* T8: 80ms - 1000ms */ > msleep(80); > > - err = regulator_disable(innolux->supply); > - if (err < 0) > - return err; Good call on dropping the early return here. > @@ -207,19 +248,28 @@ static const struct drm_panel_funcs innolux_panel_funcs = { > > - innolux->supply = devm_regulator_get(dev, "power"); > - if (IS_ERR(innolux->supply)) > - return PTR_ERR(innolux->supply); > + innolux = devm_kzalloc(dev, sizeof(*innolux), GFP_KERNEL); > + if (!innolux) > + return -ENOMEM; > + > + innolux->desc = desc; > + innolux->vddi = devm_regulator_get(dev, "power"); > + innolux->avdd = devm_regulator_get(dev, "avdd"); > + innolux->avee = devm_regulator_get(dev, "avee"); > AFAICT devm_regulator_get returns a pointer which is unsuitable to be passed into regulator_{enable,disable}. Hence, the IS_ERR check should stay. If any of the regulators are optional, you want to call regulator_{enable,disable} only as applicable. > @@ -318,5 +377,6 @@ static struct mipi_dsi_driver innolux_panel_driver = { > module_mipi_dsi_driver(innolux_panel_driver); > > MODULE_AUTHOR("Chris Zhong "); > +MODULE_AUTHOR("Lin Huang "); I don't think refactoring existing code classify as being the module author. Then again, I could be wrong. HTH Emil