]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
ASoC: wm1250-ev1: Convert to GPIO descriptors
authorLinus Walleij <linus.walleij@linaro.org>
Fri, 8 Dec 2023 10:09:26 +0000 (11:09 +0100)
committerMark Brown <broonie@kernel.org>
Fri, 8 Dec 2023 14:31:58 +0000 (14:31 +0000)
This converts the WM1250-EV1 codec to use GPIO descriptors.
It turns out that the platform data was only used to pass some
global GPIO numbers from a board file, so we get rid of this
and also switch over the single in-tree user in the S3C
Cragganmore module for S3C 6410.

The driver obtains two GPIO lines named OSR and master and just
pull them low, we leave this behaviour as it was.

Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Reviewed-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://lore.kernel.org/r/20231208-descriptors-sound-wlf-v1-2-c4dab6f521ec@linaro.org
Signed-off-by: Mark Brown <broonie@kernel.org>
arch/arm/mach-s3c/mach-crag6410.c
include/sound/wm1250-ev1.h [deleted file]
sound/soc/codecs/wm1250-ev1.c

index 7c4bed4370a1378d45fb5c295db14675fdf49d82..e5df2cb51ab27896d9dd80571f421e959db1fd1e 100644 (file)
@@ -39,8 +39,6 @@
 #include <linux/mfd/wm831x/irq.h>
 #include <linux/mfd/wm831x/gpio.h>
 
-#include <sound/wm1250-ev1.h>
-
 #include <asm/mach/arch.h>
 #include <asm/mach-types.h>
 
@@ -713,13 +711,16 @@ static struct wm831x_pdata glenfarclas_pmic_pdata = {
        .disable_touch = true,
 };
 
-static struct wm1250_ev1_pdata wm1250_ev1_pdata = {
-       .gpios = {
-               [WM1250_EV1_GPIO_CLK_ENA] = S3C64XX_GPN(12),
-               [WM1250_EV1_GPIO_CLK_SEL0] = S3C64XX_GPL(12),
-               [WM1250_EV1_GPIO_CLK_SEL1] = S3C64XX_GPL(13),
-               [WM1250_EV1_GPIO_OSR] = S3C64XX_GPL(14),
-               [WM1250_EV1_GPIO_MASTER] = S3C64XX_GPL(8),
+static struct gpiod_lookup_table crag_wm1250_ev1_gpiod_table = {
+       /* The WM1250-EV1 is device 0027 on I2C bus 1 */
+       .dev_id = "1-0027",
+       .table = {
+               GPIO_LOOKUP("GPION", 12, "clk-ena", GPIO_ACTIVE_HIGH),
+               GPIO_LOOKUP("GPIOL", 12, "clk-sel0", GPIO_ACTIVE_HIGH),
+               GPIO_LOOKUP("GPIOL", 13, "clk-sel1", GPIO_ACTIVE_HIGH),
+               GPIO_LOOKUP("GPIOL", 14, "osr", GPIO_ACTIVE_HIGH),
+               GPIO_LOOKUP("GPIOL", 8, "master", GPIO_ACTIVE_HIGH),
+               { },
        },
 };
 
@@ -733,9 +734,7 @@ static struct i2c_board_info i2c_devs1[] = {
        { I2C_BOARD_INFO("wlf-gf-module", 0x24) },
        { I2C_BOARD_INFO("wlf-gf-module", 0x25) },
        { I2C_BOARD_INFO("wlf-gf-module", 0x26) },
-
-       { I2C_BOARD_INFO("wm1250-ev1", 0x27),
-         .platform_data = &wm1250_ev1_pdata },
+       { I2C_BOARD_INFO("wm1250-ev1", 0x27), },
 };
 
 static struct s3c2410_platform_i2c i2c1_pdata = {
@@ -862,6 +861,7 @@ static void __init crag6410_machine_init(void)
 
        gpiod_add_lookup_table(&crag_pmic_gpiod_table);
        i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0));
+       gpiod_add_lookup_table(&crag_wm1250_ev1_gpiod_table);
        i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1));
 
        samsung_keypad_set_platdata(&crag6410_keypad_data);
