Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 39013bd6 authored by Lee Jones's avatar Lee Jones Committed by Mark Brown
Browse files

ASoC: Ux500: Dispose of device nodes correctly



When of_parse_phandle() is used to find a device node, its
reference count is incremented by the helper. Once we're
finished with them, it's our responsibly to ensure they
are freed in the correct manor.

Acked-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent ddffeb8c
Loading
Loading
Loading
Loading
+17 −0
Original line number Original line Diff line number Diff line
@@ -57,6 +57,20 @@ static struct snd_soc_card mop500_card = {
	.num_links = ARRAY_SIZE(mop500_dai_links),
	.num_links = ARRAY_SIZE(mop500_dai_links),
};
};


static void mop500_of_node_put(void)
{
	int i;

	for (i = 0; i < 2; i++) {
		if (mop500_dai_links[i].cpu_of_node)
			of_node_put((struct device_node *)
				mop500_dai_links[i].cpu_of_node);
		if (mop500_dai_links[i].codec_of_node)
			of_node_put((struct device_node *)
				mop500_dai_links[i].codec_of_node);
	}
}

static int __devinit mop500_of_probe(struct platform_device *pdev,
static int __devinit mop500_of_probe(struct platform_device *pdev,
				struct device_node *np)
				struct device_node *np)
{
{
@@ -69,6 +83,7 @@ static int __devinit mop500_of_probe(struct platform_device *pdev,


	if (!(msp_np[0] && msp_np[1] && codec_np)) {
	if (!(msp_np[0] && msp_np[1] && codec_np)) {
		dev_err(&pdev->dev, "Phandle missing or invalid\n");
		dev_err(&pdev->dev, "Phandle missing or invalid\n");
		mop500_of_node_put();
		return -EINVAL;
		return -EINVAL;
	}
	}


@@ -83,6 +98,7 @@ static int __devinit mop500_of_probe(struct platform_device *pdev,


	return 0;
	return 0;
}
}

static int __devinit mop500_probe(struct platform_device *pdev)
static int __devinit mop500_probe(struct platform_device *pdev)
{
{
	struct device_node *np = pdev->dev.of_node;
	struct device_node *np = pdev->dev.of_node;
@@ -128,6 +144,7 @@ static int __devexit mop500_remove(struct platform_device *pdev)


	snd_soc_unregister_card(mop500_card);
	snd_soc_unregister_card(mop500_card);
	mop500_ab8500_remove(mop500_card);
	mop500_ab8500_remove(mop500_card);
	mop500_of_node_put();


	return 0;
	return 0;
}
}