Search Linux Wireless

Re: [PATCH] rtl8187: Fix kernel oops when device is removed when LEDS enabled (Bugzilla #14539)

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

 



Em Qua 04 Nov 2009, às 14:49:38, John W. Linville escreveu:
> On Wed, Nov 04, 2009 at 04:30:19PM +0100, Christian Lamparter wrote:
> > On Wednesday 04 November 2009 16:11:33 John W. Linville wrote:
> 
> > > This seems like a band-aid.  If anything, the original order would
> > > seem to make more sense.
> > 
> > really?
> > 
> > take this code from led-class.c
> > 
> > void led_classdev_unregister(struct led_classdev *led_cdev)
> > {
> >         device_remove_file(led_cdev->dev, &dev_attr_max_brightness);
> >         device_remove_file(led_cdev->dev, &dev_attr_brightness);
> > #ifdef CONFIG_LEDS_TRIGGERS
> >         device_remove_file(led_cdev->dev, &dev_attr_trigger);
> >         down_write(&led_cdev->trigger_lock);
> >         if (led_cdev->trigger)
> >                 led_trigger_set(led_cdev, NULL);
> >         up_write(&led_cdev->trigger_lock);
> > #endif
> > 
> >         device_unregister(led_cdev->dev);
> > 
> >         down_write(&leds_list_lock);
> >         list_del(&led_cdev->node);
> >         up_write(&leds_list_lock);
> > }
> > 
> > as you can see the led is switched-off right before the device is unregistered.
> > but rtl8187, p54 & ar9170 led-triggers are timed & asynchronous. So
> > we really need a cancel_delayed_work_sync after the unregister routine
> > finished... else the timed trigger might fire when the device/module
> > is _faded_ from memory.
> 
> OK, I got it...the unregister can queue-up more work.  Thanks for
> the explanation.

Hi, I checked here and the code above in led_classdev_unregister is the same in
2.6.31, so I think the patch from Larry should also be applied/sent to 2.6.31.x
stable, as the bug could happen there too.

> 
> John
> 

-- 
[]'s
Herton
--
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

[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux