Commit 53c9fac8 authored by Mark Brown's avatar Mark Brown

ASoC: Intel: haswell and broadwell boards update

Merge series from Cezary Rojewski <cezary.rojewski@intel.com>:

A number of patches improving overall quality and readability of
haswell.c and broadwell.c source files found in sound/soc/intel/boards.
Both files are first renamed and only then actual changes are being
incrementally added. The respective names are: hsw_rt5640 and bdw_rt286
to match the pattern found in more recent boards.

Most patches bring no functional change - the more impactful patches at
are placed the end.  The last patch is removing of FE DAI ops. Given the
existence of platform FE DAI capabilities (either static declaration or
through topology file), this code is redundant.
parents 4d6c2b46 e7f68863
...@@ -41,7 +41,7 @@ config SND_SOC_INTEL_SOF_CIRRUS_COMMON ...@@ -41,7 +41,7 @@ config SND_SOC_INTEL_SOF_CIRRUS_COMMON
if SND_SOC_INTEL_CATPT if SND_SOC_INTEL_CATPT
config SND_SOC_INTEL_HASWELL_MACH config SND_SOC_INTEL_HASWELL_MACH
tristate "Haswell Lynxpoint" tristate "Haswell with RT5640 I2S codec"
depends on I2C depends on I2C
depends on I2C_DESIGNWARE_PLATFORM || COMPILE_TEST depends on I2C_DESIGNWARE_PLATFORM || COMPILE_TEST
depends on X86_INTEL_LPSS || COMPILE_TEST depends on X86_INTEL_LPSS || COMPILE_TEST
...@@ -85,7 +85,7 @@ config SND_SOC_INTEL_BDW_RT5677_MACH ...@@ -85,7 +85,7 @@ config SND_SOC_INTEL_BDW_RT5677_MACH
If unsure select "N". If unsure select "N".
config SND_SOC_INTEL_BROADWELL_MACH config SND_SOC_INTEL_BROADWELL_MACH
tristate "Broadwell Wildcatpoint" tristate "Broadwell with RT286 I2S codec"
depends on I2C depends on I2C
depends on I2C_DESIGNWARE_PLATFORM || COMPILE_TEST depends on I2C_DESIGNWARE_PLATFORM || COMPILE_TEST
depends on X86_INTEL_LPSS || COMPILE_TEST depends on X86_INTEL_LPSS || COMPILE_TEST
......
# SPDX-License-Identifier: GPL-2.0-only # SPDX-License-Identifier: GPL-2.0-only
snd-soc-sst-haswell-objs := haswell.o snd-soc-sst-haswell-objs := hsw_rt5640.o
snd-soc-sst-bdw-rt5650-mach-objs := bdw-rt5650.o snd-soc-sst-bdw-rt5650-mach-objs := bdw-rt5650.o
snd-soc-sst-bdw-rt5677-mach-objs := bdw-rt5677.o snd-soc-sst-bdw-rt5677-mach-objs := bdw-rt5677.o
snd-soc-sst-broadwell-objs := broadwell.o snd-soc-sst-broadwell-objs := bdw_rt286.o
snd-soc-sst-bxt-da7219_max98357a-objs := bxt_da7219_max98357a.o snd-soc-sst-bxt-da7219_max98357a-objs := bxt_da7219_max98357a.o
snd-soc-sst-bxt-rt298-objs := bxt_rt298.o snd-soc-sst-bxt-rt298-objs := bxt_rt298.o
snd-soc-sst-sof-pcm512x-objs := sof_pcm512x.o snd-soc-sst-sof-pcm512x-objs := sof_pcm512x.o
......
// SPDX-License-Identifier: GPL-2.0-only // SPDX-License-Identifier: GPL-2.0-only
/* /*
* Intel Haswell Lynxpoint SST Audio * Sound card driver for Intel Haswell Lynx Point with Realtek 5640
* *
* Copyright (C) 2013, Intel Corporation. All rights reserved. * Copyright (C) 2013, Intel Corporation. All rights reserved.
*/ */
...@@ -9,20 +9,17 @@ ...@@ -9,20 +9,17 @@
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <sound/core.h> #include <sound/core.h>
#include <sound/pcm.h> #include <sound/pcm.h>
#include <sound/pcm_params.h>
#include <sound/soc.h> #include <sound/soc.h>
#include <sound/soc-acpi.h> #include <sound/soc-acpi.h>
#include <sound/pcm_params.h>
#include "../../codecs/rt5640.h" #include "../../codecs/rt5640.h"
/* Haswell ULT platforms have a Headphone and Mic jack */ static const struct snd_soc_dapm_widget card_widgets[] = {
static const struct snd_soc_dapm_widget haswell_widgets[] = {
SND_SOC_DAPM_HP("Headphones", NULL), SND_SOC_DAPM_HP("Headphones", NULL),
SND_SOC_DAPM_MIC("Mic", NULL), SND_SOC_DAPM_MIC("Mic", NULL),
}; };
static const struct snd_soc_dapm_route haswell_rt5640_map[] = { static const struct snd_soc_dapm_route card_routes[] = {
{"Headphones", NULL, "HPOR"}, {"Headphones", NULL, "HPOR"},
{"Headphones", NULL, "HPOL"}, {"Headphones", NULL, "HPOL"},
{"IN2P", NULL, "Mic"}, {"IN2P", NULL, "Mic"},
...@@ -32,73 +29,55 @@ static const struct snd_soc_dapm_route haswell_rt5640_map[] = { ...@@ -32,73 +29,55 @@ static const struct snd_soc_dapm_route haswell_rt5640_map[] = {
{"AIF1 Playback", NULL, "SSP0 CODEC OUT"}, {"AIF1 Playback", NULL, "SSP0 CODEC OUT"},
}; };
static int haswell_ssp0_fixup(struct snd_soc_pcm_runtime *rtd, static int codec_link_hw_params_fixup(struct snd_soc_pcm_runtime *rtd,
struct snd_pcm_hw_params *params) struct snd_pcm_hw_params *params)
{ {
struct snd_interval *rate = hw_param_interval(params, struct snd_interval *channels = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
SNDRV_PCM_HW_PARAM_RATE); struct snd_interval *rate = hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE);
struct snd_interval *channels = hw_param_interval(params,
SNDRV_PCM_HW_PARAM_CHANNELS);
/* The ADSP will covert the FE rate to 48k, stereo */ /* The ADSP will convert the FE rate to 48k, stereo. */
rate->min = rate->max = 48000; rate->min = rate->max = 48000;
channels->min = channels->max = 2; channels->min = channels->max = 2;
/* Set SSP0 to 16 bit. */
/* set SSP0 to 16 bit */
params_set_format(params, SNDRV_PCM_FORMAT_S16_LE); params_set_format(params, SNDRV_PCM_FORMAT_S16_LE);
return 0; return 0;
} }
static int haswell_rt5640_hw_params(struct snd_pcm_substream *substream, static int codec_link_hw_params(struct snd_pcm_substream *substream,
struct snd_pcm_hw_params *params) struct snd_pcm_hw_params *params)
{ {
struct snd_soc_pcm_runtime *rtd = asoc_substream_to_rtd(substream); struct snd_soc_pcm_runtime *rtd = asoc_substream_to_rtd(substream);
struct snd_soc_dai *codec_dai = asoc_rtd_to_codec(rtd, 0); struct snd_soc_dai *codec_dai = asoc_rtd_to_codec(rtd, 0);
int ret; int ret;
ret = snd_soc_dai_set_sysclk(codec_dai, RT5640_SCLK_S_MCLK, 12288000, ret = snd_soc_dai_set_sysclk(codec_dai, RT5640_SCLK_S_MCLK, 12288000, SND_SOC_CLOCK_IN);
SND_SOC_CLOCK_IN);
if (ret < 0) { if (ret < 0) {
dev_err(rtd->dev, "can't set codec sysclk configuration\n"); dev_err(rtd->dev, "set codec sysclk failed: %d\n", ret);
return ret; return ret;
} }
/* set correct codec filter for DAI format and clock config */ /* Set correct codec filter for DAI format and clock config. */
snd_soc_component_update_bits(codec_dai->component, 0x83, 0xffff, 0x8000); snd_soc_component_update_bits(codec_dai->component, 0x83, 0xffff, 0x8000);
return ret; return ret;
} }
static const struct snd_soc_ops haswell_rt5640_ops = { static const struct snd_soc_ops codec_link_ops = {
.hw_params = haswell_rt5640_hw_params, .hw_params = codec_link_hw_params,
}; };
SND_SOC_DAILINK_DEF(dummy, SND_SOC_DAILINK_DEF(system, DAILINK_COMP_ARRAY(COMP_CPU("System Pin")));
DAILINK_COMP_ARRAY(COMP_DUMMY())); SND_SOC_DAILINK_DEF(offload0, DAILINK_COMP_ARRAY(COMP_CPU("Offload0 Pin")));
SND_SOC_DAILINK_DEF(offload1, DAILINK_COMP_ARRAY(COMP_CPU("Offload1 Pin")));
SND_SOC_DAILINK_DEF(loopback, DAILINK_COMP_ARRAY(COMP_CPU("Loopback Pin")));
SND_SOC_DAILINK_DEF(system, SND_SOC_DAILINK_DEF(dummy, DAILINK_COMP_ARRAY(COMP_DUMMY()));
DAILINK_COMP_ARRAY(COMP_CPU("System Pin"))); SND_SOC_DAILINK_DEF(codec, DAILINK_COMP_ARRAY(COMP_CODEC("i2c-INT33CA:00", "rt5640-aif1")));
SND_SOC_DAILINK_DEF(platform, DAILINK_COMP_ARRAY(COMP_PLATFORM("haswell-pcm-audio")));
SND_SOC_DAILINK_DEF(ssp0_port, DAILINK_COMP_ARRAY(COMP_CPU("ssp0-port")));
SND_SOC_DAILINK_DEF(offload0, static struct snd_soc_dai_link card_dai_links[] = {
DAILINK_COMP_ARRAY(COMP_CPU("Offload0 Pin")));
SND_SOC_DAILINK_DEF(offload1,
DAILINK_COMP_ARRAY(COMP_CPU("Offload1 Pin")));
SND_SOC_DAILINK_DEF(loopback,
DAILINK_COMP_ARRAY(COMP_CPU("Loopback Pin")));
SND_SOC_DAILINK_DEF(codec,
DAILINK_COMP_ARRAY(COMP_CODEC("i2c-INT33CA:00", "rt5640-aif1")));
SND_SOC_DAILINK_DEF(platform,
DAILINK_COMP_ARRAY(COMP_PLATFORM("haswell-pcm-audio")));
SND_SOC_DAILINK_DEF(ssp0_port,
DAILINK_COMP_ARRAY(COMP_CPU("ssp0-port")));
static struct snd_soc_dai_link haswell_rt5640_dais[] = {
/* Front End DAI links */ /* Front End DAI links */
{ {
.name = "System", .name = "System",
...@@ -137,66 +116,61 @@ static struct snd_soc_dai_link haswell_rt5640_dais[] = { ...@@ -137,66 +116,61 @@ static struct snd_soc_dai_link haswell_rt5640_dais[] = {
.dpcm_capture = 1, .dpcm_capture = 1,
SND_SOC_DAILINK_REG(loopback, dummy, platform), SND_SOC_DAILINK_REG(loopback, dummy, platform),
}, },
/* Back End DAI links */ /* Back End DAI links */
{ {
/* SSP0 - Codec */ /* SSP0 - Codec */
.name = "Codec", .name = "Codec",
.id = 0, .id = 0,
.no_pcm = 1, .no_pcm = 1,
.dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF | .dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF | SND_SOC_DAIFMT_CBC_CFC,
SND_SOC_DAIFMT_CBC_CFC,
.ignore_pmdown_time = 1, .ignore_pmdown_time = 1,
.be_hw_params_fixup = haswell_ssp0_fixup, .be_hw_params_fixup = codec_link_hw_params_fixup,
.ops = &haswell_rt5640_ops, .ops = &codec_link_ops,
.dpcm_playback = 1, .dpcm_playback = 1,
.dpcm_capture = 1, .dpcm_capture = 1,
SND_SOC_DAILINK_REG(ssp0_port, codec, platform), SND_SOC_DAILINK_REG(ssp0_port, codec, platform),
}, },
}; };
/* audio machine driver for Haswell Lynxpoint DSP + RT5640 */ static struct snd_soc_card hsw_rt5640_card = {
static struct snd_soc_card haswell_rt5640 = {
.name = "haswell-rt5640", .name = "haswell-rt5640",
.owner = THIS_MODULE, .owner = THIS_MODULE,
.dai_link = haswell_rt5640_dais, .dai_link = card_dai_links,
.num_links = ARRAY_SIZE(haswell_rt5640_dais), .num_links = ARRAY_SIZE(card_dai_links),
.dapm_widgets = haswell_widgets, .dapm_widgets = card_widgets,
.num_dapm_widgets = ARRAY_SIZE(haswell_widgets), .num_dapm_widgets = ARRAY_SIZE(card_widgets),
.dapm_routes = haswell_rt5640_map, .dapm_routes = card_routes,
.num_dapm_routes = ARRAY_SIZE(haswell_rt5640_map), .num_dapm_routes = ARRAY_SIZE(card_routes),
.fully_routed = true, .fully_routed = true,
}; };
static int haswell_audio_probe(struct platform_device *pdev) static int hsw_rt5640_probe(struct platform_device *pdev)
{ {
struct snd_soc_acpi_mach *mach; struct snd_soc_acpi_mach *mach;
struct device *dev = &pdev->dev;
int ret; int ret;
haswell_rt5640.dev = &pdev->dev; hsw_rt5640_card.dev = dev;
mach = dev_get_platdata(dev);
/* override platform name, if required */ ret = snd_soc_fixup_dai_links_platform_name(&hsw_rt5640_card, mach->mach_params.platform);
mach = pdev->dev.platform_data;
ret = snd_soc_fixup_dai_links_platform_name(&haswell_rt5640,
mach->mach_params.platform);
if (ret) if (ret)
return ret; return ret;
return devm_snd_soc_register_card(&pdev->dev, &haswell_rt5640); return devm_snd_soc_register_card(dev, &hsw_rt5640_card);
} }
static struct platform_driver haswell_audio = { static struct platform_driver hsw_rt5640_driver = {
.probe = haswell_audio_probe, .probe = hsw_rt5640_probe,
.driver = { .driver = {
.name = "haswell-audio", .name = "hsw_rt5640",
.pm = &snd_soc_pm_ops, .pm = &snd_soc_pm_ops,
}, },
}; };
module_platform_driver(haswell_audio) module_platform_driver(hsw_rt5640_driver)
/* Module information */
MODULE_AUTHOR("Liam Girdwood, Xingchao Wang"); MODULE_AUTHOR("Liam Girdwood, Xingchao Wang");
MODULE_DESCRIPTION("Intel SST Audio for Haswell Lynxpoint"); MODULE_DESCRIPTION("Sound card driver for Intel Haswell Lynx Point with Realtek 5640");
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL");
MODULE_ALIAS("platform:haswell-audio"); MODULE_ALIAS("platform:hsw_rt5640");
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
struct snd_soc_acpi_mach snd_soc_acpi_intel_haswell_machines[] = { struct snd_soc_acpi_mach snd_soc_acpi_intel_haswell_machines[] = {
{ {
.id = "INT33CA", .id = "INT33CA",
.drv_name = "haswell-audio", .drv_name = "hsw_rt5640",
.fw_filename = "intel/IntcSST1.bin", .fw_filename = "intel/IntcSST1.bin",
.sof_tplg_filename = "sof-hsw.tplg", .sof_tplg_filename = "sof-hsw.tplg",
}, },
...@@ -23,7 +23,7 @@ EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_haswell_machines); ...@@ -23,7 +23,7 @@ EXPORT_SYMBOL_GPL(snd_soc_acpi_intel_haswell_machines);
struct snd_soc_acpi_mach snd_soc_acpi_intel_broadwell_machines[] = { struct snd_soc_acpi_mach snd_soc_acpi_intel_broadwell_machines[] = {
{ {
.id = "INT343A", .id = "INT343A",
.drv_name = "broadwell-audio", .drv_name = "bdw_rt286",
.fw_filename = "intel/IntcSST2.bin", .fw_filename = "intel/IntcSST2.bin",
.sof_tplg_filename = "sof-bdw-rt286.tplg", .sof_tplg_filename = "sof-bdw-rt286.tplg",
}, },
...@@ -41,7 +41,7 @@ struct snd_soc_acpi_mach snd_soc_acpi_intel_broadwell_machines[] = { ...@@ -41,7 +41,7 @@ struct snd_soc_acpi_mach snd_soc_acpi_intel_broadwell_machines[] = {
}, },
{ {
.id = "INT33CA", .id = "INT33CA",
.drv_name = "haswell-audio", .drv_name = "hsw_rt5640",
.fw_filename = "intel/IntcSST2.bin", .fw_filename = "intel/IntcSST2.bin",
.sof_tplg_filename = "sof-bdw-rt5640.tplg", .sof_tplg_filename = "sof-bdw-rt5640.tplg",
}, },
......
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