[media] Media, DVB, Siano, smsusb: Avoid static analysis report about 'use after...
authorJesper Juhl <jj@chaosbits.net>
Thu, 21 Apr 2011 21:11:25 +0000 (18:11 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Fri, 20 May 2011 12:28:57 +0000 (09:28 -0300)
In drivers/media/dvb/siano/smsusb.c we have this code:
 ...
               kfree(dev);

               sms_info("device %p destroyed", dev);
 ...

at least one static analysis tool (Coverity Prevent) complains about this
as a use-after-free bug.
While it's true that we do use the pointer variable after freeing it, the
only use is to print the value of the pointer, so there's not actually any
problem here. But still, silencing the complaint is trivial by just moving
the kfree() call below the sms_info(), so why not just do it?. It doesn't
change the workings of the code in any way, but it makes the tool shut up.
The patch below also removes a rather pointless blank line.

Signed-off-by: Jesper Juhl <jj@chaosbits.net>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/dvb/siano/smsusb.c

index 0b8da57cf4c340fcd0336e5a65ee40f0b47fb8f4..0c8164a2cc36caf271c34848049290068b4ba855 100644 (file)
@@ -297,9 +297,8 @@ static void smsusb_term_device(struct usb_interface *intf)
                if (dev->coredev)
                        smscore_unregister_device(dev->coredev);
 
-               kfree(dev);
-
                sms_info("device %p destroyed", dev);
+               kfree(dev);
        }
 
        usb_set_intfdata(intf, NULL);