Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp473660pxh; Wed, 10 Nov 2021 04:52:01 -0800 (PST) X-Google-Smtp-Source: ABdhPJxkB9F4uhHyq3O5Yqhs6OCRds9EeNVhYT5iiX1hD2c4aPvLeEBXnZ19DmQCW0ve65Rtnltw X-Received: by 2002:a17:907:9801:: with SMTP id ji1mr20685624ejc.170.1636548720861; Wed, 10 Nov 2021 04:52:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636548720; cv=none; d=google.com; s=arc-20160816; b=jwqaDWNKW5+FSAVPvG7pNbkGaBgHlWRIbErhIU+5T9/O/kuznlPlD5kp6g5SiicrOC Fkha93omknW7v5ze+werCG2fTUl75KOrFkP774yYCr9j10qkcp7qOtIk9WuwFdgkiFCO FnNMEzmRHY3YMacM/AapHU5ITPkar9mpABjPo9iPdEXVjK0YYxdp3otomeky6lREG3j1 rmUBasOrgr7adBoaaAPS5KW72OfKg1yDCsR/WgJefnMjv9TEJZa7E0i+CyUA6u6JS1bI xrPD+zHcqVvjcGoHW5aVJpCtpbZHcTGbusObzJZwGGxzQn600yu45woHWdcHZX8tV1lU wvvQ== 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=wtNXFdoP2DSo1OWRax5ybJ2GAGMAblWg4dJT3dy0kEY=; b=V7XUkpPWy+qFTZS938MlmAhR8WuW/DhvAt/Z8rlArOMalEqVxbWSx7PjaDTZa+MAao Im3DdEfZtBdtx8xXEOQi+sBwvTi9H3bPmzf39IbP1WonAsYjW4jDqCwLXJD0azWQtPpN dvXnXbIdmvh404fjGNjQLMyvH6OcDSYsyTa6NmUH19YW6MKZYVc4KlMJoSuoLftnYD71 KUngmf+meDd9dqcZf1/SLmsc5scz/7w44pQdJjx99iKRHa1QmiBPvVJmgSZTXmQtBBKg 7SVp4cK9f0hgwbCArZzXY2CmGK/qqeJb8TdHHQ0YZEDwRJ6OYhvwjIFCviW5Bb6Ea+H0 qspg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@collabora.com header.s=mail header.b=sOaxVK8i; 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 y38si39216613ede.245.2021.11.10.04.51.36; Wed, 10 Nov 2021 04:52: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=sOaxVK8i; 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 S231773AbhKJMvV (ORCPT + 99 others); Wed, 10 Nov 2021 07:51:21 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47370 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231210AbhKJMvU (ORCPT ); Wed, 10 Nov 2021 07:51:20 -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 EDD84C061764 for ; Wed, 10 Nov 2021 04:48:32 -0800 (PST) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: dafna) with ESMTPSA id A47AA1F45536 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=collabora.com; s=mail; t=1636548511; bh=jwsdJub026Wwb55SAebMDORQGiD7sU4q5d/5s4UeTkg=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=sOaxVK8iLM1IIiBSNuKl6RpdA3raabAR4Ef1dztCdzH8+31hU+41orsEBRtAJa5ZD lzais0ceb8fIGpwmYySyCXqg5WDtNTwqOsgbUEBrxHF1/l0/umaNzTQ90nTBGJNN3t 3Gavr8rcHvETpLlBtSuUUlW6w4cMVq19fUfGw084oPfHF2IgpvgmVhg6xtyRlr/gAA pF8SJb+mHHNJ3wHyuznBSr+gctQ1Tamq2N3WS4eUYuCbF8OMkO9xcyxcZIyHKV108k 3uaPHvwWLwtk6zR5qwJPAzhsrlPoXY5lxetg9LfdnJjBzIGQxUSbecR3T1HoJ18Se9 7w+D6MwjybfsQ== Subject: Re: [PATCH v2 3/3] drm/bridge: parade-ps8640: Perform full poweroff 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> <20211102093618.114928-3-angelogioacchino.delregno@collabora.com> From: Dafna Hirschfeld Message-ID: <6a1ee7d7-abc7-ed9f-fca0-91a0950b13a8@collabora.com> Date: Wed, 10 Nov 2021 14:48:27 +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-3-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 function ps8640_bridge_poweron(), in case of a failure not relative > to the regulators enablement, the code was disabling the regulators but > the gpio changes that happened during the poweron sequence were not > being reverted back to a clean poweroff state. > > Since it is expected that, when we enter ps8640_bridge_poweron(), the > powerdown and reset GPIOs are both in active state exactly as they were > left in the poweroff function before, we can simply call function > __ps8640_bridge_poweroff() in the failure case, reverting every change > that was done during the power on sequence. > > Of course it was chosen to call the poweroff function instead of adding > code to revert the GPIO changes to the poweron one to avoid duplicating > code, as we would be doing exactly what the poweroff function does. > > Signed-off-by: AngeloGioacchino Del Regno Reviewed-by: Dafna Hirschfeld > --- > drivers/gpu/drm/bridge/parade-ps8640.c | 11 +++++------ > 1 file changed, 5 insertions(+), 6 deletions(-) > > diff --git a/drivers/gpu/drm/bridge/parade-ps8640.c b/drivers/gpu/drm/bridge/parade-ps8640.c > index 41f5d511d516..ef1b51d8b676 100644 > --- a/drivers/gpu/drm/bridge/parade-ps8640.c > +++ b/drivers/gpu/drm/bridge/parade-ps8640.c > @@ -344,7 +344,7 @@ static int ps8640_bridge_poweron(struct ps8640 *ps_bridge) > > if (ret < 0) { > DRM_ERROR("failed read PAGE2_GPIO_H: %d\n", ret); > - goto err_regulators_disable; > + goto err_poweroff; > } > > msleep(50); > @@ -360,23 +360,22 @@ static int ps8640_bridge_poweron(struct ps8640 *ps_bridge) > ret = regmap_update_bits(map, PAGE2_MCS_EN, MCS_EN, 0); > if (ret < 0) { > DRM_ERROR("failed write PAGE2_MCS_EN: %d\n", ret); > - goto err_regulators_disable; > + goto err_poweroff; > } > > /* Switch access edp panel's edid through i2c */ > ret = regmap_write(map, PAGE2_I2C_BYPASS, I2C_BYPASS_EN); > if (ret < 0) { > DRM_ERROR("failed write PAGE2_I2C_BYPASS: %d\n", ret); > - goto err_regulators_disable; > + goto err_poweroff; > } > > ps_bridge->powered = true; > > return 0; > > -err_regulators_disable: > - regulator_bulk_disable(ARRAY_SIZE(ps_bridge->supplies), > - ps_bridge->supplies); > +err_poweroff: > + __ps8640_bridge_poweroff(ps_bridge); > > return ret; > } >