Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2829913pxv; Mon, 12 Jul 2021 03:00:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwhnO4hJgL6Dc09AJmbeu4o61ibCgAjcAItAK7oO8mDku95gjEbVWrkHWSLg6R1KpRSMQhS X-Received: by 2002:a02:8521:: with SMTP id g30mr43746170jai.113.1626084025595; Mon, 12 Jul 2021 03:00:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626084025; cv=none; d=google.com; s=arc-20160816; b=S5jeyiTI9nG3lgdkBghKKj2wDVRFInzwih5B+nr3K0co+H6UTM/Kly60ah3+J5c5Sk yiKGyb/c0ruDmLdzlg1gjXbFtUycAr4pgyr+IIZmbd0VoU+YIPAu2e1UGnfHTnsE8I+7 7h1KxWJFOGpeFW8Teg0w/Kf/7UkjxNJgxD8M3PnPyPLCdplWEeFE40246+mEDql63M6o 78L1RPxPs0F8+aidrtH/XA/FNbAVvxJF14AfAxZdv20wwhp7djqtX1ifYQ9fd0HLzuuw WM2CnXI2b3wwpxFq/R94+9wVV3IibpvMdfi5A8gzILfa/AfLsfOj+WciNspo0ErKZvTi PKvw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=R0GEOrJTNMKXsW/QCuIO/UHe4YR6CgANH4jfpv24MGs=; b=PYpD52wHRbL4ETQopu7h5F97drSemHwd93C2+KrKr91oNPvX0mkdy4wc3vKFtBnbaD 8WjIooyskI3qBxEfP64Yb8fE2Ot6xWnElpDxR6IkHy1iUfCGSPyuEK76aORx3wFAFCsu FlFcXrudYQq7cEgePvwnAVb5ZbQGHmNMqsYnzNj8tLo38wKyOOl7lJTzXhkM8aPHSKTO c30xvvDF4c/6UDc8u7kdJgKBWyLIN0b8ZRColJl4PsZk4o29cJU6LFJB9csaATo++XAF N/uN7GFv3ZFmhv1JP1bBqB63cqkbKU7NP9vJR9StzAaaaQubnk12vEOdLR8zUdZ5klSw xaWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="z/Pn73Ig"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o11si10770073ilg.108.2021.07.12.03.00.12; Mon, 12 Jul 2021 03:00:25 -0700 (PDT) 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=pass header.i=@linuxfoundation.org header.s=korg header.b="z/Pn73Ig"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243477AbhGLHE6 (ORCPT + 99 others); Mon, 12 Jul 2021 03:04:58 -0400 Received: from mail.kernel.org ([198.145.29.99]:44284 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238311AbhGLGrH (ORCPT ); Mon, 12 Jul 2021 02:47:07 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D15CC6124C; Mon, 12 Jul 2021 06:43:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626072182; bh=iXdkt7lFSEcVEz9LqocFpVqjTAQ3P65zABd4cEeux3A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=z/Pn73IgtBi9xOs8pEB/MrgS86csj+ajLf4vZ/hgfHUBpXaqe2RQum7sJCdVwjNfR osER3giprICMPiDmDXsjZNpuH4e8J1OT6+13Ikj3n52dD0s7B1KVk4h1y7UwyNKkyT tvgzZG3PXitY9WWpPiYnwAzZ+98DIovYFrC5ZvmE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Maxime Ripard , Linus Walleij , Sasha Levin Subject: [PATCH 5.10 336/593] drm/vc4: hdmi: Fix error path of hpd-gpios Date: Mon, 12 Jul 2021 08:08:16 +0200 Message-Id: <20210712060922.896458263@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060843.180606720@linuxfoundation.org> References: <20210712060843.180606720@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Maxime Ripard [ Upstream commit e075a7811977ff51c917a65ed1896e08231d2615 ] If the of_get_named_gpio_flags call fails in vc4_hdmi_bind, we jump to the err_unprepare_hsm label. That label will then call pm_runtime_disable and put_device on the DDC device. We just retrieved the DDC device, so the latter is definitely justified. However at that point we still haven't called pm_runtime_enable, so the call to pm_runtime_disable is not supposed to be there. Fixes: 10ee275cb12f ("drm/vc4: prepare for CEC support") Signed-off-by: Maxime Ripard Reviewed-by: Linus Walleij Link: https://patchwork.freedesktop.org/patch/msgid/20210524131852.263883-1-maxime@cerno.tech Signed-off-by: Sasha Levin --- drivers/gpu/drm/vc4/vc4_hdmi.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/vc4/vc4_hdmi.c b/drivers/gpu/drm/vc4/vc4_hdmi.c index 88a8cb840cd5..25a09aaf5883 100644 --- a/drivers/gpu/drm/vc4/vc4_hdmi.c +++ b/drivers/gpu/drm/vc4/vc4_hdmi.c @@ -1795,7 +1795,7 @@ static int vc4_hdmi_bind(struct device *dev, struct device *master, void *data) &hpd_gpio_flags); if (vc4_hdmi->hpd_gpio < 0) { ret = vc4_hdmi->hpd_gpio; - goto err_unprepare_hsm; + goto err_put_ddc; } vc4_hdmi->hpd_active_low = hpd_gpio_flags & OF_GPIO_ACTIVE_LOW; @@ -1836,8 +1836,8 @@ err_destroy_conn: vc4_hdmi_connector_destroy(&vc4_hdmi->connector); err_destroy_encoder: drm_encoder_cleanup(encoder); -err_unprepare_hsm: pm_runtime_disable(dev); +err_put_ddc: put_device(&vc4_hdmi->ddc->dev); return ret; -- 2.30.2