diff --git a/include/sound/wm1250-ev1.h b/include/sound/wm1250-ev1.h
deleted file mode 100644 (file)
index d16614e..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-/*
- * linux/sound/wm1250-ev1.h - Platform data for WM1250-EV1
- *
- * Copyright 2011 Wolfson Microelectronics. PLC.
- */
-
-#ifndef __LINUX_SND_WM1250_EV1_H
-#define __LINUX_SND_WM1250_EV1_H
-
-#define WM1250_EV1_NUM_GPIOS 5
-
-#define WM1250_EV1_GPIO_CLK_ENA  0
-#define WM1250_EV1_GPIO_CLK_SEL0 1
-#define WM1250_EV1_GPIO_CLK_SEL1 2
-#define WM1250_EV1_GPIO_OSR      3
-#define WM1250_EV1_GPIO_MASTER   4
-
-
-struct wm1250_ev1_pdata {
-       int gpios[WM1250_EV1_NUM_GPIOS];
-};
-
-#endif
index d7eeb41ba60fa8b0732e11379226fd5f4249165e..a2a8b2a4b19befb1fb82b358129830c8c74d1438 100644 (file)
@@ -9,34 +9,23 @@
 #include <linux/module.h>
 #include <linux/slab.h>
 #include <linux/i2c.h>
-#include <linux/gpio.h>
+#include <linux/gpio/consumer.h>
 
 #include <sound/soc.h>
 #include <sound/soc-dapm.h>
-#include <sound/wm1250-ev1.h>
-
-static const char *wm1250_gpio_names[WM1250_EV1_NUM_GPIOS] = {
-       "WM1250 CLK_ENA",
-       "WM1250 CLK_SEL0",
-       "WM1250 CLK_SEL1",
-       "WM1250 OSR",
-       "WM1250 MASTER",
-};
 
 struct wm1250_priv {
-       struct gpio gpios[WM1250_EV1_NUM_GPIOS];
+       struct gpio_desc *clk_ena;
+       struct gpio_desc *clk_sel0;
+       struct gpio_desc *clk_sel1;
+       struct gpio_desc *osr;
+       struct gpio_desc *master;
 };
 
 static int wm1250_ev1_set_bias_level(struct snd_soc_component *component,
                                     enum snd_soc_bias_level level)
 {
        struct wm1250_priv *wm1250 = dev_get_drvdata(component->dev);
-       int ena;
-
-       if (wm1250)
-               ena = wm1250->gpios[WM1250_EV1_GPIO_CLK_ENA].gpio;
-       else
-               ena = -1;
 
        switch (level) {
        case SND_SOC_BIAS_ON:
@@ -46,13 +35,11 @@ static int wm1250_ev1_set_bias_level(struct snd_soc_component *component,
                break;
 
        case SND_SOC_BIAS_STANDBY:
-               if (ena >= 0)
-                       gpio_set_value_cansleep(ena, 1);
+               gpiod_set_value_cansleep(wm1250->clk_ena, 1);
                break;
 
        case SND_SOC_BIAS_OFF:
-               if (ena >= 0)
-                       gpio_set_value_cansleep(ena, 0);
+               gpiod_set_value_cansleep(wm1250->clk_ena, 0);
                break;
        }
 
@@ -80,28 +67,20 @@ static int wm1250_ev1_hw_params(struct snd_pcm_substream *substream,
 
        switch (params_rate(params)) {
        case 8000:
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL0].gpio,
-                              1);
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL1].gpio,
-                              1);
+               gpiod_set_value(wm1250->clk_sel0, 1);
+               gpiod_set_value(wm1250->clk_sel1, 1);
                break;
        case 16000:
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL0].gpio,
-                              0);
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL1].gpio,
-                              1);
+               gpiod_set_value(wm1250->clk_sel0, 0);
+               gpiod_set_value(wm1250->clk_sel1, 1);
                break;
        case 32000:
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL0].gpio,
-                              1);
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL1].gpio,
-                              0);
+               gpiod_set_value(wm1250->clk_sel0, 1);
+               gpiod_set_value(wm1250->clk_sel1, 0);
                break;
        case 64000:
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL0].gpio,
-                              0);
-               gpio_set_value(wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL1].gpio,
-                              0);
+               gpiod_set_value(wm1250->clk_sel0, 0);
+               gpiod_set_value(wm1250->clk_sel1, 0);
                break;
        default:
                return -EINVAL;
