diff options
author | Jean-Francois Moine <moinejf@free.fr> | 2008-11-22 12:26:26 +0100 |
---|---|---|
committer | Jean-Francois Moine <moinejf@free.fr> | 2008-11-22 12:26:26 +0100 |
commit | 53de899b707730eb70b95b5a90cd1519a795c88a (patch) | |
tree | 4827686ddc97fdfeb492d7e54afd0131319033e2 | |
parent | 0649e35124be51fb4e39b6c4f4235aa299422174 (diff) | |
download | mediapointer-dvb-s2-53de899b707730eb70b95b5a90cd1519a795c88a.tar.gz mediapointer-dvb-s2-53de899b707730eb70b95b5a90cd1519a795c88a.tar.bz2 |
gspca: Fix an access to freed memory at disconnect time.
From: leandro Costantino <lcostantino@gmail.com>
On disconnection (USB or rmmod subdriver), the device is freed
by video_unregister_device(). Setting the 'present' and 'streaming'
flags must be done before the call to this function.
Priority: high
Signed-off-by: leandro Costantino <lcostantino@gmail.com>
Signed-off-by: Jean-Francois Moine <moinejf@free.fr>
-rw-r--r-- | linux/drivers/media/video/gspca/gspca.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/linux/drivers/media/video/gspca/gspca.c b/linux/drivers/media/video/gspca/gspca.c index 404461b8a..d725663fc 100644 --- a/linux/drivers/media/video/gspca/gspca.c +++ b/linux/drivers/media/video/gspca/gspca.c @@ -1916,14 +1916,15 @@ void gspca_disconnect(struct usb_interface *intf) { struct gspca_dev *gspca_dev = usb_get_intfdata(intf); + gspca_dev->present = 0; + gspca_dev->streaming = 0; + usb_set_intfdata(intf, NULL); -/* We don't want people trying to open up the device */ + /* release the device */ + /* (this will call gspca_release() immediatly or on last close) */ video_unregister_device(&gspca_dev->vdev); - gspca_dev->present = 0; - gspca_dev->streaming = 0; - PDEBUG(D_PROBE, "disconnect complete"); } EXPORT_SYMBOL(gspca_disconnect); |