mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
ALSA: hda/hdmi: Rewrite to new probe method
Convert the HDMI codec drivers to use the new hda_codec_ops probe. The Intel and Nvidia-MCP HDMI drivers needed slightly more changes to deal with the unified callbacks among all models. Also another non-trivial change is Intel driver's set_power_state callback. An additional NULL check of codec->spec is needed there since the set_power_state() may be called before the probe gets called (e.g. in ASoC hda codec hda_codec_probe()). Other than that, no functional changes. Signed-off-by: Takashi Iwai <tiwai@suse.de> Link: https://patch.msgid.link/20250709160434.1859-24-tiwai@suse.de
This commit is contained in:
parent
6cce08122f
commit
ad781b550f
@ -528,19 +528,16 @@ static const struct drm_audio_component_audio_ops atihdmi_audio_ops = {
|
|||||||
.master_unbind = snd_hda_hdmi_acomp_master_unbind,
|
.master_unbind = snd_hda_hdmi_acomp_master_unbind,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int patch_atihdmi(struct hda_codec *codec)
|
static int atihdmi_probe(struct hda_codec *codec, const struct hda_device_id *id)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
struct hdmi_spec_per_cvt *per_cvt;
|
struct hdmi_spec_per_cvt *per_cvt;
|
||||||
int err, cvt_idx;
|
int err, cvt_idx;
|
||||||
|
|
||||||
err = patch_generic_hdmi(codec);
|
err = snd_hda_hdmi_generic_probe(codec);
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
codec->patch_ops.init = atihdmi_init;
|
|
||||||
|
|
||||||
spec = codec->spec;
|
spec = codec->spec;
|
||||||
|
|
||||||
spec->static_pcm_mapping = true;
|
spec->static_pcm_mapping = true;
|
||||||
@ -583,15 +580,26 @@ static int patch_atihdmi(struct hda_codec *codec)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const struct hda_codec_ops atihdmi_codec_ops = {
|
||||||
|
.probe = atihdmi_probe,
|
||||||
|
.remove = snd_hda_hdmi_generic_remove,
|
||||||
|
.init = atihdmi_init,
|
||||||
|
.build_pcms = snd_hda_hdmi_generic_build_pcms,
|
||||||
|
.build_controls = snd_hda_hdmi_generic_build_controls,
|
||||||
|
.unsol_event = snd_hda_hdmi_generic_unsol_event,
|
||||||
|
.suspend = snd_hda_hdmi_generic_suspend,
|
||||||
|
.resume = snd_hda_hdmi_generic_resume,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* patch entries
|
* driver entries
|
||||||
*/
|
*/
|
||||||
static const struct hda_device_id snd_hda_id_atihdmi[] = {
|
static const struct hda_device_id snd_hda_id_atihdmi[] = {
|
||||||
HDA_CODEC_ENTRY(0x1002793c, "RS600 HDMI", patch_atihdmi),
|
HDA_CODEC_ID(0x1002793c, "RS600 HDMI"),
|
||||||
HDA_CODEC_ENTRY(0x10027919, "RS600 HDMI", patch_atihdmi),
|
HDA_CODEC_ID(0x10027919, "RS600 HDMI"),
|
||||||
HDA_CODEC_ENTRY(0x1002791a, "RS690/780 HDMI", patch_atihdmi),
|
HDA_CODEC_ID(0x1002791a, "RS690/780 HDMI"),
|
||||||
HDA_CODEC_ENTRY(0x1002aa01, "R6xx HDMI", patch_atihdmi),
|
HDA_CODEC_ID(0x1002aa01, "R6xx HDMI"),
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_atihdmi);
|
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_atihdmi);
|
||||||
|
|
||||||
@ -601,6 +609,7 @@ MODULE_IMPORT_NS("SND_HDA_CODEC_HDMI");
|
|||||||
|
|
||||||
static struct hda_codec_driver atihdmi_driver = {
|
static struct hda_codec_driver atihdmi_driver = {
|
||||||
.id = snd_hda_id_atihdmi,
|
.id = snd_hda_id_atihdmi,
|
||||||
|
.ops = &atihdmi_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(atihdmi_driver);
|
module_hda_codec_driver(atihdmi_driver);
|
||||||
|
@ -2087,7 +2087,7 @@ void snd_hda_hdmi_generic_spec_free(struct hda_codec *codec)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_spec_free, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_spec_free, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
void snd_hda_hdmi_generic_free(struct hda_codec *codec)
|
void snd_hda_hdmi_generic_remove(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
int pin_idx, pcm_idx;
|
int pin_idx, pcm_idx;
|
||||||
@ -2113,7 +2113,7 @@ void snd_hda_hdmi_generic_free(struct hda_codec *codec)
|
|||||||
|
|
||||||
snd_hda_hdmi_generic_spec_free(codec);
|
snd_hda_hdmi_generic_spec_free(codec);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_free, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_remove, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
int snd_hda_hdmi_generic_suspend(struct hda_codec *codec)
|
int snd_hda_hdmi_generic_suspend(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
@ -2133,7 +2133,7 @@ int snd_hda_hdmi_generic_resume(struct hda_codec *codec)
|
|||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
int pin_idx;
|
int pin_idx;
|
||||||
|
|
||||||
codec->patch_ops.init(codec);
|
snd_hda_codec_init(codec);
|
||||||
snd_hda_regmap_sync(codec);
|
snd_hda_regmap_sync(codec);
|
||||||
|
|
||||||
for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
|
for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
|
||||||
@ -2144,16 +2144,6 @@ int snd_hda_hdmi_generic_resume(struct hda_codec *codec)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_resume, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_resume, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
static const struct hda_codec_ops generic_hdmi_patch_ops = {
|
|
||||||
.init = snd_hda_hdmi_generic_init,
|
|
||||||
.free = snd_hda_hdmi_generic_free,
|
|
||||||
.build_pcms = snd_hda_hdmi_generic_build_pcms,
|
|
||||||
.build_controls = snd_hda_hdmi_generic_build_controls,
|
|
||||||
.unsol_event = snd_hda_hdmi_generic_unsol_event,
|
|
||||||
.suspend = snd_hda_hdmi_generic_suspend,
|
|
||||||
.resume = snd_hda_hdmi_generic_resume,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct hdmi_ops generic_standard_hdmi_ops = {
|
static const struct hdmi_ops generic_standard_hdmi_ops = {
|
||||||
.pin_get_eld = hdmi_pin_get_eld,
|
.pin_get_eld = hdmi_pin_get_eld,
|
||||||
.pin_setup_infoframe = hdmi_pin_setup_infoframe,
|
.pin_setup_infoframe = hdmi_pin_setup_infoframe,
|
||||||
@ -2185,14 +2175,12 @@ int snd_hda_hdmi_generic_alloc(struct hda_codec *codec)
|
|||||||
codec->spec = spec;
|
codec->spec = spec;
|
||||||
hdmi_array_init(spec, 4);
|
hdmi_array_init(spec, 4);
|
||||||
|
|
||||||
codec->patch_ops = generic_hdmi_patch_ops;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_alloc, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_alloc, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
/* generic HDMI parser */
|
/* generic HDMI parser */
|
||||||
int patch_generic_hdmi(struct hda_codec *codec)
|
int snd_hda_hdmi_generic_probe(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
@ -2209,7 +2197,7 @@ int patch_generic_hdmi(struct hda_codec *codec)
|
|||||||
snd_hda_hdmi_generic_init_per_pins(codec);
|
snd_hda_hdmi_generic_init_per_pins(codec);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(patch_generic_hdmi, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_generic_probe, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* generic audio component binding
|
* generic audio component binding
|
||||||
@ -2346,65 +2334,83 @@ EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_acomp_init, "SND_HDA_CODEC_HDMI");
|
|||||||
/*
|
/*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int patch_gf_hdmi(struct hda_codec *codec)
|
enum {
|
||||||
|
MODEL_GENERIC,
|
||||||
|
MODEL_GF,
|
||||||
|
};
|
||||||
|
|
||||||
|
static int generichdmi_probe(struct hda_codec *codec,
|
||||||
|
const struct hda_device_id *id)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = patch_generic_hdmi(codec);
|
err = snd_hda_hdmi_generic_probe(codec);
|
||||||
if (err)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Glenfly GPUs have two codecs, stream switches from one codec to
|
* Glenfly GPUs have two codecs, stream switches from one codec to
|
||||||
* another, need to do actual clean-ups in codec_cleanup_stream
|
* another, need to do actual clean-ups in codec_cleanup_stream
|
||||||
*/
|
*/
|
||||||
codec->no_sticky_stream = 1;
|
if (id->driver_data == MODEL_GF)
|
||||||
|
codec->no_sticky_stream = 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static const struct hda_codec_ops generichdmi_codec_ops = {
|
||||||
* patch entries
|
.probe = generichdmi_probe,
|
||||||
*/
|
.remove = snd_hda_hdmi_generic_remove,
|
||||||
static const struct hda_device_id snd_hda_id_hdmi[] = {
|
.init = snd_hda_hdmi_generic_init,
|
||||||
HDA_CODEC_ENTRY(0x00147a47, "Loongson HDMI", patch_generic_hdmi),
|
.build_pcms = snd_hda_hdmi_generic_build_pcms,
|
||||||
HDA_CODEC_ENTRY(0x10951390, "SiI1390 HDMI", patch_generic_hdmi),
|
.build_controls = snd_hda_hdmi_generic_build_controls,
|
||||||
HDA_CODEC_ENTRY(0x10951392, "SiI1392 HDMI", patch_generic_hdmi),
|
.unsol_event = snd_hda_hdmi_generic_unsol_event,
|
||||||
HDA_CODEC_ENTRY(0x17e80047, "Chrontel HDMI", patch_generic_hdmi),
|
.suspend = snd_hda_hdmi_generic_suspend,
|
||||||
HDA_CODEC_ENTRY(0x67663d82, "Arise 82 HDMI/DP", patch_gf_hdmi),
|
.resume = snd_hda_hdmi_generic_resume,
|
||||||
HDA_CODEC_ENTRY(0x67663d83, "Arise 83 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x67663d84, "Arise 84 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x67663d85, "Arise 85 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x67663d86, "Arise 86 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x67663d87, "Arise 87 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x11069f84, "VX11 HDMI/DP", patch_generic_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x11069f85, "VX11 HDMI/DP", patch_generic_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f86, "ZX-100S HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f87, "ZX-100S HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f88, "KX-5000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f89, "KX-5000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f8a, "KX-6000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f8b, "KX-6000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f8c, "KX-6000G HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f8d, "KX-6000G HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f8e, "KX-7000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f8f, "KX-7000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x1d179f90, "KX-7000 HDMI/DP", patch_gf_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x80862801, "Bearlake HDMI", patch_generic_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x80862802, "Cantiga HDMI", patch_generic_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x80862803, "Eaglelake HDMI", patch_generic_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x80862880, "CedarTrail HDMI", patch_generic_hdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x808629fb, "Crestline HDMI", patch_generic_hdmi),
|
|
||||||
/* special ID for generic HDMI */
|
|
||||||
HDA_CODEC_ENTRY(HDA_CODEC_ID_GENERIC_HDMI, "Generic HDMI", patch_generic_hdmi),
|
|
||||||
{} /* terminator */
|
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_hdmi);
|
|
||||||
|
/*
|
||||||
|
*/
|
||||||
|
static const struct hda_device_id snd_hda_id_generichdmi[] = {
|
||||||
|
HDA_CODEC_ID_MODEL(0x00147a47, "Loongson HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x10951390, "SiI1390 HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x10951392, "SiI1392 HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x11069f84, "VX11 HDMI/DP", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x11069f85, "VX11 HDMI/DP", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x17e80047, "Chrontel HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f86, "ZX-100S HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f87, "ZX-100S HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f88, "KX-5000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f89, "KX-5000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f8a, "KX-6000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f8b, "KX-6000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f8c, "KX-6000G HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f8d, "KX-6000G HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f8e, "KX-7000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f8f, "KX-7000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x1d179f90, "KX-7000 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x67663d82, "Arise 82 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x67663d83, "Arise 83 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x67663d84, "Arise 84 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x67663d85, "Arise 85 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x67663d86, "Arise 86 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x67663d87, "Arise 87 HDMI/DP", MODEL_GF),
|
||||||
|
HDA_CODEC_ID_MODEL(0x80862801, "Bearlake HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x80862802, "Cantiga HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x80862803, "Eaglelake HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x80862880, "CedarTrail HDMI", MODEL_GENERIC),
|
||||||
|
HDA_CODEC_ID_MODEL(0x808629fb, "Crestline HDMI", MODEL_GENERIC),
|
||||||
|
/* special ID for generic HDMI */
|
||||||
|
HDA_CODEC_ID_MODEL(HDA_CODEC_ID_GENERIC_HDMI, "Generic HDMI", MODEL_GENERIC),
|
||||||
|
{} /* terminator */
|
||||||
|
};
|
||||||
|
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_generichdmi);
|
||||||
|
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
MODULE_DESCRIPTION("HDMI HD-audio codec");
|
MODULE_DESCRIPTION("Generic HDMI HD-audio codec");
|
||||||
|
|
||||||
static struct hda_codec_driver hdmi_driver = {
|
static struct hda_codec_driver generichdmi_driver = {
|
||||||
.id = snd_hda_id_hdmi,
|
.id = snd_hda_id_generichdmi,
|
||||||
|
.ops = &generichdmi_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(hdmi_driver);
|
module_hda_codec_driver(generichdmi_driver);
|
||||||
|
@ -237,8 +237,8 @@ union audio_infoframe {
|
|||||||
/* Generic HDMI codec support */
|
/* Generic HDMI codec support */
|
||||||
int snd_hda_hdmi_generic_alloc(struct hda_codec *codec);
|
int snd_hda_hdmi_generic_alloc(struct hda_codec *codec);
|
||||||
int snd_hda_hdmi_parse_codec(struct hda_codec *codec);
|
int snd_hda_hdmi_parse_codec(struct hda_codec *codec);
|
||||||
int patch_generic_hdmi(struct hda_codec *codec);
|
int snd_hda_hdmi_generic_probe(struct hda_codec *codec);
|
||||||
void snd_hda_hdmi_generic_free(struct hda_codec *codec);
|
void snd_hda_hdmi_generic_remove(struct hda_codec *codec);
|
||||||
|
|
||||||
int snd_hda_hdmi_generic_build_pcms(struct hda_codec *codec);
|
int snd_hda_hdmi_generic_build_pcms(struct hda_codec *codec);
|
||||||
int snd_hda_hdmi_generic_build_controls(struct hda_codec *codec);
|
int snd_hda_hdmi_generic_build_controls(struct hda_codec *codec);
|
||||||
@ -286,9 +286,9 @@ void snd_hda_hdmi_acomp_master_unbind(struct device *dev,
|
|||||||
struct drm_audio_component *acomp);
|
struct drm_audio_component *acomp);
|
||||||
|
|
||||||
/* Simple / legacy HDMI codec support */
|
/* Simple / legacy HDMI codec support */
|
||||||
int patch_simple_hdmi(struct hda_codec *codec,
|
int snd_hda_hdmi_simple_probe(struct hda_codec *codec,
|
||||||
hda_nid_t cvt_nid, hda_nid_t pin_nid);
|
hda_nid_t cvt_nid, hda_nid_t pin_nid);
|
||||||
void snd_hda_hdmi_simple_free(struct hda_codec *codec);
|
void snd_hda_hdmi_simple_remove(struct hda_codec *codec);
|
||||||
|
|
||||||
int snd_hda_hdmi_simple_build_pcms(struct hda_codec *codec);
|
int snd_hda_hdmi_simple_build_pcms(struct hda_codec *codec);
|
||||||
int snd_hda_hdmi_simple_build_controls(struct hda_codec *codec);
|
int snd_hda_hdmi_simple_build_controls(struct hda_codec *codec);
|
||||||
|
@ -18,6 +18,16 @@ IS_ENABLED(CONFIG_SND_HDA_INTEL_HDMI_SILENT_STREAM);
|
|||||||
module_param(enable_silent_stream, bool, 0644);
|
module_param(enable_silent_stream, bool, 0644);
|
||||||
MODULE_PARM_DESC(enable_silent_stream, "Enable Silent Stream for HDMI devices");
|
MODULE_PARM_DESC(enable_silent_stream, "Enable Silent Stream for HDMI devices");
|
||||||
|
|
||||||
|
enum {
|
||||||
|
MODEL_HSW,
|
||||||
|
MODEL_GLK,
|
||||||
|
MODEL_ICL,
|
||||||
|
MODEL_TGL,
|
||||||
|
MODEL_ADLP,
|
||||||
|
MODEL_BYT,
|
||||||
|
MODEL_CPT,
|
||||||
|
};
|
||||||
|
|
||||||
#define INTEL_GET_VENDOR_VERB 0xf81
|
#define INTEL_GET_VENDOR_VERB 0xf81
|
||||||
#define INTEL_SET_VENDOR_VERB 0x781
|
#define INTEL_SET_VENDOR_VERB 0x781
|
||||||
#define INTEL_EN_DP12 0x02 /* enable DP 1.2 features */
|
#define INTEL_EN_DP12 0x02 /* enable DP 1.2 features */
|
||||||
@ -67,9 +77,12 @@ static void intel_haswell_fixup_enable_dp12(struct hda_codec *codec)
|
|||||||
static void haswell_set_power_state(struct hda_codec *codec, hda_nid_t fg,
|
static void haswell_set_power_state(struct hda_codec *codec, hda_nid_t fg,
|
||||||
unsigned int power_state)
|
unsigned int power_state)
|
||||||
{
|
{
|
||||||
if (power_state == AC_PWRST_D0) {
|
/* check codec->spec: it can be called before the probe gets called */
|
||||||
intel_haswell_enable_all_pins(codec, false);
|
if (codec->spec) {
|
||||||
intel_haswell_fixup_enable_dp12(codec);
|
if (power_state == AC_PWRST_D0) {
|
||||||
|
intel_haswell_enable_all_pins(codec, false);
|
||||||
|
intel_haswell_fixup_enable_dp12(codec);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
snd_hda_codec_read(codec, fg, 0, AC_VERB_SET_POWER_STATE, power_state);
|
snd_hda_codec_read(codec, fg, 0, AC_VERB_SET_POWER_STATE, power_state);
|
||||||
@ -456,13 +469,15 @@ static void i915_pin_cvt_fixup(struct hda_codec *codec,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int i915_adlp_hdmi_suspend(struct hda_codec *codec)
|
static int i915_hdmi_suspend(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
bool silent_streams = false;
|
bool silent_streams = false;
|
||||||
int pin_idx, res;
|
int pin_idx, res;
|
||||||
|
|
||||||
res = snd_hda_hdmi_generic_suspend(codec);
|
res = snd_hda_hdmi_generic_suspend(codec);
|
||||||
|
if (spec->silent_stream_type != SILENT_STREAM_KAE)
|
||||||
|
return res;
|
||||||
|
|
||||||
for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
|
for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
|
||||||
struct hdmi_spec_per_pin *per_pin = get_pin(spec, pin_idx);
|
struct hdmi_spec_per_pin *per_pin = get_pin(spec, pin_idx);
|
||||||
@ -495,12 +510,14 @@ static int i915_adlp_hdmi_suspend(struct hda_codec *codec)
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int i915_adlp_hdmi_resume(struct hda_codec *codec)
|
static int i915_hdmi_resume(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
int pin_idx, res;
|
int pin_idx, res;
|
||||||
|
|
||||||
res = snd_hda_hdmi_generic_resume(codec);
|
res = snd_hda_hdmi_generic_resume(codec);
|
||||||
|
if (spec->silent_stream_type != SILENT_STREAM_KAE)
|
||||||
|
return res;
|
||||||
|
|
||||||
/* KAE not programmed at suspend, nothing to do here */
|
/* KAE not programmed at suspend, nothing to do here */
|
||||||
if (!codec->no_stream_clean_at_suspend)
|
if (!codec->no_stream_clean_at_suspend)
|
||||||
@ -539,8 +556,6 @@ static int i915_adlp_hdmi_resume(struct hda_codec *codec)
|
|||||||
/* precondition and allocation for Intel codecs */
|
/* precondition and allocation for Intel codecs */
|
||||||
static int alloc_intel_hdmi(struct hda_codec *codec)
|
static int alloc_intel_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
int err;
|
|
||||||
|
|
||||||
/* requires i915 binding */
|
/* requires i915 binding */
|
||||||
if (!codec->bus->core.audio_component) {
|
if (!codec->bus->core.audio_component) {
|
||||||
codec_info(codec, "No i915 binding for Intel HDMI/DP codec\n");
|
codec_info(codec, "No i915 binding for Intel HDMI/DP codec\n");
|
||||||
@ -549,12 +564,7 @@ static int alloc_intel_hdmi(struct hda_codec *codec)
|
|||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = snd_hda_hdmi_generic_alloc(codec);
|
return snd_hda_hdmi_generic_alloc(codec);
|
||||||
if (err < 0)
|
|
||||||
return err;
|
|
||||||
/* no need to handle unsol events */
|
|
||||||
codec->patch_ops.unsol_event = NULL;
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* parse and post-process for Intel codecs */
|
/* parse and post-process for Intel codecs */
|
||||||
@ -580,11 +590,7 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
|||||||
bool send_silent_stream)
|
bool send_silent_stream)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
|
||||||
|
|
||||||
err = alloc_intel_hdmi(codec);
|
|
||||||
if (err < 0)
|
|
||||||
return err;
|
|
||||||
spec = codec->spec;
|
spec = codec->spec;
|
||||||
codec->dp_mst = true;
|
codec->dp_mst = true;
|
||||||
spec->vendor_nid = vendor_nid;
|
spec->vendor_nid = vendor_nid;
|
||||||
@ -598,7 +604,6 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
|||||||
|
|
||||||
codec->display_power_control = 1;
|
codec->display_power_control = 1;
|
||||||
|
|
||||||
codec->patch_ops.set_power_state = haswell_set_power_state;
|
|
||||||
codec->depop_delay = 0;
|
codec->depop_delay = 0;
|
||||||
codec->auto_runtime_pm = 1;
|
codec->auto_runtime_pm = 1;
|
||||||
|
|
||||||
@ -616,13 +621,13 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
|
|||||||
return parse_intel_hdmi(codec);
|
return parse_intel_hdmi(codec);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_hsw_hdmi(struct hda_codec *codec)
|
static int probe_i915_hsw_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
return intel_hsw_common_init(codec, 0x08, NULL, 0, 3,
|
return intel_hsw_common_init(codec, 0x08, NULL, 0, 3,
|
||||||
enable_silent_stream);
|
enable_silent_stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_glk_hdmi(struct hda_codec *codec)
|
static int probe_i915_glk_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Silent stream calls audio component .get_power() from
|
* Silent stream calls audio component .get_power() from
|
||||||
@ -632,7 +637,7 @@ static int patch_i915_glk_hdmi(struct hda_codec *codec)
|
|||||||
return intel_hsw_common_init(codec, 0x0b, NULL, 0, 3, false);
|
return intel_hsw_common_init(codec, 0x0b, NULL, 0, 3, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_icl_hdmi(struct hda_codec *codec)
|
static int probe_i915_icl_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* pin to port mapping table where the value indicate the pin number and
|
* pin to port mapping table where the value indicate the pin number and
|
||||||
@ -644,7 +649,7 @@ static int patch_i915_icl_hdmi(struct hda_codec *codec)
|
|||||||
enable_silent_stream);
|
enable_silent_stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_tgl_hdmi(struct hda_codec *codec)
|
static int probe_i915_tgl_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* pin to port mapping table where the value indicate the pin number and
|
* pin to port mapping table where the value indicate the pin number and
|
||||||
@ -656,35 +661,27 @@ static int patch_i915_tgl_hdmi(struct hda_codec *codec)
|
|||||||
enable_silent_stream);
|
enable_silent_stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_i915_adlp_hdmi(struct hda_codec *codec)
|
static int probe_i915_adlp_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
res = patch_i915_tgl_hdmi(codec);
|
res = probe_i915_tgl_hdmi(codec);
|
||||||
if (!res) {
|
if (!res) {
|
||||||
spec = codec->spec;
|
spec = codec->spec;
|
||||||
|
|
||||||
if (spec->silent_stream_type) {
|
if (spec->silent_stream_type)
|
||||||
spec->silent_stream_type = SILENT_STREAM_KAE;
|
spec->silent_stream_type = SILENT_STREAM_KAE;
|
||||||
|
|
||||||
codec->patch_ops.resume = i915_adlp_hdmi_resume;
|
|
||||||
codec->patch_ops.suspend = i915_adlp_hdmi_suspend;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Intel Baytrail and Braswell; with eld notifier */
|
/* Intel Baytrail and Braswell; with eld notifier */
|
||||||
static int patch_i915_byt_hdmi(struct hda_codec *codec)
|
static int probe_i915_byt_hdmi(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
|
||||||
|
|
||||||
err = alloc_intel_hdmi(codec);
|
|
||||||
if (err < 0)
|
|
||||||
return err;
|
|
||||||
spec = codec->spec;
|
spec = codec->spec;
|
||||||
|
|
||||||
/* For Valleyview/Cherryview, only the display codec is in the display
|
/* For Valleyview/Cherryview, only the display codec is in the display
|
||||||
@ -701,51 +698,104 @@ static int patch_i915_byt_hdmi(struct hda_codec *codec)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Intel IronLake, SandyBridge and IvyBridge; with eld notifier */
|
/* Intel IronLake, SandyBridge and IvyBridge; with eld notifier */
|
||||||
static int patch_i915_cpt_hdmi(struct hda_codec *codec)
|
static int probe_i915_cpt_hdmi(struct hda_codec *codec)
|
||||||
|
{
|
||||||
|
return parse_intel_hdmi(codec);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* common driver probe
|
||||||
|
*/
|
||||||
|
static int intelhdmi_probe(struct hda_codec *codec, const struct hda_device_id *id)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = alloc_intel_hdmi(codec);
|
err = alloc_intel_hdmi(codec);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
return parse_intel_hdmi(codec);
|
|
||||||
|
switch (id->driver_data) {
|
||||||
|
case MODEL_HSW:
|
||||||
|
err = probe_i915_hsw_hdmi(codec);
|
||||||
|
break;
|
||||||
|
case MODEL_GLK:
|
||||||
|
err = probe_i915_glk_hdmi(codec);
|
||||||
|
break;
|
||||||
|
case MODEL_ICL:
|
||||||
|
err = probe_i915_icl_hdmi(codec);
|
||||||
|
break;
|
||||||
|
case MODEL_TGL:
|
||||||
|
err = probe_i915_tgl_hdmi(codec);
|
||||||
|
break;
|
||||||
|
case MODEL_ADLP:
|
||||||
|
err = probe_i915_adlp_hdmi(codec);
|
||||||
|
break;
|
||||||
|
case MODEL_BYT:
|
||||||
|
err = probe_i915_byt_hdmi(codec);
|
||||||
|
break;
|
||||||
|
case MODEL_CPT:
|
||||||
|
err = probe_i915_cpt_hdmi(codec);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
err = -EINVAL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (err < 0) {
|
||||||
|
snd_hda_hdmi_generic_spec_free(codec);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const struct hda_codec_ops intelhdmi_codec_ops = {
|
||||||
|
.probe = intelhdmi_probe,
|
||||||
|
.remove = snd_hda_hdmi_generic_remove,
|
||||||
|
.init = snd_hda_hdmi_generic_init,
|
||||||
|
.build_pcms = snd_hda_hdmi_generic_build_pcms,
|
||||||
|
.build_controls = snd_hda_hdmi_generic_build_controls,
|
||||||
|
.unsol_event = snd_hda_hdmi_generic_unsol_event,
|
||||||
|
.suspend = i915_hdmi_suspend,
|
||||||
|
.resume = i915_hdmi_resume,
|
||||||
|
.set_power_state = haswell_set_power_state,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* driver entries
|
* driver entries
|
||||||
*/
|
*/
|
||||||
static const struct hda_device_id snd_hda_id_intelhdmi[] = {
|
static const struct hda_device_id snd_hda_id_intelhdmi[] = {
|
||||||
HDA_CODEC_ENTRY(0x80860054, "IbexPeak HDMI", patch_i915_cpt_hdmi),
|
HDA_CODEC_ID_MODEL(0x80860054, "IbexPeak HDMI", MODEL_CPT),
|
||||||
HDA_CODEC_ENTRY(0x80862800, "Geminilake HDMI", patch_i915_glk_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862800, "Geminilake HDMI", MODEL_GLK),
|
||||||
HDA_CODEC_ENTRY(0x80862804, "IbexPeak HDMI", patch_i915_cpt_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862804, "IbexPeak HDMI", MODEL_CPT),
|
||||||
HDA_CODEC_ENTRY(0x80862805, "CougarPoint HDMI", patch_i915_cpt_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862805, "CougarPoint HDMI", MODEL_CPT),
|
||||||
HDA_CODEC_ENTRY(0x80862806, "PantherPoint HDMI", patch_i915_cpt_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862806, "PantherPoint HDMI", MODEL_CPT),
|
||||||
HDA_CODEC_ENTRY(0x80862807, "Haswell HDMI", patch_i915_hsw_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862807, "Haswell HDMI", MODEL_HSW),
|
||||||
HDA_CODEC_ENTRY(0x80862808, "Broadwell HDMI", patch_i915_hsw_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862808, "Broadwell HDMI", MODEL_HSW),
|
||||||
HDA_CODEC_ENTRY(0x80862809, "Skylake HDMI", patch_i915_hsw_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862809, "Skylake HDMI", MODEL_HSW),
|
||||||
HDA_CODEC_ENTRY(0x8086280a, "Broxton HDMI", patch_i915_hsw_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086280a, "Broxton HDMI", MODEL_HSW),
|
||||||
HDA_CODEC_ENTRY(0x8086280b, "Kabylake HDMI", patch_i915_hsw_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086280b, "Kabylake HDMI", MODEL_HSW),
|
||||||
HDA_CODEC_ENTRY(0x8086280c, "Cannonlake HDMI", patch_i915_glk_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086280c, "Cannonlake HDMI", MODEL_GLK),
|
||||||
HDA_CODEC_ENTRY(0x8086280d, "Geminilake HDMI", patch_i915_glk_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086280d, "Geminilake HDMI", MODEL_GLK),
|
||||||
HDA_CODEC_ENTRY(0x8086280f, "Icelake HDMI", patch_i915_icl_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086280f, "Icelake HDMI", MODEL_ICL),
|
||||||
HDA_CODEC_ENTRY(0x80862812, "Tigerlake HDMI", patch_i915_tgl_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862812, "Tigerlake HDMI", MODEL_TGL),
|
||||||
HDA_CODEC_ENTRY(0x80862814, "DG1 HDMI", patch_i915_tgl_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862814, "DG1 HDMI", MODEL_TGL),
|
||||||
HDA_CODEC_ENTRY(0x80862815, "Alderlake HDMI", patch_i915_tgl_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862815, "Alderlake HDMI", MODEL_TGL),
|
||||||
HDA_CODEC_ENTRY(0x80862816, "Rocketlake HDMI", patch_i915_tgl_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862816, "Rocketlake HDMI", MODEL_TGL),
|
||||||
HDA_CODEC_ENTRY(0x80862818, "Raptorlake HDMI", patch_i915_tgl_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862818, "Raptorlake HDMI", MODEL_TGL),
|
||||||
HDA_CODEC_ENTRY(0x80862819, "DG2 HDMI", patch_i915_tgl_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862819, "DG2 HDMI", MODEL_TGL),
|
||||||
HDA_CODEC_ENTRY(0x8086281a, "Jasperlake HDMI", patch_i915_icl_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086281a, "Jasperlake HDMI", MODEL_ICL),
|
||||||
HDA_CODEC_ENTRY(0x8086281b, "Elkhartlake HDMI", patch_i915_icl_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086281b, "Elkhartlake HDMI", MODEL_ICL),
|
||||||
HDA_CODEC_ENTRY(0x8086281c, "Alderlake-P HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086281c, "Alderlake-P HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x8086281d, "Meteor Lake HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086281d, "Meteor Lake HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x8086281e, "Battlemage HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086281e, "Battlemage HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x8086281f, "Raptor Lake P HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x8086281f, "Raptor Lake P HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x80862820, "Lunar Lake HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862820, "Lunar Lake HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x80862822, "Panther Lake HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862822, "Panther Lake HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x80862823, "Wildcat Lake HDMI", patch_i915_adlp_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862823, "Wildcat Lake HDMI", MODEL_ADLP),
|
||||||
HDA_CODEC_ENTRY(0x80862882, "Valleyview2 HDMI", patch_i915_byt_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862882, "Valleyview2 HDMI", MODEL_BYT),
|
||||||
HDA_CODEC_ENTRY(0x80862883, "Braswell HDMI", patch_i915_byt_hdmi),
|
HDA_CODEC_ID_MODEL(0x80862883, "Braswell HDMI", MODEL_BYT),
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_intelhdmi);
|
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_intelhdmi);
|
||||||
|
|
||||||
@ -755,6 +805,7 @@ MODULE_IMPORT_NS("SND_HDA_CODEC_HDMI");
|
|||||||
|
|
||||||
static struct hda_codec_driver intelhdmi_driver = {
|
static struct hda_codec_driver intelhdmi_driver = {
|
||||||
.id = snd_hda_id_intelhdmi,
|
.id = snd_hda_id_intelhdmi,
|
||||||
|
.ops = &intelhdmi_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(intelhdmi_driver);
|
module_hda_codec_driver(intelhdmi_driver);
|
||||||
|
@ -12,6 +12,8 @@
|
|||||||
#include "hda_local.h"
|
#include "hda_local.h"
|
||||||
#include "hdmi_local.h"
|
#include "hdmi_local.h"
|
||||||
|
|
||||||
|
enum { MODEL_2CH, MODEL_8CH };
|
||||||
|
|
||||||
#define Nv_VERB_SET_Channel_Allocation 0xF79
|
#define Nv_VERB_SET_Channel_Allocation 0xF79
|
||||||
#define Nv_VERB_SET_Info_Frame_Checksum 0xF7A
|
#define Nv_VERB_SET_Info_Frame_Checksum 0xF7A
|
||||||
#define Nv_VERB_SET_Audio_Protection_On 0xF98
|
#define Nv_VERB_SET_Audio_Protection_On 0xF98
|
||||||
@ -45,15 +47,14 @@ static const struct hda_verb nvhdmi_basic_init_7x_8ch[] = {
|
|||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
|
|
||||||
static int nvhdmi_7x_init_2ch(struct hda_codec *codec)
|
static int nvhdmi_mcp_init(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
snd_hda_sequence_write(codec, nvhdmi_basic_init_7x_2ch);
|
struct hdmi_spec *spec = codec->spec;
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int nvhdmi_7x_init_8ch(struct hda_codec *codec)
|
if (spec->multiout.max_channels == 2)
|
||||||
{
|
snd_hda_sequence_write(codec, nvhdmi_basic_init_7x_2ch);
|
||||||
snd_hda_sequence_write(codec, nvhdmi_basic_init_7x_8ch);
|
else
|
||||||
|
snd_hda_sequence_write(codec, nvhdmi_basic_init_7x_8ch);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -233,31 +234,13 @@ static const struct hda_pcm_stream nvhdmi_pcm_playback_8ch_7x = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static int patch_nvhdmi_2ch(struct hda_codec *codec)
|
static int nvhdmi_mcp_build_pcms(struct hda_codec *codec)
|
||||||
{
|
|
||||||
struct hdmi_spec *spec;
|
|
||||||
int err = patch_simple_hdmi(codec, nvhdmi_master_con_nid_7x,
|
|
||||||
nvhdmi_master_pin_nid_7x);
|
|
||||||
if (err < 0)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
codec->patch_ops.init = nvhdmi_7x_init_2ch;
|
|
||||||
/* override the PCM rates, etc, as the codec doesn't give full list */
|
|
||||||
spec = codec->spec;
|
|
||||||
spec->pcm_playback.rates = SUPPORTED_RATES;
|
|
||||||
spec->pcm_playback.maxbps = SUPPORTED_MAXBPS;
|
|
||||||
spec->pcm_playback.formats = SUPPORTED_FORMATS;
|
|
||||||
spec->nv_dp_workaround = true;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int nvhdmi_7x_8ch_build_pcms(struct hda_codec *codec)
|
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = snd_hda_hdmi_simple_build_pcms(codec);
|
err = snd_hda_hdmi_simple_build_pcms(codec);
|
||||||
if (!err) {
|
if (!err && spec->multiout.max_channels == 8) {
|
||||||
struct hda_pcm *info = get_pcm_rec(spec, 0);
|
struct hda_pcm *info = get_pcm_rec(spec, 0);
|
||||||
|
|
||||||
info->own_chmap = true;
|
info->own_chmap = true;
|
||||||
@ -265,7 +248,7 @@ static int nvhdmi_7x_8ch_build_pcms(struct hda_codec *codec)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nvhdmi_7x_8ch_build_controls(struct hda_codec *codec)
|
static int nvhdmi_mcp_build_controls(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
struct hda_pcm *info;
|
struct hda_pcm *info;
|
||||||
@ -276,6 +259,9 @@ static int nvhdmi_7x_8ch_build_controls(struct hda_codec *codec)
|
|||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
|
if (spec->multiout.max_channels != 8)
|
||||||
|
return 0;
|
||||||
|
|
||||||
/* add channel maps */
|
/* add channel maps */
|
||||||
info = get_pcm_rec(spec, 0);
|
info = get_pcm_rec(spec, 0);
|
||||||
err = snd_pcm_add_chmap_ctls(info->pcm,
|
err = snd_pcm_add_chmap_ctls(info->pcm,
|
||||||
@ -316,20 +302,29 @@ static const struct snd_pcm_hw_constraint_list hw_constraints_2_8_channels = {
|
|||||||
.mask = 0,
|
.mask = 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int patch_nvhdmi_8ch_7x(struct hda_codec *codec)
|
static int nvhdmi_mcp_probe(struct hda_codec *codec,
|
||||||
|
const struct hda_device_id *id)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = patch_nvhdmi_2ch(codec);
|
err = snd_hda_hdmi_simple_probe(codec, nvhdmi_master_con_nid_7x,
|
||||||
|
nvhdmi_master_pin_nid_7x);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
|
/* override the PCM rates, etc, as the codec doesn't give full list */
|
||||||
spec = codec->spec;
|
spec = codec->spec;
|
||||||
|
spec->pcm_playback.rates = SUPPORTED_RATES;
|
||||||
|
spec->pcm_playback.maxbps = SUPPORTED_MAXBPS;
|
||||||
|
spec->pcm_playback.formats = SUPPORTED_FORMATS;
|
||||||
|
spec->nv_dp_workaround = true;
|
||||||
|
|
||||||
|
if (id->driver_data == MODEL_2CH)
|
||||||
|
return 0;
|
||||||
|
|
||||||
spec->multiout.max_channels = 8;
|
spec->multiout.max_channels = 8;
|
||||||
spec->pcm_playback = nvhdmi_pcm_playback_8ch_7x;
|
spec->pcm_playback = nvhdmi_pcm_playback_8ch_7x;
|
||||||
codec->patch_ops.init = nvhdmi_7x_init_8ch;
|
|
||||||
codec->patch_ops.build_pcms = nvhdmi_7x_8ch_build_pcms;
|
|
||||||
codec->patch_ops.build_controls = nvhdmi_7x_8ch_build_controls;
|
|
||||||
|
|
||||||
switch (codec->preset->vendor_id) {
|
switch (codec->preset->vendor_id) {
|
||||||
case 0x10de0002:
|
case 0x10de0002:
|
||||||
@ -353,21 +348,27 @@ static int patch_nvhdmi_8ch_7x(struct hda_codec *codec)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static const struct hda_codec_ops nvhdmi_mcp_codec_ops = {
|
||||||
* patch entries
|
.probe = nvhdmi_mcp_probe,
|
||||||
*/
|
.remove = snd_hda_hdmi_simple_remove,
|
||||||
|
.build_controls = nvhdmi_mcp_build_pcms,
|
||||||
|
.build_pcms = nvhdmi_mcp_build_controls,
|
||||||
|
.init = nvhdmi_mcp_init,
|
||||||
|
.unsol_event = snd_hda_hdmi_simple_unsol_event,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct hda_device_id snd_hda_id_nvhdmi_mcp[] = {
|
static const struct hda_device_id snd_hda_id_nvhdmi_mcp[] = {
|
||||||
HDA_CODEC_ENTRY(0x10de0001, "MCP73 HDMI", patch_nvhdmi_2ch),
|
HDA_CODEC_ID_MODEL(0x10de0001, "MCP73 HDMI", MODEL_2CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0002, "MCP77/78 HDMI", patch_nvhdmi_8ch_7x),
|
HDA_CODEC_ID_MODEL(0x10de0002, "MCP77/78 HDMI", MODEL_8CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0003, "MCP77/78 HDMI", patch_nvhdmi_8ch_7x),
|
HDA_CODEC_ID_MODEL(0x10de0003, "MCP77/78 HDMI", MODEL_8CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0004, "GPU 04 HDMI", patch_nvhdmi_8ch_7x),
|
HDA_CODEC_ID_MODEL(0x10de0004, "GPU 04 HDMI", MODEL_8CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0005, "MCP77/78 HDMI", patch_nvhdmi_8ch_7x),
|
HDA_CODEC_ID_MODEL(0x10de0005, "MCP77/78 HDMI", MODEL_8CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0006, "MCP77/78 HDMI", patch_nvhdmi_8ch_7x),
|
HDA_CODEC_ID_MODEL(0x10de0006, "MCP77/78 HDMI", MODEL_8CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0007, "MCP79/7A HDMI", patch_nvhdmi_8ch_7x),
|
HDA_CODEC_ID_MODEL(0x10de0007, "MCP79/7A HDMI", MODEL_8CH),
|
||||||
HDA_CODEC_ENTRY(0x10de0067, "MCP67 HDMI", patch_nvhdmi_2ch),
|
HDA_CODEC_ID_MODEL(0x10de0067, "MCP67 HDMI", MODEL_2CH),
|
||||||
HDA_CODEC_ENTRY(0x10de8001, "MCP73 HDMI", patch_nvhdmi_2ch),
|
HDA_CODEC_ID_MODEL(0x10de8001, "MCP73 HDMI", MODEL_2CH),
|
||||||
HDA_CODEC_ENTRY(0x10de8067, "MCP67/68 HDMI", patch_nvhdmi_2ch),
|
HDA_CODEC_ID_MODEL(0x10de8067, "MCP67/68 HDMI", MODEL_2CH),
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_nvhdmi_mcp);
|
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_nvhdmi_mcp);
|
||||||
|
|
||||||
@ -377,6 +378,7 @@ MODULE_IMPORT_NS("SND_HDA_CODEC_HDMI");
|
|||||||
|
|
||||||
static struct hda_codec_driver nvhdmi_mcp_driver = {
|
static struct hda_codec_driver nvhdmi_mcp_driver = {
|
||||||
.id = snd_hda_id_nvhdmi_mcp,
|
.id = snd_hda_id_nvhdmi_mcp,
|
||||||
|
.ops = &nvhdmi_mcp_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(nvhdmi_mcp_driver);
|
module_hda_codec_driver(nvhdmi_mcp_driver);
|
||||||
|
@ -13,6 +13,11 @@
|
|||||||
#include "hda_local.h"
|
#include "hda_local.h"
|
||||||
#include "hdmi_local.h"
|
#include "hdmi_local.h"
|
||||||
|
|
||||||
|
enum {
|
||||||
|
MODEL_GENERIC,
|
||||||
|
MODEL_LEGACY,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* NVIDIA codecs ignore ASP mapping for 2ch - confirmed on:
|
* NVIDIA codecs ignore ASP mapping for 2ch - confirmed on:
|
||||||
* - 0x10de0015
|
* - 0x10de0015
|
||||||
@ -61,7 +66,7 @@ static const struct drm_audio_component_audio_ops nvhdmi_audio_ops = {
|
|||||||
.master_unbind = snd_hda_hdmi_acomp_master_unbind,
|
.master_unbind = snd_hda_hdmi_acomp_master_unbind,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int patch_nvhdmi(struct hda_codec *codec)
|
static int probe_generic(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
int err;
|
||||||
@ -95,12 +100,12 @@ static int patch_nvhdmi(struct hda_codec *codec)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_nvhdmi_legacy(struct hda_codec *codec)
|
static int probe_legacy(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = patch_generic_hdmi(codec);
|
err = snd_hda_hdmi_generic_probe(codec);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
@ -117,93 +122,92 @@ static int patch_nvhdmi_legacy(struct hda_codec *codec)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static int nvhdmi_probe(struct hda_codec *codec, const struct hda_device_id *id)
|
||||||
* patch entries
|
{
|
||||||
*/
|
if (id->driver_data == MODEL_LEGACY)
|
||||||
|
return probe_legacy(codec);
|
||||||
|
else
|
||||||
|
return probe_generic(codec);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct hda_codec_ops nvhdmi_codec_ops = {
|
||||||
|
.probe = nvhdmi_probe,
|
||||||
|
.remove = snd_hda_hdmi_generic_remove,
|
||||||
|
.init = snd_hda_hdmi_generic_init,
|
||||||
|
.build_pcms = snd_hda_hdmi_generic_build_pcms,
|
||||||
|
.build_controls = snd_hda_hdmi_generic_build_controls,
|
||||||
|
.unsol_event = snd_hda_hdmi_generic_unsol_event,
|
||||||
|
.suspend = snd_hda_hdmi_generic_suspend,
|
||||||
|
.resume = snd_hda_hdmi_generic_resume,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct hda_device_id snd_hda_id_nvhdmi[] = {
|
static const struct hda_device_id snd_hda_id_nvhdmi[] = {
|
||||||
HDA_CODEC_ENTRY(0x10de0008, "GPU 08 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0008, "GPU 08 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0009, "GPU 09 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0009, "GPU 09 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de000a, "GPU 0a HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de000a, "GPU 0a HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de000b, "GPU 0b HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de000b, "GPU 0b HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de000c, "MCP89 HDMI", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de000c, "MCP89 HDMI", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de000d, "GPU 0d HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de000d, "GPU 0d HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0010, "GPU 10 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0010, "GPU 10 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0011, "GPU 11 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0011, "GPU 11 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0012, "GPU 12 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0012, "GPU 12 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0013, "GPU 13 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0013, "GPU 13 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0014, "GPU 14 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0014, "GPU 14 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0015, "GPU 15 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0015, "GPU 15 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0016, "GPU 16 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0016, "GPU 16 HDMI/DP", MODEL_LEGACY),
|
||||||
/* 17 is known to be absent */
|
/* 17 is known to be absent */
|
||||||
HDA_CODEC_ENTRY(0x10de0018, "GPU 18 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0018, "GPU 18 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0019, "GPU 19 HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de0019, "GPU 19 HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de001a, "GPU 1a HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de001a, "GPU 1a HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de001b, "GPU 1b HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de001b, "GPU 1b HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de001c, "GPU 1c HDMI/DP", patch_nvhdmi_legacy),
|
HDA_CODEC_ID_MODEL(0x10de001c, "GPU 1c HDMI/DP", MODEL_LEGACY),
|
||||||
HDA_CODEC_ENTRY(0x10de0040, "GPU 40 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0040, "GPU 40 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0041, "GPU 41 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0041, "GPU 41 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0042, "GPU 42 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0042, "GPU 42 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0043, "GPU 43 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0043, "GPU 43 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0044, "GPU 44 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0044, "GPU 44 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0045, "GPU 45 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0045, "GPU 45 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0050, "GPU 50 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0050, "GPU 50 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0051, "GPU 51 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0051, "GPU 51 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0052, "GPU 52 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0052, "GPU 52 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0060, "GPU 60 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0060, "GPU 60 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0061, "GPU 61 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0061, "GPU 61 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0062, "GPU 62 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0062, "GPU 62 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0070, "GPU 70 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0070, "GPU 70 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0071, "GPU 71 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0071, "GPU 71 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0072, "GPU 72 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0072, "GPU 72 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0073, "GPU 73 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0073, "GPU 73 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0074, "GPU 74 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0074, "GPU 74 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0076, "GPU 76 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0076, "GPU 76 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de007b, "GPU 7b HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de007b, "GPU 7b HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de007c, "GPU 7c HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de007c, "GPU 7c HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de007d, "GPU 7d HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de007d, "GPU 7d HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de007e, "GPU 7e HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de007e, "GPU 7e HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0080, "GPU 80 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0080, "GPU 80 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0081, "GPU 81 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0081, "GPU 81 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0082, "GPU 82 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0082, "GPU 82 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0083, "GPU 83 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0083, "GPU 83 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0084, "GPU 84 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0084, "GPU 84 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0090, "GPU 90 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0090, "GPU 90 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0091, "GPU 91 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0091, "GPU 91 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0092, "GPU 92 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0092, "GPU 92 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0093, "GPU 93 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0093, "GPU 93 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0094, "GPU 94 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0094, "GPU 94 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0095, "GPU 95 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0095, "GPU 95 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0097, "GPU 97 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0097, "GPU 97 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0098, "GPU 98 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0098, "GPU 98 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de0099, "GPU 99 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de0099, "GPU 99 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de009a, "GPU 9a HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de009a, "GPU 9a HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de009b, "GPU 9b HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de009d, "GPU 9d HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de009c, "GPU 9c HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de009e, "GPU 9e HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de009d, "GPU 9d HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de009f, "GPU 9f HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de009e, "GPU 9e HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de00a0, "GPU a0 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de009f, "GPU 9f HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de00a3, "GPU a3 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de00a0, "GPU a0 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de00a4, "GPU a4 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de00a1, "GPU a1 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de00a5, "GPU a5 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de00a3, "GPU a3 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de00a6, "GPU a6 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de00a4, "GPU a4 HDMI/DP", patch_nvhdmi),
|
HDA_CODEC_ID_MODEL(0x10de00a7, "GPU a7 HDMI/DP", MODEL_GENERIC),
|
||||||
HDA_CODEC_ENTRY(0x10de00a5, "GPU a5 HDMI/DP", patch_nvhdmi),
|
{} /* terminator */
|
||||||
HDA_CODEC_ENTRY(0x10de00a6, "GPU a6 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00a7, "GPU a7 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00a8, "GPU a8 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00a9, "GPU a9 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00aa, "GPU aa HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00ab, "GPU ab HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00ad, "GPU ad HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00ae, "GPU ae HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00af, "GPU af HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00b0, "GPU b0 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00b1, "GPU b1 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00c0, "GPU c0 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00c1, "GPU c1 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00c3, "GPU c3 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00c4, "GPU c4 HDMI/DP", patch_nvhdmi),
|
|
||||||
HDA_CODEC_ENTRY(0x10de00c5, "GPU c5 HDMI/DP", patch_nvhdmi),
|
|
||||||
{} /* terminator */
|
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_nvhdmi);
|
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_nvhdmi);
|
||||||
|
|
||||||
@ -213,6 +217,7 @@ MODULE_IMPORT_NS("SND_HDA_CODEC_HDMI");
|
|||||||
|
|
||||||
static struct hda_codec_driver nvhdmi_driver = {
|
static struct hda_codec_driver nvhdmi_driver = {
|
||||||
.id = snd_hda_id_nvhdmi,
|
.id = snd_hda_id_nvhdmi,
|
||||||
|
.ops = &nvhdmi_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(nvhdmi_driver);
|
module_hda_codec_driver(nvhdmi_driver);
|
||||||
|
@ -107,7 +107,7 @@ int snd_hda_hdmi_simple_init(struct hda_codec *codec)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_simple_init, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_simple_init, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
void snd_hda_hdmi_simple_free(struct hda_codec *codec)
|
void snd_hda_hdmi_simple_remove(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec = codec->spec;
|
struct hdmi_spec *spec = codec->spec;
|
||||||
|
|
||||||
@ -115,7 +115,7 @@ void snd_hda_hdmi_simple_free(struct hda_codec *codec)
|
|||||||
snd_array_free(&spec->cvts);
|
snd_array_free(&spec->cvts);
|
||||||
kfree(spec);
|
kfree(spec);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_simple_free, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_simple_remove, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
int snd_hda_hdmi_simple_pcm_open(struct hda_pcm_stream *hinfo,
|
int snd_hda_hdmi_simple_pcm_open(struct hda_pcm_stream *hinfo,
|
||||||
struct hda_codec *codec,
|
struct hda_codec *codec,
|
||||||
@ -168,16 +168,8 @@ static const struct hda_pcm_stream simple_pcm_playback = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct hda_codec_ops simple_hdmi_patch_ops = {
|
int snd_hda_hdmi_simple_probe(struct hda_codec *codec,
|
||||||
.build_controls = snd_hda_hdmi_simple_build_controls,
|
hda_nid_t cvt_nid, hda_nid_t pin_nid)
|
||||||
.build_pcms = snd_hda_hdmi_simple_build_pcms,
|
|
||||||
.init = snd_hda_hdmi_simple_init,
|
|
||||||
.free = snd_hda_hdmi_simple_free,
|
|
||||||
.unsol_event = snd_hda_hdmi_simple_unsol_event,
|
|
||||||
};
|
|
||||||
|
|
||||||
int patch_simple_hdmi(struct hda_codec *codec,
|
|
||||||
hda_nid_t cvt_nid, hda_nid_t pin_nid)
|
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
struct hdmi_spec_per_cvt *per_cvt;
|
struct hdmi_spec_per_cvt *per_cvt;
|
||||||
@ -200,35 +192,52 @@ int patch_simple_hdmi(struct hda_codec *codec,
|
|||||||
per_pin = snd_array_new(&spec->pins);
|
per_pin = snd_array_new(&spec->pins);
|
||||||
per_cvt = snd_array_new(&spec->cvts);
|
per_cvt = snd_array_new(&spec->cvts);
|
||||||
if (!per_pin || !per_cvt) {
|
if (!per_pin || !per_cvt) {
|
||||||
snd_hda_hdmi_simple_free(codec);
|
snd_hda_hdmi_simple_remove(codec);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
per_cvt->cvt_nid = cvt_nid;
|
per_cvt->cvt_nid = cvt_nid;
|
||||||
per_pin->pin_nid = pin_nid;
|
per_pin->pin_nid = pin_nid;
|
||||||
spec->pcm_playback = simple_pcm_playback;
|
spec->pcm_playback = simple_pcm_playback;
|
||||||
|
|
||||||
codec->patch_ops = simple_hdmi_patch_ops;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_NS_GPL(patch_simple_hdmi, "SND_HDA_CODEC_HDMI");
|
EXPORT_SYMBOL_NS_GPL(snd_hda_hdmi_simple_probe, "SND_HDA_CODEC_HDMI");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* driver entries
|
||||||
|
*/
|
||||||
|
|
||||||
|
enum { MODEL_VIA };
|
||||||
|
|
||||||
/* VIA HDMI Implementation */
|
/* VIA HDMI Implementation */
|
||||||
#define VIAHDMI_CVT_NID 0x02 /* audio converter1 */
|
#define VIAHDMI_CVT_NID 0x02 /* audio converter1 */
|
||||||
#define VIAHDMI_PIN_NID 0x03 /* HDMI output pin1 */
|
#define VIAHDMI_PIN_NID 0x03 /* HDMI output pin1 */
|
||||||
|
|
||||||
static int patch_via_hdmi(struct hda_codec *codec)
|
static int simplehdmi_probe(struct hda_codec *codec,
|
||||||
|
const struct hda_device_id *id)
|
||||||
{
|
{
|
||||||
return patch_simple_hdmi(codec, VIAHDMI_CVT_NID, VIAHDMI_PIN_NID);
|
switch (id->driver_data) {
|
||||||
|
case MODEL_VIA:
|
||||||
|
return snd_hda_hdmi_simple_probe(codec, VIAHDMI_CVT_NID,
|
||||||
|
VIAHDMI_PIN_NID);
|
||||||
|
default:
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static const struct hda_codec_ops simplehdmi_codec_ops = {
|
||||||
* patch entries
|
.probe = simplehdmi_probe,
|
||||||
*/
|
.remove = snd_hda_hdmi_simple_remove,
|
||||||
|
.build_controls = snd_hda_hdmi_simple_build_controls,
|
||||||
|
.build_pcms = snd_hda_hdmi_simple_build_pcms,
|
||||||
|
.init = snd_hda_hdmi_simple_init,
|
||||||
|
.unsol_event = snd_hda_hdmi_simple_unsol_event,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct hda_device_id snd_hda_id_simplehdmi[] = {
|
static const struct hda_device_id snd_hda_id_simplehdmi[] = {
|
||||||
HDA_CODEC_ENTRY(0x11069f80, "VX900 HDMI/DP", patch_via_hdmi),
|
HDA_CODEC_ID_MODEL(0x11069f80, "VX900 HDMI/DP", MODEL_VIA),
|
||||||
HDA_CODEC_ENTRY(0x11069f81, "VX900 HDMI/DP", patch_via_hdmi),
|
HDA_CODEC_ID_MODEL(0x11069f81, "VX900 HDMI/DP", MODEL_VIA),
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
|
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
@ -236,6 +245,7 @@ MODULE_DESCRIPTION("Simple HDMI HD-audio codec support");
|
|||||||
|
|
||||||
static struct hda_codec_driver simplehdmi_driver = {
|
static struct hda_codec_driver simplehdmi_driver = {
|
||||||
.id = snd_hda_id_simplehdmi,
|
.id = snd_hda_id_simplehdmi,
|
||||||
|
.ops = &simplehdmi_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(simplehdmi_driver);
|
module_hda_codec_driver(simplehdmi_driver);
|
||||||
|
@ -13,6 +13,11 @@
|
|||||||
#include "hda_local.h"
|
#include "hda_local.h"
|
||||||
#include "hdmi_local.h"
|
#include "hdmi_local.h"
|
||||||
|
|
||||||
|
enum {
|
||||||
|
MODEL_TEGRA,
|
||||||
|
MODEL_TEGRA234,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The HDA codec on NVIDIA Tegra contains two scratch registers that are
|
* The HDA codec on NVIDIA Tegra contains two scratch registers that are
|
||||||
* accessed using vendor-defined verbs. These registers can be used for
|
* accessed using vendor-defined verbs. These registers can be used for
|
||||||
@ -241,7 +246,6 @@ static int tegra_hdmi_init(struct hda_codec *codec)
|
|||||||
snd_hda_hdmi_generic_init_per_pins(codec);
|
snd_hda_hdmi_generic_init_per_pins(codec);
|
||||||
|
|
||||||
codec->depop_delay = 10;
|
codec->depop_delay = 10;
|
||||||
codec->patch_ops.build_pcms = tegra_hdmi_build_pcms;
|
|
||||||
spec->chmap.ops.chmap_cea_alloc_validate_get_type =
|
spec->chmap.ops.chmap_cea_alloc_validate_get_type =
|
||||||
nvhdmi_chmap_cea_alloc_validate_get_type;
|
nvhdmi_chmap_cea_alloc_validate_get_type;
|
||||||
spec->chmap.ops.chmap_validate = nvhdmi_chmap_validate;
|
spec->chmap.ops.chmap_validate = nvhdmi_chmap_validate;
|
||||||
@ -254,18 +258,8 @@ static int tegra_hdmi_init(struct hda_codec *codec)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int patch_tegra_hdmi(struct hda_codec *codec)
|
static int tegrahdmi_probe(struct hda_codec *codec,
|
||||||
{
|
const struct hda_device_id *id)
|
||||||
int err;
|
|
||||||
|
|
||||||
err = snd_hda_hdmi_generic_alloc(codec);
|
|
||||||
if (err < 0)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return tegra_hdmi_init(codec);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int patch_tegra234_hdmi(struct hda_codec *codec)
|
|
||||||
{
|
{
|
||||||
struct hdmi_spec *spec;
|
struct hdmi_spec *spec;
|
||||||
int err;
|
int err;
|
||||||
@ -274,31 +268,39 @@ static int patch_tegra234_hdmi(struct hda_codec *codec)
|
|||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
codec->dp_mst = true;
|
if (id->driver_data == MODEL_TEGRA234) {
|
||||||
spec = codec->spec;
|
codec->dp_mst = true;
|
||||||
spec->dyn_pin_out = true;
|
spec = codec->spec;
|
||||||
spec->hdmi_intr_trig_ctrl = true;
|
spec->dyn_pin_out = true;
|
||||||
|
spec->hdmi_intr_trig_ctrl = true;
|
||||||
|
}
|
||||||
|
|
||||||
return tegra_hdmi_init(codec);
|
return tegra_hdmi_init(codec);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static const struct hda_codec_ops tegrahdmi_codec_ops = {
|
||||||
* patch entries
|
.probe = tegrahdmi_probe,
|
||||||
*/
|
.remove = snd_hda_hdmi_generic_remove,
|
||||||
|
.init = snd_hda_hdmi_generic_init,
|
||||||
|
.build_pcms = tegra_hdmi_build_pcms,
|
||||||
|
.build_controls = snd_hda_hdmi_generic_build_controls,
|
||||||
|
.unsol_event = snd_hda_hdmi_generic_unsol_event,
|
||||||
|
.suspend = snd_hda_hdmi_generic_suspend,
|
||||||
|
.resume = snd_hda_hdmi_generic_resume,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct hda_device_id snd_hda_id_tegrahdmi[] = {
|
static const struct hda_device_id snd_hda_id_tegrahdmi[] = {
|
||||||
HDA_CODEC_ENTRY(0x10de0020, "Tegra30 HDMI", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0020, "Tegra30 HDMI", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de0022, "Tegra114 HDMI", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0022, "Tegra114 HDMI", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de0028, "Tegra124 HDMI", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0028, "Tegra124 HDMI", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de0029, "Tegra210 HDMI/DP", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0029, "Tegra210 HDMI/DP", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de002d, "Tegra186 HDMI/DP0", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de002d, "Tegra186 HDMI/DP0", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de002e, "Tegra186 HDMI/DP1", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de002e, "Tegra186 HDMI/DP1", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de002f, "Tegra194 HDMI/DP2", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de002f, "Tegra194 HDMI/DP2", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de0030, "Tegra194 HDMI/DP3", patch_tegra_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0030, "Tegra194 HDMI/DP3", MODEL_TEGRA),
|
||||||
HDA_CODEC_ENTRY(0x10de0031, "Tegra234 HDMI/DP", patch_tegra234_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0031, "Tegra234 HDMI/DP", MODEL_TEGRA234),
|
||||||
HDA_CODEC_ENTRY(0x10de0033, "SoC 33 HDMI/DP", patch_tegra234_hdmi),
|
HDA_CODEC_ID_MODEL(0x10de0034, "Tegra264 HDMI/DP", MODEL_TEGRA234),
|
||||||
HDA_CODEC_ENTRY(0x10de0034, "Tegra264 HDMI/DP", patch_tegra234_hdmi),
|
{} /* terminator */
|
||||||
HDA_CODEC_ENTRY(0x10de0035, "SoC 35 HDMI/DP", patch_tegra234_hdmi),
|
|
||||||
{} /* terminator */
|
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_tegrahdmi);
|
MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_tegrahdmi);
|
||||||
|
|
||||||
@ -308,6 +310,7 @@ MODULE_IMPORT_NS("SND_HDA_CODEC_HDMI");
|
|||||||
|
|
||||||
static struct hda_codec_driver tegrahdmi_driver = {
|
static struct hda_codec_driver tegrahdmi_driver = {
|
||||||
.id = snd_hda_id_tegrahdmi,
|
.id = snd_hda_id_tegrahdmi,
|
||||||
|
.ops = &tegrahdmi_codec_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
module_hda_codec_driver(tegrahdmi_driver);
|
module_hda_codec_driver(tegrahdmi_driver);
|
||||||
|
Loading…
Reference in New Issue
Block a user