Commit c14f61a8 authored by Hans de Goede's avatar Hans de Goede Committed by Mark Brown

ASoC: rt5670: Remove struct rt5670_platform_data

platform_data is an obsolete concept, instead device_properties,
set through e.g. device-tree, should be used.

struct rt5670_platform_data is only used internally by the rt5670 codec
driver, so lets remove it before someone starts relying on it.
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Reviewed-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/20200703100823.258033-2-hdegoede@redhat.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent c950e9fc
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* linux/sound/rt5670.h -- Platform data for RT5670
*
* Copyright 2014 Realtek Microelectronics
*/
#ifndef __LINUX_SND_RT5670_H
#define __LINUX_SND_RT5670_H
struct rt5670_platform_data {
int jd_mode;
bool in2_diff;
bool dev_gpio;
bool gpio1_is_ext_spk_en;
bool dmic_en;
unsigned int dmic1_data_pin;
/* 0 = GPIO6; 1 = IN2P; 3 = GPIO7*/
unsigned int dmic2_data_pin;
/* 0 = GPIO8; 1 = IN3N; */
unsigned int dmic3_data_pin;
/* 0 = GPIO9; 1 = GPIO10; 2 = GPIO5*/
};
#endif
...@@ -25,7 +25,6 @@ ...@@ -25,7 +25,6 @@
#include <sound/soc-dapm.h> #include <sound/soc-dapm.h>
#include <sound/initval.h> #include <sound/initval.h>
#include <sound/tlv.h> #include <sound/tlv.h>
#include <sound/rt5670.h>
#include "rl6231.h" #include "rl6231.h"
#include "rt5670.h" #include "rt5670.h"
...@@ -518,7 +517,7 @@ static int rt5670_irq_detection(void *data) ...@@ -518,7 +517,7 @@ static int rt5670_irq_detection(void *data)
struct snd_soc_jack *jack = rt5670->jack; struct snd_soc_jack *jack = rt5670->jack;
int val, btn_type, report = jack->status; int val, btn_type, report = jack->status;
if (rt5670->pdata.jd_mode == 1) /* 2 port */ if (rt5670->jd_mode == 1) /* 2 port */
val = snd_soc_component_read(rt5670->component, RT5670_A_JD_CTRL1) & 0x0070; val = snd_soc_component_read(rt5670->component, RT5670_A_JD_CTRL1) & 0x0070;
else else
val = snd_soc_component_read(rt5670->component, RT5670_A_JD_CTRL1) & 0x0020; val = snd_soc_component_read(rt5670->component, RT5670_A_JD_CTRL1) & 0x0020;
...@@ -1454,7 +1453,7 @@ static int rt5670_spk_event(struct snd_soc_dapm_widget *w, ...@@ -1454,7 +1453,7 @@ static int rt5670_spk_event(struct snd_soc_dapm_widget *w,
struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
struct rt5670_priv *rt5670 = snd_soc_component_get_drvdata(component); struct rt5670_priv *rt5670 = snd_soc_component_get_drvdata(component);
if (!rt5670->pdata.gpio1_is_ext_spk_en) if (!rt5670->gpio1_is_ext_spk_en)
return 0; return 0;
switch (event) { switch (event) {
...@@ -2624,7 +2623,7 @@ static int rt5670_set_bias_level(struct snd_soc_component *component, ...@@ -2624,7 +2623,7 @@ static int rt5670_set_bias_level(struct snd_soc_component *component,
RT5670_LDO_SEL_MASK, 0x3); RT5670_LDO_SEL_MASK, 0x3);
break; break;
case SND_SOC_BIAS_OFF: case SND_SOC_BIAS_OFF:
if (rt5670->pdata.jd_mode) if (rt5670->jd_mode)
snd_soc_component_update_bits(component, RT5670_PWR_ANLG1, snd_soc_component_update_bits(component, RT5670_PWR_ANLG1,
RT5670_PWR_VREF1 | RT5670_PWR_MB | RT5670_PWR_VREF1 | RT5670_PWR_MB |
RT5670_PWR_BG | RT5670_PWR_VREF2 | RT5670_PWR_BG | RT5670_PWR_VREF2 |
...@@ -2927,7 +2926,6 @@ static const struct dmi_system_id dmi_platform_intel_quirks[] = { ...@@ -2927,7 +2926,6 @@ static const struct dmi_system_id dmi_platform_intel_quirks[] = {
static int rt5670_i2c_probe(struct i2c_client *i2c, static int rt5670_i2c_probe(struct i2c_client *i2c,
const struct i2c_device_id *id) const struct i2c_device_id *id)
{ {
struct rt5670_platform_data *pdata = dev_get_platdata(&i2c->dev);
struct rt5670_priv *rt5670; struct rt5670_priv *rt5670;
int ret; int ret;
unsigned int val; unsigned int val;
...@@ -2940,9 +2938,6 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -2940,9 +2938,6 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
i2c_set_clientdata(i2c, rt5670); i2c_set_clientdata(i2c, rt5670);
if (pdata)
rt5670->pdata = *pdata;
dmi_check_system(dmi_platform_intel_quirks); dmi_check_system(dmi_platform_intel_quirks);
if (quirk_override) { if (quirk_override) {
dev_info(&i2c->dev, "Overriding quirk 0x%x => 0x%x\n", dev_info(&i2c->dev, "Overriding quirk 0x%x => 0x%x\n",
...@@ -2951,56 +2946,56 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -2951,56 +2946,56 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
} }
if (rt5670_quirk & RT5670_DEV_GPIO) { if (rt5670_quirk & RT5670_DEV_GPIO) {
rt5670->pdata.dev_gpio = true; rt5670->dev_gpio = true;
dev_info(&i2c->dev, "quirk dev_gpio\n"); dev_info(&i2c->dev, "quirk dev_gpio\n");
} }
if (rt5670_quirk & RT5670_GPIO1_IS_EXT_SPK_EN) { if (rt5670_quirk & RT5670_GPIO1_IS_EXT_SPK_EN) {
rt5670->pdata.gpio1_is_ext_spk_en = true; rt5670->gpio1_is_ext_spk_en = true;
dev_info(&i2c->dev, "quirk GPIO1 is external speaker enable\n"); dev_info(&i2c->dev, "quirk GPIO1 is external speaker enable\n");
} }
if (rt5670_quirk & RT5670_IN2_DIFF) { if (rt5670_quirk & RT5670_IN2_DIFF) {
rt5670->pdata.in2_diff = true; rt5670->in2_diff = true;
dev_info(&i2c->dev, "quirk IN2_DIFF\n"); dev_info(&i2c->dev, "quirk IN2_DIFF\n");
} }
if (rt5670_quirk & RT5670_DMIC_EN) { if (rt5670_quirk & RT5670_DMIC_EN) {
rt5670->pdata.dmic_en = true; rt5670->dmic_en = true;
dev_info(&i2c->dev, "quirk DMIC enabled\n"); dev_info(&i2c->dev, "quirk DMIC enabled\n");
} }
if (rt5670_quirk & RT5670_DMIC1_IN2P) { if (rt5670_quirk & RT5670_DMIC1_IN2P) {
rt5670->pdata.dmic1_data_pin = RT5670_DMIC_DATA_IN2P; rt5670->dmic1_data_pin = RT5670_DMIC_DATA_IN2P;
dev_info(&i2c->dev, "quirk DMIC1 on IN2P pin\n"); dev_info(&i2c->dev, "quirk DMIC1 on IN2P pin\n");
} }
if (rt5670_quirk & RT5670_DMIC1_GPIO6) { if (rt5670_quirk & RT5670_DMIC1_GPIO6) {
rt5670->pdata.dmic1_data_pin = RT5670_DMIC_DATA_GPIO6; rt5670->dmic1_data_pin = RT5670_DMIC_DATA_GPIO6;
dev_info(&i2c->dev, "quirk DMIC1 on GPIO6 pin\n"); dev_info(&i2c->dev, "quirk DMIC1 on GPIO6 pin\n");
} }
if (rt5670_quirk & RT5670_DMIC1_GPIO7) { if (rt5670_quirk & RT5670_DMIC1_GPIO7) {
rt5670->pdata.dmic1_data_pin = RT5670_DMIC_DATA_GPIO7; rt5670->dmic1_data_pin = RT5670_DMIC_DATA_GPIO7;
dev_info(&i2c->dev, "quirk DMIC1 on GPIO7 pin\n"); dev_info(&i2c->dev, "quirk DMIC1 on GPIO7 pin\n");
} }
if (rt5670_quirk & RT5670_DMIC2_INR) { if (rt5670_quirk & RT5670_DMIC2_INR) {
rt5670->pdata.dmic2_data_pin = RT5670_DMIC_DATA_IN3N; rt5670->dmic2_data_pin = RT5670_DMIC_DATA_IN3N;
dev_info(&i2c->dev, "quirk DMIC2 on INR pin\n"); dev_info(&i2c->dev, "quirk DMIC2 on INR pin\n");
} }
if (rt5670_quirk & RT5670_DMIC2_GPIO8) { if (rt5670_quirk & RT5670_DMIC2_GPIO8) {
rt5670->pdata.dmic2_data_pin = RT5670_DMIC_DATA_GPIO8; rt5670->dmic2_data_pin = RT5670_DMIC_DATA_GPIO8;
dev_info(&i2c->dev, "quirk DMIC2 on GPIO8 pin\n"); dev_info(&i2c->dev, "quirk DMIC2 on GPIO8 pin\n");
} }
if (rt5670_quirk & RT5670_DMIC3_GPIO5) { if (rt5670_quirk & RT5670_DMIC3_GPIO5) {
rt5670->pdata.dmic3_data_pin = RT5670_DMIC_DATA_GPIO5; rt5670->dmic3_data_pin = RT5670_DMIC_DATA_GPIO5;
dev_info(&i2c->dev, "quirk DMIC3 on GPIO5 pin\n"); dev_info(&i2c->dev, "quirk DMIC3 on GPIO5 pin\n");
} }
if (rt5670_quirk & RT5670_JD_MODE1) { if (rt5670_quirk & RT5670_JD_MODE1) {
rt5670->pdata.jd_mode = 1; rt5670->jd_mode = 1;
dev_info(&i2c->dev, "quirk JD mode 1\n"); dev_info(&i2c->dev, "quirk JD mode 1\n");
} }
if (rt5670_quirk & RT5670_JD_MODE2) { if (rt5670_quirk & RT5670_JD_MODE2) {
rt5670->pdata.jd_mode = 2; rt5670->jd_mode = 2;
dev_info(&i2c->dev, "quirk JD mode 2\n"); dev_info(&i2c->dev, "quirk JD mode 2\n");
} }
if (rt5670_quirk & RT5670_JD_MODE3) { if (rt5670_quirk & RT5670_JD_MODE3) {
rt5670->pdata.jd_mode = 3; rt5670->jd_mode = 3;
dev_info(&i2c->dev, "quirk JD mode 3\n"); dev_info(&i2c->dev, "quirk JD mode 3\n");
} }
...@@ -3041,11 +3036,11 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -3041,11 +3036,11 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
regmap_update_bits(rt5670->regmap, RT5670_DIG_MISC, regmap_update_bits(rt5670->regmap, RT5670_DIG_MISC,
RT5670_MCLK_DET, RT5670_MCLK_DET); RT5670_MCLK_DET, RT5670_MCLK_DET);
if (rt5670->pdata.in2_diff) if (rt5670->in2_diff)
regmap_update_bits(rt5670->regmap, RT5670_IN2, regmap_update_bits(rt5670->regmap, RT5670_IN2,
RT5670_IN_DF2, RT5670_IN_DF2); RT5670_IN_DF2, RT5670_IN_DF2);
if (rt5670->pdata.dev_gpio) { if (rt5670->dev_gpio) {
/* for push button */ /* for push button */
regmap_write(rt5670->regmap, RT5670_IL_CMD, 0x0000); regmap_write(rt5670->regmap, RT5670_IL_CMD, 0x0000);
regmap_write(rt5670->regmap, RT5670_IL_CMD2, 0x0010); regmap_write(rt5670->regmap, RT5670_IL_CMD2, 0x0010);
...@@ -3057,14 +3052,14 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -3057,14 +3052,14 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
RT5670_GP1_PF_MASK, RT5670_GP1_PF_OUT); RT5670_GP1_PF_MASK, RT5670_GP1_PF_OUT);
} }
if (rt5670->pdata.gpio1_is_ext_spk_en) { if (rt5670->gpio1_is_ext_spk_en) {
regmap_update_bits(rt5670->regmap, RT5670_GPIO_CTRL1, regmap_update_bits(rt5670->regmap, RT5670_GPIO_CTRL1,
RT5670_GP1_PIN_MASK, RT5670_GP1_PIN_GPIO1); RT5670_GP1_PIN_MASK, RT5670_GP1_PIN_GPIO1);
regmap_update_bits(rt5670->regmap, RT5670_GPIO_CTRL2, regmap_update_bits(rt5670->regmap, RT5670_GPIO_CTRL2,
RT5670_GP1_PF_MASK, RT5670_GP1_PF_OUT); RT5670_GP1_PF_MASK, RT5670_GP1_PF_OUT);
} }
if (rt5670->pdata.jd_mode) { if (rt5670->jd_mode) {
regmap_update_bits(rt5670->regmap, RT5670_GLB_CLK, regmap_update_bits(rt5670->regmap, RT5670_GLB_CLK,
RT5670_SCLK_SRC_MASK, RT5670_SCLK_SRC_RCCLK); RT5670_SCLK_SRC_MASK, RT5670_SCLK_SRC_RCCLK);
rt5670->sysclk = 0; rt5670->sysclk = 0;
...@@ -3079,7 +3074,7 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -3079,7 +3074,7 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
RT5670_JD_TRI_CBJ_SEL_MASK | RT5670_JD_TRI_CBJ_SEL_MASK |
RT5670_JD_TRI_HPO_SEL_MASK, RT5670_JD_TRI_HPO_SEL_MASK,
RT5670_JD_CBJ_JD1_1 | RT5670_JD_HPO_JD1_1); RT5670_JD_CBJ_JD1_1 | RT5670_JD_HPO_JD1_1);
switch (rt5670->pdata.jd_mode) { switch (rt5670->jd_mode) {
case 1: case 1:
regmap_update_bits(rt5670->regmap, RT5670_A_JD_CTRL1, regmap_update_bits(rt5670->regmap, RT5670_A_JD_CTRL1,
RT5670_JD1_MODE_MASK, RT5670_JD1_MODE_MASK,
...@@ -3100,12 +3095,12 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -3100,12 +3095,12 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
} }
} }
if (rt5670->pdata.dmic_en) { if (rt5670->dmic_en) {
regmap_update_bits(rt5670->regmap, RT5670_GPIO_CTRL1, regmap_update_bits(rt5670->regmap, RT5670_GPIO_CTRL1,
RT5670_GP2_PIN_MASK, RT5670_GP2_PIN_MASK,
RT5670_GP2_PIN_DMIC1_SCL); RT5670_GP2_PIN_DMIC1_SCL);
switch (rt5670->pdata.dmic1_data_pin) { switch (rt5670->dmic1_data_pin) {
case RT5670_DMIC_DATA_IN2P: case RT5670_DMIC_DATA_IN2P:
regmap_update_bits(rt5670->regmap, RT5670_DMIC_CTRL1, regmap_update_bits(rt5670->regmap, RT5670_DMIC_CTRL1,
RT5670_DMIC_1_DP_MASK, RT5670_DMIC_1_DP_MASK,
...@@ -3134,7 +3129,7 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -3134,7 +3129,7 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
break; break;
} }
switch (rt5670->pdata.dmic2_data_pin) { switch (rt5670->dmic2_data_pin) {
case RT5670_DMIC_DATA_IN3N: case RT5670_DMIC_DATA_IN3N:
regmap_update_bits(rt5670->regmap, RT5670_DMIC_CTRL1, regmap_update_bits(rt5670->regmap, RT5670_DMIC_CTRL1,
RT5670_DMIC_2_DP_MASK, RT5670_DMIC_2_DP_MASK,
...@@ -3154,7 +3149,7 @@ static int rt5670_i2c_probe(struct i2c_client *i2c, ...@@ -3154,7 +3149,7 @@ static int rt5670_i2c_probe(struct i2c_client *i2c,
break; break;
} }
switch (rt5670->pdata.dmic3_data_pin) { switch (rt5670->dmic3_data_pin) {
case RT5670_DMIC_DATA_GPIO5: case RT5670_DMIC_DATA_GPIO5:
regmap_update_bits(rt5670->regmap, RT5670_DMIC_CTRL2, regmap_update_bits(rt5670->regmap, RT5670_DMIC_CTRL2,
RT5670_DMIC_3_DP_MASK, RT5670_DMIC_3_DP_MASK,
......
...@@ -9,8 +9,6 @@ ...@@ -9,8 +9,6 @@
#ifndef __RT5670_H__ #ifndef __RT5670_H__
#define __RT5670_H__ #define __RT5670_H__
#include <sound/rt5670.h>
/* Info */ /* Info */
#define RT5670_RESET 0x00 #define RT5670_RESET 0x00
#define RT5670_VENDOR_ID 0xfd #define RT5670_VENDOR_ID 0xfd
...@@ -1988,11 +1986,23 @@ int rt5670_sel_asrc_clk_src(struct snd_soc_component *component, ...@@ -1988,11 +1986,23 @@ int rt5670_sel_asrc_clk_src(struct snd_soc_component *component,
struct rt5670_priv { struct rt5670_priv {
struct snd_soc_component *component; struct snd_soc_component *component;
struct rt5670_platform_data pdata;
struct regmap *regmap; struct regmap *regmap;
struct snd_soc_jack *jack; struct snd_soc_jack *jack;
struct snd_soc_jack_gpio hp_gpio; struct snd_soc_jack_gpio hp_gpio;
int jd_mode;
bool in2_diff;
bool dev_gpio;
bool gpio1_is_ext_spk_en;
bool dmic_en;
unsigned int dmic1_data_pin;
/* 0 = GPIO6; 1 = IN2P; 3 = GPIO7*/
unsigned int dmic2_data_pin;
/* 0 = GPIO8; 1 = IN3N; */
unsigned int dmic3_data_pin;
/* 0 = GPIO9; 1 = GPIO10; 2 = GPIO5*/
int sysclk; int sysclk;
int sysclk_src; int sysclk_src;
int lrck[RT5670_AIFS]; int lrck[RT5670_AIFS];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment