bsg: add a request_queue argument to scsi_cmd_ioctl()
[linux-2.6.git] / block / bsg.c
index c56618a..0427ece 100644 (file)
@@ -128,7 +128,8 @@ static struct bsg_command *__bsg_alloc_command(struct bsg_device *bd)
        bc = kmem_cache_alloc(bsg_cmd_cachep, GFP_USER);
        if (unlikely(!bc)) {
                spin_lock_irq(&bd->lock);
-               goto alloc_fail;
+               bd->queued_cmds--;
+               goto out;
        }
 
        memset(bc, 0, sizeof(*bc));
@@ -136,8 +137,6 @@ static struct bsg_command *__bsg_alloc_command(struct bsg_device *bd)
        INIT_LIST_HEAD(&bc->list);
        dprintk("%s: returning free cmd %p\n", bd->name, bc);
        return bc;
-alloc_fail:
-       bd->queued_cmds--;
 out:
        spin_unlock_irq(&bd->lock);
        return bc;
@@ -901,7 +900,7 @@ bsg_ioctl(struct inode *inode, struct file *file, unsigned int cmd,
        case SG_EMULATED_HOST:
        case SCSI_IOCTL_SEND_COMMAND: {
                void __user *uarg = (void __user *) arg;
-               return scsi_cmd_ioctl(file, bd->disk, cmd, uarg);
+               return scsi_cmd_ioctl(file, bd->queue, bd->disk, cmd, uarg);
        }
        case SG_IO: {
                struct request *rq;
@@ -983,10 +982,19 @@ int bsg_register_disk(struct gendisk *disk)
        bsg_device_nr++;
        bcd->disk = disk;
        bcd->class_dev = class_device_create(bsg_class, NULL, dev, bcd->dev, "%s", disk->disk_name);
+       if (!bcd->class_dev)
+               goto err;
        list_add_tail(&bcd->list, &bsg_class_list);
-       sysfs_create_link(&q->kobj, &bcd->class_dev->kobj, "bsg");
+       if (sysfs_create_link(&q->kobj, &bcd->class_dev->kobj, "bsg"))
+               goto err;
        mutex_unlock(&bsg_mutex);
        return 0;
+err:
+       bsg_device_nr--;
+       if (bcd->class_dev)
+               class_device_destroy(bsg_class, MKDEV(BSG_MAJOR, bcd->minor));
+       mutex_unlock(&bsg_mutex);
+       return -ENOMEM;
 }
 
 static int __init bsg_init(void)