[alsa-devel] [PATCH 2/2] ASoC: Add SPI support for WM8741
Liam Girdwood
lrg at ti.com
Tue Aug 9 14:28:58 CEST 2011
On 03/08/11 09:47, Mark Brown wrote:
> Signed-off-by: Mark Brown <broonie at opensource.wolfsonmicro.com>
> ---
Could not see 1/2
but 2/2
Acked-by: Liam Girdwood <lrg at ti.com>
> sound/soc/codecs/wm8741.c | 48 +++++++++++++++++++++++++++++++++++++++++++++
> 1 files changed, 48 insertions(+), 0 deletions(-)
>
> diff --git a/sound/soc/codecs/wm8741.c b/sound/soc/codecs/wm8741.c
> index d4bfffd..c1b6e91 100644
> --- a/sound/soc/codecs/wm8741.c
> +++ b/sound/soc/codecs/wm8741.c
> @@ -17,6 +17,7 @@
> #include <linux/delay.h>
> #include <linux/pm.h>
> #include <linux/i2c.h>
> +#include <linux/spi/spi.h>
> #include <linux/platform_device.h>
> #include <linux/regulator/consumer.h>
> #include <linux/slab.h>
> @@ -549,6 +550,43 @@ static struct i2c_driver wm8741_i2c_driver = {
> };
> #endif
>
> +#if defined(CONFIG_SPI_MASTER)
> +static int __devinit wm8741_spi_probe(struct spi_device *spi)
> +{
> + struct wm8741_priv *wm8741;
> + int ret;
> +
> + wm8741 = kzalloc(sizeof(struct wm8741_priv), GFP_KERNEL);
> + if (wm8741 == NULL)
> + return -ENOMEM;
> +
> + wm8741->control_type = SND_SOC_SPI;
> + spi_set_drvdata(spi, wm8741);
> +
> + ret = snd_soc_register_codec(&spi->dev,
> + &soc_codec_dev_wm8741, &wm8741_dai, 1);
> + if (ret < 0)
> + kfree(wm8741);
> + return ret;
> +}
> +
> +static int __devexit wm8741_spi_remove(struct spi_device *spi)
> +{
> + snd_soc_unregister_codec(&spi->dev);
> + kfree(spi_get_drvdata(spi));
> + return 0;
> +}
> +
> +static struct spi_driver wm8741_spi_driver = {
> + .driver = {
> + .name = "wm8741",
> + .owner = THIS_MODULE,
> + },
> + .probe = wm8741_spi_probe,
> + .remove = __devexit_p(wm8741_spi_remove),
> +};
> +#endif /* CONFIG_SPI_MASTER */
> +
> static int __init wm8741_modinit(void)
> {
> int ret = 0;
> @@ -558,6 +596,13 @@ static int __init wm8741_modinit(void)
> if (ret != 0)
> pr_err("Failed to register WM8741 I2C driver: %d\n", ret);
> #endif
> +#if defined(CONFIG_SPI_MASTER)
> + ret = spi_register_driver(&wm8741_spi_driver);
> + if (ret != 0) {
> + printk(KERN_ERR "Failed to register wm8741 SPI driver: %d\n",
> + ret);
> + }
> +#endif
>
> return ret;
> }
> @@ -565,6 +610,9 @@ module_init(wm8741_modinit);
>
> static void __exit wm8741_exit(void)
> {
> +#if defined(CONFIG_SPI_MASTER)
> + spi_unregister_driver(&wm8741_spi_driver);
> +#endif
> #if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
> i2c_del_driver(&wm8741_i2c_driver);
> #endif
More information about the Alsa-devel
mailing list