[alsa-devel] [PATCH 1/2] ASoC: add generic simple-amplifier support

Mark Brown broonie at kernel.org
Mon Jun 25 13:21:44 CEST 2018


On Mon, Jun 25, 2018 at 01:06:16PM +0200, Nicolò Veronese wrote:
> Many boards have speaker amplifier attached on an analog output.
> Most of them are only managed by a mute or shutdown GPIO.
> In order to reduce duplicate driver, this patch adds generic/simple-amplifier.

Copying in Hans who has a machine that needs something like this, not
deleting context for his benefit.

This looks good to me, one coding style thing below but otherwise the
main thing I'm thinking is that we might want to add a mono channel as
well for simplicity when wiring up a system using a mono amplifier.
That could always be done later though.

> 
> Signed-off-by: Nicolò Veronese <nicveronese at gmail.com>
> ---
>  sound/soc/generic/Kconfig            |   5 ++
>  sound/soc/generic/Makefile           |   2 +
>  sound/soc/generic/simple-amplifier.c | 109 +++++++++++++++++++++++++++++++++++
>  3 files changed, 116 insertions(+)
>  create mode 100644 sound/soc/generic/simple-amplifier.c
> 
> diff --git a/sound/soc/generic/Kconfig b/sound/soc/generic/Kconfig
> index c954be0..ace17c3a 100644
> --- a/sound/soc/generic/Kconfig
> +++ b/sound/soc/generic/Kconfig
> @@ -7,6 +7,11 @@ config SND_SIMPLE_CARD
>  	help
>  	  This option enables generic simple sound card support
>  
> +config SND_SIMPLE_AMPLIFIER
> +	tristate "ASoC Simple Amplifier support"
> +	help
> +	  This option enables generic simple amplifier support
> +
>  config SND_SIMPLE_SCU_CARD
>  	tristate "ASoC Simple SCU sound card support"
>  	depends on OF
> diff --git a/sound/soc/generic/Makefile b/sound/soc/generic/Makefile
> index 9dec293..805a746 100644
> --- a/sound/soc/generic/Makefile
> +++ b/sound/soc/generic/Makefile
> @@ -1,12 +1,14 @@
>  # SPDX-License-Identifier: GPL-2.0
>  snd-soc-simple-card-utils-objs	:= simple-card-utils.o
>  snd-soc-simple-card-objs	:= simple-card.o
> +snd-soc-simple-amplifier-objs		:= simple-amplifier.o
>  snd-soc-simple-scu-card-objs	:= simple-scu-card.o
>  snd-soc-audio-graph-card-objs	:= audio-graph-card.o
>  snd-soc-audio-graph-scu-card-objs	:= audio-graph-scu-card.o
>  
>  obj-$(CONFIG_SND_SIMPLE_CARD_UTILS)	+= snd-soc-simple-card-utils.o
>  obj-$(CONFIG_SND_SIMPLE_CARD)		+= snd-soc-simple-card.o
> +obj-$(CONFIG_SND_SIMPLE_AMPLIFIER)		+= snd-soc-simple-amplifier.o
>  obj-$(CONFIG_SND_SIMPLE_SCU_CARD)	+= snd-soc-simple-scu-card.o
>  obj-$(CONFIG_SND_AUDIO_GRAPH_CARD)	+= snd-soc-audio-graph-card.o
>  obj-$(CONFIG_SND_AUDIO_GRAPH_SCU_CARD)	+= snd-soc-audio-graph-scu-card.o
> diff --git a/sound/soc/generic/simple-amplifier.c b/sound/soc/generic/simple-amplifier.c
> new file mode 100644
> index 0000000..e135a43
> --- /dev/null
> +++ b/sound/soc/generic/simple-amplifier.c
> @@ -0,0 +1,109 @@
> +// SPDX-License-Identifier: GPL-2.0
> +// ALSA SoC simple amplifier driver
> +//
> +// Copyright 2018
> +// Author:  Nicolò Veronese <nicveronese at gmail.com>
> +
> +#include <linux/module.h>
> +#include <linux/platform_device.h>
> +#include <linux/gpio/consumer.h>
> +#include <linux/regulator/consumer.h>
> +
> +#include <sound/soc.h>
> +#include <sound/soc-dapm.h>
> +
> +/* This struct is used to save the context */
> +struct simple_amp_data {
> +	struct device *dev;
> +	struct regmap *regmap;

You don't need a regmap here.

> +	struct gpio_desc *power_gpio;
> +};
> +
> +static int simple_amp_power_event(struct snd_soc_dapm_widget *widget,
> +				 struct snd_kcontrol *kctrl, int event)
> +{
> +	struct snd_soc_component *c = snd_soc_dapm_to_component(widget->dapm);
> +	struct simple_amp_data *data = snd_soc_component_get_drvdata(c);
> +
> +	/* Shutdown GPIO */
> +    if (data->power_gpio)
> +        gpiod_set_value_cansleep(data->power_gpio, SND_SOC_DAPM_EVENT_ON(event));
> +
> +	return 0;
> +}
> +
> +static const struct snd_soc_dapm_widget simple_amp_dapm_widgets[] = {
> +	SND_SOC_DAPM_INPUT("LEFT AMP IN"),
> +	SND_SOC_DAPM_INPUT("RIGHT AMP IN"),
> +
> +	SND_SOC_DAPM_OUTPUT("SPK LEFT"),
> +	SND_SOC_DAPM_OUTPUT("SPK RIGHT"),
> +
> +	SND_SOC_DAPM_REGULATOR_SUPPLY("VCC", 20, 0),
> +	SND_SOC_DAPM_SPK("MUTE", simple_amp_power_event),
> +};
> +
> +static const struct snd_soc_dapm_route simple_amp_dapm_routes[] = {
> +	{ "MUTE", NULL, "LEFT AMP IN" },
> +	{ "MUTE", NULL, "RIGHT AMP IN" },
> +
> +	{ "SPK LEFT", NULL, "VCC" },
> +	{ "SPK RIGHT", NULL, "VCC" },
> +
> +	{ "SPK LEFT", NULL, "MUTE" },
> +	{ "SPK RIGHT", NULL, "MUTE" },
> +};
> +
> +static const struct snd_soc_component_driver simple_amp_component_driver = {
> +	.name = "simple-amplifier",
> +	.dapm_widgets = simple_amp_dapm_widgets,
> +	.num_dapm_widgets = ARRAY_SIZE(simple_amp_dapm_widgets),
> +	.dapm_routes = simple_amp_dapm_routes,
> +	.num_dapm_routes = ARRAY_SIZE(simple_amp_dapm_routes),
> +};
> +
> +static int asoc_simple_amp_probe(struct platform_device *pdev)
> +{
> +	struct simple_amp_data *data;
> +	struct device *dev = &pdev->dev;
> +	int ret;
> +
> +	data = devm_kzalloc(dev, sizeof(*data), GFP_KERNEL);
> +	if (!data)
> +		return -ENOMEM;
> +	data->dev = &pdev->dev;
> +	platform_set_drvdata(pdev, data);
> +
> +	if(of_property_read_bool(pdev->dev.of_node,"shutdown-gpios")) {

Coding style: should be if (

> +		data->power_gpio = devm_gpiod_get_optional(&pdev->dev, "shutdown", GPIOD_OUT_LOW);
> +
> +		if (IS_ERR(data->power_gpio)) {
> +			ret = PTR_ERR(data->power_gpio);
> +			dev_err(&pdev->dev, "Failed to get shutdown gpio: %d\n", ret);
> +			return ret;
> +		}
> +	}
> +
> +	return devm_snd_soc_register_component(dev,
> +			&simple_amp_component_driver, NULL, 0);
> +}
> +
> +static const struct of_device_id asoc_simple_of_match[] = {
> +	{ .compatible = "simple-audio-amplifier", },
> +	{},
> +};
> +MODULE_DEVICE_TABLE(of, asoc_simple_of_match);
> +
> +static struct platform_driver asoc_simple_amp = {
> +	.driver = {
> +		.name = "asoc-simple-amplifier",
> +		.of_match_table = of_match_ptr(asoc_simple_of_match),
> +	},
> +	.probe = asoc_simple_amp_probe,
> +};
> +
> +module_platform_driver(asoc_simple_amp);
> +
> +MODULE_LICENSE("GPL v2");
> +MODULE_DESCRIPTION("ASoC Simple Amplifier");
> +MODULE_AUTHOR("Nicolò Veronese <nicveronese at gmail.com>");
> -- 
> 2.7.4
> 
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 488 bytes
Desc: not available
URL: <http://mailman.alsa-project.org/pipermail/alsa-devel/attachments/20180625/ae0a7287/attachment.sig>


More information about the Alsa-devel mailing list