|
@@ -93,7 +93,13 @@ enum {
|
|
|
|
|
|
enum {
|
|
enum {
|
|
STAC_925x_REF,
|
|
STAC_925x_REF,
|
|
|
|
+ STAC_M1,
|
|
|
|
+ STAC_M1_2,
|
|
|
|
+ STAC_M2,
|
|
STAC_M2_2,
|
|
STAC_M2_2,
|
|
|
|
+ STAC_M3,
|
|
|
|
+ STAC_M5,
|
|
|
|
+ STAC_M6,
|
|
STAC_MA6,
|
|
STAC_MA6,
|
|
STAC_PA6,
|
|
STAC_PA6,
|
|
STAC_925x_MODELS
|
|
STAC_925x_MODELS
|
|
@@ -1600,11 +1606,40 @@ static unsigned int ref925x_pin_configs[8] = {
|
|
0x90a70320, 0x02214210, 0x01019020, 0x9033032e,
|
|
0x90a70320, 0x02214210, 0x01019020, 0x9033032e,
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static unsigned int stac925xM1_pin_configs[8] = {
|
|
|
|
+ 0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
|
|
|
|
+ 0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
|
|
|
|
+};
|
|
|
|
+static unsigned int stac925xM1_2_pin_configs[8] = {
|
|
|
|
+ 0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
|
|
|
|
+ 0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
|
|
|
|
+};
|
|
|
|
+static unsigned int stac925xM2_pin_configs[8] = {
|
|
|
|
+ 0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
|
|
|
|
+ 0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static unsigned int stac925xM3_pin_configs[8] = {
|
|
|
|
+ 0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
|
|
|
|
+ 0x40a000f0, 0x90100210, 0x400003f1, 0x503303f3,
|
|
|
|
+};
|
|
|
|
+static unsigned int stac925xM5_pin_configs[8] = {
|
|
|
|
+ 0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
|
|
|
|
+ 0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/* Original M6 entry at .ini file */
|
|
|
|
+static unsigned int stac925xM6_pin_configs[8] = {
|
|
|
|
+ 0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
|
|
|
|
+ 0x40a000f0, 0x90100210, 0x400003f1, 0x90330320,
|
|
|
|
+};
|
|
|
|
+
|
|
static unsigned int stac925x_MA6_pin_configs[8] = {
|
|
static unsigned int stac925x_MA6_pin_configs[8] = {
|
|
0x40c003f0, 0x424503f2, 0x01813022, 0x02a19021,
|
|
0x40c003f0, 0x424503f2, 0x01813022, 0x02a19021,
|
|
0x90a70320, 0x90100211, 0x400003f1, 0x9033032e,
|
|
0x90a70320, 0x90100211, 0x400003f1, 0x9033032e,
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+/* This entry should be M2 */
|
|
static unsigned int stac925x_PA6_pin_configs[8] = {
|
|
static unsigned int stac925x_PA6_pin_configs[8] = {
|
|
0x40c003f0, 0x424503f2, 0x01813022, 0x02a19021,
|
|
0x40c003f0, 0x424503f2, 0x01813022, 0x02a19021,
|
|
0x50a103f0, 0x90100211, 0x400003f1, 0x9033032e,
|
|
0x50a103f0, 0x90100211, 0x400003f1, 0x9033032e,
|
|
@@ -1617,27 +1652,55 @@ static unsigned int stac925xM2_2_pin_configs[8] = {
|
|
|
|
|
|
static unsigned int *stac925x_brd_tbl[STAC_925x_MODELS] = {
|
|
static unsigned int *stac925x_brd_tbl[STAC_925x_MODELS] = {
|
|
[STAC_REF] = ref925x_pin_configs,
|
|
[STAC_REF] = ref925x_pin_configs,
|
|
|
|
+ [STAC_M1] = stac925xM1_pin_configs,
|
|
|
|
+ [STAC_M1_2] = stac925xM1_2_pin_configs,
|
|
|
|
+ [STAC_M2] = stac925xM2_pin_configs,
|
|
[STAC_M2_2] = stac925xM2_2_pin_configs,
|
|
[STAC_M2_2] = stac925xM2_2_pin_configs,
|
|
|
|
+ [STAC_M3] = stac925xM3_pin_configs,
|
|
|
|
+ [STAC_M5] = stac925xM5_pin_configs,
|
|
|
|
+ [STAC_M6] = stac925xM6_pin_configs,
|
|
[STAC_MA6] = stac925x_MA6_pin_configs,
|
|
[STAC_MA6] = stac925x_MA6_pin_configs,
|
|
[STAC_PA6] = stac925x_PA6_pin_configs,
|
|
[STAC_PA6] = stac925x_PA6_pin_configs,
|
|
};
|
|
};
|
|
|
|
|
|
static const char *stac925x_models[STAC_925x_MODELS] = {
|
|
static const char *stac925x_models[STAC_925x_MODELS] = {
|
|
[STAC_REF] = "ref",
|
|
[STAC_REF] = "ref",
|
|
|
|
+ [STAC_M1] = "m1",
|
|
|
|
+ [STAC_M1_2] = "m1-2",
|
|
|
|
+ [STAC_M2] = "m2",
|
|
[STAC_M2_2] = "m2-2",
|
|
[STAC_M2_2] = "m2-2",
|
|
- [STAC_MA6] = "m6",
|
|
|
|
|
|
+ [STAC_M3] = "m3",
|
|
|
|
+ [STAC_M5] = "m5",
|
|
|
|
+ [STAC_M6] = "m6",
|
|
|
|
+ [STAC_MA6] = "ma6",
|
|
[STAC_PA6] = "pa6",
|
|
[STAC_PA6] = "pa6",
|
|
};
|
|
};
|
|
|
|
|
|
-static struct snd_pci_quirk stac925x_cfg_tbl[] = {
|
|
|
|
- /* SigmaTel reference board */
|
|
|
|
- SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, "DFI LanParty", STAC_REF),
|
|
|
|
- SND_PCI_QUIRK(0x8384, 0x7632, "Stac9202 Reference Board", STAC_REF),
|
|
|
|
|
|
+static struct snd_pci_quirk stac925x_codec_id_cfg_tbl[] = {
|
|
SND_PCI_QUIRK(0x107b, 0x0316, "Gateway M255", STAC_REF),
|
|
SND_PCI_QUIRK(0x107b, 0x0316, "Gateway M255", STAC_REF),
|
|
SND_PCI_QUIRK(0x107b, 0x0366, "Gateway MP6954", STAC_REF),
|
|
SND_PCI_QUIRK(0x107b, 0x0366, "Gateway MP6954", STAC_REF),
|
|
|
|
+
|
|
SND_PCI_QUIRK(0x107b, 0x0461, "Gateway NX560XL", STAC_MA6),
|
|
SND_PCI_QUIRK(0x107b, 0x0461, "Gateway NX560XL", STAC_MA6),
|
|
SND_PCI_QUIRK(0x107b, 0x0681, "Gateway NX860", STAC_PA6),
|
|
SND_PCI_QUIRK(0x107b, 0x0681, "Gateway NX860", STAC_PA6),
|
|
- SND_PCI_QUIRK(0x1002, 0x437b, "Gateway MX6453", STAC_M2_2),
|
|
|
|
|
|
+ SND_PCI_QUIRK(0x107b, 0x0367, "Gateway MX6453", STAC_M1_2),
|
|
|
|
+
|
|
|
|
+ /* Not sure about the brand name for those */
|
|
|
|
+ SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M1),
|
|
|
|
+ SND_PCI_QUIRK(0x107b, 0x0507, "Gateway mobile", STAC_M3),
|
|
|
|
+ SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M6),
|
|
|
|
+ SND_PCI_QUIRK(0x107b, 0x0685, "Gateway mobile", STAC_M2_2),
|
|
|
|
+
|
|
|
|
+ {} /* terminator */
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct snd_pci_quirk stac925x_cfg_tbl[] = {
|
|
|
|
+ /* SigmaTel reference board */
|
|
|
|
+ SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, "DFI LanParty", STAC_REF),
|
|
|
|
+ SND_PCI_QUIRK(0x8384, 0x7632, "Stac9202 Reference Board", STAC_REF),
|
|
|
|
+
|
|
|
|
+ /* Default table for unknown ID */
|
|
|
|
+ SND_PCI_QUIRK(0x1002, 0x437b, "Gateway mobile", STAC_M2_2),
|
|
|
|
+
|
|
{} /* terminator */
|
|
{} /* terminator */
|
|
};
|
|
};
|
|
|
|
|
|
@@ -4371,12 +4434,22 @@ static int patch_stac925x(struct hda_codec *codec)
|
|
codec->spec = spec;
|
|
codec->spec = spec;
|
|
spec->num_pins = ARRAY_SIZE(stac925x_pin_nids);
|
|
spec->num_pins = ARRAY_SIZE(stac925x_pin_nids);
|
|
spec->pin_nids = stac925x_pin_nids;
|
|
spec->pin_nids = stac925x_pin_nids;
|
|
- spec->board_config = snd_hda_check_board_config(codec, STAC_925x_MODELS,
|
|
|
|
|
|
+
|
|
|
|
+ /* Check first for codec ID */
|
|
|
|
+ spec->board_config = snd_hda_check_board_codec_sid_config(codec,
|
|
|
|
+ STAC_925x_MODELS,
|
|
|
|
+ stac925x_models,
|
|
|
|
+ stac925x_codec_id_cfg_tbl);
|
|
|
|
+
|
|
|
|
+ /* Now checks for PCI ID, if codec ID is not found */
|
|
|
|
+ if (spec->board_config < 0)
|
|
|
|
+ spec->board_config = snd_hda_check_board_config(codec,
|
|
|
|
+ STAC_925x_MODELS,
|
|
stac925x_models,
|
|
stac925x_models,
|
|
stac925x_cfg_tbl);
|
|
stac925x_cfg_tbl);
|
|
again:
|
|
again:
|
|
if (spec->board_config < 0) {
|
|
if (spec->board_config < 0) {
|
|
- snd_printdd(KERN_INFO "hda_codec: Unknown model for STAC925x,"
|
|
|
|
|
|
+ snd_printdd(KERN_INFO "hda_codec: Unknown model for STAC925x,"
|
|
"using BIOS defaults\n");
|
|
"using BIOS defaults\n");
|
|
err = stac92xx_save_bios_config_regs(codec);
|
|
err = stac92xx_save_bios_config_regs(codec);
|
|
} else
|
|
} else
|