[alsa-devel] [PATCH 4/4] ASoC: rt5645: Add jack detection workaround for GPD Win

Pierre-Louis Bossart pierre-louis.bossart at linux.intel.com
Wed Jun 28 23:07:01 CEST 2017


On 6/28/17 7:49 AM, Takashi Iwai wrote:
> GPD Win requires jd_mode=3 and the inverted flag for making the jack
> detection working.  Unfortunately, the BIOS doesn't give a nice way to
> match with DMI strings, and the only working way so far is to match
> with the board vendor/name/version/date to some known patterns.
>
> Hopefully other vendors won't do such a stupid setup, too...
>
> Thanks to Hans de Goede for the DMI matching suggestion.
>
> Suggested-by: Hans de Goede <hdegoede at redhat.com>
> Tested-by: Hans de Goede <hdegoede at redhat.com>
> Signed-off-by: Takashi Iwai <tiwai at suse.de>
> ---
>  sound/soc/codecs/rt5645.c | 29 +++++++++++++++++++++++++++++
>  1 file changed, 29 insertions(+)
>
> diff --git a/sound/soc/codecs/rt5645.c b/sound/soc/codecs/rt5645.c
> index 162044d82632..308c22f5909a 100644
> --- a/sound/soc/codecs/rt5645.c
> +++ b/sound/soc/codecs/rt5645.c
> @@ -3599,6 +3599,33 @@ static struct dmi_system_id dmi_platform_intel_broadwell[] = {
>  	{ }
>  };
>
> +static struct rt5645_platform_data gpd_win_platform_data = {
> +	.jd_mode = 3,
> +	.inv_jd1_1 = true,
> +};
> +
> +static const struct dmi_system_id dmi_platform_gpd_win[] = {
> +	{
> +		/*
> +		 * Match for the GPDwin which unfortunately uses somewhat
> +		 * generic dmi strings, which is why we test for 4 strings.
> +		 * Comparing against 23 other byt/cht boards, board_vendor
> +		 * and board_name are unique to the GPDwin, where as only one
> +		 * other board has the same board_serial and 3 others have
> +		 * the same default product_name. Also the GPDwin is the
> +		 * only device to have both board_ and product_name not set.
> +		 */
> +		.ident = "GPD Win",
> +		.matches = {
> +			DMI_MATCH(DMI_BOARD_VENDOR, "AMI Corporation"),
> +			DMI_MATCH(DMI_BOARD_NAME, "Default string"),
> +			DMI_MATCH(DMI_BOARD_SERIAL, "Default string"),
> +			DMI_MATCH(DMI_PRODUCT_NAME, "Default string"),
> +		},
> +	},
> +	{}

it feels like it's time to add a quirk parameter for this codec module 
to avoid chasing all possible DMI/BIOS issues?

> +};
> +
>  static bool rt5645_check_dp(struct device *dev)
>  {
>  	if (device_property_present(dev, "realtek,in2-differential") ||
> @@ -3649,6 +3676,8 @@ static int rt5645_i2c_probe(struct i2c_client *i2c,
>  		rt5645_parse_dt(rt5645, &i2c->dev);
>  	else if (dmi_check_system(dmi_platform_intel_braswell))
>  		rt5645->pdata = general_platform_data;
> +	else if (dmi_check_system(dmi_platform_gpd_win))
> +		rt5645->pdata = gpd_win_platform_data;
>
>  	rt5645->gpiod_hp_det = devm_gpiod_get_optional(&i2c->dev, "hp-detect",
>  						       GPIOD_IN);
>



More information about the Alsa-devel mailing list