Commit 84ae1840 authored by Osama Abdelkader's avatar Osama Abdelkader Committed by Raphael Gallais-Pou
Browse files

drm/sti: remove bridge when sti_hda component_add fails



Use devm_drm_bridge_add() so the bridge is released if probe fails after
registration, and drop the manual drm_bridge_remove() in remove().

Check the return value of devm_drm_bridge_add().

Signed-off-by: default avatarOsama Abdelkader <osama.abdelkader@gmail.com>
Fixes: d28726ef ("drm/sti: hda: add bridge before attaching")
Cc: stable@vger.kernel.org
Reviewed-by: default avatarLuca Ceresoli <luca.ceresoli@bootlin.com>
Acked-by: default avatarRaphaël Gallais-Pou <rgallaispou@gmail.com>
Link: https://patch.msgid.link/20260423200622.325076-1-osama.abdelkader@gmail.com


Signed-off-by: default avatarRaphael Gallais-Pou <raphael.gallais-pou@foss.st.com>
parent b5d0ad61
Loading
Loading
Loading
Loading
+4 −4
Original line number Diff line number Diff line
@@ -741,6 +741,7 @@ static int sti_hda_probe(struct platform_device *pdev)
	struct device *dev = &pdev->dev;
	struct sti_hda *hda;
	struct resource *res;
	int ret;

	DRM_INFO("%s\n", __func__);

@@ -779,7 +780,9 @@ static int sti_hda_probe(struct platform_device *pdev)
		return PTR_ERR(hda->clk_hddac);
	}

	drm_bridge_add(&hda->bridge);
	ret = devm_drm_bridge_add(dev, &hda->bridge);
	if (ret)
		return ret;

	platform_set_drvdata(pdev, hda);

@@ -788,10 +791,7 @@ static int sti_hda_probe(struct platform_device *pdev)

static void sti_hda_remove(struct platform_device *pdev)
{
	struct sti_hda *hda = platform_get_drvdata(pdev);

	component_del(&pdev->dev, &sti_hda_ops);
	drm_bridge_remove(&hda->bridge);
}

static const struct of_device_id hda_of_match[] = {