Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp469124pxh; Wed, 10 Nov 2021 04:47:00 -0800 (PST) X-Google-Smtp-Source: ABdhPJzZ7Qckn5Tygog514d8msKBT0bfR4z5YP0a+nVlwGI22JPTR55EpR/28lXF056Gr1fSJn0X X-Received: by 2002:a17:906:7ac9:: with SMTP id k9mr19883518ejo.411.1636548420353; Wed, 10 Nov 2021 04:47:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636548420; cv=none; d=google.com; s=arc-20160816; b=CNXnMl7O6oJLu5ukBZ9Tx1GJncYRnz1x1NYsevFc0B20mdD+qD688why0evADRz2aK 1yi+SrdOLPomKdKW/uWFW7TsJDPZv2EAu2+xn5Z0KY5kPGUzn6uZAuxOaYPzXOQ95Q2R RvIAiSZqjEqPSnNoGtMgJnIgtBf/lrcM09xWRMj3OvQswcKd0N2QDblUAeFR1vWVySxv wPgI7mx13pK0WwbYQt+Gsjt0L3W5y6IQUmFaDLQwLjgN3B+bmIEJ0sdpNuHDJgCPTR27 xczgORjSDfCAsn23nGe8b21k6r/RaBLJTXkuc7ToQvhoWxb3k/iAVdZ2mPm5BX2DXXHJ 4jcg== 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=h3RKDnkFfciBSiKntTHQUxS0ugHD7JlY1uMaeeMAAEI=; b=KMTuQ8XEdsZt4HHwTwLVFfSoxf0g5Su8bVOXKPMID/ScWOqMFFyoGufNxmCJPrGzIs cZYwYyUf8qfJyOs53zkF6SXImUrIFCqBbmAPhm02hBbV2up3eVI44ETBP26ugDrwd/k4 JtJPZ4echvcNgysJs1SZthN5XwUjpzMa/+nEPP3PfFiNTS5OS4/y0JXspEclvUJiMcpR N5yimePe8ttFSZGs7elUeYMpusnhjEOovUEuiOrE2/4JgoKzmMWCpcN1eqZUX0heBLiR o8xoJRuLVUJyV8gsijmPhEs/Krno2dmTwuQ0ZVogt5JiG0DaC7meZSI9LbEpYrYvjTkH bbHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@collabora.com header.s=mail header.b=mNvXs4ak; 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 gt20si44772716ejc.185.2021.11.10.04.46.33; Wed, 10 Nov 2021 04:47:00 -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=mNvXs4ak; 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 S231503AbhKJMrC (ORCPT + 99 others); Wed, 10 Nov 2021 07:47:02 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46366 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229653AbhKJMrB (ORCPT ); Wed, 10 Nov 2021 07:47:01 -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 ECDB5C061764 for ; Wed, 10 Nov 2021 04:44:13 -0800 (PST) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: dafna) with ESMTPSA id B493E1F45477 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=collabora.com; s=mail; t=1636548252; bh=UMtO2IEIb9liiv4GEnJ/KRnLSOBjGePRppyxukrmtSY=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=mNvXs4akh9UACLvEBnjWYlK+qVtuLUFHG7bIgyZ/5u3gbZp3izHdr2jRkstgFD8m4 PnMPiV+7r+GNcq7RUmpHqto+K6vh8oD42HlSNJajwrDqM9v9VtJMbEj8MQYAd3RILj N4nKoKG65IWr7s9xPu3lzhDjXVNaPh3+Nm90M73dGvB7fj7UaX4ZK5HjiHHB+UiF5G Zi9Qw/1z+td7m2M9fyfjNQASCb8yMd7ROc5TgEkbErWKmwCJ4dwr4x+6pEaAmxIWVN 1jnLgyWYJ8IVd/DQxVC7n/SLZ/T2deD/RpAHznlmKeBGJEoRDWmTuCa0QTPyAatHSB R/DCoca2NGcMA== Subject: Re: [PATCH v2 2/3] drm/bridge: parade-ps8640: Move real poweroff action to new function 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> <20211102093618.114928-2-angelogioacchino.delregno@collabora.com> From: Dafna Hirschfeld Message-ID: Date: Wed, 10 Nov 2021 14:44:09 +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-2-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: > In preparation for varying the poweron error handling in function > ps8640_bridge_poweron(), move function ps8640_bridge_poweroff() up > and also move the actual logic to power off the chip to a new > __ps8640_bridge_poweroff() function. > > Signed-off-by: AngeloGioacchino Del Regno > --- > drivers/gpu/drm/bridge/parade-ps8640.c | 37 ++++++++++++++------------ > 1 file changed, 20 insertions(+), 17 deletions(-) > > diff --git a/drivers/gpu/drm/bridge/parade-ps8640.c b/drivers/gpu/drm/bridge/parade-ps8640.c > index 8c5402947b3c..41f5d511d516 100644 > --- a/drivers/gpu/drm/bridge/parade-ps8640.c > +++ b/drivers/gpu/drm/bridge/parade-ps8640.c > @@ -293,6 +293,26 @@ static int ps8640_bridge_vdo_control(struct ps8640 *ps_bridge, > return 0; > } > > +static void __ps8640_bridge_poweroff(struct ps8640 *ps_bridge) > +{ > + gpiod_set_value(ps_bridge->gpio_reset, 1); > + gpiod_set_value(ps_bridge->gpio_powerdown, 1); > + if (regulator_bulk_disable(ARRAY_SIZE(ps_bridge->supplies), > + ps_bridge->supplies)) { > + DRM_ERROR("cannot disable regulators\n"); > + } That '{' is redundant Thanks, Danfa > +} > + > +static void ps8640_bridge_poweroff(struct ps8640 *ps_bridge) > +{ > + if (!ps_bridge->powered) > + return; > + > + __ps8640_bridge_poweroff(ps_bridge); > + > + ps_bridge->powered = false; > +} > + > static int ps8640_bridge_poweron(struct ps8640 *ps_bridge) > { > struct regmap *map = ps_bridge->regmap[PAGE2_TOP_CNTL]; > @@ -361,23 +381,6 @@ static int ps8640_bridge_poweron(struct ps8640 *ps_bridge) > return ret; > } > > -static void ps8640_bridge_poweroff(struct ps8640 *ps_bridge) > -{ > - int ret; > - > - if (!ps_bridge->powered) > - return; > - > - gpiod_set_value(ps_bridge->gpio_reset, 1); > - gpiod_set_value(ps_bridge->gpio_powerdown, 1); > - ret = regulator_bulk_disable(ARRAY_SIZE(ps_bridge->supplies), > - ps_bridge->supplies); > - if (ret < 0) > - DRM_ERROR("cannot disable regulators %d\n", ret); > - > - ps_bridge->powered = false; > -} > - > static void ps8640_pre_enable(struct drm_bridge *bridge) > { > struct ps8640 *ps_bridge = bridge_to_ps8640(bridge); >