aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-cd.c17
-rw-r--r--drivers/ide/ide-floppy.c21
-rw-r--r--drivers/ide/ide-tape.c23
-rw-r--r--include/linux/ide.h8
4 files changed, 30 insertions, 39 deletions
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c
index 465a92ca0179..8650ad43b324 100644
--- a/drivers/ide/ide-cd.c
+++ b/drivers/ide/ide-cd.c
@@ -52,11 +52,6 @@
52 52
53static DEFINE_MUTEX(idecd_ref_mutex); 53static DEFINE_MUTEX(idecd_ref_mutex);
54 54
55#define to_ide_cd(obj) container_of(obj, struct cdrom_info, kref)
56
57#define ide_cd_g(disk) \
58 container_of((disk)->private_data, struct cdrom_info, driver)
59
60static void ide_cd_release(struct kref *); 55static void ide_cd_release(struct kref *);
61 56
62static struct cdrom_info *ide_cd_get(struct gendisk *disk) 57static struct cdrom_info *ide_cd_get(struct gendisk *disk)
@@ -64,7 +59,7 @@ static struct cdrom_info *ide_cd_get(struct gendisk *disk)
64 struct cdrom_info *cd = NULL; 59 struct cdrom_info *cd = NULL;
65 60
66 mutex_lock(&idecd_ref_mutex); 61 mutex_lock(&idecd_ref_mutex);
67 cd = ide_cd_g(disk); 62 cd = ide_drv_g(disk, cdrom_info);
68 if (cd) { 63 if (cd) {
69 if (ide_device_get(cd->drive)) 64 if (ide_device_get(cd->drive))
70 cd = NULL; 65 cd = NULL;
@@ -1941,7 +1936,7 @@ static void ide_cd_remove(ide_drive_t *drive)
1941 1936
1942static void ide_cd_release(struct kref *kref) 1937static void ide_cd_release(struct kref *kref)
1943{ 1938{
1944 struct cdrom_info *info = to_ide_cd(kref); 1939 struct cdrom_info *info = to_ide_drv(kref, cdrom_info);
1945 struct cdrom_device_info *devinfo = &info->devinfo; 1940 struct cdrom_device_info *devinfo = &info->devinfo;
1946 ide_drive_t *drive = info->drive; 1941 ide_drive_t *drive = info->drive;
1947 struct gendisk *g = info->disk; 1942 struct gendisk *g = info->disk;
@@ -1999,7 +1994,7 @@ static int idecd_open(struct inode *inode, struct file *file)
1999static int idecd_release(struct inode *inode, struct file *file) 1994static int idecd_release(struct inode *inode, struct file *file)
2000{ 1995{
2001 struct gendisk *disk = inode->i_bdev->bd_disk; 1996 struct gendisk *disk = inode->i_bdev->bd_disk;
2002 struct cdrom_info *info = ide_cd_g(disk); 1997 struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
2003 1998
2004 cdrom_release(&info->devinfo, file); 1999 cdrom_release(&info->devinfo, file);
2005 2000
@@ -2051,7 +2046,7 @@ static int idecd_ioctl(struct inode *inode, struct file *file,
2051 unsigned int cmd, unsigned long arg) 2046 unsigned int cmd, unsigned long arg)
2052{ 2047{
2053 struct block_device *bdev = inode->i_bdev; 2048 struct block_device *bdev = inode->i_bdev;
2054 struct cdrom_info *info = ide_cd_g(bdev->bd_disk); 2049 struct cdrom_info *info = ide_drv_g(bdev->bd_disk, cdrom_info);
2055 int err; 2050 int err;
2056 2051
2057 switch (cmd) { 2052 switch (cmd) {
@@ -2072,13 +2067,13 @@ static int idecd_ioctl(struct inode *inode, struct file *file,
2072 2067
2073static int idecd_media_changed(struct gendisk *disk) 2068static int idecd_media_changed(struct gendisk *disk)
2074{ 2069{
2075 struct cdrom_info *info = ide_cd_g(disk); 2070 struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
2076 return cdrom_media_changed(&info->devinfo); 2071 return cdrom_media_changed(&info->devinfo);
2077} 2072}
2078 2073
2079static int idecd_revalidate_disk(struct gendisk *disk) 2074static int idecd_revalidate_disk(struct gendisk *disk)
2080{ 2075{
2081 struct cdrom_info *info = ide_cd_g(disk); 2076 struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
2082 struct request_sense sense; 2077 struct request_sense sense;
2083 2078
2084 ide_cd_read_toc(info->drive, &sense); 2079 ide_cd_read_toc(info->drive, &sense);
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c
index 2a34f1ad2284..2a54a25090cb 100644
--- a/drivers/ide/ide-floppy.c
+++ b/drivers/ide/ide-floppy.c
@@ -84,11 +84,6 @@
84 84
85static DEFINE_MUTEX(idefloppy_ref_mutex); 85static DEFINE_MUTEX(idefloppy_ref_mutex);
86 86
87#define to_ide_floppy(obj) container_of(obj, struct ide_floppy_obj, kref)
88
89#define ide_floppy_g(disk) \
90 container_of((disk)->private_data, struct ide_floppy_obj, driver)
91
92static void idefloppy_cleanup_obj(struct kref *); 87static void idefloppy_cleanup_obj(struct kref *);
93 88
94static struct ide_floppy_obj *ide_floppy_get(struct gendisk *disk) 89static struct ide_floppy_obj *ide_floppy_get(struct gendisk *disk)
@@ -96,7 +91,7 @@ static struct ide_floppy_obj *ide_floppy_get(struct gendisk *disk)
96 struct ide_floppy_obj *floppy = NULL; 91 struct ide_floppy_obj *floppy = NULL;
97 92
98 mutex_lock(&idefloppy_ref_mutex); 93 mutex_lock(&idefloppy_ref_mutex);
99 floppy = ide_floppy_g(disk); 94 floppy = ide_drv_g(disk, ide_floppy_obj);
100 if (floppy) { 95 if (floppy) {
101 if (ide_device_get(floppy->drive)) 96 if (ide_device_get(floppy->drive))
102 floppy = NULL; 97 floppy = NULL;
@@ -625,7 +620,7 @@ static void ide_floppy_remove(ide_drive_t *drive)
625 620
626static void idefloppy_cleanup_obj(struct kref *kref) 621static void idefloppy_cleanup_obj(struct kref *kref)
627{ 622{
628 struct ide_floppy_obj *floppy = to_ide_floppy(kref); 623 struct ide_floppy_obj *floppy = to_ide_drv(kref, ide_floppy_obj);
629 ide_drive_t *drive = floppy->drive; 624 ide_drive_t *drive = floppy->drive;
630 struct gendisk *g = floppy->disk; 625 struct gendisk *g = floppy->disk;
631 626
@@ -733,7 +728,7 @@ out_put_floppy:
733static int idefloppy_release(struct inode *inode, struct file *filp) 728static int idefloppy_release(struct inode *inode, struct file *filp)
734{ 729{
735 struct gendisk *disk = inode->i_bdev->bd_disk; 730 struct gendisk *disk = inode->i_bdev->bd_disk;
736 struct ide_floppy_obj *floppy = ide_floppy_g(disk); 731 struct ide_floppy_obj *floppy = ide_drv_g(disk, ide_floppy_obj);
737 ide_drive_t *drive = floppy->drive; 732 ide_drive_t *drive = floppy->drive;
738 733
739 debug_log("Reached %s\n", __func__); 734 debug_log("Reached %s\n", __func__);
@@ -752,7 +747,8 @@ static int idefloppy_release(struct inode *inode, struct file *filp)
752 747
753static int idefloppy_getgeo(struct block_device *bdev, struct hd_geometry *geo) 748static int idefloppy_getgeo(struct block_device *bdev, struct hd_geometry *geo)
754{ 749{
755 struct ide_floppy_obj *floppy = ide_floppy_g(bdev->bd_disk); 750 struct ide_floppy_obj *floppy = ide_drv_g(bdev->bd_disk,
751 ide_floppy_obj);
756 ide_drive_t *drive = floppy->drive; 752 ide_drive_t *drive = floppy->drive;
757 753
758 geo->heads = drive->bios_head; 754 geo->heads = drive->bios_head;
@@ -783,7 +779,8 @@ static int idefloppy_ioctl(struct inode *inode, struct file *file,
783 unsigned int cmd, unsigned long arg) 779 unsigned int cmd, unsigned long arg)
784{ 780{
785 struct block_device *bdev = inode->i_bdev; 781 struct block_device *bdev = inode->i_bdev;
786 struct ide_floppy_obj *floppy = ide_floppy_g(bdev->bd_disk); 782 struct ide_floppy_obj *floppy = ide_drv_g(bdev->bd_disk,
783 ide_floppy_obj);
787 ide_drive_t *drive = floppy->drive; 784 ide_drive_t *drive = floppy->drive;
788 struct ide_atapi_pc pc; 785 struct ide_atapi_pc pc;
789 void __user *argp = (void __user *)arg; 786 void __user *argp = (void __user *)arg;
@@ -812,7 +809,7 @@ static int idefloppy_ioctl(struct inode *inode, struct file *file,
812 809
813static int idefloppy_media_changed(struct gendisk *disk) 810static int idefloppy_media_changed(struct gendisk *disk)
814{ 811{
815 struct ide_floppy_obj *floppy = ide_floppy_g(disk); 812 struct ide_floppy_obj *floppy = ide_drv_g(disk, ide_floppy_obj);
816 ide_drive_t *drive = floppy->drive; 813 ide_drive_t *drive = floppy->drive;
817 int ret; 814 int ret;
818 815
@@ -828,7 +825,7 @@ static int idefloppy_media_changed(struct gendisk *disk)
828 825
829static int idefloppy_revalidate_disk(struct gendisk *disk) 826static int idefloppy_revalidate_disk(struct gendisk *disk)
830{ 827{
831 struct ide_floppy_obj *floppy = ide_floppy_g(disk); 828 struct ide_floppy_obj *floppy = ide_drv_g(disk, ide_floppy_obj);
832 set_capacity(disk, idefloppy_capacity(floppy->drive)); 829 set_capacity(disk, idefloppy_capacity(floppy->drive));
833 return 0; 830 return 0;
834} 831}
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c
index 622d5fed2dc5..2c235401aad1 100644
--- a/drivers/ide/ide-tape.c
+++ b/drivers/ide/ide-tape.c
@@ -267,11 +267,6 @@ static DEFINE_MUTEX(idetape_ref_mutex);
267 267
268static struct class *idetape_sysfs_class; 268static struct class *idetape_sysfs_class;
269 269
270#define to_ide_tape(obj) container_of(obj, struct ide_tape_obj, kref)
271
272#define ide_tape_g(disk) \
273 container_of((disk)->private_data, struct ide_tape_obj, driver)
274
275static void ide_tape_release(struct kref *); 270static void ide_tape_release(struct kref *);
276 271
277static struct ide_tape_obj *ide_tape_get(struct gendisk *disk) 272static struct ide_tape_obj *ide_tape_get(struct gendisk *disk)
@@ -279,7 +274,7 @@ static struct ide_tape_obj *ide_tape_get(struct gendisk *disk)
279 struct ide_tape_obj *tape = NULL; 274 struct ide_tape_obj *tape = NULL;
280 275
281 mutex_lock(&idetape_ref_mutex); 276 mutex_lock(&idetape_ref_mutex);
282 tape = ide_tape_g(disk); 277 tape = ide_drv_g(disk, ide_tape_obj);
283 if (tape) { 278 if (tape) {
284 if (ide_device_get(tape->drive)) 279 if (ide_device_get(tape->drive))
285 tape = NULL; 280 tape = NULL;
@@ -306,8 +301,6 @@ static void ide_tape_put(struct ide_tape_obj *tape)
306 */ 301 */
307static struct ide_tape_obj *idetape_devs[MAX_HWIFS * MAX_DRIVES]; 302static struct ide_tape_obj *idetape_devs[MAX_HWIFS * MAX_DRIVES];
308 303
309#define ide_tape_f(file) ((file)->private_data)
310
311static struct ide_tape_obj *ide_tape_chrdev_get(unsigned int i) 304static struct ide_tape_obj *ide_tape_chrdev_get(unsigned int i)
312{ 305{
313 struct ide_tape_obj *tape = NULL; 306 struct ide_tape_obj *tape = NULL;
@@ -1542,7 +1535,7 @@ static int idetape_space_over_filemarks(ide_drive_t *drive, short mt_op,
1542static ssize_t idetape_chrdev_read(struct file *file, char __user *buf, 1535static ssize_t idetape_chrdev_read(struct file *file, char __user *buf,
1543 size_t count, loff_t *ppos) 1536 size_t count, loff_t *ppos)
1544{ 1537{
1545 struct ide_tape_obj *tape = ide_tape_f(file); 1538 struct ide_tape_obj *tape = file->private_data;
1546 ide_drive_t *drive = tape->drive; 1539 ide_drive_t *drive = tape->drive;
1547 ssize_t bytes_read, temp, actually_read = 0, rc; 1540 ssize_t bytes_read, temp, actually_read = 0, rc;
1548 ssize_t ret = 0; 1541 ssize_t ret = 0;
@@ -1604,7 +1597,7 @@ finish:
1604static ssize_t idetape_chrdev_write(struct file *file, const char __user *buf, 1597static ssize_t idetape_chrdev_write(struct file *file, const char __user *buf,
1605 size_t count, loff_t *ppos) 1598 size_t count, loff_t *ppos)
1606{ 1599{
1607 struct ide_tape_obj *tape = ide_tape_f(file); 1600 struct ide_tape_obj *tape = file->private_data;
1608 ide_drive_t *drive = tape->drive; 1601 ide_drive_t *drive = tape->drive;
1609 ssize_t actually_written = 0; 1602 ssize_t actually_written = 0;
1610 ssize_t ret = 0; 1603 ssize_t ret = 0;
@@ -1836,7 +1829,7 @@ static int idetape_mtioctop(ide_drive_t *drive, short mt_op, int mt_count)
1836static int idetape_chrdev_ioctl(struct inode *inode, struct file *file, 1829static int idetape_chrdev_ioctl(struct inode *inode, struct file *file,
1837 unsigned int cmd, unsigned long arg) 1830 unsigned int cmd, unsigned long arg)
1838{ 1831{
1839 struct ide_tape_obj *tape = ide_tape_f(file); 1832 struct ide_tape_obj *tape = file->private_data;
1840 ide_drive_t *drive = tape->drive; 1833 ide_drive_t *drive = tape->drive;
1841 struct mtop mtop; 1834 struct mtop mtop;
1842 struct mtget mtget; 1835 struct mtget mtget;
@@ -2013,7 +2006,7 @@ static void idetape_write_release(ide_drive_t *drive, unsigned int minor)
2013 2006
2014static int idetape_chrdev_release(struct inode *inode, struct file *filp) 2007static int idetape_chrdev_release(struct inode *inode, struct file *filp)
2015{ 2008{
2016 struct ide_tape_obj *tape = ide_tape_f(filp); 2009 struct ide_tape_obj *tape = filp->private_data;
2017 ide_drive_t *drive = tape->drive; 2010 ide_drive_t *drive = tape->drive;
2018 unsigned int minor = iminor(inode); 2011 unsigned int minor = iminor(inode);
2019 2012
@@ -2272,7 +2265,7 @@ static void ide_tape_remove(ide_drive_t *drive)
2272 2265
2273static void ide_tape_release(struct kref *kref) 2266static void ide_tape_release(struct kref *kref)
2274{ 2267{
2275 struct ide_tape_obj *tape = to_ide_tape(kref); 2268 struct ide_tape_obj *tape = to_ide_drv(kref, ide_tape_obj);
2276 ide_drive_t *drive = tape->drive; 2269 ide_drive_t *drive = tape->drive;
2277 struct gendisk *g = tape->disk; 2270 struct gendisk *g = tape->disk;
2278 2271
@@ -2355,7 +2348,7 @@ static int idetape_open(struct inode *inode, struct file *filp)
2355static int idetape_release(struct inode *inode, struct file *filp) 2348static int idetape_release(struct inode *inode, struct file *filp)
2356{ 2349{
2357 struct gendisk *disk = inode->i_bdev->bd_disk; 2350 struct gendisk *disk = inode->i_bdev->bd_disk;
2358 struct ide_tape_obj *tape = ide_tape_g(disk); 2351 struct ide_tape_obj *tape = ide_drv_g(disk, ide_tape_obj);
2359 2352
2360 ide_tape_put(tape); 2353 ide_tape_put(tape);
2361 2354
@@ -2366,7 +2359,7 @@ static int idetape_ioctl(struct inode *inode, struct file *file,
2366 unsigned int cmd, unsigned long arg) 2359 unsigned int cmd, unsigned long arg)
2367{ 2360{
2368 struct block_device *bdev = inode->i_bdev; 2361 struct block_device *bdev = inode->i_bdev;
2369 struct ide_tape_obj *tape = ide_tape_g(bdev->bd_disk); 2362 struct ide_tape_obj *tape = ide_drv_g(bdev->bd_disk, ide_tape_obj);
2370 ide_drive_t *drive = tape->drive; 2363 ide_drive_t *drive = tape->drive;
2371 int err = generic_ide_ioctl(drive, file, bdev, cmd, arg); 2364 int err = generic_ide_ioctl(drive, file, bdev, cmd, arg);
2372 if (err == -EINVAL) 2365 if (err == -EINVAL)
diff --git a/include/linux/ide.h b/include/linux/ide.h
index 85cb96c1fd61..350ef47ed616 100644
--- a/include/linux/ide.h
+++ b/include/linux/ide.h
@@ -570,7 +570,13 @@ struct ide_drive_s {
570 570
571typedef struct ide_drive_s ide_drive_t; 571typedef struct ide_drive_s ide_drive_t;
572 572
573#define to_ide_device(dev)container_of(dev, ide_drive_t, gendev) 573#define to_ide_device(dev) container_of(dev, ide_drive_t, gendev)
574
575#define to_ide_drv(obj, cont_type) \
576 container_of(obj, struct cont_type, kref)
577
578#define ide_drv_g(disk, cont_type) \
579 container_of((disk)->private_data, struct cont_type, driver)
574 580
575struct ide_task_s; 581struct ide_task_s;
576struct ide_port_info; 582struct ide_port_info;