All of lore.kernel.org
 help / color / mirror / Atom feed
From: Johan Hovold <johan@kernel.org>
To: Jacob Siverskog <jacob@teenage.engineering>
Cc: Liam Girdwood <lgirdwood@gmail.com>,
	Mark Brown <broonie@kernel.org>, Jaroslav Kysela <perex@perex.cz>,
	Takashi Iwai <tiwai@suse.com>,
	Michael Trimarchi <michael@amarulasolutions.com>,
	Johan Hovold <johan@kernel.org>,
	alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v3 1/3] ASoC: pcm179x: Split into core and SPI parts
Date: Thu, 21 Jan 2016 16:36:15 +0100	[thread overview]
Message-ID: <20160121153615.GJ31514@localhost> (raw)
In-Reply-To: <1453390018-16854-2-git-send-email-jacob@teenage.engineering>

On Thu, Jan 21, 2016 at 04:26:56PM +0100, Jacob Siverskog wrote:
> The pcm179x family supports both SPI and I2C for configuration. This
> patch splits the driver into core and SPI parts, in preparation for
> I2C support.
> 
> Reviewed-by: Johan Hovold <johan@kernel.org>
> Signed-off-by: Jacob Siverskog <jacob@teenage.engineering>
> ---

> diff --git a/sound/soc/codecs/pcm179x-spi.c b/sound/soc/codecs/pcm179x-spi.c
> new file mode 100644
> index 0000000..5842add9
> --- /dev/null
> +++ b/sound/soc/codecs/pcm179x-spi.c
> @@ -0,0 +1,63 @@
> +/*
> + * PCM179X ASoC SPI driver
> + *
> + * Copyright (c) Amarula Solutions B.V. 2013
> + *
> + *     Michael Trimarchi <michael@amarulasolutions.com>
> + *
> + * This program is free software; you can redistribute it and/or
> + * modify it under the terms of the GNU General Public License
> + * as published by the Free Software Foundation; either version 2
> + * of the License, or (at your option) any later version.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> + * GNU General Public License for more details.
> + */
> +
> +#include <linux/module.h>
> +#include <linux/of.h>
> +#include <linux/spi/spi.h>
> +#include <linux/regmap.h>
> +
> +#include "pcm179x.h"
> +
> +static int pcm179x_spi_probe(struct spi_device *spi)
> +{
> +	return pcm179x_common_init(&spi->dev,
> +			devm_regmap_init_spi(spi, &pcm179x_regmap_config));
> +}
> +
  
> -static int pcm179x_spi_probe(struct spi_device *spi)
> +int pcm179x_common_init(struct device *dev, struct regmap *regmap)
>  {
>  	struct pcm179x_private *pcm179x;
>  	int ret;
>  
> -	pcm179x = devm_kzalloc(&spi->dev, sizeof(struct pcm179x_private),
> +	if (IS_ERR(regmap)) {
> +		ret = PTR_ERR(regmap);
> +		dev_err(dev, "Failed to register regmap: %d\n", ret);
> +		return ret;
> +	}

This looks weird. I think you should check for error where you do the
allocation even if this means a four more lines of code in total.

> +
> +	pcm179x = devm_kzalloc(dev, sizeof(struct pcm179x_private),
>  				GFP_KERNEL);
>  	if (!pcm179x)
>  		return -ENOMEM;
>  
> -	spi_set_drvdata(spi, pcm179x);
> -
> -	pcm179x->regmap = devm_regmap_init_spi(spi, &pcm179x_regmap);
> -	if (IS_ERR(pcm179x->regmap)) {
> -		ret = PTR_ERR(pcm179x->regmap);
> -		dev_err(&spi->dev, "Failed to register regmap: %d\n", ret);
> -		return ret;
> -	}
> +	pcm179x->regmap = regmap;
> +	dev_set_drvdata(dev, pcm179x);
>  
> -	return snd_soc_register_codec(&spi->dev,
> +	return snd_soc_register_codec(dev,
>  			&soc_codec_dev_pcm179x, &pcm179x_dai, 1);
>  }

Thanks,
Johan

  reply	other threads:[~2016-01-21 15:36 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-01-21 15:26 [PATCH v3 0/3] ASoC: pcm179x: Add I2C support, declare support for continuous rates Jacob Siverskog
2016-01-21 15:26 ` [PATCH v3 1/3] ASoC: pcm179x: Split into core and SPI parts Jacob Siverskog
2016-01-21 15:36   ` Johan Hovold [this message]
2016-01-21 16:27     ` Michael Trimarchi
2016-01-21 16:27       ` Michael Trimarchi
2016-01-21 17:56       ` Johan Hovold
2016-01-22 12:17         ` Jacob Siverskog
2016-01-21 15:26 ` [PATCH v3 2/3] ASoC: pcm179x: Add I2C interface driver Jacob Siverskog
2016-01-21 15:26 ` [PATCH v3 3/3] ASoC: pcm179x: Support continuous rates Jacob Siverskog
2016-01-29  0:22   ` Applied "ASoC: pcm179x: Support continuous rates" to the asoc tree Mark Brown

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20160121153615.GJ31514@localhost \
    --to=johan@kernel.org \
    --cc=alsa-devel@alsa-project.org \
    --cc=broonie@kernel.org \
    --cc=jacob@teenage.engineering \
    --cc=lgirdwood@gmail.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=michael@amarulasolutions.com \
    --cc=perex@perex.cz \
    --cc=tiwai@suse.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.