Skip to content

Commit

Permalink
ide: remove ide_drive_t.usage
Browse files Browse the repository at this point in the history
This field is no longer used by the core IDE code so fix ide-{disk,floppy}
drivers to keep openers count in the driver specific objects and remove
it from ide-{cd,scsi,tape} drivers (it was write-only).

Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
  • Loading branch information
Bartlomiej Zolnierkiewicz committed Feb 17, 2007
1 parent 7b77d86 commit c94964a
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 42 deletions.
15 changes: 4 additions & 11 deletions drivers/ide/ide-cd.c
Original file line number Diff line number Diff line change
Expand Up @@ -3353,21 +3353,16 @@ static int idecd_open(struct inode * inode, struct file * file)
{
struct gendisk *disk = inode->i_bdev->bd_disk;
struct cdrom_info *info;
ide_drive_t *drive;
int rc = -ENOMEM;

if (!(info = ide_cd_get(disk)))
return -ENXIO;

drive = info->drive;

drive->usage++;

if (!info->buffer)
info->buffer = kmalloc(SECTOR_BUFFER_SIZE,
GFP_KERNEL|__GFP_REPEAT);
if (!info->buffer || (rc = cdrom_open(&info->devinfo, inode, file)))
drive->usage--;
info->buffer = kmalloc(SECTOR_BUFFER_SIZE, GFP_KERNEL|__GFP_REPEAT);

if (info->buffer)
rc = cdrom_open(&info->devinfo, inode, file);

if (rc < 0)
ide_cd_put(info);
Expand All @@ -3379,10 +3374,8 @@ static int idecd_release(struct inode * inode, struct file * file)
{
struct gendisk *disk = inode->i_bdev->bd_disk;
struct cdrom_info *info = ide_cd_g(disk);
ide_drive_t *drive = info->drive;

cdrom_release (&info->devinfo, file);
drive->usage--;

ide_cd_put(info);

Expand Down
14 changes: 9 additions & 5 deletions drivers/ide/ide-disk.c
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ struct ide_disk_obj {
ide_driver_t *driver;
struct gendisk *disk;
struct kref kref;
unsigned int openers; /* protected by BKL for now */
};

static DEFINE_MUTEX(idedisk_ref_mutex);
Expand Down Expand Up @@ -1081,8 +1082,9 @@ static int idedisk_open(struct inode *inode, struct file *filp)

drive = idkp->drive;

drive->usage++;
if (drive->removable && drive->usage == 1) {
idkp->openers++;

if (drive->removable && idkp->openers == 1) {
ide_task_t args;
memset(&args, 0, sizeof(ide_task_t));
args.tfRegister[IDE_COMMAND_OFFSET] = WIN_DOORLOCK;
Expand All @@ -1106,9 +1108,10 @@ static int idedisk_release(struct inode *inode, struct file *filp)
struct ide_disk_obj *idkp = ide_disk_g(disk);
ide_drive_t *drive = idkp->drive;

if (drive->usage == 1)
if (idkp->openers == 1)
ide_cacheflush_p(drive);
if (drive->removable && drive->usage == 1) {

if (drive->removable && idkp->openers == 1) {
ide_task_t args;
memset(&args, 0, sizeof(ide_task_t));
args.tfRegister[IDE_COMMAND_OFFSET] = WIN_DOORUNLOCK;
Expand All @@ -1117,7 +1120,8 @@ static int idedisk_release(struct inode *inode, struct file *filp)
if (drive->doorlocking && ide_raw_taskfile(drive, &args, NULL))
drive->doorlocking = 0;
}
drive->usage--;

idkp->openers--;

ide_disk_put(idkp);

Expand Down
18 changes: 9 additions & 9 deletions drivers/ide/ide-floppy.c
Original file line number Diff line number Diff line change
Expand Up @@ -279,6 +279,7 @@ typedef struct ide_floppy_obj {
ide_driver_t *driver;
struct gendisk *disk;
struct kref kref;
unsigned int openers; /* protected by BKL for now */

/* Current packet command */
idefloppy_pc_t *pc;
Expand Down Expand Up @@ -1950,9 +1951,9 @@ static int idefloppy_open(struct inode *inode, struct file *filp)

drive = floppy->drive;

drive->usage++;
floppy->openers++;

if (drive->usage == 1) {
if (floppy->openers == 1) {
clear_bit(IDEFLOPPY_FORMAT_IN_PROGRESS, &floppy->flags);
/* Just in case */

Expand All @@ -1970,13 +1971,11 @@ static int idefloppy_open(struct inode *inode, struct file *filp)
** capacity of the drive or begin the format - Sam
*/
) {
drive->usage--;
ret = -EIO;
goto out_put_floppy;
}

if (floppy->wp && (filp->f_mode & 2)) {
drive->usage--;
ret = -EROFS;
goto out_put_floppy;
}
Expand All @@ -1988,13 +1987,13 @@ static int idefloppy_open(struct inode *inode, struct file *filp)
}
check_disk_change(inode->i_bdev);
} else if (test_bit(IDEFLOPPY_FORMAT_IN_PROGRESS, &floppy->flags)) {
drive->usage--;
ret = -EBUSY;
goto out_put_floppy;
}
return 0;

out_put_floppy:
floppy->openers--;
ide_floppy_put(floppy);
return ret;
}
Expand All @@ -2008,7 +2007,7 @@ static int idefloppy_release(struct inode *inode, struct file *filp)

debug_log(KERN_INFO "Reached idefloppy_release\n");

if (drive->usage == 1) {
if (floppy->openers == 1) {
/* IOMEGA Clik! drives do not support lock/unlock commands */
if (!test_bit(IDEFLOPPY_CLIK_DRIVE, &floppy->flags)) {
idefloppy_create_prevent_cmd(&pc, 0);
Expand All @@ -2017,7 +2016,8 @@ static int idefloppy_release(struct inode *inode, struct file *filp)

clear_bit(IDEFLOPPY_FORMAT_IN_PROGRESS, &floppy->flags);
}
drive->usage--;

floppy->openers--;

ide_floppy_put(floppy);

Expand Down Expand Up @@ -2051,7 +2051,7 @@ static int idefloppy_ioctl(struct inode *inode, struct file *file,
prevent = 0;
/* fall through */
case CDROM_LOCKDOOR:
if (drive->usage > 1)
if (floppy->openers > 1)
return -EBUSY;

/* The IOMEGA Clik! Drive doesn't support this command - no room for an eject mechanism */
Expand All @@ -2073,7 +2073,7 @@ static int idefloppy_ioctl(struct inode *inode, struct file *file,
if (!(file->f_mode & 2))
return -EPERM;

if (drive->usage > 1) {
if (floppy->openers > 1) {
/* Don't format if someone is using the disk */

clear_bit(IDEFLOPPY_FORMAT_IN_PROGRESS,
Expand Down
8 changes: 0 additions & 8 deletions drivers/ide/ide-tape.c
Original file line number Diff line number Diff line change
Expand Up @@ -4792,25 +4792,17 @@ static int idetape_open(struct inode *inode, struct file *filp)
{
struct gendisk *disk = inode->i_bdev->bd_disk;
struct ide_tape_obj *tape;
ide_drive_t *drive;

if (!(tape = ide_tape_get(disk)))
return -ENXIO;

drive = tape->drive;

drive->usage++;

return 0;
}

static int idetape_release(struct inode *inode, struct file *filp)
{
struct gendisk *disk = inode->i_bdev->bd_disk;
struct ide_tape_obj *tape = ide_tape_g(disk);
ide_drive_t *drive = tape->drive;

drive->usage--;

ide_tape_put(tape);

Expand Down
8 changes: 0 additions & 8 deletions drivers/scsi/ide-scsi.c
Original file line number Diff line number Diff line change
Expand Up @@ -801,25 +801,17 @@ static int idescsi_ide_open(struct inode *inode, struct file *filp)
{
struct gendisk *disk = inode->i_bdev->bd_disk;
struct ide_scsi_obj *scsi;
ide_drive_t *drive;

if (!(scsi = ide_scsi_get(disk)))
return -ENXIO;

drive = scsi->drive;

drive->usage++;

return 0;
}

static int idescsi_ide_release(struct inode *inode, struct file *filp)
{
struct gendisk *disk = inode->i_bdev->bd_disk;
struct ide_scsi_obj *scsi = ide_scsi_g(disk);
ide_drive_t *drive = scsi->drive;

drive->usage--;

ide_scsi_put(scsi);

Expand Down
1 change: 0 additions & 1 deletion include/linux/ide.h
Original file line number Diff line number Diff line change
Expand Up @@ -636,7 +636,6 @@ typedef struct ide_drive_s {
unsigned int bios_cyl; /* BIOS/fdisk/LILO number of cyls */
unsigned int cyl; /* "real" number of cyls */
unsigned int drive_data; /* use by tuneproc/selectproc */
unsigned int usage; /* current "open()" count for drive */
unsigned int failures; /* current failure count */
unsigned int max_failures; /* maximum allowed failure count */
u64 probed_capacity;/* initial reported media capacity (ide-cd only currently) */
Expand Down

0 comments on commit c94964a

Please sign in to comment.