Re: acer-wmi: rfkill and bluetooth enabling doesn't work as in 2.6.37

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Johaness,

On Wednesday 23 March 2011 12:58:08 Johannes Berg wrote:
> On Mon, 2011-03-21 at 20:27 +0100, OldÅich JedliÄka wrote:
> > hci0 doesn't exist when the BT switch is off. The hci0 device and rfkill
> > switch appears when you unblock SW rfkill or by pressing the HW switch.
> > It disappears when you block the switch again. hci0 is set to "blocked"
> > when it appears, because the acer-wmi driver have registered
> > acpi-bluetooth rfkill switch during boot, which was set to "blocked"
> > initially with a call to rfkill_init_sw_state. So what happens actually
> > is this:
> > 
> > 1) at boot, BIOS says the bluetooth is disabled, so the not-registered
> > state of acer-bluetooth rfkill is set to "blocked"
> > (rfkill_init_sw_state, sets the "persistent" bit). The acer-bluetooth is
> > then registered, which forces the global bluetooth state to go
> > "blocked". No hci0 exists at this time.
> > 
> > 2) when you press the button, hci0 appears and the rfkill is set to the
> > global bluetooth state (in rfkill_sync_work), which is "blocked".
> > 
> > From my understanding acer-wmi reports the change via acer_rfkill_update
> > work (executed every second). It just calls rfkill_set_sw_state, but
> > that doesn't update the global state. I don't know at which time that
> > happens, but generally I didn't find anything that could eventually
> > enable hci0 state or global state to "unblocked".
> 
> Ah. So I guess when hci0 gets registered, the acer rfkill state hasn't
> been updated yet, hence registering hci0 as blocked.

No, that is not the case. I can play with `rfkill list` immediately after I 
press the HW bluetooth switch and show that hci0 is not there (still 
unregistered) while acer-bluetooth is already "unblocked" - I've tried to run 
`rfkill list` repeatedly manually from console immediately after I pressed the 
HW BT switch and acer-bluetooth was "unblocked" several runs while the hci0 
wasn't there. When hci0 appeared, it was "blocked".

As I wrote, I didn't find anything changing the global state, which is actually 
used to "block" the newly appearing hci0 (in the rfkill_sync_work method). It 
looks like the global state is just "blocked" forever - and it is "blocked" as 
a side-effect of the call to rfkill_init_sw_state (changes permanent=true) and 
then call to rfkill_register from the acer-wmi driver. I can verify this in 
the following days (that the global state stays the same all the time).

Cheers,
OldÅich.

> 
> johannes
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux