Searched hist:dc39596a906d5b604f4e64597b6e904fc14625e8 (Results 1 – 1 of 1) sorted by relevance
/linux/sound/soc/kirkwood/ |
H A D | kirkwood-i2s.c | diff dc39596a906d5b604f4e64597b6e904fc14625e8 Wed Oct 23 15:46:49 CEST 2019 Russell King <rmk+kernel@armlinux.org.uk> ASoC: kirkwood: fix device remove ordering
The devm conversion of kirkwood was incorrect; on removal, devm takes effect after the "remove" function has returned. So, the effect of the conversion was to change the order during remove from:
- snd_soc_unregister_component() (unpublishes interfaces) - clk_disable_unprepare() - cleanup resources
After the conversion, this became:
- clk_disable_unprepare() - while the device may still be active - snd_soc_unregister_component() - cleanup resources
Hence, it introduces a bug, where the internal clock for the device may be shut down before the device itself has been shut down. It is known that Marvell SoCs, including Dove, locks up if registers for a peripheral that has its clocks disabled are accessed.
Fixes: f98fc0f8154e ("ASoC: kirkwood: replace platform to component") Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk> Link: https://lore.kernel.org/r/E1iNGyP-0004oN-BA@rmk-PC.armlinux.org.uk Signed-off-by: Mark Brown <broonie@kernel.org>
|