Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save hitech95/065f4c5b959d4ea1f2d893fcc2de1c21 to your computer and use it in GitHub Desktop.
Save hitech95/065f4c5b959d4ea1f2d893fcc2de1c21 to your computer and use it in GitHub Desktop.
From f98d3008b89a03fca0030301da3db4b8a3a18361 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Nicol=C3=B2=20Veronese?= <nicveronese@gmail.com>
Date: Sun, 24 Jun 2018 12:53:16 +0200
Subject: [PATCH 1/2] ASoC: add generic simple-amplifier support
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
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.
Signed-off-by: Nicolò Veronese <nicveronese@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@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;
+ 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")) {
+ 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@gmail.com>");
--
2.7.4
From 8c870997b00393ba8d57d3809eee554bcbf53868 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Nicol=C3=B2=20Veronese?= <nicveronese@gmail.com>
Date: Sun, 24 Jun 2018 13:01:17 +0200
Subject: [PATCH 2/2] ASoC: simple-amplifier: add dt-bindings
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Signed-off-by: Nicolò Veronese <nicveronese@gmail.com>
---
.../devicetree/bindings/sound/simple-amplifier.txt | 36 ++++++++++++++++++++++
1 file changed, 36 insertions(+)
create mode 100644 Documentation/devicetree/bindings/sound/simple-amplifier.txt
diff --git a/Documentation/devicetree/bindings/sound/simple-amplifier.txt b/Documentation/devicetree/bindings/sound/simple-amplifier.txt
new file mode 100644
index 0000000..1c2b57c
--- /dev/null
+++ b/Documentation/devicetree/bindings/sound/simple-amplifier.txt
@@ -0,0 +1,36 @@
+Simple-Amplifier:
+
+Simple-Amplifier specifies a simple aux device for your codec.
+Most aplifiers are managed by a single GPIO. The main function
+of this driver is to toggle the MUTE/SHUTDOWN GPIO.
+
+Required properties:
+
+- compatible : "simple-audio-amplifier"
+
+- VCC-supply : power supply for the device, as covered
+in Documentation/devicetree/bindings/regulator/regulator.txt
+
+Optional properties:
+
+- shutdown-gpios : The gpio to be toggled on and off
+to shutdown the amplifier when not in use. as covered
+in Documentation/gpio/board.txt
+
+Example:
+
+sound {
+ compatible = "simple-audio-card";
+ ...
+ simple-audio-card,routing =
+ "LEFT AMP IN", "LINE_OUT_LEFT",
+ "RIGHT AMP IN", "LINE_OUT_RIGHT";
+ simple-audio-card,aux-devs = <&amp>;
+ ...
+};
+
+amp: amplifier {
+ compatible = "simple-audio-amplifier";
+ VCC-supply = <&regulator>
+ shutdown-gpios = <&r_pio 2 GPIO_ACTIVE_LOW>;
+};
--
2.7.4
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment