Skip to content

Commit bbc1cc9

Browse files
author
Al Viro
committed
[PATCH] switch cdrom_{open,release,ioctl} to sane APIs
... convert to it in callers Signed-off-by: Al Viro <[email protected]>
1 parent 08f8585 commit bbc1cc9

File tree

7 files changed

+38
-36
lines changed

7 files changed

+38
-36
lines changed

drivers/block/paride/pcd.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -226,20 +226,22 @@ static int pcd_warned; /* Have we logged a phase warning ? */
226226
static int pcd_block_open(struct inode *inode, struct file *file)
227227
{
228228
struct pcd_unit *cd = inode->i_bdev->bd_disk->private_data;
229-
return cdrom_open(&cd->info, inode, file);
229+
return cdrom_open(&cd->info, inode->i_bdev, file->f_mode);
230230
}
231231

232232
static int pcd_block_release(struct inode *inode, struct file *file)
233233
{
234234
struct pcd_unit *cd = inode->i_bdev->bd_disk->private_data;
235-
return cdrom_release(&cd->info, file);
235+
cdrom_release(&cd->info, file ? file->f_mode : 0);
236+
return 0;
236237
}
237238

238239
static int pcd_block_ioctl(struct inode *inode, struct file *file,
239240
unsigned cmd, unsigned long arg)
240241
{
241242
struct pcd_unit *cd = inode->i_bdev->bd_disk->private_data;
242-
return cdrom_ioctl(file, &cd->info, inode, cmd, arg);
243+
return cdrom_ioctl(&cd->info, inode->i_bdev,
244+
file ? file->f_mode : 0, cmd, arg);
243245
}
244246

245247
static int pcd_block_media_changed(struct gendisk *disk)

drivers/cdrom/cdrom.c

