diff mbox

[2/2] ASoC: rt298: Add DMI match for Broxton-P reference platform

Message ID 1463026130-18651-2-git-send-email-vinod.koul@intel.com (mailing list archive)
State Accepted
Commit b9c17f13ba484d8492278c67cd95b7207def776f
Headers show

Commit Message

Vinod Koul May 12, 2016, 4:08 a.m. UTC
Broxton-P reference platform also uses combo jack for audio
connector so we need to set codec pdata to use this based on DMI
match for this board.

Signed-off-by: Ramesh Babu <ramesh.babu@intel.com>
Signed-off-by: Senthilnathan Veppur <senthilnathanx.veppur@intel.com>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
---
 sound/soc/codecs/rt298.c | 17 +++++++++++++++++
 1 file changed, 17 insertions(+)

Comments

Bard Liao May 12, 2016, 5:59 a.m. UTC | #1
> -----Original Message-----
> From: Vinod Koul [mailto:vinod.koul@intel.com]
> Sent: Thursday, May 12, 2016 12:09 PM
> To: alsa-devel@alsa-project.org
> Cc: broonie@kernel.org; liam.r.girdwood@linux.intel.com;
> patches.audio@intel.com; Bard Liao; Vinod Koul; Ramesh Babu;
> Senthilnathan Veppur
> Subject: [PATCH 2/2] ASoC: rt298: Add DMI match for Broxton-P
> reference platform
> 
> Broxton-P reference platform also uses combo jack for audio connector
> so we need to set codec pdata to use this based on DMI match for this
> board.
> 
> Signed-off-by: Ramesh Babu <ramesh.babu@intel.com>
> Signed-off-by: Senthilnathan Veppur <senthilnathanx.veppur@intel.com>
> Signed-off-by: Vinod Koul <vinod.koul@intel.com>

Acked-by: Bard Liao <bardliao@realtek.com>

> ---
>  sound/soc/codecs/rt298.c | 17 +++++++++++++++++
>  1 file changed, 17 insertions(+)
> 
> diff --git a/sound/soc/codecs/rt298.c b/sound/soc/codecs/rt298.c index
> 45dc5fa24961..f80cfe4d2ef2 100644
> --- a/sound/soc/codecs/rt298.c
> +++ b/sound/soc/codecs/rt298.c
> @@ -17,6 +17,7 @@
>  #include <linux/i2c.h>
>  #include <linux/platform_device.h>
>  #include <linux/spi/spi.h>
> +#include <linux/dmi.h>
>  #include <linux/acpi.h>
>  #include <sound/core.h>
>  #include <sound/pcm.h>
> @@ -1127,6 +1128,17 @@ static const struct acpi_device_id
> rt298_acpi_match[] = {  };  MODULE_DEVICE_TABLE(acpi,
> rt298_acpi_match);
> 
> +static const struct dmi_system_id force_combo_jack_table[] = {
> +	{
> +		.ident = "Intel Broxton P",
> +		.matches = {
> +			DMI_MATCH(DMI_SYS_VENDOR, "Intel Corp"),
> +			DMI_MATCH(DMI_PRODUCT_NAME, "Broxton P")
> +		}
> +	},
> +	{ }
> +};
> +
>  static int rt298_i2c_probe(struct i2c_client *i2c,
>  			   const struct i2c_device_id *id)
>  {
> @@ -1184,6 +1196,11 @@ static int rt298_i2c_probe(struct i2c_client
> *i2c,
>  				acpiid->driver_data;
>  	}
> 
> +	if (dmi_check_system(force_combo_jack_table)) {
> +		rt298->pdata.cbj_en = true;
> +		rt298->pdata.gpio2_en = false;
> +	}
> +
>  	/* VREF Charging */
>  	regmap_update_bits(rt298->regmap, 0x04, 0x80, 0x80);
>  	regmap_update_bits(rt298->regmap, 0x1b, 0x860, 0x860);
> --
> 1.9.1
diff mbox

Patch

diff --git a/sound/soc/codecs/rt298.c b/sound/soc/codecs/rt298.c
index 45dc5fa24961..f80cfe4d2ef2 100644
--- a/sound/soc/codecs/rt298.c
+++ b/sound/soc/codecs/rt298.c
@@ -17,6 +17,7 @@ 
 #include <linux/i2c.h>
 #include <linux/platform_device.h>
 #include <linux/spi/spi.h>
+#include <linux/dmi.h>
 #include <linux/acpi.h>
 #include <sound/core.h>
 #include <sound/pcm.h>
@@ -1127,6 +1128,17 @@  static const struct acpi_device_id rt298_acpi_match[] = {
 };
 MODULE_DEVICE_TABLE(acpi, rt298_acpi_match);
 
+static const struct dmi_system_id force_combo_jack_table[] = {
+	{
+		.ident = "Intel Broxton P",
+		.matches = {
+			DMI_MATCH(DMI_SYS_VENDOR, "Intel Corp"),
+			DMI_MATCH(DMI_PRODUCT_NAME, "Broxton P")
+		}
+	},
+	{ }
+};
+
 static int rt298_i2c_probe(struct i2c_client *i2c,
 			   const struct i2c_device_id *id)
 {
@@ -1184,6 +1196,11 @@  static int rt298_i2c_probe(struct i2c_client *i2c,
 				acpiid->driver_data;
 	}
 
+	if (dmi_check_system(force_combo_jack_table)) {
+		rt298->pdata.cbj_en = true;
+		rt298->pdata.gpio2_en = false;
+	}
+
 	/* VREF Charging */
 	regmap_update_bits(rt298->regmap, 0x04, 0x80, 0x80);
 	regmap_update_bits(rt298->regmap, 0x1b, 0x860, 0x860);