On Tue, Jul 26, 2016 at 12:15 PM, Brian Starkey <brian.starkey@xxxxxxx> wrote: > The CRTC's port pointer was being set to the endpoint node instead of > the port. Fix that, and hold a reference on the port node. > > Signed-off-by: Brian Starkey <brian.starkey@xxxxxxx> > Acked-by: Liviu Dudau <Liviu.Dudau@xxxxxxx> Applied to drm-misc > --- > drivers/gpu/drm/arm/malidp_drv.c | 13 ++++++++++--- > 1 file changed, 10 insertions(+), 3 deletions(-) > > diff --git a/drivers/gpu/drm/arm/malidp_drv.c b/drivers/gpu/drm/arm/malidp_drv.c > index e5b44e9..4e61ea5 100644 > --- a/drivers/gpu/drm/arm/malidp_drv.c > +++ b/drivers/gpu/drm/arm/malidp_drv.c > @@ -257,6 +257,7 @@ static int malidp_bind(struct device *dev) > { > struct resource *res; > struct drm_device *drm; > + struct device_node *ep; > struct malidp_drm *malidp; > struct malidp_hw_device *hwdev; > struct platform_device *pdev = to_platform_device(dev); > @@ -360,11 +361,12 @@ static int malidp_bind(struct device *dev) > goto register_fail; > > /* Set the CRTC's port so that the encoder component can find it */ > - malidp->crtc.port = of_graph_get_next_endpoint(dev->of_node, NULL); > + ep = of_graph_get_next_endpoint(dev->of_node, NULL); > + if (!ep) > + goto port_fail; > + malidp->crtc.port = of_get_next_parent(ep); > > ret = component_bind_all(dev, drm); > - of_node_put(malidp->crtc.port); > - > if (ret) { > DRM_ERROR("Failed to bind all components\n"); > goto bind_fail; > @@ -402,6 +404,9 @@ vblank_fail: > irq_init_fail: > component_unbind_all(dev, drm); > bind_fail: > + of_node_put(malidp->crtc.port); > + malidp->crtc.port = NULL; > +port_fail: > drm_dev_unregister(drm); > register_fail: > malidp_de_planes_destroy(drm); > @@ -435,6 +440,8 @@ static void malidp_unbind(struct device *dev) > malidp_de_irq_fini(drm); > drm_vblank_cleanup(drm); > component_unbind_all(dev, drm); > + of_node_put(malidp->crtc.port); > + malidp->crtc.port = NULL; > drm_dev_unregister(drm); > malidp_de_planes_destroy(drm); > drm_mode_config_cleanup(drm); > -- > 1.7.9.5 > > _______________________________________________ > dri-devel mailing list > dri-devel@xxxxxxxxxxxxxxxxxxxxx > https://lists.freedesktop.org/mailman/listinfo/dri-devel _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel