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

ASoC: arizona-jack: Move jack-detect variables to struct arizona_priv

Move all the jack-detect variables from struct arizona_extcon_info to
struct arizona_priv.

This is part of a patch series converting the arizona extcon driver into
a helper library for letting the arizona codec-drivers directly report jack
state through the standard sound/soc/soc-jack.c functions.
Reviewed-by: default avatarAndy Shevchenko <andy.shevchenko@gmail.com>
Acked-by: default avatarCharles Keepax <ckeepax@opensource.cirrus.com>
Tested-by: default avatarCharles Keepax <ckeepax@opensource.cirrus.com>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Link: https://lore.kernel.org/r/20210307151807.35201-8-hdegoede@redhat.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent f89c0a87
...@@ -27,6 +27,8 @@ ...@@ -27,6 +27,8 @@
#include <linux/mfd/arizona/registers.h> #include <linux/mfd/arizona/registers.h>
#include <dt-bindings/mfd/arizona.h> #include <dt-bindings/mfd/arizona.h>
#include "arizona.h"
#define ARIZONA_MAX_MICD_RANGE 8 #define ARIZONA_MAX_MICD_RANGE 8
#define ARIZONA_MICD_CLAMP_MODE_JDL 0x4 #define ARIZONA_MICD_CLAMP_MODE_JDL 0x4
...@@ -61,47 +63,6 @@ ...@@ -61,47 +63,6 @@
#define MICD_LVL_0_TO_8 (MICD_LVL_0_TO_7 | ARIZONA_MICD_LVL_8) #define MICD_LVL_0_TO_8 (MICD_LVL_0_TO_7 | ARIZONA_MICD_LVL_8)
struct arizona_extcon_info {
struct device *dev;
struct arizona *arizona;
struct mutex lock;
struct regulator *micvdd;
struct input_dev *input;
u16 last_jackdet;
int micd_mode;
const struct arizona_micd_config *micd_modes;
int micd_num_modes;
const struct arizona_micd_range *micd_ranges;
int num_micd_ranges;
bool micd_reva;
bool micd_clamp;
struct delayed_work hpdet_work;
struct delayed_work micd_detect_work;
struct delayed_work micd_timeout_work;
bool hpdet_active;
bool hpdet_done;
bool hpdet_retried;
int num_hpdet_res;
unsigned int hpdet_res[3];
bool mic;
bool detecting;
int jack_flips;
int hpdet_ip_version;
struct extcon_dev *edev;
struct gpio_desc *micd_pol_gpio;
};
static const struct arizona_micd_config micd_default_modes[] = { static const struct arizona_micd_config micd_default_modes[] = {
{ ARIZONA_ACCDET_SRC, 1, 0 }, { ARIZONA_ACCDET_SRC, 1, 0 },
{ 0, 2, 1 }, { 0, 2, 1 },
...@@ -135,9 +96,9 @@ static const unsigned int arizona_cable[] = { ...@@ -135,9 +96,9 @@ static const unsigned int arizona_cable[] = {
EXTCON_NONE, EXTCON_NONE,
}; };
static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info); static void arizona_start_hpdet_acc_id(struct arizona_priv *info);
static void arizona_extcon_hp_clamp(struct arizona_extcon_info *info, static void arizona_extcon_hp_clamp(struct arizona_priv *info,
bool clamp) bool clamp)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
...@@ -222,7 +183,7 @@ static void arizona_extcon_hp_clamp(struct arizona_extcon_info *info, ...@@ -222,7 +183,7 @@ static void arizona_extcon_hp_clamp(struct arizona_extcon_info *info,
snd_soc_dapm_mutex_unlock(arizona->dapm); snd_soc_dapm_mutex_unlock(arizona->dapm);
} }
static void arizona_extcon_set_mode(struct arizona_extcon_info *info, int mode) static void arizona_extcon_set_mode(struct arizona_priv *info, int mode)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
...@@ -243,7 +204,7 @@ static void arizona_extcon_set_mode(struct arizona_extcon_info *info, int mode) ...@@ -243,7 +204,7 @@ static void arizona_extcon_set_mode(struct arizona_extcon_info *info, int mode)
dev_dbg(arizona->dev, "Set jack polarity to %d\n", mode); dev_dbg(arizona->dev, "Set jack polarity to %d\n", mode);
} }
static const char *arizona_extcon_get_micbias(struct arizona_extcon_info *info) static const char *arizona_extcon_get_micbias(struct arizona_priv *info)
{ {
switch (info->micd_modes[0].bias) { switch (info->micd_modes[0].bias) {
case 1: case 1:
...@@ -257,7 +218,7 @@ static const char *arizona_extcon_get_micbias(struct arizona_extcon_info *info) ...@@ -257,7 +218,7 @@ static const char *arizona_extcon_get_micbias(struct arizona_extcon_info *info)
} }
} }
static void arizona_extcon_pulse_micbias(struct arizona_extcon_info *info) static void arizona_extcon_pulse_micbias(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
const char *widget = arizona_extcon_get_micbias(info); const char *widget = arizona_extcon_get_micbias(info);
...@@ -282,7 +243,7 @@ static void arizona_extcon_pulse_micbias(struct arizona_extcon_info *info) ...@@ -282,7 +243,7 @@ static void arizona_extcon_pulse_micbias(struct arizona_extcon_info *info)
} }
} }
static void arizona_start_mic(struct arizona_extcon_info *info) static void arizona_start_mic(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
bool change; bool change;
...@@ -339,7 +300,7 @@ static void arizona_start_mic(struct arizona_extcon_info *info) ...@@ -339,7 +300,7 @@ static void arizona_start_mic(struct arizona_extcon_info *info)
} }
} }
static void arizona_stop_mic(struct arizona_extcon_info *info) static void arizona_stop_mic(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
const char *widget = arizona_extcon_get_micbias(info); const char *widget = arizona_extcon_get_micbias(info);
...@@ -407,7 +368,7 @@ static struct { ...@@ -407,7 +368,7 @@ static struct {
{ 1000, 10000 }, { 1000, 10000 },
}; };
static int arizona_hpdet_read(struct arizona_extcon_info *info) static int arizona_hpdet_read(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
unsigned int val, range; unsigned int val, range;
...@@ -527,7 +488,7 @@ static int arizona_hpdet_read(struct arizona_extcon_info *info) ...@@ -527,7 +488,7 @@ static int arizona_hpdet_read(struct arizona_extcon_info *info)
return val; return val;
} }
static int arizona_hpdet_do_id(struct arizona_extcon_info *info, int *reading, static int arizona_hpdet_do_id(struct arizona_priv *info, int *reading,
bool *mic) bool *mic)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
...@@ -597,7 +558,7 @@ static int arizona_hpdet_do_id(struct arizona_extcon_info *info, int *reading, ...@@ -597,7 +558,7 @@ static int arizona_hpdet_do_id(struct arizona_extcon_info *info, int *reading,
static irqreturn_t arizona_hpdet_irq(int irq, void *data) static irqreturn_t arizona_hpdet_irq(int irq, void *data)
{ {
struct arizona_extcon_info *info = data; struct arizona_priv *info = data;
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int id_gpio = arizona->pdata.hpdet_id_gpio; int id_gpio = arizona->pdata.hpdet_id_gpio;
unsigned int report = EXTCON_JACK_HEADPHONE; unsigned int report = EXTCON_JACK_HEADPHONE;
...@@ -684,7 +645,7 @@ static irqreturn_t arizona_hpdet_irq(int irq, void *data) ...@@ -684,7 +645,7 @@ static irqreturn_t arizona_hpdet_irq(int irq, void *data)
return IRQ_HANDLED; return IRQ_HANDLED;
} }
static void arizona_identify_headphone(struct arizona_extcon_info *info) static void arizona_identify_headphone(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int ret; int ret;
...@@ -737,7 +698,7 @@ static void arizona_identify_headphone(struct arizona_extcon_info *info) ...@@ -737,7 +698,7 @@ static void arizona_identify_headphone(struct arizona_extcon_info *info)
info->hpdet_active = false; info->hpdet_active = false;
} }
static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info) static void arizona_start_hpdet_acc_id(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int hp_reading = 32; int hp_reading = 32;
...@@ -790,8 +751,8 @@ static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info) ...@@ -790,8 +751,8 @@ static void arizona_start_hpdet_acc_id(struct arizona_extcon_info *info)
static void arizona_micd_timeout_work(struct work_struct *work) static void arizona_micd_timeout_work(struct work_struct *work)
{ {
struct arizona_extcon_info *info = container_of(work, struct arizona_priv *info = container_of(work,
struct arizona_extcon_info, struct arizona_priv,
micd_timeout_work.work); micd_timeout_work.work);
mutex_lock(&info->lock); mutex_lock(&info->lock);
...@@ -805,7 +766,7 @@ static void arizona_micd_timeout_work(struct work_struct *work) ...@@ -805,7 +766,7 @@ static void arizona_micd_timeout_work(struct work_struct *work)
mutex_unlock(&info->lock); mutex_unlock(&info->lock);
} }
static int arizona_micd_adc_read(struct arizona_extcon_info *info) static int arizona_micd_adc_read(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
unsigned int val; unsigned int val;
...@@ -842,7 +803,7 @@ static int arizona_micd_adc_read(struct arizona_extcon_info *info) ...@@ -842,7 +803,7 @@ static int arizona_micd_adc_read(struct arizona_extcon_info *info)
return val; return val;
} }
static int arizona_micd_read(struct arizona_extcon_info *info) static int arizona_micd_read(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
unsigned int val = 0; unsigned int val = 0;
...@@ -875,7 +836,7 @@ static int arizona_micd_read(struct arizona_extcon_info *info) ...@@ -875,7 +836,7 @@ static int arizona_micd_read(struct arizona_extcon_info *info)
static int arizona_micdet_reading(void *priv) static int arizona_micdet_reading(void *priv)
{ {
struct arizona_extcon_info *info = priv; struct arizona_priv *info = priv;
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int ret, val; int ret, val;
...@@ -969,7 +930,7 @@ static int arizona_micdet_reading(void *priv) ...@@ -969,7 +930,7 @@ static int arizona_micdet_reading(void *priv)
static int arizona_button_reading(void *priv) static int arizona_button_reading(void *priv)
{ {
struct arizona_extcon_info *info = priv; struct arizona_priv *info = priv;
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int val, key, lvl, i; int val, key, lvl, i;
...@@ -1017,8 +978,8 @@ static int arizona_button_reading(void *priv) ...@@ -1017,8 +978,8 @@ static int arizona_button_reading(void *priv)
static void arizona_micd_detect(struct work_struct *work) static void arizona_micd_detect(struct work_struct *work)
{ {
struct arizona_extcon_info *info = container_of(work, struct arizona_priv *info = container_of(work,
struct arizona_extcon_info, struct arizona_priv,
micd_detect_work.work); micd_detect_work.work);
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int ret; int ret;
...@@ -1051,7 +1012,7 @@ static void arizona_micd_detect(struct work_struct *work) ...@@ -1051,7 +1012,7 @@ static void arizona_micd_detect(struct work_struct *work)
static irqreturn_t arizona_micdet(int irq, void *data) static irqreturn_t arizona_micdet(int irq, void *data)
{ {
struct arizona_extcon_info *info = data; struct arizona_priv *info = data;
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int debounce = arizona->pdata.micd_detect_debounce; int debounce = arizona->pdata.micd_detect_debounce;
...@@ -1075,8 +1036,8 @@ static irqreturn_t arizona_micdet(int irq, void *data) ...@@ -1075,8 +1036,8 @@ static irqreturn_t arizona_micdet(int irq, void *data)
static void arizona_hpdet_work(struct work_struct *work) static void arizona_hpdet_work(struct work_struct *work)
{ {
struct arizona_extcon_info *info = container_of(work, struct arizona_priv *info = container_of(work,
struct arizona_extcon_info, struct arizona_priv,
hpdet_work.work); hpdet_work.work);
mutex_lock(&info->lock); mutex_lock(&info->lock);
...@@ -1084,7 +1045,7 @@ static void arizona_hpdet_work(struct work_struct *work) ...@@ -1084,7 +1045,7 @@ static void arizona_hpdet_work(struct work_struct *work)
mutex_unlock(&info->lock); mutex_unlock(&info->lock);
} }
static int arizona_hpdet_wait(struct arizona_extcon_info *info) static int arizona_hpdet_wait(struct arizona_priv *info)
{ {
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
unsigned int val; unsigned int val;
...@@ -1120,7 +1081,7 @@ static int arizona_hpdet_wait(struct arizona_extcon_info *info) ...@@ -1120,7 +1081,7 @@ static int arizona_hpdet_wait(struct arizona_extcon_info *info)
static irqreturn_t arizona_jackdet(int irq, void *data) static irqreturn_t arizona_jackdet(int irq, void *data)
{ {
struct arizona_extcon_info *info = data; struct arizona_priv *info = data;
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
unsigned int val, present, mask; unsigned int val, present, mask;
bool cancelled_hp, cancelled_mic; bool cancelled_hp, cancelled_mic;
...@@ -1380,7 +1341,7 @@ static int arizona_extcon_probe(struct platform_device *pdev) ...@@ -1380,7 +1341,7 @@ static int arizona_extcon_probe(struct platform_device *pdev)
{ {
struct arizona *arizona = dev_get_drvdata(pdev->dev.parent); struct arizona *arizona = dev_get_drvdata(pdev->dev.parent);
struct arizona_pdata *pdata = &arizona->pdata; struct arizona_pdata *pdata = &arizona->pdata;
struct arizona_extcon_info *info; struct arizona_priv *info;
unsigned int val; unsigned int val;
unsigned int clamp_mode; unsigned int clamp_mode;
int jack_irq_fall, jack_irq_rise; int jack_irq_fall, jack_irq_rise;
...@@ -1754,7 +1715,7 @@ static int arizona_extcon_probe(struct platform_device *pdev) ...@@ -1754,7 +1715,7 @@ static int arizona_extcon_probe(struct platform_device *pdev)
static int arizona_extcon_remove(struct platform_device *pdev) static int arizona_extcon_remove(struct platform_device *pdev)
{ {
struct arizona_extcon_info *info = platform_get_drvdata(pdev); struct arizona_priv *info = platform_get_drvdata(pdev);
struct arizona *arizona = info->arizona; struct arizona *arizona = info->arizona;
int jack_irq_rise, jack_irq_fall; int jack_irq_rise, jack_irq_fall;
bool change; bool change;
......
...@@ -91,6 +91,42 @@ struct arizona_priv { ...@@ -91,6 +91,42 @@ struct arizona_priv {
unsigned int dvfs_reqs; unsigned int dvfs_reqs;
struct mutex dvfs_lock; struct mutex dvfs_lock;
bool dvfs_cached; bool dvfs_cached;
/* Variables used by arizona-jack.c code */
struct device *dev;
struct mutex lock;
struct delayed_work hpdet_work;
struct delayed_work micd_detect_work;
struct delayed_work micd_timeout_work;
struct regulator *micvdd;
struct input_dev *input;
struct extcon_dev *edev;
struct gpio_desc *micd_pol_gpio;
u16 last_jackdet;
int micd_mode;
const struct arizona_micd_config *micd_modes;
int micd_num_modes;
const struct arizona_micd_range *micd_ranges;
int num_micd_ranges;
bool micd_reva;
bool micd_clamp;
bool hpdet_active;
bool hpdet_done;
bool hpdet_retried;
bool mic;
bool detecting;
int num_hpdet_res;
unsigned int hpdet_res[3];
int jack_flips;
int hpdet_ip_version;
}; };
struct arizona_voice_trigger_info { struct arizona_voice_trigger_info {
......
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