ALSA: oxygen: add Kuroutoshikou CMI8787-HG2PCI support
authorClemens Ladisch <clemens@ladisch.de>
Tue, 2 Nov 2010 16:18:23 +0000 (17:18 +0100)
committerTakashi Iwai <tiwai@suse.de>
Wed, 3 Nov 2010 07:26:13 +0000 (08:26 +0100)
Add support for the Kuroutoshikou CMI8787-HG2PCI sound card.

[replaced non-latin letters in the patch by tiwai]

Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Documentation/sound/alsa/ALSA-Configuration.txt
sound/pci/Kconfig
sound/pci/oxygen/oxygen.c
sound/pci/oxygen/oxygen_lib.c

index f1a1787e71e5d8d9dbe436a6e19f79a77387d3c3..fdd388ded62a40f6ebaf0bd0b30f0b74f627b42f 100644 (file)
@@ -1531,6 +1531,7 @@ Prior to version 0.9.0rc4 options had a 'snd_' prefix. This was removed.
     * Club3D Theatron DTS
     * HT-Omega Claro (plus)
     * HT-Omega Claro halo (XT)
+    * Kuroutoshikou CMI8787-HG2PCI
     * Razer Barracuda AC-1
     * Sondigo Inferno
     * TempoTec HiFier Fantasia
index dfe406de99351277af9583ac2c98e79844ee94dd..f7139d09cbbeda30743447d6fb82968236729968 100644 (file)
@@ -222,6 +222,7 @@ config SND_OXYGEN
           * Club3D Theatron DTS
           * HT-Omega Claro (plus)
           * HT-Omega Claro halo (XT)
+          * Kuroutoshikou CMI8787-HG2PCI
           * Razer Barracuda AC-1
           * Sondigo Inferno
           * TempoTec/MediaTek HiFier Fantasia
index 5e258b26f044f084d3e51110d2d7478033cf8fe5..dd0f3f4789991d485ff6ebbe58d957082382a2ba 100644 (file)
@@ -71,6 +71,7 @@ enum {
        MODEL_CLARO,            /* HT-Omega Claro */
        MODEL_CLARO_HALO,       /* HT-Omega Claro halo */
        MODEL_HIFIER,           /* TempoTec HiFier Fantasia */
+       MODEL_HG2PCI,           /* Kuroutoshikou CMI8787-HG2PCI */
 };
 
 static DEFINE_PCI_DEVICE_TABLE(oxygen_ids) = {
@@ -80,7 +81,7 @@ static DEFINE_PCI_DEVICE_TABLE(oxygen_ids) = {
        { OXYGEN_PCI_SUBID(0x13f6, 0x0001), .driver_data = MODEL_CMEDIA_REF },
        { OXYGEN_PCI_SUBID(0x13f6, 0x0010), .driver_data = MODEL_CMEDIA_REF },
        { OXYGEN_PCI_SUBID(0x13f6, 0x8788), .driver_data = MODEL_CMEDIA_REF },
-       { OXYGEN_PCI_SUBID(0x13f6, 0xffff), .driver_data = MODEL_CMEDIA_REF },
+       { OXYGEN_PCI_SUBID(0x13f6, 0xffff), .driver_data = MODEL_HG2PCI },
        { OXYGEN_PCI_SUBID(0x147a, 0xa017), .driver_data = MODEL_CMEDIA_REF },
        { OXYGEN_PCI_SUBID(0x14c3, 0x1710), .driver_data = MODEL_HIFIER },
        { OXYGEN_PCI_SUBID(0x14c3, 0x1711), .driver_data = MODEL_HIFIER },
@@ -243,6 +244,11 @@ static void hifier_init(struct oxygen *chip)
        snd_component_add(chip->card, "CS5340");
 }
 
+static void hg2pci_init(struct oxygen *chip)
+{
+       ak4396_init(chip);
+}
+
 static void generic_cleanup(struct oxygen *chip)
 {
 }
@@ -572,15 +578,20 @@ static int __devinit get_oxygen_model(struct oxygen *chip,
                                            CAPTURE_1_FROM_SPDIF;
                break;
        case MODEL_HIFIER:
+       case MODEL_HG2PCI:
                chip->model.shortname = "C-Media CMI8787";
                chip->model.chip = "CMI8787";
-               chip->model.init = hifier_init;
+               if (id->driver_data == MODEL_HIFIER)
+                       chip->model.init = hifier_init;
+               else
+                       chip->model.init = hg2pci_init;
                chip->model.resume = stereo_resume;
                chip->model.mixer_init = generic_mixer_init;
                chip->model.set_adc_params = set_no_params;
                chip->model.device_config = PLAYBACK_0_TO_I2S |
-                                           PLAYBACK_1_TO_SPDIF |
-                                           CAPTURE_0_FROM_I2S_1;
+                                           PLAYBACK_1_TO_SPDIF;
+               if (id->driver_data == MODEL_HIFIER)
+                       chip->model.device_config |= CAPTURE_0_FROM_I2S_1;
                chip->model.dac_channels = 2;
                break;
        }
index e5ebe56fb0c5c5129206f5fa4be6fcfc99e8888c..2e65799622173731264a68eadcd73f81e5d15857 100644 (file)
@@ -262,7 +262,7 @@ oxygen_search_pci_id(struct oxygen *chip, const struct pci_device_id ids[])
         */
        subdevice = oxygen_read_eeprom(chip, 2);
        /* use default ID if EEPROM is missing */
-       if (subdevice == 0xffff)
+       if (subdevice == 0xffff && oxygen_read_eeprom(chip, 1) == 0xffff)
                subdevice = 0x8788;
        /*
         * We use only the subsystem device ID for searching because it is