[alsa-devel] [PATCH] Mixer quirk for QuickCam E 3500

Alexey Fisher bug-track at fisher-privat.net
Wed Jul 22 12:37:10 CEST 2009


Takashi Iwai schrieb:
> At Wed, 22 Jul 2009 07:15:41 +0200,
> Alexey Fisher wrote:
>> Takashi Iwai schrieb:
>>> At Tue, 21 Jul 2009 23:57:46 +0200,
>>> Alexey Fisher wrote:
>>>> Takashi Iwai schrieb:
>>>>> At Tue, 21 Jul 2009 23:10:42 +0200,
>>>>> Alexey Fisher wrote:
>>>>>> 1. E3500 report cval->max more than it actually can handel, so if you
>>>>>> set 95% capture level it will be muted.
>>>>>> 2. betwen cval->min and cval-max(real) is 2940 control units,
>>>>>> but real are only 7.
>>>>>> 3. we found only 7 real control units, with cval->res = 384,
>>>>>> but alsa can't handel less than 10 controls, so make it more
>>>>>> and set cval->res = 192.
>>>>>>
>>>>>> Signed-off-by: Alexey Fisher <bug-track at fisher-privat.net>
>>>>> Thanks for the patch.  The added code looks almost good.
>>>>> But, it's better to put your code into another place, e.g. a bit
>>>>> later so that you don't insert it between the comment and the other
>>>>> code.  Also, if you use switch(), you need break.
>>>>>
>>>>> In your case, simply put a new if () block with a proper comment
>>>>> after that switch() block.  It's not necessarily merged into a single
>>>>> switch.  The compiler should be clever enough.
>>>>>
>>>>> Also, try to keep the patch checkpatch.pl-clean.  Run it once before
>>>>> submitting your patch.
>>>>>
>>>>> Could you fix these and repost?
>>>>>
>>>>>
>>>>> thanks,
>>>>>
>>>>> Takashi
>>>>>
>>>>>> ---
>>>>>>  sound/usb/usbmixer.c |    7 +++++++
>>>>>>  1 files changed, 7 insertions(+), 0 deletions(-)
>>>>>>
>>>>>> diff --git a/sound/usb/usbmixer.c b/sound/usb/usbmixer.c
>>>>>> index 4bd3a7a..72562ee 100644
>>>>>> --- a/sound/usb/usbmixer.c
>>>>>> +++ b/sound/usb/usbmixer.c
>>>>>> @@ -995,6 +995,13 @@ static void build_feature_ctl(struct mixer_build *state, unsigned char *desc,
>>>>>>  	/* is not very clear from datasheets */
>>>>>>  	/* I hope that the min value is -15360 for newer firmware --jk */
>>>>>>  	switch (state->chip->usb_id) {
>>>>>> +	case USB_ID(0x046d, 0x09a4):
>>>>>> +		if (!strcmp(kctl->id.name, "Mic Capture Volume")) {
>>>>>> +			snd_printk(KERN_INFO "using volume control quirk for the QuickCam E3500\n");
>>>>>> +			cval->min = 6080;
>>>>>> +			cval->max = 8768;
>>>>>> +			cval->res = 192;
>>>>>> +		}
>>>>>>  	case USB_ID(0x0471, 0x0101):
>>>>>>  	case USB_ID(0x0471, 0x0104):
>>>>>>  	case USB_ID(0x0471, 0x0105):
>>>> There is some thing wrong with this. After suspend and resume this quirk 
>>>> not working. Even replug the cam not help, only reloading of 
>>>> snd_usb_sound will do it work again.
>>> But isn't it irrelevant with your patch?
>>>
>>>
>>> Takashi
>> it should be irrelevant, but some times it doesn't use this quirk. Seems 
>> like it depend on my usb.. so if quirk is not used there passably (if 
>> capture level set to more then 90%) will be no sound on this cam.
>>
>> here is example. On this port it's working fine:
>> ===========================================================================
>> [ 1197.141867] ALSA sound/usb/usbaudio.c:2802: 17:3:1: add audio 
>> endpoint 0x86
>> [ 1198.144187] ALSA sound/usb/usbaudio.c:1295: 17:3:1: cannot get freq 
>> at ep 0x86
>> [ 1198.144344] ALSA sound/usb/usbmixer.c:1017: [5] FU [Mic Capture 
>> Switch] ch = 1, val = 0/1/1
>> [ 1198.917814] ALSA sound/usb/usbmixer.c:1000: using volume control 
>> quirk for the QuickCam E3500
>> [ 1198.917818] ALSA sound/usb/usbmixer.c:1017: [5] FU [Mic Capture 
>> Volume] ch = 1, val = 6080/8768/192
>> [ 1198.972148] ALSA sound/usb/usbaudio.c:1349: setting usb interface 3:1
>> [ 1198.999384] ALSA sound/usb/usbaudio.c:1349: setting usb interface 3:1
>> ==================================================================================
>>
>> and quirk is applied:
>> =================================================================
>> amixer -D hw:1
>> Simple mixer control 'Mic',0
>>    Capabilities: cvolume cvolume-joined cswitch cswitch-joined
>>    Capture channels: Mono
>>    Limits: Capture 0 - 14
>>    Mono: Capture 14 [100%] [34.25dB] [on]
>> ======================================================================
>>
>>
>>
>> On this port it's looks different:
>> ==================================================================
>> [  434.298740] ALSA sound/usb/usbaudio.c:2802: 16:3:1: add audio 
>> endpoint 0x86
>> [  435.296189] ALSA sound/usb/usbaudio.c:1288: 16:3:1: cannot set freq 
>> 16000 to ep 0x86
>> [  435.296346] ALSA sound/usb/usbmixer.c:1017: [5] FU [Mic Capture 
>> Switch] ch = 1, val = 0/1/1
>> [  436.055930] ALSA sound/usb/usbmixer.c:374: cannot get ctl value: req 
>> = 0x83, wValue = 0x200, wIndex = 0x502, type = 4
>> [  436.055936] ALSA sound/usb/usbmixer.c:730: 5:2: cannot get min/max 
>> values for control 2 (id 5)
>> [  436.055954] ALSA sound/usb/usbmixer.c:1000: using volume control 
>> quirk for the QuickCam E3500
>> [  436.055957] ALSA sound/usb/usbmixer.c:1017: [5] FU [Mic Capture 
>> Volume] ch = 1, val = 6080/8768/192
>> [  436.107018] ALSA sound/usb/usbaudio.c:1349: setting usb interface 3:1
>> [  436.133640] ALSA sound/usb/usbaudio.c:1349: setting usb interface 3:1
>> ========================================================================
>>
>> and quirk is not working:
>> =========================================================
>> amixer -D hw:1
>> Simple mixer control 'Mic',0
>>    Capabilities: cvolume cvolume-joined cswitch cswitch-joined
>>    Capture channels: Mono
>>    Limits: Capture 0 - 3072
>>    Mono: Capture 3072 [100%] [23.00dB] [on]
>> ============================================================
>>
>> this can't  be reproduce with every plug in.. but some port have better 
>> possibility to get error. On this kind of port  the setting can be 
>> changed after resume.
> 
> Hm, then it means that chip->usb_id has a different number.
> Could you check with printk?

 From the second dmesg you can see, the quirk was applyed. But for some 
reason overwrite after it did get_min_max. i did some debuging with 
printk but was not able to reproduce this issue. So will leave this 
until i have some more time.



More information about the Alsa-devel mailing list