[PATCH 2/3] ASoC: CS4271 codec support
Jamie Iles
jamie at jamieiles.com
Wed Dec 8 08:07:20 EST 2010
Hi Alexander,
I can't comment on the codec side of things but a couple of general comments
inline. Otherwise looks good to me!
Jamie
On Wed, Dec 08, 2010 at 03:02:52PM +0300, Alexander wrote:
> From: Alexander Sverdlin <subaparts at yandex.ru>
>
> Added support for CS4271 codec to ASoC.
>
> Signed-off-by: Alexander Sverdlin <subaparts at yandex.ru>
> ---
> include/sound/cs4271.h | 25 ++
> sound/soc/codecs/Kconfig | 4 +
> sound/soc/codecs/Makefile | 2 +
> sound/soc/codecs/cs4271.c | 607 +++++++++++++++++++++++++++++++++++++++++++++
> 4 files changed, 638 insertions(+), 0 deletions(-)
>
[...]
> diff --git a/sound/soc/codecs/cs4271.c b/sound/soc/codecs/cs4271.c
> new file mode 100644
> index 0000000..c0d74da
> --- /dev/null
> +++ b/sound/soc/codecs/cs4271.c
> @@ -0,0 +1,607 @@
[...]
> +struct cs4271_private {
> + /* SND_SOC_I2C or SND_SOC_SPI */
> + enum snd_soc_control_type bus_type;
> + void *control_data;
> + unsigned int mclk;
> + /* SND_SOC_DAIFMT_I2S or SND_SOC_DAIFMT_LEFT_J */
> + unsigned int mode;
> + unsigned int master;
> + /* GPIO driving Reset pin, if any */
> + int gpio_nreset;
> + /* GPIO that disable serial bus, if any */
> + int gpio_disable;
Align gpio_nreset and gpio_disable with the other fields?
[...]
> +#if defined(CONFIG_SPI_MASTER)
> +static int __devinit cs4271_spi_probe(struct spi_device *spi)
> +{
> + struct cs4271_private *cs4271;
> + int ret;
> +
> + cs4271 = kzalloc(sizeof(*cs4271), GFP_KERNEL);
> + if (!cs4271)
> + return -ENOMEM;
> +
> + spi_set_drvdata(spi, cs4271);
> + cs4271->control_data = spi;
> + cs4271->bus_type = SND_SOC_SPI;
> +
> + ret = snd_soc_register_codec(&spi->dev, &soc_codec_dev_cs4271,
> + &cs4271_dai, 1);
> + if (ret < 0)
> + kfree(cs4271);
> + return ret;
> +}
> +
> +static int __devexit cs4271_spi_remove(struct spi_device *spi)
> +{
> + snd_soc_unregister_codec(&spi->dev);
> + kfree(spi_get_drvdata(spi));
> + return 0;
> +}
Is it worth using devm_kzalloc() for the i2c and spi probe functions to
simplify the error handling and release functions? Admittedly they are fairly
simple functions though.
[...]
> +/*
> + * We only register our serial bus driver here without
> + * assignment to particular chip. So if any of the below
> + * fails, there is some problem with I2C or SPI subsystem.
> + * In most cases this module will be compiled with support
> + * of only one serial bus.
> + */
> +static int __init cs4271_modinit(void)
> +{
> + int ret;
> +
> +#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
> + ret = i2c_add_driver(&cs4271_i2c_driver);
> + if (ret) {
> + pr_err("Failed to register CS4271 I2C driver: %d\n", ret);
> + return ret;
> + }
> +#endif
> +
> +#if defined(CONFIG_SPI_MASTER)
> + ret = spi_register_driver(&cs4271_spi_driver);
> + if (ret) {
> + pr_err("Failed to register CS4271 SPI driver: %d\n", ret);
> + return ret;
> + }
> +#endif
> +
> + return 0;
> +}
> +module_init(cs4271_modinit);
> +
> +static void __exit cs4271_modexit(void)
> +{
> +#if defined(CONFIG_SPI_MASTER)
> + spi_unregister_driver(&cs4271_spi_driver);
> +#endif
> +
> +#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
> + i2c_del_driver(&cs4271_i2c_driver);
> +#endif
> +}
> +module_exit(cs4271_modexit);
Doesn't the dependency on SND_SOC_I2C_AND_SPI mean that you will always have
I2C and SPI_MASTER?
More information about the linux-arm-kernel
mailing list