Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp469365pxh; Wed, 10 Nov 2021 04:47:15 -0800 (PST) X-Google-Smtp-Source: ABdhPJxcKTbXOF+cPYMbyZwJPW5pC2w0aqjln3sQqCBvj7pADsIQRqKR5ggTc3Dzq4c5eZzgnpD0 X-Received: by 2002:a17:906:8699:: with SMTP id g25mr19952033ejx.271.1636548434834; Wed, 10 Nov 2021 04:47:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636548434; cv=none; d=google.com; s=arc-20160816; b=OGWLt7KkBPCuHZ5gC4L4BKJbTV8KFrZ4YqctNKGITRFCkMCx/HWOToHzr2acBdHZIv rN35KpM3OT2dfE/w9H8eD80nydEJEWr5wj3Z9KHchzvNhfhxdaXXD5r4HJrxH0+B5q1L sgRgNK8Mj9MK1wpq3MzUt6K/AT9XrQ5FHmx8/z8rqtauc/dBuGOq+QpAdF0/UMg7mOnG m4RGHht7qO++QT4vjMGTKK7BsR7+1wQ8fNbEbNerI9A9jCR5ItDpkT5m4Xl8fXoGBuRA 1d7BbEOIYGUTUUhorPloS0uJYWiSR1cf7RTCCwZhujivS9B2YtvHGiOWtgZhK4Axi4hm SmZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=pZSUdRGSZa+6MHnp8qNchGyfbTiZfbmXa6o3waVEgso=; b=jVwatfmVbHzbfluaQ4tKbrSFsD01RJiXkb5TR0aGskveICF6gvxmQg9KroUR8jgn/A qNVz7aH5I6dCKVZd792G9asaAEMCAJckkJWBhDgkqNUAPlQNYl6BnbNe68QyFrQXCv2U issiYKmOobfnOhIcgIJnMMOQWprrr3WhhYGgPWbgO3KUzq42rq/1Z19oEEdkCGpElpsg pupaLn6NJv7/+ZdFR6x9XfxzDyrD9rOmfe53gX23nzDilFtANuhcZzdtlFrQ0t0Nrv2K dDwIQJFBthPXjsbZBDZeMUDPphE4fTKawHUxc58BLxM0pzhkyRHDBikDTfJlLnoc0hRj CfmA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@collabora.com header.s=mail header.b=UY7+1wlD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x12si51789780edd.539.2021.11.10.04.46.50; Wed, 10 Nov 2021 04:47:14 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@collabora.com header.s=mail header.b=UY7+1wlD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231613AbhKJMpZ (ORCPT + 99 others); Wed, 10 Nov 2021 07:45:25 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46014 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231210AbhKJMpY (ORCPT ); Wed, 10 Nov 2021 07:45:24 -0500 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e3e3]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3BFC7C061764 for ; Wed, 10 Nov 2021 04:42:37 -0800 (PST) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: dafna) with ESMTPSA id B677A1F45422 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=collabora.com; s=mail; t=1636548155; bh=ZsdqjNJRTzFZxNm9jZSSqsLxhmhLOYqnDc2uooP2j4s=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=UY7+1wlDPgAYmS8fH5yNoKPbqU3ypTNCdTx5M1AUZspII1o1AWL/PACLBfyZSdH3T Qj02/9mxmAGUOY6J6zEnDw0gHcierAn1+t9d/QKQwdlROSvQatKPajO0Bkxk5L99C2 ZgFX/psZdl4NMT+rW6JRbQzM1es+mmYX+Gu1OEW5Vu/os5VlMrP2OjNE5Z2tNYDL3m PFU3EyRjbKyRCJIQNTLMVWS5RpLv1ilP7TLbungFd84idK3Hm1+UCHUssLwfRKRV7A DYC11vpP7u0kU1y8z4E+W/yeHPF2N20rHefr6EJWPBg8NM3C79rW/akkKeEr4f+1s2 Icwv+4/bByHTg== Subject: Re: [PATCH v2 1/3] drm/bridge: parade-ps8640: Don't try to enable VDO if poweron fails To: AngeloGioacchino Del Regno , a.hajda@samsung.com Cc: narmstrong@baylibre.com, robert.foss@linaro.org, Laurent.pinchart@ideasonboard.com, jonas@kwiboo.se, jernej.skrabec@gmail.com, airlied@linux.ie, daniel@ffwll.ch, dri-devel@lists.freedesktop.org, kernel@collabora.com, linux-kernel@vger.kernel.org References: <20211102093618.114928-1-angelogioacchino.delregno@collabora.com> From: Dafna Hirschfeld Message-ID: <18ac7077-2926-0817-e3bf-023187bbc4f3@collabora.com> Date: Wed, 10 Nov 2021 14:42:32 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <20211102093618.114928-1-angelogioacchino.delregno@collabora.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02.11.21 11:36, AngeloGioacchino Del Regno wrote: > If the bridge cannot get powered on, there's no reason to try to > communicate with it: change the ps8640_bridge_poweron function to > return an error value to the caller, so that we can avoid calling > ps8640_bridge_vdo_control() in ps8640_pre_enable() if the poweron > sequence fails. > > Signed-off-by: AngeloGioacchino Del Regno Reviewed-by: Dafna Hirschfeld > --- > drivers/gpu/drm/bridge/parade-ps8640.c | 14 +++++++++----- > 1 file changed, 9 insertions(+), 5 deletions(-) > > diff --git a/drivers/gpu/drm/bridge/parade-ps8640.c b/drivers/gpu/drm/bridge/parade-ps8640.c > index 4b36e4dc78f1..8c5402947b3c 100644 > --- a/drivers/gpu/drm/bridge/parade-ps8640.c > +++ b/drivers/gpu/drm/bridge/parade-ps8640.c > @@ -293,19 +293,19 @@ static int ps8640_bridge_vdo_control(struct ps8640 *ps_bridge, > return 0; > } > > -static void ps8640_bridge_poweron(struct ps8640 *ps_bridge) > +static int ps8640_bridge_poweron(struct ps8640 *ps_bridge) > { > struct regmap *map = ps_bridge->regmap[PAGE2_TOP_CNTL]; > int ret, status; > > if (ps_bridge->powered) > - return; > + return 0; > > ret = regulator_bulk_enable(ARRAY_SIZE(ps_bridge->supplies), > ps_bridge->supplies); > if (ret < 0) { > DRM_ERROR("cannot enable regulators %d\n", ret); > - return; > + return ret; > } > > gpiod_set_value(ps_bridge->gpio_powerdown, 0); > @@ -352,11 +352,13 @@ static void ps8640_bridge_poweron(struct ps8640 *ps_bridge) > > ps_bridge->powered = true; > > - return; > + return 0; > > err_regulators_disable: > regulator_bulk_disable(ARRAY_SIZE(ps_bridge->supplies), > ps_bridge->supplies); > + > + return ret; > } > > static void ps8640_bridge_poweroff(struct ps8640 *ps_bridge) > @@ -381,7 +383,9 @@ static void ps8640_pre_enable(struct drm_bridge *bridge) > struct ps8640 *ps_bridge = bridge_to_ps8640(bridge); > int ret; > > - ps8640_bridge_poweron(ps_bridge); > + ret = ps8640_bridge_poweron(ps_bridge); > + if (ret) > + return; > > ret = ps8640_bridge_vdo_control(ps_bridge, ENABLE); > if (ret < 0) >