aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--block/compat_ioctl.c10
-rw-r--r--block/ioctl.c9
-rw-r--r--drivers/char/raw.c2
-rw-r--r--fs/block_dev.c8
-rw-r--r--include/linux/fs.h2
5 files changed, 14 insertions, 17 deletions
diff --git a/block/compat_ioctl.c b/block/compat_ioctl.c
index 5b3db0640d87..3098c92402fd 100644
--- a/block/compat_ioctl.c
+++ b/block/compat_ioctl.c
@@ -177,7 +177,7 @@ struct compat_blkpg_ioctl_arg {
177 compat_caddr_t data; 177 compat_caddr_t data;
178}; 178};
179 179
180static int compat_blkpg_ioctl(struct inode *inode, struct file *file, 180static int compat_blkpg_ioctl(struct block_device *bdev, fmode_t mode,
181 unsigned int cmd, struct compat_blkpg_ioctl_arg __user *ua32) 181 unsigned int cmd, struct compat_blkpg_ioctl_arg __user *ua32)
182{ 182{
183 struct blkpg_ioctl_arg __user *a = compat_alloc_user_space(sizeof(*a)); 183 struct blkpg_ioctl_arg __user *a = compat_alloc_user_space(sizeof(*a));
@@ -196,7 +196,7 @@ static int compat_blkpg_ioctl(struct inode *inode, struct file *file,
196 if (err) 196 if (err)
197 return err; 197 return err;
198 198
199 return blkdev_ioctl(inode, file, cmd, (unsigned long)a); 199 return blkdev_ioctl(bdev, mode, cmd, (unsigned long)a);
200} 200}
201 201
202#define BLKBSZGET_32 _IOR(0x12, 112, int) 202#define BLKBSZGET_32 _IOR(0x12, 112, int)
@@ -715,13 +715,13 @@ long compat_blkdev_ioctl(struct file *file, unsigned cmd, unsigned long arg)
715 * but we call blkdev_ioctl, which gets the lock for us 715 * but we call blkdev_ioctl, which gets the lock for us
716 */ 716 */
717 case BLKRRPART: 717 case BLKRRPART:
718 return blkdev_ioctl(inode, file, cmd, 718 return blkdev_ioctl(bdev, mode, cmd,
719 (unsigned long)compat_ptr(arg)); 719 (unsigned long)compat_ptr(arg));
720 case BLKBSZSET_32: 720 case BLKBSZSET_32:
721 return blkdev_ioctl(inode, file, BLKBSZSET, 721 return blkdev_ioctl(bdev, mode, BLKBSZSET,
722 (unsigned long)compat_ptr(arg)); 722 (unsigned long)compat_ptr(arg));
723 case BLKPG: 723 case BLKPG:
724 return compat_blkpg_ioctl(inode, file, cmd, compat_ptr(arg)); 724 return compat_blkpg_ioctl(bdev, mode, cmd, compat_ptr(arg));
725 case BLKRAGET: 725 case BLKRAGET:
726 case BLKFRAGET: 726 case BLKFRAGET:
727 if (!arg) 727 if (!arg)
diff --git a/block/ioctl.c b/block/ioctl.c
index 14b7f2c10662..c832d639b6e2 100644
--- a/block/ioctl.c
+++ b/block/ioctl.c
@@ -230,20 +230,13 @@ EXPORT_SYMBOL_GPL(__blkdev_driver_ioctl);
230 * always keep this in sync with compat_blkdev_ioctl() and 230 * always keep this in sync with compat_blkdev_ioctl() and
231 * compat_blkdev_locked_ioctl() 231 * compat_blkdev_locked_ioctl()
232 */ 232 */
233int blkdev_ioctl(struct inode *inode, struct file *file, unsigned cmd, 233int blkdev_ioctl(struct block_device *bdev, fmode_t mode, unsigned cmd,
234 unsigned long arg) 234 unsigned long arg)
235{ 235{
236 struct block_device *bdev = inode->i_bdev;
237 struct gendisk *disk = bdev->bd_disk; 236 struct gendisk *disk = bdev->bd_disk;
238 struct backing_dev_info *bdi; 237 struct backing_dev_info *bdi;
239 loff_t size; 238 loff_t size;
240 int ret, n; 239 int ret, n;
241 fmode_t mode = 0;
242 if (file) {
243 mode = file->f_mode;
244 if (file->f_flags & O_NDELAY)
245 mode |= FMODE_NDELAY_NOW;
246 }
247 240
248 switch(cmd) { 241 switch(cmd) {
249 case BLKFLSBUF: 242 case BLKFLSBUF:
diff --git a/drivers/char/raw.c b/drivers/char/raw.c
index f3cf5eb9b7fb..96adf28a17e4 100644
--- a/drivers/char/raw.c
+++ b/drivers/char/raw.c
@@ -125,7 +125,7 @@ raw_ioctl(struct inode *inode, struct file *filp,
125{ 125{
126 struct block_device *bdev = filp->private_data; 126 struct block_device *bdev = filp->private_data;
127 127
128 return blkdev_ioctl(bdev->bd_inode, NULL, command, arg); 128 return blkdev_ioctl(bdev, 0, command, arg);
129} 129}
130 130
131static void bind_device(struct raw_config_request *rq) 131static void bind_device(struct raw_config_request *rq)
diff --git a/fs/block_dev.c b/fs/block_dev.c
index b89c956e04f6..05865b93f7e1 100644
--- a/fs/block_dev.c
+++ b/fs/block_dev.c
@@ -1202,7 +1202,11 @@ static int blkdev_close(struct inode * inode, struct file * filp)
1202 1202
1203static long block_ioctl(struct file *file, unsigned cmd, unsigned long arg) 1203static long block_ioctl(struct file *file, unsigned cmd, unsigned long arg)
1204{ 1204{
1205 return blkdev_ioctl(file->f_mapping->host, file, cmd, arg); 1205 struct block_device *bdev = I_BDEV(file->f_mapping->host);
1206 fmode_t mode = file->f_mode;
1207 if (file->f_flags & O_NDELAY)
1208 mode |= FMODE_NDELAY_NOW;
1209 return blkdev_ioctl(bdev, mode, cmd, arg);
1206} 1210}
1207 1211
1208static const struct address_space_operations def_blk_aops = { 1212static const struct address_space_operations def_blk_aops = {
@@ -1238,7 +1242,7 @@ int ioctl_by_bdev(struct block_device *bdev, unsigned cmd, unsigned long arg)
1238 int res; 1242 int res;
1239 mm_segment_t old_fs = get_fs(); 1243 mm_segment_t old_fs = get_fs();
1240 set_fs(KERNEL_DS); 1244 set_fs(KERNEL_DS);
1241 res = blkdev_ioctl(bdev->bd_inode, NULL, cmd, arg); 1245 res = blkdev_ioctl(bdev, 0, cmd, arg);
1242 set_fs(old_fs); 1246 set_fs(old_fs);
1243 return res; 1247 return res;
1244} 1248}
diff --git a/include/linux/fs.h b/include/linux/fs.h
index 11de682c65a1..ff536e106b4e 100644
--- a/include/linux/fs.h
+++ b/include/linux/fs.h
@@ -1717,7 +1717,7 @@ extern const struct file_operations bad_sock_fops;
1717extern const struct file_operations def_fifo_fops; 1717extern const struct file_operations def_fifo_fops;
1718#ifdef CONFIG_BLOCK 1718#ifdef CONFIG_BLOCK
1719extern int ioctl_by_bdev(struct block_device *, unsigned, unsigned long); 1719extern int ioctl_by_bdev(struct block_device *, unsigned, unsigned long);
1720extern int blkdev_ioctl(struct inode *, struct file *, unsigned, unsigned long); 1720extern int blkdev_ioctl(struct block_device *, fmode_t, unsigned, unsigned long);
1721extern long compat_blkdev_ioctl(struct file *, unsigned, unsigned long); 1721extern long compat_blkdev_ioctl(struct file *, unsigned, unsigned long);
1722extern int blkdev_get(struct block_device *, fmode_t); 1722extern int blkdev_get(struct block_device *, fmode_t);
1723extern int blkdev_put(struct block_device *, fmode_t); 1723extern int blkdev_put(struct block_device *, fmode_t);