mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-19 02:04:19 +08:00
8fed436841
During host driver module removal del_gendisk() results in a final put on drive->gendev and freeing the drive by drive_release_dev(). Convert device drivers from using struct kref to use struct device so device driver's object holds reference on ->gendev and prevents drive from prematurely going away. Also fix ->remove methods to not erroneously drop reference on a host driver by using only put_device() instead of ide*_put(). Reported-by: Stanislaw Gruszka <stf_xl@wp.pl> Tested-by: Stanislaw Gruszka <stf_xl@wp.pl> Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
45 lines
996 B
C
45 lines
996 B
C
#ifndef __IDE_GD_H
|
|
#define __IDE_GD_H
|
|
|
|
#define DRV_NAME "ide-gd"
|
|
#define PFX DRV_NAME ": "
|
|
|
|
/* define to see debug info */
|
|
#define IDE_GD_DEBUG_LOG 0
|
|
|
|
#if IDE_GD_DEBUG_LOG
|
|
#define ide_debug_log(lvl, fmt, args...) __ide_debug_log(lvl, fmt, args)
|
|
#else
|
|
#define ide_debug_log(lvl, fmt, args...) do {} while (0)
|
|
#endif
|
|
|
|
struct ide_disk_obj {
|
|
ide_drive_t *drive;
|
|
struct ide_driver *driver;
|
|
struct gendisk *disk;
|
|
struct device dev;
|
|
unsigned int openers; /* protected by BKL for now */
|
|
|
|
/* Last failed packet command */
|
|
struct ide_atapi_pc *failed_pc;
|
|
/* used for blk_{fs,pc}_request() requests */
|
|
struct ide_atapi_pc queued_pc;
|
|
|
|
/* Last error information */
|
|
u8 sense_key, asc, ascq;
|
|
|
|
int progress_indication;
|
|
|
|
/* Device information */
|
|
/* Current format */
|
|
int blocks, block_size, bs_factor;
|
|
/* Last format capacity descriptor */
|
|
u8 cap_desc[8];
|
|
/* Copy of the flexible disk page */
|
|
u8 flexible_disk_page[32];
|
|
};
|
|
|
|
sector_t ide_gd_capacity(ide_drive_t *);
|
|
|
|
#endif /* __IDE_GD_H */
|