Re: Headset driver detection problem during bootup

From: anish singh
Date: Tue Aug 23 2011 - 11:01:55 EST


On Tue, Aug 23, 2011 at 10:52 PM, Takashi Iwai <tiwai@xxxxxxx> wrote:
> At Sat, 20 Aug 2011 22:21:10 +0900,
> anish singh wrote:
>>
>> adding more information and experts on alsa.
>>
>> On Fri, Aug 19, 2011 at 9:23 PM, anish singh
>> <anish198519851985@xxxxxxxxx> wrote:
>> > I need some suggestions for below situation:
>> >
>> > Headset if it is inserted before the device is powered up is
>> > now detected by forcefully calling the interrupt handler in
>> > the probe function of the headset driver.
>> Headset is detected in our andorid device by using a detect gpio
>> Âwhich is turned on when headset is inserted.If the headset
>> Âis inserted right from very beginging i.e. before device is even
>> Âturned on then we forcefully call the handler and thereby in
>> Âhandler we check if gpio is turned on or not and do the rest
>> of things.
>>
>> > Once the handler is called then we find out if the headset
>> > is there or not using gpio and then normal detection happens
>> >
>> > Is it the right way to detect the device during power-up?
>> Does not linux have any other way of doing this which i may
>> be missing? How this is handled in the case of ALSA jack i.e.
>> the jack drivers which is using alsa framework for detection?
>> Android doesn't use ALSA framework for reporting JACK.
>
> Judging from the source code, the likely problem is that the driver
> doesn't initialize the switch-state in input device. ÂThe switch-state
> is updated only when GPIO IRQ comes up.
Absolutely right.During bootup we check the gpio and if we find out
that the headset is inserted then we update the switch.In Android
updating the switch is nothing but updating some sysfs file and
generating uevent AFAIK.
>
>
> Takashi
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/