1 #include <linux/module.h>
2 #include <linux/types.h>
3 #include <linux/string.h>
4 #include <linux/kernel.h>
5 #include <linux/errno.h>
6 #include <linux/genhd.h>
7 #include <linux/mutex.h>
9 #include <linux/hdreg.h>
11 #if !defined(CONFIG_DEBUG_BLOCK_EXT_DEVT)
12 #define IDE_DISK_MINORS (1 << PARTN_BITS)
14 #define IDE_DISK_MINORS 0
18 #include "ide-floppy.h"
20 #define IDE_GD_VERSION "1.18"
22 /* module parameters */
23 static unsigned long debug_mask;
24 module_param(debug_mask, ulong, 0644);
26 static DEFINE_MUTEX(ide_disk_ref_mutex);
28 static void ide_disk_release(struct kref *);
30 static struct ide_disk_obj *ide_disk_get(struct gendisk *disk)
32 struct ide_disk_obj *idkp = NULL;
34 mutex_lock(&ide_disk_ref_mutex);
35 idkp = ide_drv_g(disk, ide_disk_obj);
37 if (ide_device_get(idkp->drive))
40 kref_get(&idkp->kref);
42 mutex_unlock(&ide_disk_ref_mutex);
46 static void ide_disk_put(struct ide_disk_obj *idkp)
48 ide_drive_t *drive = idkp->drive;
50 mutex_lock(&ide_disk_ref_mutex);
51 kref_put(&idkp->kref, ide_disk_release);
52 ide_device_put(drive);
53 mutex_unlock(&ide_disk_ref_mutex);
56 sector_t ide_gd_capacity(ide_drive_t *drive)
58 return drive->capacity64;
61 static int ide_gd_probe(ide_drive_t *);
63 static void ide_gd_remove(ide_drive_t *drive)
65 struct ide_disk_obj *idkp = drive->driver_data;
66 struct gendisk *g = idkp->disk;
68 ide_proc_unregister_driver(drive, idkp->driver);
72 drive->disk_ops->flush(drive);
77 static void ide_disk_release(struct kref *kref)
79 struct ide_disk_obj *idkp = to_ide_drv(kref, ide_disk_obj);
80 ide_drive_t *drive = idkp->drive;
81 struct gendisk *g = idkp->disk;
83 drive->disk_ops = NULL;
84 drive->driver_data = NULL;
85 g->private_data = NULL;
91 * On HPA drives the capacity needs to be
92 * reinitilized on resume otherwise the disk
93 * can not be used and a hard reset is required
95 static void ide_gd_resume(ide_drive_t *drive)
97 if (ata_id_hpa_enabled(drive->id))
98 (void)drive->disk_ops->get_capacity(drive);
101 static void ide_gd_shutdown(ide_drive_t *drive)
104 /* On Alpha, halt(8) doesn't actually turn the machine off,
105 it puts you into the sort of firmware monitor. Typically,
106 it's used to boot another kernel image, so it's not much
107 different from reboot(8). Therefore, we don't need to
108 spin down the disk in this case, especially since Alpha
109 firmware doesn't handle disks in standby mode properly.
110 On the other hand, it's reasonably safe to turn the power
111 off when the shutdown process reaches the firmware prompt,
112 as the firmware initialization takes rather long time -
113 at least 10 seconds, which should be sufficient for
114 the disk to expire its write cache. */
115 if (system_state != SYSTEM_POWER_OFF) {
117 if (system_state == SYSTEM_RESTART) {
119 drive->disk_ops->flush(drive);
123 printk(KERN_INFO "Shutdown: %s\n", drive->name);
125 drive->gendev.bus->suspend(&drive->gendev, PMSG_SUSPEND);
128 #ifdef CONFIG_IDE_PROC_FS
129 static ide_proc_entry_t *ide_disk_proc_entries(ide_drive_t *drive)
131 return (drive->media == ide_disk) ? ide_disk_proc : ide_floppy_proc;
134 static const struct ide_proc_devset *ide_disk_proc_devsets(ide_drive_t *drive)
136 return (drive->media == ide_disk) ? ide_disk_settings
137 : ide_floppy_settings;
141 static ide_startstop_t ide_gd_do_request(ide_drive_t *drive,
142 struct request *rq, sector_t sector)
144 return drive->disk_ops->do_request(drive, rq, sector);
147 static int ide_gd_end_request(ide_drive_t *drive, int uptodate, int nrsecs)
149 return drive->disk_ops->end_request(drive, uptodate, nrsecs);
152 static struct ide_driver ide_gd_driver = {
154 .owner = THIS_MODULE,
156 .bus = &ide_bus_type,
158 .probe = ide_gd_probe,
159 .remove = ide_gd_remove,
160 .resume = ide_gd_resume,
161 .shutdown = ide_gd_shutdown,
162 .version = IDE_GD_VERSION,
163 .do_request = ide_gd_do_request,
164 .end_request = ide_gd_end_request,
165 #ifdef CONFIG_IDE_PROC_FS
166 .proc_entries = ide_disk_proc_entries,
167 .proc_devsets = ide_disk_proc_devsets,
171 static int ide_gd_open(struct block_device *bdev, fmode_t mode)
173 struct gendisk *disk = bdev->bd_disk;
174 struct ide_disk_obj *idkp;
178 idkp = ide_disk_get(disk);
184 ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
188 if ((drive->dev_flags & IDE_DFLAG_REMOVABLE) && idkp->openers == 1) {
189 drive->dev_flags &= ~IDE_DFLAG_FORMAT_IN_PROGRESS;
192 ret = drive->disk_ops->init_media(drive, disk);
195 * Allow O_NDELAY to open a drive without a disk, or with an
196 * unreadable disk, so that we can get the format capacity
197 * of the drive or begin the format - Sam
199 if (ret && (mode & FMODE_NDELAY) == 0) {
204 if ((drive->dev_flags & IDE_DFLAG_WP) && (mode & FMODE_WRITE)) {
210 * Ignore the return code from door_lock,
211 * since the open() has already succeeded,
212 * and the door_lock is irrelevant at this point.
214 drive->disk_ops->set_doorlock(drive, disk, 1);
215 drive->dev_flags |= IDE_DFLAG_MEDIA_CHANGED;
216 check_disk_change(bdev);
217 } else if (drive->dev_flags & IDE_DFLAG_FORMAT_IN_PROGRESS) {
229 static int ide_gd_release(struct gendisk *disk, fmode_t mode)
231 struct ide_disk_obj *idkp = ide_drv_g(disk, ide_disk_obj);
232 ide_drive_t *drive = idkp->drive;
234 ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
236 if (idkp->openers == 1)
237 drive->disk_ops->flush(drive);
239 if ((drive->dev_flags & IDE_DFLAG_REMOVABLE) && idkp->openers == 1) {
240 drive->disk_ops->set_doorlock(drive, disk, 0);
241 drive->dev_flags &= ~IDE_DFLAG_FORMAT_IN_PROGRESS;
251 static int ide_gd_getgeo(struct block_device *bdev, struct hd_geometry *geo)
253 struct ide_disk_obj *idkp = ide_drv_g(bdev->bd_disk, ide_disk_obj);
254 ide_drive_t *drive = idkp->drive;
256 geo->heads = drive->bios_head;
257 geo->sectors = drive->bios_sect;
258 geo->cylinders = (u16)drive->bios_cyl; /* truncate */
262 static int ide_gd_media_changed(struct gendisk *disk)
264 struct ide_disk_obj *idkp = ide_drv_g(disk, ide_disk_obj);
265 ide_drive_t *drive = idkp->drive;
268 /* do not scan partitions twice if this is a removable device */
269 if (drive->dev_flags & IDE_DFLAG_ATTACH) {
270 drive->dev_flags &= ~IDE_DFLAG_ATTACH;
274 ret = !!(drive->dev_flags & IDE_DFLAG_MEDIA_CHANGED);
275 drive->dev_flags &= ~IDE_DFLAG_MEDIA_CHANGED;
280 static int ide_gd_revalidate_disk(struct gendisk *disk)
282 struct ide_disk_obj *idkp = ide_drv_g(disk, ide_disk_obj);
283 ide_drive_t *drive = idkp->drive;
285 if (ide_gd_media_changed(disk))
286 drive->disk_ops->get_capacity(drive);
288 set_capacity(disk, ide_gd_capacity(drive));
292 static int ide_gd_ioctl(struct block_device *bdev, fmode_t mode,
293 unsigned int cmd, unsigned long arg)
295 struct ide_disk_obj *idkp = ide_drv_g(bdev->bd_disk, ide_disk_obj);
296 ide_drive_t *drive = idkp->drive;
298 return drive->disk_ops->ioctl(drive, bdev, mode, cmd, arg);
301 static struct block_device_operations ide_gd_ops = {
302 .owner = THIS_MODULE,
304 .release = ide_gd_release,
305 .locked_ioctl = ide_gd_ioctl,
306 .getgeo = ide_gd_getgeo,
307 .media_changed = ide_gd_media_changed,
308 .revalidate_disk = ide_gd_revalidate_disk
311 static int ide_gd_probe(ide_drive_t *drive)
313 const struct ide_disk_ops *disk_ops = NULL;
314 struct ide_disk_obj *idkp;
317 /* strstr("foo", "") is non-NULL */
318 if (!strstr("ide-gd", drive->driver_req))
321 #ifdef CONFIG_IDE_GD_ATA
322 if (drive->media == ide_disk)
323 disk_ops = &ide_ata_disk_ops;
325 #ifdef CONFIG_IDE_GD_ATAPI
326 if (drive->media == ide_floppy)
327 disk_ops = &ide_atapi_disk_ops;
329 if (disk_ops == NULL)
332 if (disk_ops->check(drive, DRV_NAME) == 0) {
333 printk(KERN_ERR PFX "%s: not supported by this driver\n",
338 idkp = kzalloc(sizeof(*idkp), GFP_KERNEL);
340 printk(KERN_ERR PFX "%s: can't allocate a disk structure\n",
345 g = alloc_disk_node(IDE_DISK_MINORS, hwif_to_node(drive->hwif));
349 ide_init_disk(g, drive);
351 kref_init(&idkp->kref);
354 idkp->driver = &ide_gd_driver;
357 g->private_data = &idkp->driver;
359 drive->driver_data = idkp;
360 drive->debug_mask = debug_mask;
361 drive->disk_ops = disk_ops;
363 disk_ops->setup(drive);
365 set_capacity(g, ide_gd_capacity(drive));
367 g->minors = IDE_DISK_MINORS;
368 g->driverfs_dev = &drive->gendev;
369 g->flags |= GENHD_FL_EXT_DEVT;
370 if (drive->dev_flags & IDE_DFLAG_REMOVABLE)
371 g->flags = GENHD_FL_REMOVABLE;
372 g->fops = &ide_gd_ops;
382 static int __init ide_gd_init(void)
384 printk(KERN_INFO DRV_NAME " driver " IDE_GD_VERSION "\n");
385 return driver_register(&ide_gd_driver.gen_driver);
388 static void __exit ide_gd_exit(void)
390 driver_unregister(&ide_gd_driver.gen_driver);
393 MODULE_ALIAS("ide:*m-disk*");
394 MODULE_ALIAS("ide-disk");
395 MODULE_ALIAS("ide:*m-floppy*");
396 MODULE_ALIAS("ide-floppy");
397 module_init(ide_gd_init);
398 module_exit(ide_gd_exit);
399 MODULE_LICENSE("GPL");
400 MODULE_DESCRIPTION("generic ATA/ATAPI disk driver");