Lines changed: 11 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -973,7 +973,7 @@ static int cdrom_close_write(struct cdrom_device_info *cdi)
973973
* is in their own interest: device control becomes a lot easier
974974
* this way.
975975
*/
976-
int cdrom_open(struct cdrom_device_info *cdi, struct inode *ip, struct file *fp)
976+
int cdrom_open(struct cdrom_device_info *cdi, struct block_device *bdev, fmode_t mode)
977977
{
978978
int ret;
979979

@@ -982,14 +982,14 @@ int cdrom_open(struct cdrom_device_info *cdi, struct inode *ip, struct file *fp)
982982
/* if this was a O_NONBLOCK open and we should honor the flags,
983983
* do a quick open without drive/disc integrity checks. */
984984
cdi->use_count++;
985-
if ((fp->f_mode & FMODE_NDELAY) && (cdi->options & CDO_USE_FFLAGS)) {
985+
if ((mode & FMODE_NDELAY) && (cdi->options & CDO_USE_FFLAGS)) {
986986
ret = cdi->ops->open(cdi, 1);
987987
} else {
988988
ret = open_for_data(cdi);
989989
if (ret)
990990
goto err;
991991
cdrom_mmc3_profile(cdi);
992-
if (fp->f_mode & FMODE_WRITE) {
992+
if (mode & FMODE_WRITE) {
993993
ret = -EROFS;
994994
if (cdrom_open_write(cdi))
995995
goto err_release;
@@ -1007,7 +1007,7 @@ int cdrom_open(struct cdrom_device_info *cdi, struct inode *ip, struct file *fp)
10071007
cdi->name, cdi->use_count);
10081008
/* Do this on open. Don't wait for mount, because they might
10091009
not be mounting, but opening with O_NONBLOCK */
1010-
check_disk_change(ip->i_bdev);
1010+
check_disk_change(bdev);
10111011
return 0;
10121012
err_release:
10131013
if (CDROM_CAN(CDC_LOCK) && cdi->options & CDO_LOCK) {
@@ -1184,7 +1184,7 @@ static int check_for_audio_disc(struct cdrom_device_info * cdi,
11841184
return 0;
11851185
}
11861186

1187-
int cdrom_release(struct cdrom_device_info *cdi, struct file *fp)
1187+
void cdrom_release(struct cdrom_device_info *cdi, fmode_t mode)
11881188
{
11891189
struct cdrom_device_ops *cdo = cdi->ops;
11901190
int opened_for_data;
@@ -1205,7 +1205,7 @@ int cdrom_release(struct cdrom_device_info *cdi, struct file *fp)
12051205
}
12061206

12071207
opened_for_data = !(cdi->options & CDO_USE_FFLAGS) ||
1208-
!(fp && fp->f_mode & FMODE_NDELAY);
1208+
!(mode & FMODE_NDELAY);
12091209

12101210
/*
12111211
* flush cache on last write release
@@ -1219,7 +1219,6 @@ int cdrom_release(struct cdrom_device_info *cdi, struct file *fp)
12191219
cdi->options & CDO_AUTO_EJECT && CDROM_CAN(CDC_OPEN_TRAY))
12201220
cdo->tray_move(cdi, 1);
12211221
}
1222-
return 0;
12231222
}
12241223

12251224
static int cdrom_read_mech_status(struct cdrom_device_info *cdi,
@@ -2662,17 +2661,17 @@ static int cdrom_ioctl_audioctl(struct cdrom_device_info *cdi,
26622661
* these days.
26632662
* ATAPI / SCSI specific code now mainly resides in mmc_ioctl().
26642663
*/
2665-
int cdrom_ioctl(struct file * file, struct cdrom_device_info *cdi,
2666-
struct inode *ip, unsigned int cmd, unsigned long arg)
2664+
int cdrom_ioctl(struct cdrom_device_info *cdi, struct block_device *bdev,
2665+
fmode_t mode, unsigned int cmd, unsigned long arg)
26672666
{
26682667
void __user *argp = (void __user *)arg;
26692668
int ret;
2670-
struct gendisk *disk = ip->i_bdev->bd_disk;
2669+
struct gendisk *disk = bdev->bd_disk;
26712670

26722671
/*
26732672
* Try the generic SCSI command ioctl's first.
26742673
*/
2675-
ret = scsi_cmd_ioctl(disk->queue, disk, file ? file->f_mode : 0, cmd, argp);
2674+
ret = scsi_cmd_ioctl(disk->queue, disk, mode, cmd, argp);
26762675
if (ret != -ENOTTY)
26772676
return ret;
26782677

@@ -2696,7 +2695,7 @@ int cdrom_ioctl(struct file * file, struct cdrom_device_info *cdi,
26962695
case CDROM_SELECT_DISC:
26972696
return cdrom_ioctl_select_disc(cdi, arg);
26982697
case CDROMRESET:
2699-
return cdrom_ioctl_reset(cdi, ip->i_bdev);
2698+
return cdrom_ioctl_reset(cdi, bdev);
27002699
case CDROM_LOCKDOOR:
27012700
return cdrom_ioctl_lock_door(cdi, arg);
27022701
case CDROM_DEBUG:

drivers/cdrom/gdrom.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -492,12 +492,12 @@ static struct cdrom_device_ops gdrom_ops = {
492492

493493
static int gdrom_bdops_open(struct inode *inode, struct file *file)
494494
{
495-
return cdrom_open(gd.cd_info, inode, file);
495+
return cdrom_open(gd.cd_info, inode->i_bdev, file->f_mode);
496496
}
497497

498498
static int gdrom_bdops_release(struct inode *inode, struct file *file)
499499
{
500-
return cdrom_release(gd.cd_info, file);
500+
return cdrom_release(gd.cd_info, file ? file->f_mode : 0);
501501
}
502502

503503
static int gdrom_bdops_mediachanged(struct gendisk *disk)
@@ -508,7 +508,8 @@ static int gdrom_bdops_mediachanged(struct gendisk *disk)
508508
static int gdrom_bdops_ioctl(struct inode *inode, struct file *file,
509509
unsigned cmd, unsigned long arg)
510510
{
511-
return cdrom_ioctl(file, gd.cd_info, inode, cmd, arg);
511+
return cdrom_ioctl(gd.cd_info, inode->i_bdev,
512+
file ? file->f_mode : 0, cmd, arg);
512513
}
513514

514515
static struct block_device_operations gdrom_bdops = {

drivers/cdrom/viocd.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -154,20 +154,22 @@ static const struct file_operations proc_viocd_operations = {
154154
static int viocd_blk_open(struct inode *inode, struct file *file)
155155
{
156156
struct disk_info *di = inode->i_bdev->bd_disk->private_data;
157-
return cdrom_open(&di->viocd_info, inode, file);
157+
return cdrom_open(&di->viocd_info, inode->i_bdev, file->f_mode);
158158
}
159159

160160
static int viocd_blk_release(struct inode *inode, struct file *file)
161161
{
162162
struct disk_info *di = inode->i_bdev->bd_disk->private_data;
163-
return cdrom_release(&di->viocd_info, file);
163+
cdrom_release(&di->viocd_info, file ? file->f_mode : 0);
164+
return 0;
164165
}
165166

166167
static int viocd_blk_ioctl(struct inode *inode, struct file *file,
167168
unsigned cmd, unsigned long arg)
168169
{
169170
struct disk_info *di = inode->i_bdev->bd_disk->private_data;
170-
return cdrom_ioctl(file, &di->viocd_info, inode, cmd, arg);
171+
return cdrom_ioctl(&di->viocd_info, inode->i_bdev,
172+
file ? file->f_mode : 0, cmd, arg);
171173
}
172174

173175
static int viocd_blk_media_changed(struct gendisk *disk)

drivers/ide/ide-cd.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2099,7 +2099,7 @@ static int idecd_open(struct inode *inode, struct file *file)
20992099
if (!info)
21002100
return -ENXIO;
21012101

2102-
rc = cdrom_open(&info->devinfo, inode, file);
2102+
rc = cdrom_open(&info->devinfo, inode->i_bdev, file->f_mode);
21032103

21042104
if (rc < 0)
21052105
ide_cd_put(info);
@@ -2112,7 +2112,7 @@ static int idecd_release(struct inode *inode, struct file *file)
21122112
struct gendisk *disk = inode->i_bdev->bd_disk;
21132113
struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
21142114

2115-
cdrom_release(&info->devinfo, file);
2115+
cdrom_release(&info->devinfo, file ? file->f_mode : 0);
21162116

21172117
ide_cd_put(info);
21182118

@@ -2176,7 +2176,8 @@ static int idecd_ioctl(struct inode *inode, struct file *file,
21762176

21772177
err = generic_ide_ioctl(info->drive, bdev, cmd, arg);
21782178
if (err == -EINVAL)
2179-
err = cdrom_ioctl(file, &info->devinfo, inode, cmd, arg);
2179+
err = cdrom_ioctl(&info->devinfo, bdev,
2180+
file ? file->f_mode : 0, cmd, arg);
21802181

21812182
return err;
21822183
}

drivers/scsi/sr.c

Lines changed: 4 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -480,20 +480,16 @@ static int sr_block_open(struct inode *inode, struct file *file)
480480
if(!(cd = scsi_cd_get(disk)))
481481
return -ENXIO;
482482

483-
if((ret = cdrom_open(&cd->cdi, inode, file)) != 0)
483+
if((ret = cdrom_open(&cd->cdi, inode->i_bdev, file->f_mode)) != 0)
484484
scsi_cd_put(cd);
485485

486486
return ret;
487487
}
488488

489489
static int sr_block_release(struct inode *inode, struct file *file)
490490
{
491-
int ret;
492491
struct scsi_cd *cd = scsi_cd(inode->i_bdev->bd_disk);
493-
ret = cdrom_release(&cd->cdi, file);
494-
if(ret)
495-
return ret;
496-
492+
cdrom_release(&cd->cdi, file ? file->f_mode : 0);
497493
scsi_cd_put(cd);
498494

499495
return 0;
@@ -517,7 +513,8 @@ static int sr_block_ioctl(struct inode *inode, struct file *file, unsigned cmd,
517513
return scsi_ioctl(sdev, cmd, argp);
518514
}
519515

520-
ret = cdrom_ioctl(file, &cd->cdi, inode, cmd, arg);
516+
ret = cdrom_ioctl(&cd->cdi, inode->i_bdev,
517+
file ? file->f_mode : 0, cmd, arg);
521518
if (ret != -ENOSYS)
522519
return ret;
523520

include/linux/cdrom.h

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -987,11 +987,11 @@ struct cdrom_device_ops {
987987
};
988988

989989
/* the general block_device operations structure: */
990-
extern int cdrom_open(struct cdrom_device_info *cdi, struct inode *ip,
991-
struct file *fp);
992-
extern int cdrom_release(struct cdrom_device_info *cdi, struct file *fp);
993-
extern int cdrom_ioctl(struct file *file, struct cdrom_device_info *cdi,
994-
struct inode *ip, unsigned int cmd, unsigned long arg);
990+
extern int cdrom_open(struct cdrom_device_info *cdi, struct block_device *bdev,
991+
fmode_t mode);
992+
extern void cdrom_release(struct cdrom_device_info *cdi, fmode_t mode);
993+
extern int cdrom_ioctl(struct cdrom_device_info *cdi, struct block_device *bdev,
994+
fmode_t mode, unsigned int cmd, unsigned long arg);
995995
extern int cdrom_media_changed(struct cdrom_device_info *);
996996

997997
extern int register_cdrom(struct cdrom_device_info *cdi);

0 commit comments

Comments
 (0)