Received: by 10.213.65.68 with SMTP id h4csp1160201imn; Wed, 14 Mar 2018 11:20:33 -0700 (PDT) X-Google-Smtp-Source: AG47ELvLOKyy5yiiWL/unnlkzpN71zaLPSwSttzOuuQni0dVHUydG6/5pXgdIRuaYPWGpw6Sq3JY X-Received: by 10.98.78.68 with SMTP id c65mr5177587pfb.65.1521051633358; Wed, 14 Mar 2018 11:20:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521051633; cv=none; d=google.com; s=arc-20160816; b=x5JBxsi0J3q+95tmzGmZDS56WIacILQZ0aT66xDzyg/FbgprzuWJpLwpVGpMwO/R+M H74++pJtENWNk3xaRyhDFsROTSmibX38CYr0UdzPGrR7oQMgRgfCY6zzejws4tAf6hwX rWjGfp8/biKtID0QoORL0NEIvhJFDK7vw3j0ZEofA5GCzUrH7kdMJi6omm1hS9imlWUg F4BxqY1tJnoAubVF2oLDW9Egr71RR2R4MPrb/xzRtNh1BoRX/bDeOJkm9nUSi6kIUfeU 4JUNaeGOHXOOKk9WGlF6Ko8bSWJoMOVK8DVPVFFsJvdlMhtu4nDvDDgxkq9TcPG0URRl 3H2w== 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=Yd01UyHAky8LSwT58YhO1amuU0m0/z7Jf+Ijb83vbG8=; b=kQPFey5MWEyOd1h4CDx4A6SdPa2a4eC39/lifBMRkG0rJbfEBWPlEEUBoTEWQ5M7k0 RzhIPdVHpu4L9X+wZJa/ulyZrVfxGv40N4oI7QyqPP+UbvzdVaxG0yUru4Hx5UYYcjJr nc2NcSrTm6e3UYupY1hTa4wwIRVK3895Cx5dGhO9Eiuyp3LdNsd36KaDzWnR2rj5SedP xM9QO1u4XFXAn9JgsDyhuoYXsqVEDiP6qVvyl9i+gNoaSEffot7Rzc7je1YBT/OXs+y5 PYq3Vuhn3InjtVC0TJGazhYvHPF2T6a8Cv5QvtTpSlXBH9X0vnECF0isrfVeGYoUUdLH QRrQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cogentembedded-com.20150623.gappssmtp.com header.s=20150623 header.b=KR3GIrwQ; 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 j10si2206027pgs.597.2018.03.14.11.19.48; Wed, 14 Mar 2018 11:20:33 -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=KR3GIrwQ; 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 S1752406AbeCNSRU (ORCPT + 99 others); Wed, 14 Mar 2018 14:17:20 -0400 Received: from mail-lf0-f66.google.com ([209.85.215.66]:36186 "EHLO mail-lf0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752369AbeCNSRP (ORCPT ); Wed, 14 Mar 2018 14:17:15 -0400 Received: by mail-lf0-f66.google.com with SMTP id p74-v6so6258301lfd.3 for ; Wed, 14 Mar 2018 11:17:15 -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=Yd01UyHAky8LSwT58YhO1amuU0m0/z7Jf+Ijb83vbG8=; b=KR3GIrwQT9HkhGIBs7G2eig85Bd8cmY/4S66IXKpsc4u3YC5VvYfPCfd+C09NgO3x9 243I4citZ6p1j7QbVUHs4feg4SJoKbm+Fixl7MqiN0sZBM9Bcs0gzbpxDJrQXwKmuZEg 6LGQUy7EitUFfLx2S5ICRQaCyvsrhVdk+thD4x2vwQmUy9ynV/lPkRxYd3CCuD/3kldD C50gbvZLAipzhWFuXEw+JTaeJ7hprP79OdrzTuSTaAJlPNC0jF0g6RUCpfmv4K0trpxr bQbgYbAEF6PuROMLKgQ90sXzQhGJIsVCCNEnpVFjpnPus6VYI5VQRmmLKcvXwDMP+vWE zjrg== 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=Yd01UyHAky8LSwT58YhO1amuU0m0/z7Jf+Ijb83vbG8=; b=ej13c0cV4XfS+c+Mgg8HzL7AekCjhlFsa2s6OdWocGOY/gydW5Eg2A9Csyqm4GG1MA 5SnT5K3yPPXd0H/CV92E7x2pM3URnon+icl7/qxOqvQtudF+yFYZhfDZVNr/QBumvVt2 1GxWFSoOkou6qGGlVaC/USRTbu8xJqWHCjuirWXOz/y57cizmrA/pBzbEx0Zsvy+bocM oPnBhUONkWIfMfYboRV/wkLKsQs4UOMrbFq+NRnkCQYV5CQL8nCU+XHgF5OgePSdq3cR oZpGMlPRyYprapzjGp+9RUNN/T2vNHDHp+LmZ/UDvbHsKK+SXeWWvzhlQ65aOeEruTao 0IdA== X-Gm-Message-State: AElRT7FoTKlvIK3Ki0RDeH+4Rz7c4evt7QWV9isaDv0xp5hmKn/FNp+J skj8e0Kac87a+yrz3QbCy6YXNgCH/5o= X-Received: by 2002:a19:2651:: with SMTP id m78-v6mr2599880lfm.7.1521051433451; Wed, 14 Mar 2018 11:17:13 -0700 (PDT) Received: from wasted.cogentembedded.com ([31.173.81.226]) by smtp.gmail.com with ESMTPSA id 30-v6sm767976lfw.7.2018.03.14.11.17.11 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 14 Mar 2018 11:17:12 -0700 (PDT) Subject: Re: [PATCH v3 2/3] drm: bridge: Add thc63lvd1024 LVDS decoder driver To: jacopo mondi Cc: 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, 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> <20180314180438.GD16424@w540> From: Sergei Shtylyov Organization: Cogent Embedded Message-ID: Date: Wed, 14 Mar 2018 21:17:10 +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: <20180314180438.GD16424@w540> 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/14/2018 09:04 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 @@ [...] >>> +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? > > Well, goto breaks the loop, if I only print out the error message, the > enable sequence will go on and enable the other regulators. > I can print out and break, but I don't see that much benefit Sorry, I meant that you should *return* there instead of *goto*. > One thing I could do instead, is not only print out the error message, > but disable the already enabled regulators if one fails to start. Yeah, probably... [...] >>> +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? > > Are you referring to the error message? Yes, seems more clear what to look for this way, IMHO... [...] MBR, Sergei