diff options
Diffstat (limited to 'sound/pci/hda/hda_codec.c')
-rw-r--r-- | sound/pci/hda/hda_codec.c | 57 |
1 files changed, 35 insertions, 22 deletions
diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c index 18bbc87e376f..c07d5db6b050 100644 --- a/sound/pci/hda/hda_codec.c +++ b/sound/pci/hda/hda_codec.c | |||
@@ -1714,6 +1714,8 @@ EXPORT_SYMBOL(snd_hda_build_pcms); | |||
1714 | /** | 1714 | /** |
1715 | * snd_hda_check_board_config - compare the current codec with the config table | 1715 | * snd_hda_check_board_config - compare the current codec with the config table |
1716 | * @codec: the HDA codec | 1716 | * @codec: the HDA codec |
1717 | * @num_configs: number of config enums | ||
1718 | * @models: array of model name strings | ||
1717 | * @tbl: configuration table, terminated by null entries | 1719 | * @tbl: configuration table, terminated by null entries |
1718 | * | 1720 | * |
1719 | * Compares the modelname or PCI subsystem id of the current codec with the | 1721 | * Compares the modelname or PCI subsystem id of the current codec with the |
@@ -1722,33 +1724,44 @@ EXPORT_SYMBOL(snd_hda_build_pcms); | |||
1722 | * | 1724 | * |
1723 | * If no entries are matching, the function returns a negative value. | 1725 | * If no entries are matching, the function returns a negative value. |
1724 | */ | 1726 | */ |
1725 | int snd_hda_check_board_config(struct hda_codec *codec, const struct hda_board_config *tbl) | 1727 | int snd_hda_check_board_config(struct hda_codec *codec, |
1726 | { | 1728 | int num_configs, const char **models, |
1727 | const struct hda_board_config *c; | 1729 | const struct snd_pci_quirk *tbl) |
1728 | 1730 | { | |
1729 | if (codec->bus->modelname) { | 1731 | if (codec->bus->modelname && models) { |
1730 | for (c = tbl; c->modelname || c->pci_subvendor; c++) { | 1732 | int i; |
1731 | if (c->modelname && | 1733 | for (i = 0; i < num_configs; i++) { |
1732 | ! strcmp(codec->bus->modelname, c->modelname)) { | 1734 | if (models[i] && |
1733 | snd_printd(KERN_INFO "hda_codec: model '%s' is selected\n", c->modelname); | 1735 | !strcmp(codec->bus->modelname, models[i])) { |
1734 | return c->config; | 1736 | snd_printd(KERN_INFO "hda_codec: model '%s' is " |
1737 | "selected\n", models[i]); | ||
1738 | return i; | ||
1735 | } | 1739 | } |
1736 | } | 1740 | } |
1737 | } | 1741 | } |
1738 | 1742 | ||
1739 | if (codec->bus->pci) { | 1743 | if (!codec->bus->pci || !tbl) |
1740 | u16 subsystem_vendor, subsystem_device; | 1744 | return -1; |
1741 | pci_read_config_word(codec->bus->pci, PCI_SUBSYSTEM_VENDOR_ID, &subsystem_vendor); | 1745 | |
1742 | pci_read_config_word(codec->bus->pci, PCI_SUBSYSTEM_ID, &subsystem_device); | 1746 | tbl = snd_pci_quirk_lookup(codec->bus->pci, tbl); |
1743 | for (c = tbl; c->modelname || c->pci_subvendor; c++) { | 1747 | if (!tbl) |
1744 | if (c->pci_subvendor == subsystem_vendor && | 1748 | return -1; |
1745 | (! c->pci_subdevice /* all match */|| | 1749 | if (tbl->value >= 0 && tbl->value < num_configs) { |
1746 | (c->pci_subdevice == subsystem_device))) { | 1750 | #ifdef CONFIG_SND_DEBUG_DETECT |
1747 | snd_printdd(KERN_INFO "hda_codec: PCI %x:%x, codec config %d is selected\n", | 1751 | char tmp[10]; |
1748 | subsystem_vendor, subsystem_device, c->config); | 1752 | const char *model = NULL; |
1749 | return c->config; | 1753 | if (models) |
1750 | } | 1754 | model = models[tbl->value]; |
1755 | if (!model) { | ||
1756 | sprintf(tmp, "#%d", tbl->value); | ||
1757 | model = tmp; | ||
1751 | } | 1758 | } |
1759 | snd_printdd(KERN_INFO "hda_codec: model '%s' is selected " | ||
1760 | "for config %x:%x (%s)\n", | ||
1761 | model, tbl->subvendor, tbl->subdevice, | ||
1762 | (tbl->name ? tbl->name : "Unknown device")); | ||
1763 | #endif | ||
1764 | return tbl->value; | ||
1752 | } | 1765 | } |
1753 | return -1; | 1766 | return -1; |
1754 | } | 1767 | } |