Commit 49e1caa9 authored by Jaroslav Kysela's avatar Jaroslav Kysela

ALSA CVS update - Takashi Iwai <tiwai@suse.de>

Opti9xx drivers
- fixed the detection of opti92x-ad1848 pnp.
parent 1ee670e4
...@@ -543,11 +543,11 @@ static int __devinit snd_opti9xx_configure(opti9xx_t *chip) ...@@ -543,11 +543,11 @@ static int __devinit snd_opti9xx_configure(opti9xx_t *chip)
__skip_base: __skip_base:
switch (chip->irq) { switch (chip->irq) {
#ifdef OPTi93X //#ifdef OPTi93X
case 5: case 5:
irq_bits = 0x05; irq_bits = 0x05;
break; break;
#endif /* OPTi93X */ //#endif /* OPTi93X */
case 7: case 7:
irq_bits = 0x01; irq_bits = 0x01;
break; break;
...@@ -1735,15 +1735,23 @@ static int __devinit snd_card_opti9xx_pnp(opti9xx_t *chip, struct pnp_card_link ...@@ -1735,15 +1735,23 @@ static int __devinit snd_card_opti9xx_pnp(opti9xx_t *chip, struct pnp_card_link
#if defined(CS4231) || defined(OPTi93X) #if defined(CS4231) || defined(OPTi93X)
if (dma2 != SNDRV_AUTO_DMA) if (dma2 != SNDRV_AUTO_DMA)
pnp_resource_change(&cfg->dma_resource[1], dma2, 1); pnp_resource_change(&cfg->dma_resource[1], dma2, 1);
#else
#ifdef snd_opti9xx_fixup_dma2
snd_opti9xx_fixup_dma2(pdev);
#endif
#endif /* CS4231 || OPTi93X */ #endif /* CS4231 || OPTi93X */
if (fm_port != SNDRV_AUTO_PORT) #ifdef OPTi93X
if (fm_port > 0 && fm_port != SNDRV_AUTO_PORT)
pnp_resource_change(&cfg->port_resource[1], fm_port, 4); pnp_resource_change(&cfg->port_resource[1], fm_port, 4);
#else
if (fm_port > 0 && fm_port != SNDRV_AUTO_PORT)
pnp_resource_change(&cfg->port_resource[2], fm_port, 4);
#endif
if (pnp_manual_config_dev(pdev, cfg, 0) < 0) if (pnp_manual_config_dev(pdev, cfg, 0) < 0)
snd_printk(KERN_ERR "AUDIO the requested resources are invalid, using auto config\n"); snd_printk(KERN_ERR "AUDIO the requested resources are invalid, using auto config\n");
err = pnp_activate_dev(pdev); err = pnp_activate_dev(pdev);
if (err < 0) { if (err < 0) {
snd_printk(KERN_ERR "AUDIO pnp configure failure\n"); snd_printk(KERN_ERR "AUDIO pnp configure failure: %d\n", err);
kfree(cfg); kfree(cfg);
return err; return err;
} }
...@@ -1763,7 +1771,7 @@ static int __devinit snd_card_opti9xx_pnp(opti9xx_t *chip, struct pnp_card_link ...@@ -1763,7 +1771,7 @@ static int __devinit snd_card_opti9xx_pnp(opti9xx_t *chip, struct pnp_card_link
#endif /* CS4231 || OPTi93X */ #endif /* CS4231 || OPTi93X */
pdev = chip->devmpu; pdev = chip->devmpu;
if (pdev) { if (pdev && mpu_port > 0) {
pnp_init_resource_table(cfg); pnp_init_resource_table(cfg);
if (mpu_port != SNDRV_AUTO_PORT) if (mpu_port != SNDRV_AUTO_PORT)
...@@ -1986,9 +1994,6 @@ static int __devinit snd_card_opti9xx_probe(struct pnp_card_link *pcard, ...@@ -1986,9 +1994,6 @@ static int __devinit snd_card_opti9xx_probe(struct pnp_card_link *pcard,
chip->dma2 = dma2; chip->dma2 = dma2;
#endif #endif
#ifdef CONFIG_PNP
if (!isapnp) {
#endif
if (chip->wss_base == SNDRV_AUTO_PORT) { if (chip->wss_base == SNDRV_AUTO_PORT) {
if ((chip->wss_base = snd_legacy_find_free_ioport(possible_ports, 4)) < 0) { if ((chip->wss_base = snd_legacy_find_free_ioport(possible_ports, 4)) < 0) {
snd_card_free(card); snd_card_free(card);
...@@ -1996,6 +2001,9 @@ static int __devinit snd_card_opti9xx_probe(struct pnp_card_link *pcard, ...@@ -1996,6 +2001,9 @@ static int __devinit snd_card_opti9xx_probe(struct pnp_card_link *pcard,
return -EBUSY; return -EBUSY;
} }
} }
#ifdef CONFIG_PNP
if (!isapnp) {
#endif
if (chip->mpu_port == SNDRV_AUTO_PORT) { if (chip->mpu_port == SNDRV_AUTO_PORT) {
if ((chip->mpu_port = snd_legacy_find_free_ioport(possible_mpu_ports, 2)) < 0) { if ((chip->mpu_port = snd_legacy_find_free_ioport(possible_mpu_ports, 2)) < 0) {
snd_card_free(card); snd_card_free(card);
......
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