[alsa-devel] [PATCH] snd-opti9xx: fixes for MED3931 card (opti931)

Takashi Iwai tiwai at suse.de
Mon Jun 18 09:44:35 CEST 2012


At Fri, 15 Jun 2012 20:55:54 +0200,
Ondrej Zary wrote:
> 
> MED3931 card did not work (failed with "OPTI chip not found") because
> snd-opti9xx gets mc_indir_index from pnp by adding 2 to the pnp-reported port.
> It probably works for some cards but not for this one. Datasheet says that
> the port is always at 0xe?e so just force the lowest nibble to be 0xe.
> 
> Also this card powers up with (ugly) 3D sound enabled. As there's no mixer
> control for this, just disable it.
> 
> Signed-off-by: Ondrej Zary <linux at rainbow-software.org>

Applied.  Thanks.


Takashi


> 
> --- a/sound/isa/opti9xx/opti92x-ad1848.c
> +++ b/sound/isa/opti9xx/opti92x-ad1848.c
> @@ -135,7 +135,6 @@ struct snd_opti9xx {
>  	unsigned long mc_base_size;
>  #ifdef OPTi93X
>  	unsigned long mc_indir_index;
> -	unsigned long mc_indir_size;
>  	struct resource *res_mc_indir;
>  	struct snd_wss *codec;
>  #endif	/* OPTi93X */
> @@ -245,10 +244,8 @@ static int __devinit snd_opti9xx_init(struct snd_opti9xx *chip,
>  	case OPTi9XX_HW_82C931:
>  	case OPTi9XX_HW_82C933:
>  		chip->mc_base = (hardware == OPTi9XX_HW_82C930) ? 0xf8f : 0xf8d;
> -		if (!chip->mc_indir_index) {
> +		if (!chip->mc_indir_index)
>  			chip->mc_indir_index = 0xe0e;
> -			chip->mc_indir_size = 2;
> -		}
>  		chip->password = 0xe4;
>  		chip->pwd_reg = 0;
>  		break;
> @@ -403,7 +400,9 @@ static int __devinit snd_opti9xx_configure(struct snd_opti9xx *chip,
>  
>  #else	/* OPTi93X */
>  	case OPTi9XX_HW_82C931:
> -	case OPTi9XX_HW_82C933:
> +		/* disable 3D sound (set GPIO1 as output, low) */
> +		snd_opti9xx_write_mask(chip, OPTi9XX_MC_REG(20), 0x04, 0x0c);
> +	case OPTi9XX_HW_82C933: /* FALL THROUGH */
>  		/*
>  		 * The BTC 1817DW has QS1000 wavetable which is connected
>  		 * to the serial digital input of the OPTI931.
> @@ -696,8 +695,7 @@ static int __devinit snd_opti9xx_read_check(struct snd_opti9xx *chip)
>  		if (value == snd_opti9xx_read(chip, OPTi9XX_MC_REG(1)))
>  			return 0;
>  #else	/* OPTi93X */
> -	chip->res_mc_indir = request_region(chip->mc_indir_index,
> -					    chip->mc_indir_size,
> +	chip->res_mc_indir = request_region(chip->mc_indir_index, 2,
>  					    "OPTi93x MC");
>  	if (chip->res_mc_indir == NULL)
>  		return -EBUSY;
> @@ -770,8 +768,9 @@ static int __devinit snd_card_opti9xx_pnp(struct snd_opti9xx *chip,
>  #ifdef OPTi93X
>  	port = pnp_port_start(pdev, 0) - 4;
>  	fm_port = pnp_port_start(pdev, 1) + 8;
> -	chip->mc_indir_index = pnp_port_start(pdev, 3) + 2;
> -	chip->mc_indir_size = pnp_port_len(pdev, 3) - 2;
> +	/* adjust mc_indir_index - some cards report it at 0xe?d,
> +	   other at 0xe?c but it really is always at 0xe?e */
> +	chip->mc_indir_index = (pnp_port_start(pdev, 3) & ~0xf) | 0xe;
>  #else
>  	devmc = pnp_request_card_device(card, pid->devs[2].id, NULL);
>  	if (devmc == NULL)
> 
> -- 
> Ondrej Zary
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
> 


More information about the Alsa-devel mailing list