mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
ASoC: Intel: bytcht_es8316: Add quirk for inverted jack detect
Add a quirk to support boards whose jack detection mechanism is inverted. It will set the 'everest,jack-detect-inverted' boolean device property for the es8316 codec driver. Signed-off-by: Paul Cercueil <paul@crapouillou.net> Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
a03584b75a
commit
ba49cf6f8e
@ -40,6 +40,9 @@
|
|||||||
#include "../atom/sst-atom-controls.h"
|
#include "../atom/sst-atom-controls.h"
|
||||||
#include "../common/sst-dsp.h"
|
#include "../common/sst-dsp.h"
|
||||||
|
|
||||||
|
/* jd-inv + terminating entry */
|
||||||
|
#define MAX_NO_PROPS 2
|
||||||
|
|
||||||
struct byt_cht_es8316_private {
|
struct byt_cht_es8316_private {
|
||||||
struct clk *mclk;
|
struct clk *mclk;
|
||||||
struct snd_soc_jack jack;
|
struct snd_soc_jack jack;
|
||||||
@ -55,6 +58,7 @@ enum {
|
|||||||
#define BYT_CHT_ES8316_MAP(quirk) ((quirk) & GENMASK(3, 0))
|
#define BYT_CHT_ES8316_MAP(quirk) ((quirk) & GENMASK(3, 0))
|
||||||
#define BYT_CHT_ES8316_SSP0 BIT(16)
|
#define BYT_CHT_ES8316_SSP0 BIT(16)
|
||||||
#define BYT_CHT_ES8316_MONO_SPEAKER BIT(17)
|
#define BYT_CHT_ES8316_MONO_SPEAKER BIT(17)
|
||||||
|
#define BYT_CHT_ES8316_JD_INVERTED BIT(18)
|
||||||
|
|
||||||
static int quirk;
|
static int quirk;
|
||||||
|
|
||||||
@ -72,6 +76,8 @@ static void log_quirks(struct device *dev)
|
|||||||
dev_info(dev, "quirk SSP0 enabled");
|
dev_info(dev, "quirk SSP0 enabled");
|
||||||
if (quirk & BYT_CHT_ES8316_MONO_SPEAKER)
|
if (quirk & BYT_CHT_ES8316_MONO_SPEAKER)
|
||||||
dev_info(dev, "quirk MONO_SPEAKER enabled\n");
|
dev_info(dev, "quirk MONO_SPEAKER enabled\n");
|
||||||
|
if (quirk & BYT_CHT_ES8316_JD_INVERTED)
|
||||||
|
dev_info(dev, "quirk JD_INVERTED enabled\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
static int byt_cht_es8316_speaker_power_event(struct snd_soc_dapm_widget *w,
|
static int byt_cht_es8316_speaker_power_event(struct snd_soc_dapm_widget *w,
|
||||||
@ -438,12 +444,14 @@ static const struct acpi_gpio_mapping byt_cht_es8316_gpios[] = {
|
|||||||
static int snd_byt_cht_es8316_mc_probe(struct platform_device *pdev)
|
static int snd_byt_cht_es8316_mc_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
static const char * const mic_name[] = { "in1", "in2" };
|
static const char * const mic_name[] = { "in1", "in2" };
|
||||||
|
struct property_entry props[MAX_NO_PROPS] = {};
|
||||||
struct byt_cht_es8316_private *priv;
|
struct byt_cht_es8316_private *priv;
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
struct snd_soc_acpi_mach *mach;
|
struct snd_soc_acpi_mach *mach;
|
||||||
const char *platform_name;
|
const char *platform_name;
|
||||||
struct acpi_device *adev;
|
struct acpi_device *adev;
|
||||||
struct device *codec_dev;
|
struct device *codec_dev;
|
||||||
|
unsigned int cnt = 0;
|
||||||
int dai_index = 0;
|
int dai_index = 0;
|
||||||
int i;
|
int i;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -513,6 +521,15 @@ static int snd_byt_cht_es8316_mc_probe(struct platform_device *pdev)
|
|||||||
if (!codec_dev)
|
if (!codec_dev)
|
||||||
return -EPROBE_DEFER;
|
return -EPROBE_DEFER;
|
||||||
|
|
||||||
|
if (quirk & BYT_CHT_ES8316_JD_INVERTED)
|
||||||
|
props[cnt++] = PROPERTY_ENTRY_BOOL("everest,jack-detect-inverted");
|
||||||
|
|
||||||
|
if (cnt) {
|
||||||
|
ret = device_add_properties(codec_dev, props);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
devm_acpi_dev_add_driver_gpios(codec_dev, byt_cht_es8316_gpios);
|
devm_acpi_dev_add_driver_gpios(codec_dev, byt_cht_es8316_gpios);
|
||||||
priv->speaker_en_gpio =
|
priv->speaker_en_gpio =
|
||||||
gpiod_get_index(codec_dev, "speaker-enable", 0,
|
gpiod_get_index(codec_dev, "speaker-enable", 0,
|
||||||
|
Loading…
Reference in New Issue
Block a user