@@ -150,45 +129,43 @@ static int wm1250_ev1_pdata(struct i2c_client *i2c)
 {
        struct wm1250_ev1_pdata *pdata = dev_get_platdata(&i2c->dev);
        struct wm1250_priv *wm1250;
-       int i, ret;
+       int ret;
 
        if (!pdata)
                return 0;
 
        wm1250 = devm_kzalloc(&i2c->dev, sizeof(*wm1250), GFP_KERNEL);
-       if (!wm1250) {
-               ret = -ENOMEM;
-               goto err;
-       }
-
-       for (i = 0; i < ARRAY_SIZE(wm1250->gpios); i++) {
-               wm1250->gpios[i].gpio = pdata->gpios[i];
-               wm1250->gpios[i].label = wm1250_gpio_names[i];
-               wm1250->gpios[i].flags = GPIOF_OUT_INIT_LOW;
-       }
-       wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL0].flags = GPIOF_OUT_INIT_HIGH;
-       wm1250->gpios[WM1250_EV1_GPIO_CLK_SEL1].flags = GPIOF_OUT_INIT_HIGH;
-
-       ret = gpio_request_array(wm1250->gpios, ARRAY_SIZE(wm1250->gpios));
-       if (ret != 0) {
-               dev_err(&i2c->dev, "Failed to get GPIOs: %d\n", ret);
-               goto err;
-       }
+       if (!wm1250)
+               return -ENOMEM;
+
+       wm1250->clk_ena = devm_gpiod_get(&i2c->dev, "clk-ena", GPIOD_OUT_LOW);
+       if (IS_ERR(wm1250->clk_ena))
+               return dev_err_probe(&i2c->dev, PTR_ERR(wm1250->clk_ena),
+                                    "failed to get clock enable GPIO\n");
+
+       wm1250->clk_sel0 = devm_gpiod_get(&i2c->dev, "clk-sel0", GPIOD_OUT_HIGH);
+       if (IS_ERR(wm1250->clk_sel0))
+               return dev_err_probe(&i2c->dev, PTR_ERR(wm1250->clk_sel0),
+                                    "failed to get clock sel0 GPIO\n");
+
+       wm1250->clk_sel1 = devm_gpiod_get(&i2c->dev, "clk-sel1", GPIOD_OUT_HIGH);
+       if (IS_ERR(wm1250->clk_sel1))
+               return dev_err_probe(&i2c->dev, PTR_ERR(wm1250->clk_sel1),
+                                    "failed to get clock sel1 GPIO\n");
+
+       wm1250->osr = devm_gpiod_get(&i2c->dev, "osr", GPIOD_OUT_LOW);
+       if (IS_ERR(wm1250->osr))
+               return dev_err_probe(&i2c->dev, PTR_ERR(wm1250->osr),
+                                    "failed to get OSR GPIO\n");
+
+       wm1250->master = devm_gpiod_get(&i2c->dev, "master", GPIOD_OUT_LOW);
+       if (IS_ERR(wm1250->master))
+               return dev_err_probe(&i2c->dev, PTR_ERR(wm1250->master),
+                                    "failed to get MASTER GPIO\n");
 
        dev_set_drvdata(&i2c->dev, wm1250);
 
        return ret;
-
-err:
-       return ret;
-}
-
-static void wm1250_ev1_free(struct i2c_client *i2c)
-{
-       struct wm1250_priv *wm1250 = dev_get_drvdata(&i2c->dev);
-
-       if (wm1250)
-               gpio_free_array(wm1250->gpios, ARRAY_SIZE(wm1250->gpios));
 }
 
 static int wm1250_ev1_probe(struct i2c_client *i2c)
@@ -221,18 +198,12 @@ static int wm1250_ev1_probe(struct i2c_client *i2c)
                                     &wm1250_ev1_dai, 1);
        if (ret != 0) {
                dev_err(&i2c->dev, "Failed to register CODEC: %d\n", ret);
-               wm1250_ev1_free(i2c);
                return ret;
        }
 
        return 0;
 }
 
-static void wm1250_ev1_remove(struct i2c_client *i2c)
-{
-       wm1250_ev1_free(i2c);
-}
-
 static const struct i2c_device_id wm1250_ev1_i2c_id[] = {
        { "wm1250-ev1", 0 },
        { }
@@ -244,7 +215,6 @@ static struct i2c_driver wm1250_ev1_i2c_driver = {
                .name = "wm1250-ev1",
        },
        .probe =    wm1250_ev1_probe,
-       .remove =   wm1250_ev1_remove,
        .id_table = wm1250_ev1_i2c_id,
 };