[alsa-devel] [PATCH] opti93x: use dB scale for mixer controls

Takashi Iwai tiwai at suse.de
Sat Dec 12 18:07:25 CET 2009


At Sat, 12 Dec 2009 09:51:03 +0100,
Krzysztof Helt wrote:
> 
> From: Krzysztof Helt <krzysztof.h1 at wp.pl>
> 
> Add dB scale for mixer controls. Fix dB scale for
> Master Volume control.
> 
> Signed-off-by: Krzysztof Helt <krzysztof.h1 at wp.pl>
> ---
> The opti93x control patches can wait till next Linux version. I would like to see
> the patch "opti93x: fix irq releasing if the irq cannot be allocated" in this release
> as this is a typical bug fix.

Yes, the irq release fix is in a different branch.  It'll be included
in the next pull request.  The others including this one go to the branch
for the next kernel.


thanks,

Takashi


> 
> Regards,
> Krzysztof
> 
>  sound/isa/opti9xx/opti92x-ad1848.c |   36 ++++++++++++++++++++++--------------
>  1 files changed, 22 insertions(+), 14 deletions(-)
> 
> diff --git a/sound/isa/opti9xx/opti92x-ad1848.c b/sound/isa/opti9xx/opti92x-ad1848.c
> index 3f55b31..a4af53b 100644
> --- a/sound/isa/opti9xx/opti92x-ad1848.c
> +++ b/sound/isa/opti9xx/opti92x-ad1848.c
> @@ -547,32 +547,40 @@ __skip_mpu:
>  
>  #ifdef OPTi93X
>  
> -static const DECLARE_TLV_DB_SCALE(db_scale_6bit, -9450, 150, 0);
> +static const DECLARE_TLV_DB_SCALE(db_scale_5bit_3db_step, -9300, 300, 0);
> +static const DECLARE_TLV_DB_SCALE(db_scale_5bit, -4650, 150, 0);
> +static const DECLARE_TLV_DB_SCALE(db_scale_4bit_12db_max, -3300, 300, 0);
>  
>  static struct snd_kcontrol_new snd_opti93x_controls[] = {
>  WSS_DOUBLE("Master Playback Switch", 0,
>  		OPTi93X_OUT_LEFT, OPTi93X_OUT_RIGHT, 7, 7, 1, 1),
>  WSS_DOUBLE_TLV("Master Playback Volume", 0,
>  		OPTi93X_OUT_LEFT, OPTi93X_OUT_RIGHT, 1, 1, 31, 1,
> -		db_scale_6bit),
> -WSS_DOUBLE("PCM Playback Volume", 0,
> -		CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 0, 0, 31, 1),
> -WSS_DOUBLE("FM Playback Volume", 0,
> -		CS4231_AUX2_LEFT_INPUT, CS4231_AUX2_RIGHT_INPUT, 1, 1, 15, 1),
> +		db_scale_5bit_3db_step),
> +WSS_DOUBLE_TLV("PCM Playback Volume", 0,
> +		CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 0, 0, 31, 1,
> +		db_scale_5bit),
> +WSS_DOUBLE_TLV("FM Playback Volume", 0,
> +		CS4231_AUX2_LEFT_INPUT, CS4231_AUX2_RIGHT_INPUT, 1, 1, 15, 1,
> +		db_scale_4bit_12db_max),
>  WSS_DOUBLE("Line Playback Switch", 0,
>  		CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 7, 7, 1, 1),
> -WSS_DOUBLE("Line Playback Volume", 0,
> -		CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 0, 0, 15, 1),
> +WSS_DOUBLE_TLV("Line Playback Volume", 0,
> +		CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 0, 0, 15, 1,
> +		db_scale_4bit_12db_max),
>  WSS_DOUBLE("Mic Playback Switch", 0,
>  		OPTi93X_MIC_LEFT_INPUT, OPTi93X_MIC_RIGHT_INPUT, 7, 7, 1, 1),
> -WSS_DOUBLE("Mic Playback Volume", 0,
> -		OPTi93X_MIC_LEFT_INPUT, OPTi93X_MIC_RIGHT_INPUT, 1, 1, 15, 1),
> -WSS_DOUBLE("CD Playback Volume", 0,
> -		CS4231_AUX1_LEFT_INPUT, CS4231_AUX1_RIGHT_INPUT, 1, 1, 15, 1),
> +WSS_DOUBLE_TLV("Mic Playback Volume", 0,
> +		OPTi93X_MIC_LEFT_INPUT, OPTi93X_MIC_RIGHT_INPUT, 1, 1, 15, 1,
> +		db_scale_4bit_12db_max),
> +WSS_DOUBLE_TLV("CD Playback Volume", 0,
> +		CS4231_AUX1_LEFT_INPUT, CS4231_AUX1_RIGHT_INPUT, 1, 1, 15, 1,
> +		db_scale_4bit_12db_max),
>  WSS_DOUBLE("Aux Playback Switch", 0,
>  		OPTi931_AUX_LEFT_INPUT, OPTi931_AUX_RIGHT_INPUT, 7, 7, 1, 1),
> -WSS_DOUBLE("Aux Playback Volume", 0,
> -		OPTi931_AUX_LEFT_INPUT, OPTi931_AUX_RIGHT_INPUT, 1, 1, 15, 1),
> +WSS_DOUBLE_TLV("Aux Playback Volume", 0,
> +		OPTi931_AUX_LEFT_INPUT, OPTi931_AUX_RIGHT_INPUT, 1, 1, 15, 1,
> +		db_scale_4bit_12db_max),
>  };
>  
>  static int __devinit snd_opti93x_mixer(struct snd_wss *chip)
> -- 
> 1.6.4
> 
> 
> ----------------------------------------------------------------------
> Zbieraj punkty - wygrywaj nagrody!
> Kliknij >>> http://link.interia.pl/f24a8
> 


More information about the Alsa-devel mailing list