Received: by 10.213.65.68 with SMTP id h4csp1122076imn; Wed, 14 Mar 2018 10:12:12 -0700 (PDT) X-Google-Smtp-Source: AG47ELtx4EM9hTUjmNP4gi37loE/utV9RiqAfa6L7S5g89oDPK5fg+TNlMXQXq2xlU23PpKajNKi X-Received: by 2002:a17:902:b101:: with SMTP id q1-v6mr4763110plr.287.1521047532091; Wed, 14 Mar 2018 10:12:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521047532; cv=none; d=google.com; s=arc-20160816; b=PqfRflFLrCn3y9dBZGHMNvnL3xNAQJj0Q9pa1iQbdBX3odWgLzc7NDCYpmj46deQWj VvTmLPnh66drslO4H89LRdx+YhEKIwgHO5t9xm6hOliouyaZ8xXP6yBH/P1HSZUYmnGj pZpRMWPyFvxRGlV2/1Dj/BqJf4KluhRHB5rlTBdd96wykg08BuEAmprdi1CbuauvfmEb e5FU2LEGO4rCuZ0vdiYExzV+6nm2crEBSIh/oFL6PMV0/3B/yLVKV2q9/KuVz+KXD1zu r8QtweLwnZddG4dK/7l+c+nSOERq/A8TedU3K6ferzkOcGmGA+SdYYo17144Y1/UzgH3 iAxQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject :dkim-signature:arc-authentication-results; bh=28GFaMzymnJMsRKufT2vKz9Tx7FdeC9uDp0UVgqU+4k=; b=Ok3KBKkw4i0sMDKXoAi/uKFp5J3Th7cbVUVuD/0FsFTWwFJB1KzcGNhEm7vHrq7ZHK TdoTN7YKmHA19zd17x3PF+af9dk8Tq6Z7pgQsqnfQqooPjl2reBC9NCqtljfP4tKO5ky tSZlXrIaErh4hfmWJelLJsgbXvu7XmiMPis+A3z81TAWQfEKuHloB8csjWqsI/ZAHX/6 8T06cfHbVMVWU4MNCZFNcOLDXxc62ovj4UE9JMxVZZCedmH88wvYdpxldnVb7arPMaSw zbL7ck5hHpBs8zsbArr2sh4YZSO9xG3YWoAFNbsKJf72QFu01R23s4zXZ+heWnF5hbOU UDJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cogentembedded-com.20150623.gappssmtp.com header.s=20150623 header.b=dKZ1xB2B; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j5si2319884pfi.225.2018.03.14.10.11.57; Wed, 14 Mar 2018 10:12:12 -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=@cogentembedded-com.20150623.gappssmtp.com header.s=20150623 header.b=dKZ1xB2B; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751790AbeCNRJ6 (ORCPT + 99 others); Wed, 14 Mar 2018 13:09:58 -0400 Received: from mail-lf0-f68.google.com ([209.85.215.68]:36557 "EHLO mail-lf0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751456AbeCNRJ4 (ORCPT ); Wed, 14 Mar 2018 13:09:56 -0400 Received: by mail-lf0-f68.google.com with SMTP id p74-v6so5947929lfd.3 for ; Wed, 14 Mar 2018 10:09:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cogentembedded-com.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:organization:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=28GFaMzymnJMsRKufT2vKz9Tx7FdeC9uDp0UVgqU+4k=; b=dKZ1xB2BkitPjVMBW5O1s7nGXxGJeuRqI0At6FZgcjbOHOIGQ3b+nUCJxV8xAHTzDR bLROM3KtuTPQEasIPu1YpzQXKjouyZ//bowujrh7C5IPK4STraS9w5KaScX9zaAlMQAt ehMXKF180beYSyTUQrdA+lRByJRMj6h6mKcZW1aC5Z8nbKnnUbWienSZpGQtEioWivH/ zZE1ILpYzMurD54w75iyTmonI9vVOYZetcvL9r4tQ96ZyQjjt5KJZvmaUJNdglZuRTg9 jv8sEroGby5BDepH8BMSR09ayGI2XFCUxQEjWhEHMqfES/DUgwgUTW5aOHu20Yfa5k9u hwDA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:organization :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=28GFaMzymnJMsRKufT2vKz9Tx7FdeC9uDp0UVgqU+4k=; b=UI8J4WVNDlKJ039lhw+nXH1EPhbLDQBu3anaIH0GRwu1Ev8dMEOGhqXJlVPyCxh48p zs6Ugk0BWczoPe9DR8Kx/MmWmLeQLPkzjyj5Kvap5Vsg6KFA1WyYdBFEgxvlj55MQ0cn ahnOWlgpe35FNHQD10SGeGEsMqEkLjxUwDsUpIqWLFZa0OVDLYOfOZy2GnRhwrXt4Kyk 4Y296Bl2P7nX2ScdC+SOSwnKGVqNASRC+b/+8plnn+Bq0XU3t48NzsYeFcdw2iFBMRXU Ve/HfSvEsImMHbgzMnLjeBLNPoqXee7I1EGNUkpLfgo3DYjvcE6ERzn7GVsVR+KWNbMY cQvg== X-Gm-Message-State: AElRT7Fq7vJqbMgLpsPrF6D+mXZ43LplSmI+9nc11KUP0YKCAkD1Dv9q LJ7XdjZWw82WRszZ89F3bgl3/fRwlOM= X-Received: by 2002:a19:e112:: with SMTP id y18-v6mr3857332lfg.102.1521047394553; Wed, 14 Mar 2018 10:09:54 -0700 (PDT) Received: from wasted.cogentembedded.com ([31.173.81.226]) by smtp.gmail.com with ESMTPSA id n2sm686669ljb.3.2018.03.14.10.09.52 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 14 Mar 2018 10:09:53 -0700 (PDT) Subject: Re: [PATCH v3 2/3] drm: bridge: Add thc63lvd1024 LVDS decoder driver To: Jacopo Mondi , architt@codeaurora.org, a.hajda@samsung.com, Laurent.pinchart@ideasonboard.com, airlied@linux.ie, horms@verge.net.au, magnus.damm@gmail.com, geert@linux-m68k.org, niklas.soderlund@ragnatech.se, robh+dt@kernel.org, mark.rutland@arm.com Cc: dri-devel@lists.freedesktop.org, linux-renesas-soc@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org References: <1520951425-13843-1-git-send-email-jacopo+renesas@jmondi.org> <1520951425-13843-3-git-send-email-jacopo+renesas@jmondi.org> From: Sergei Shtylyov Organization: Cogent Embedded Message-ID: Date: Wed, 14 Mar 2018 20:09:52 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <1520951425-13843-3-git-send-email-jacopo+renesas@jmondi.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-MW Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 03/13/2018 05:30 PM, Jacopo Mondi wrote: > Add DRM bridge driver for Thine THC63LVD1024 LVDS to digital parallel > output decoder. > > Signed-off-by: Jacopo Mondi [...] > diff --git a/drivers/gpu/drm/bridge/thc63lvd1024.c b/drivers/gpu/drm/bridge/thc63lvd1024.c > new file mode 100644 > index 0000000..4b059c0 > --- /dev/null > +++ b/drivers/gpu/drm/bridge/thc63lvd1024.c > @@ -0,0 +1,241 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * THC63LVD1024 LVDS to parallel data DRM bridge driver. > + * > + * Copyright (C) 2018 Jacopo Mondi > + */ > + > +#include > +#include > +#include > + > +#include > +#include > +#include > + > +static const char * const thc63_reg_names[] = { > + "vcc", "lvcc", "pvcc", "cvcc", }; Your bracing style is pretty strange -- neither here nor there. Please place }; on the next line... [...] > +static void thc63_enable(struct drm_bridge *bridge) > +{ > + struct thc63_dev *thc63 = to_thc63(bridge); > + struct regulator *vcc; > + unsigned int i; > + int ret; > + > + for (i = 0; i < ARRAY_SIZE(thc63->vccs); i++) { > + vcc = thc63->vccs[i]; > + if (vcc) { > + ret = regulator_enable(vcc); > + if (ret) You hardly need this variable, could do a call right in this *if*. [...] > +error_vcc_enable: > + dev_err(thc63->dev, "Failed to enable regulator %u\n", i); > +} > + Why not do this instead of *goto* before? > +static void thc63_disable(struct drm_bridge *bridge) > +{ > + struct thc63_dev *thc63 = to_thc63(bridge); > + struct regulator *vcc; > + unsigned int i; > + int ret; > + > + for (i = 0; i < ARRAY_SIZE(thc63->vccs); i++) { > + vcc = thc63->vccs[i]; > + if (vcc) { > + ret = regulator_disable(vcc); > + if (ret) Again, no need for 'ret' whatsoever... > + goto error_vcc_disable; > + } > + } > + > + if (thc63->pwdn) > + gpiod_set_value(thc63->pwdn, 1); > + > + if (thc63->oe) > + gpiod_set_value(thc63->oe, 0); > + > + return; > + > +error_vcc_disable: > + dev_err(thc63->dev, "Failed to disable regulator %u\n", i); Again, why not do it instead of *goto*? [...] > +static int thc63_gpio_init(struct thc63_dev *thc63) > +{ > + thc63->pwdn = devm_gpiod_get_optional(thc63->dev, "pwdn", > + GPIOD_OUT_LOW); > + if (IS_ERR(thc63->pwdn)) { > + dev_err(thc63->dev, "Unable to get GPIO \"pwdn\"\n"); "pwdn-gpios" maybe? > + return PTR_ERR(thc63->pwdn); > + } > + > + thc63->oe = devm_gpiod_get_optional(thc63->dev, "oe", GPIOD_OUT_LOW); > + if (IS_ERR(thc63->oe)) { > + dev_err(thc63->dev, "Unable to get GPIO \"oe\"\n"); "oe-gpios" maybe? [...] MBR, Sergei