Johannes Berg wrote: > This patch completely rewrites the rfkill core to address > the following deficiencies: > > * all rfkill drivers need to implement polling where necessary > rather than having one central implementation > > * updating the rfkill state cannot be done from arbitrary > contexts, forcing drivers to use schedule_work and requiring > lots of code > > * rfkill drivers need to keep track of soft/hard blocked > internally -- the core should do this > > * the rfkill API has many unexpected quirks, for example being > asymmetric wrt. alloc/free and register/unregister > > * rfkill can call back into a driver from within a function the > driver called -- this is prone to deadlocks and generally > should be avoided > > * rfkill-input pointlessly is a separate module > > * drivers need to #ifdef rfkill functions (unless they want to > depend on or select RFKILL) -- rfkill should provide inlines > that do nothing if it isn't compiled in > > * the rfkill structure is not opaque -- drivers need to initialise > it correctly (lots of sanity checking code required) -- instead > force drivers to pass the right variables to rfkill_alloc() > > * the documentation is hard to read because it always assumes the > reader is completely clueless and contains way TOO MANY CAPS > > * the rfkill code needlessly uses a lot of locks and atomic > operations in locked sections > > Signed-off-by: Johannes Berg <johannes@xxxxxxxxxxxxxxxx> > --- > TODO > * convert toshiba, thinkpad > * compile-test tosa conversion > * figure out tosa-default LED trigger thing > * apply default state to devices after being registered > * test > > Requires the other rfkill patches -- which you can also get at > http://johannes.sipsolutions.net/patches/kernel/all/LATEST/ Initial testing shows at least two problems with b43legacy (and probably b43 as well): (1) On bootup with my radio switch OFF, the driver ignored that switch and associated with my AP. Only when the switch was turned on and off again did the driver log the expected "switch off" message". (2) The radio LED is on no matter the state of the switch. Larry -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html