Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp501305imm; Wed, 17 Oct 2018 03:54:21 -0700 (PDT) X-Google-Smtp-Source: ACcGV60tJ5Y/eHFng7PspQuEsBxrIejd4Q84maf0sT41S2r5cfx4DTqVhjYAh5ipZ6udBeFmt9FW X-Received: by 2002:a62:7a81:: with SMTP id v123-v6mr26493362pfc.240.1539773661782; Wed, 17 Oct 2018 03:54:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539773661; cv=none; d=google.com; s=arc-20160816; b=At3b8crux0L//4c3WAZAFaFWEty78pdxAjs3+YTNWBHz98NW3JEKkYRxrEYfJCSVC8 m5PI6lOvOSsz4kVyqQA8QL04K/c0hRs9uSrE81lYevIQyK3n5xWEajlw2HkAGOHnxSEO z1+LwxrUaAzKtI+cFNIQsk2ae48Kz043/FBIB5DMoyZGvq3bMOIHDiR15NSz2nxSgS0w TIBmu7sPc6axOfVeg8SQhb/Z9ynwLqxWTTyzlfOyR4LcWQrCAYLUPpmUc2wVhONF1w5N 8+eGYEqxLIuTrhQ3KZBn4/tJaq0AIIQtnhROdgQaSnOGfBLV861esLy9A9eS17WuOZ1R 5pqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=4M0RqDD4RKziDvTXJnkE4GPy7LWAwZ0GrPlKiU4G/ik=; b=l1O7kCTnL4WaauqVjNYAjq1JoNUkp7qlMR9GjCU4/1gJYgssJMOHon6j9qXyLKDXL5 KUV7AyIPCq8H4CYNkHKB/AsxnJjRX9v6AT18FVqYAU5w/5BCkd+wk3B60OPEkRt8YY53 UBmyj5jlHBoqyKC9t2fMyMsCww7jjNUywag+8IUxzJVPvsVZVIjNEZD7/pZ0thnMR50W dvHL7QlB85EkcLyM6pHEimtcszlR2QZqKM8qCkoMcCXIgXyCPW12984/OEKq7czUDplW pFq8JGFIC8uSt5bGJOyOxW5QdG4zHkUbGlTaMUOP+utJtrRn1YAsyu4gbmSaAQSHlC34 rxeA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b="YH/7MZiK"; 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 14-v6si17227532pgk.497.2018.10.17.03.54.06; Wed, 17 Oct 2018 03:54:21 -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=@agner.ch header.s=dkim header.b="YH/7MZiK"; 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 S1727048AbeJQSre (ORCPT + 99 others); Wed, 17 Oct 2018 14:47:34 -0400 Received: from mail.kmu-office.ch ([178.209.48.109]:41356 "EHLO mail.kmu-office.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726861AbeJQSrd (ORCPT ); Wed, 17 Oct 2018 14:47:33 -0400 Received: from webmail.kmu-office.ch (unknown [IPv6:2a02:418:6a02::a3]) by mail.kmu-office.ch (Postfix) with ESMTPSA id F07045C02D9; Wed, 17 Oct 2018 12:52:21 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=agner.ch; s=dkim; t=1539773541; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=4M0RqDD4RKziDvTXJnkE4GPy7LWAwZ0GrPlKiU4G/ik=; b=YH/7MZiKm/lpqcejwpE56w1w1+qC4CETjFFJeaAzLDATS6G+My5wntiCrlX/V9G73AzfUk ZNkq1Inq/vT6sAUvF4rZuc+kaFgAu12ZR66O2exKHnb7L35wRsGyaBaZ2vvJ8P8IYViWg0 KoL/s0TwMmrtxQrSS/57P05H4Ptz1Hs= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Date: Wed, 17 Oct 2018 12:52:21 +0200 From: Stefan Agner To: Lucas Stach Cc: p.zabel@pengutronix.de, airlied@linux.ie, rmk+kernel@armlinux.org.uk, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] Revert "drm/imx: don't destroy mode objects manually on driver unbind" In-Reply-To: <1539708694.3688.16.camel@pengutronix.de> References: <20181016160923.2042-1-stefan@agner.ch> <1539708694.3688.16.camel@pengutronix.de> Message-ID: X-Sender: stefan@agner.ch User-Agent: Roundcube Webmail/1.3.7 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 16.10.2018 18:51, Lucas Stach wrote: > Am Dienstag, den 16.10.2018, 18:09 +0200 schrieb Stefan Agner: >> This reverts commit 8e3b16e2117409625b89807de3912ff773aea354. >> >> Using the component framework requires all components to undo in >> ->unbind what ->bind does. Unfortunately that particular commit >> broke this rule. In particular, this is an issue if a single >> component during probe fails. In that case, component_bind_all() >> calls unbind on already succussfully bound components, and then >> frees memory allocated using devm. If one of those components >> registered e.g. an encoder with the framework then this leads to >> use after free situations. >> >> Revert the commit to ensure that all components properly undo >> what ->bind does. > > I agree with this patch in general, but I think I remember why I > changed this in the first place: dw_hdmi_imx_unbind does not destroy > the encoder that has been registered in dw_hdmi_imx_bind. Good point, yeah that is missing. > > 8e3b16e21174 was an (apparently wrong) attempt to fix such issues once > and for all. By reverting this commit we go back to leaking the HDMI > encoder, so I think this patch should include a fix to destroy the > encoder on unbind. Makes sense, will add that to the same commit and send a v2. -- Stefan > > Regards, > Lucas > >> Link: https://www.mail-archive.com/dri-devel@lists.freedesktop.org/msg233327.html >> > Suggested-by: Russell King >> > Signed-off-by: Stefan Agner >> --- >>  drivers/gpu/drm/imx/imx-drm-core.c     | 4 ++-- >>  drivers/gpu/drm/imx/imx-ldb.c          | 6 ++++++ >>  drivers/gpu/drm/imx/imx-tve.c          | 3 +++ >>  drivers/gpu/drm/imx/parallel-display.c | 3 +++ >>  4 files changed, 14 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/gpu/drm/imx/imx-drm-core.c b/drivers/gpu/drm/imx/imx-drm-core.c >> index 5ea0c82f9957..caa6061a98ba 100644 >> --- a/drivers/gpu/drm/imx/imx-drm-core.c >> +++ b/drivers/gpu/drm/imx/imx-drm-core.c >> @@ -305,11 +305,11 @@ static void imx_drm_unbind(struct device *dev) >>   >> >   drm_fb_cma_fbdev_fini(drm); >>   >> > - drm_mode_config_cleanup(drm); >> - >> >   component_unbind_all(drm->dev, drm); >> >   dev_set_drvdata(dev, NULL); >>   >> > + drm_mode_config_cleanup(drm); >> + >> >   drm_dev_put(drm); >>  } >>   >> diff --git a/drivers/gpu/drm/imx/imx-ldb.c b/drivers/gpu/drm/imx/imx-ldb.c >> index 3bd0f8a18e74..592aabc4a262 100644 >> --- a/drivers/gpu/drm/imx/imx-ldb.c >> +++ b/drivers/gpu/drm/imx/imx-ldb.c >> @@ -723,6 +723,12 @@ static void imx_ldb_unbind(struct device *dev, struct device *master, >> >   if (channel->panel) >> >   drm_panel_detach(channel->panel); >>   >> > + if (!channel->connector.funcs) >> > + continue; >> + >> > + channel->connector.funcs->destroy(&channel->connector); >> > + channel->encoder.funcs->destroy(&channel->encoder); >> + >> >   kfree(channel->edid); >> >   i2c_put_adapter(channel->ddc); >> >   } >> diff --git a/drivers/gpu/drm/imx/imx-tve.c b/drivers/gpu/drm/imx/imx-tve.c >> index cffd3310240e..8d6e89ce1edb 100644 >> --- a/drivers/gpu/drm/imx/imx-tve.c >> +++ b/drivers/gpu/drm/imx/imx-tve.c >> @@ -673,6 +673,9 @@ static void imx_tve_unbind(struct device *dev, struct device *master, >>  { >> >   struct imx_tve *tve = dev_get_drvdata(dev); >>   >> > + tve->connector.funcs->destroy(&tve->connector); >> > + tve->encoder.funcs->destroy(&tve->encoder); >> + >> >   if (!IS_ERR(tve->dac_reg)) >> >   regulator_disable(tve->dac_reg); >>  } >> diff --git a/drivers/gpu/drm/imx/parallel-display.c b/drivers/gpu/drm/imx/parallel-display.c >> index aefd04e18f93..6f11bffcde37 100644 >> --- a/drivers/gpu/drm/imx/parallel-display.c >> +++ b/drivers/gpu/drm/imx/parallel-display.c >> @@ -258,6 +258,9 @@ static void imx_pd_unbind(struct device *dev, struct device *master, >> >   if (imxpd->panel) >> >   drm_panel_detach(imxpd->panel); >>   >> > + imxpd->encoder.funcs->destroy(&imxpd->encoder); >> > + imxpd->connector.funcs->destroy(&imxpd->connector); >> + >> >   kfree(imxpd->edid); >>  } >>