upstream: [media] em28xx-cards: properly initialize the device bitmap
authorMauro Carvalho Chehab <m.chehab@samsung.com>
Tue, 14 Jan 2014 20:35:15 +0000 (17:35 -0300)
committerChanho Park <chanho61.park@samsung.com>
Thu, 7 Aug 2014 05:26:44 +0000 (14:26 +0900)
Instead of just creating a long int, use DECLARE_BITMAP().

No functional changes.

Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
drivers/media/usb/em28xx/em28xx-cards.c

index 57c3895..32f087d 100644 (file)
@@ -66,7 +66,7 @@ MODULE_PARM_DESC(usb_xfer_mode,
 
 
 /* Bitmask marking allocated devices from 0 to EM28XX_MAXBOARDS - 1 */
-static unsigned long em28xx_devused;
+DECLARE_BITMAP(em28xx_devused, EM28XX_MAXBOARDS);
 
 struct em28xx_hash_table {
        unsigned long hash;
@@ -2905,7 +2905,7 @@ void em28xx_release_resources(struct em28xx *dev)
        usb_put_dev(dev->udev);
 
        /* Mark device as unused */
-       clear_bit(dev->devno, &em28xx_devused);
+       clear_bit(dev->devno, em28xx_devused);
 
        mutex_unlock(&dev->lock);
 };
@@ -3114,7 +3114,7 @@ static int em28xx_usb_probe(struct usb_interface *interface,
 
        /* Check to see next free device and mark as used */
        do {
-               nr = find_first_zero_bit(&em28xx_devused, EM28XX_MAXBOARDS);
+               nr = find_first_zero_bit(em28xx_devused, EM28XX_MAXBOARDS);
                if (nr >= EM28XX_MAXBOARDS) {
                        /* No free device slots */
                        printk(DRIVER_NAME ": Supports only %i em28xx boards.\n",
@@ -3122,7 +3122,7 @@ static int em28xx_usb_probe(struct usb_interface *interface,
                        retval = -ENOMEM;
                        goto err_no_slot;
                }
-       } while (test_and_set_bit(nr, &em28xx_devused));
+       } while (test_and_set_bit(nr, em28xx_devused));
 
        /* Don't register audio interfaces */
        if (interface->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) {
@@ -3375,7 +3375,7 @@ err_free:
        kfree(dev);
 
 err:
-       clear_bit(nr, &em28xx_devused);
+       clear_bit(nr, em28xx_devused);
 
 err_no_slot:
        usb_put_dev(udev);