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

Commit 5168c547 authored by Koro Chen's avatar Koro Chen Committed by Mark Brown
Browse files

ASoC: rt5645: Fix missing free_irq



The driver does not free irq when snd_soc_register_codec returns error.
It does not return error when request irq failed, either.

Add return when request irq failed, and free_irq if
snd_soc_register_codec failed.

Signed-off-by: default avatarKoro Chen <koro.chen@mediatek.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 582edace
Loading
Loading
Loading
Loading
+14 −3
Original line number Original line Diff line number Diff line
@@ -3397,12 +3397,23 @@ static int rt5645_i2c_probe(struct i2c_client *i2c,
		ret = request_threaded_irq(rt5645->i2c->irq, NULL, rt5645_irq,
		ret = request_threaded_irq(rt5645->i2c->irq, NULL, rt5645_irq,
			IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING
			IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING
			| IRQF_ONESHOT, "rt5645", rt5645);
			| IRQF_ONESHOT, "rt5645", rt5645);
		if (ret)
		if (ret) {
			dev_err(&i2c->dev, "Failed to reguest IRQ: %d\n", ret);
			dev_err(&i2c->dev, "Failed to reguest IRQ: %d\n", ret);
			return ret;
		}
	}
	}


	return snd_soc_register_codec(&i2c->dev, &soc_codec_dev_rt5645,
	ret = snd_soc_register_codec(&i2c->dev, &soc_codec_dev_rt5645,
				     rt5645_dai, ARRAY_SIZE(rt5645_dai));
				     rt5645_dai, ARRAY_SIZE(rt5645_dai));
	if (ret)
		goto err_irq;

	return 0;

err_irq:
	if (rt5645->i2c->irq)
		free_irq(rt5645->i2c->irq, rt5645);
	return ret;
}
}


static int rt5645_i2c_remove(struct i2c_client *i2c)
static int rt5645_i2c_remove(struct i2c_client *i2c)