Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp5407671imm; Tue, 16 Oct 2018 09:46:12 -0700 (PDT) X-Google-Smtp-Source: ACcGV614kV8//eosAZHG3Ag1KTDU0Sg3YLI8QjIGaTmSmL7tOEQABTPOguX2y9gDOHtycIeHlgdK X-Received: by 2002:a63:e256:: with SMTP id y22-v6mr20751747pgj.439.1539708372485; Tue, 16 Oct 2018 09:46:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539708372; cv=none; d=google.com; s=arc-20160816; b=0TgzoEYLKCsVimCr1yS060AJkwaBMLy6/zK9TdHWKJaQ12ZcaWrna9Eq/+X5z9OpVA hVkAscIP2mIalCq2M586bRN35cOWgHqjqoSdPqc++DiJojJV4IncL216Th3EukJ3dKIe oR0ifAogVPwS561S5wDvwVwtIkRWHxxllXLOV77NIump4ln1aV8M1zTNLT5BvilUUQIn 39DKkfSprwhvvZq6AXZjjIOt6/2tea7+rONrueArdqLbOBT0mNUsC90lSGpbOJqFaKF6 JuSdW72wVctMRlR+ol12vhZOvEsolkHHWvcSy6kGh1THWy8+iFx8LTJPBID4GTOD7YfH sR1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature; bh=ote3CaEJ6LuHeJUB867rC781HriwO22stBLo0Z09DMw=; b=EG8731Nt60meXZNGwhnLrowI2BPKMbHnHwduFw0QQ0tbhiCpa5MlYWL16Z27Mrb9Qm V6o/aubpLzzCvLr2spM3Kzjr9Eav38NpDmtATF83gHb2upGlmiKbX6KYRdLqvASwQSUg YaJ4H09MiJcwQPeh22DSFkEbfEKxs5qYB4/xZpKK6lM1qf2CIVZvFPCWgWEkvXv8oSXd KpHxBokMvDRghgLC2lQFVr78OgPaZqK8MWhkGEFe7c/he5Yp+0dnQ3VvjaL0HdDbUFcg kptYECP1xG00l5W4nno+qGjytwBsFzkrJFrMqpL9m2eh4HdZzkXYACW188NWO1/rXSYj /V4g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b="hXXjqv6/"; 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 u69-v6si13378088pgd.353.2018.10.16.09.45.56; Tue, 16 Oct 2018 09:46:12 -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=fail header.i=@ffwll.ch header.s=google header.b="hXXjqv6/"; 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 S1727237AbeJQAgs (ORCPT + 99 others); Tue, 16 Oct 2018 20:36:48 -0400 Received: from mail-ed1-f66.google.com ([209.85.208.66]:40727 "EHLO mail-ed1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727159AbeJQAgs (ORCPT ); Tue, 16 Oct 2018 20:36:48 -0400 Received: by mail-ed1-f66.google.com with SMTP id r1-v6so22020721edd.7 for ; Tue, 16 Oct 2018 09:45:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=sender:date:from:to:cc:subject:message-id:mail-followup-to :references:mime-version:content-disposition:in-reply-to:user-agent; bh=ote3CaEJ6LuHeJUB867rC781HriwO22stBLo0Z09DMw=; b=hXXjqv6/a7V0h0dCr3ksmMm9b7d4aIyDcdFkMlaOc3aP9MEO5giy5f0OcsqQDiMVc6 YCPeMgjcfL3M2dczHrfxRDkNv/oQv48HL8xdiqYnrq5gxMfIiGYIUmqzK5ASrXqwm+Cj 5yRN8KHFY6MkOITojOwgnrbP5e/GeRZ3T5Jiw= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to:user-agent; bh=ote3CaEJ6LuHeJUB867rC781HriwO22stBLo0Z09DMw=; b=ZR5AiTLYsp0WN8usCHuyoCVwCPif9w+b6T6TU7T9m11TmL9muB1knJP6tG0TTGYL9n juGd3qbt6aleq0xZS6s5qTiBNPXA/9Y1dW+iV4JSH0J+g8o6Xe6x0kF1pPMTMUGyKCXB FP39/SJ7MlEeoUX6jqC5qc0e6W2nFbeh8BuShgMoOEohBxiccKc3MlKR6K8QneLHvINs ppkq9RwZ+xlGMssMM7zWwmDazDc1KLxPD8Q6zMwnbRSygt9gBHOYY7nC0j3oWkKqwIOb 9B7xSuc8xywyNhQ7pW2WT3FlK/1Yu5eQ1N7jVQw31OqJPKnMNmTFaadcFwuadlh1nC2T 5xQw== X-Gm-Message-State: ABuFfohFqpNLvQ0Wg+gCeNhSWcmIz94t34nFDsdBSxfxP/tOgdxCEa0F UP/NQFBONQzNFjSXsROEPJbDB76NSlw= X-Received: by 2002:a17:906:6983:: with SMTP id i3-v6mr24962078ejr.141.1539708331556; Tue, 16 Oct 2018 09:45:31 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:569e:0:3106:d637:d723:e855]) by smtp.gmail.com with ESMTPSA id b26-v6sm4799761edw.0.2018.10.16.09.45.30 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 16 Oct 2018 09:45:30 -0700 (PDT) Date: Tue, 16 Oct 2018 18:45:28 +0200 From: Daniel Vetter To: Stefan Agner Cc: p.zabel@pengutronix.de, airlied@linux.ie, linux-kernel@vger.kernel.org, rmk+kernel@armlinux.org.uk, dri-devel@lists.freedesktop.org, Benjamin Gaignard Subject: Re: [PATCH] Revert "drm/imx: don't destroy mode objects manually on driver unbind" Message-ID: <20181016164528.GD31561@phenom.ffwll.local> Mail-Followup-To: Stefan Agner , p.zabel@pengutronix.de, airlied@linux.ie, linux-kernel@vger.kernel.org, rmk+kernel@armlinux.org.uk, dri-devel@lists.freedesktop.org, Benjamin Gaignard References: <20181016160923.2042-1-stefan@agner.ch> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181016160923.2042-1-stefan@agner.ch> X-Operating-System: Linux phenom 4.14.0-1-amd64 User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Oct 16, 2018 at 06:09:23PM +0200, Stefan Agner wrote: > 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. > > Link: https://www.mail-archive.com/dri-devel@lists.freedesktop.org/msg233327.html > Suggested-by: Russell King > Signed-off-by: Stefan Agner Adding Benjamin, who just made the same mistake I think (and I reviewed it ... oh well). -Daniel > --- > 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); > } > > -- > 2.19.1 > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch