ide-cd.c 49.4 KB
Newer Older
L
Linus Torvalds 已提交
1
/*
2
 * ATAPI CD-ROM driver.
L
Linus Torvalds 已提交
3
 *
4 5 6 7
 * Copyright (C) 1994-1996   Scott Snyder <snyder@fnald0.fnal.gov>
 * Copyright (C) 1996-1998   Erik Andersen <andersee@debian.org>
 * Copyright (C) 1998-2000   Jens Axboe <axboe@suse.de>
 * Copyright (C) 2005, 2007  Bartlomiej Zolnierkiewicz
L
Linus Torvalds 已提交
8 9 10 11 12 13 14
 *
 * May be copied or modified under the terms of the GNU General Public
 * License.  See linux/COPYING for more information.
 *
 * See Documentation/cdrom/ide-cd for usage information.
 *
 * Suggestions are welcome. Patches that work are more welcome though. ;-)
15 16 17
 *
 * Documentation:
 *	Mt. Fuji (SFF8090 version 4) and ATAPI (SFF-8020i rev 2.6) standards.
L
Linus Torvalds 已提交
18
 *
19 20 21 22
 * For historical changelog please see:
 *	Documentation/ide/ChangeLog.ide-cd.1994-2004
 */

23 24 25
#define DRV_NAME "ide-cd"
#define PFX DRV_NAME ": "

26
#define IDECD_VERSION "5.00"
L
Linus Torvalds 已提交
27 28 29 30 31 32 33 34 35 36 37 38

#include <linux/module.h>
#include <linux/types.h>
#include <linux/kernel.h>
#include <linux/delay.h>
#include <linux/timer.h>
#include <linux/slab.h>
#include <linux/interrupt.h>
#include <linux/errno.h>
#include <linux/cdrom.h>
#include <linux/ide.h>
#include <linux/completion.h>
39
#include <linux/mutex.h>
40
#include <linux/bcd.h>
L
Linus Torvalds 已提交
41

B
Borislav Petkov 已提交
42 43
/* For SCSI -> ATAPI command conversion */
#include <scsi/scsi.h>
L
Linus Torvalds 已提交
44

B
Borislav Petkov 已提交
45 46
#include <linux/irq.h>
#include <linux/io.h>
L
Linus Torvalds 已提交
47
#include <asm/byteorder.h>
B
Borislav Petkov 已提交
48
#include <linux/uaccess.h>
L
Linus Torvalds 已提交
49 50 51 52
#include <asm/unaligned.h>

#include "ide-cd.h"

53
static DEFINE_MUTEX(idecd_ref_mutex);
L
Linus Torvalds 已提交
54

55
static void ide_cd_release(struct device *);
56

L
Linus Torvalds 已提交
57 58 59 60
static struct cdrom_info *ide_cd_get(struct gendisk *disk)
{
	struct cdrom_info *cd = NULL;

61
	mutex_lock(&idecd_ref_mutex);
B
Borislav Petkov 已提交
62
	cd = ide_drv_g(disk, cdrom_info);
63
	if (cd) {
64
		if (ide_device_get(cd->drive))
65
			cd = NULL;
66
		else
67
			get_device(&cd->dev);
68

69
	}
70
	mutex_unlock(&idecd_ref_mutex);
L
Linus Torvalds 已提交
71 72 73 74 75
	return cd;
}

static void ide_cd_put(struct cdrom_info *cd)
{
76 77
	ide_drive_t *drive = cd->drive;

78
	mutex_lock(&idecd_ref_mutex);
79
	put_device(&cd->dev);
80
	ide_device_put(drive);
81
	mutex_unlock(&idecd_ref_mutex);
L
Linus Torvalds 已提交
82 83
}

B
Borislav Petkov 已提交
84
/*
L
Linus Torvalds 已提交
85 86 87
 * Generic packet command support and error handling routines.
 */

B
Borislav Petkov 已提交
88
/* Mark that we've seen a media change and invalidate our internal buffers. */
89
static void cdrom_saw_media_change(ide_drive_t *drive)
L
Linus Torvalds 已提交
90
{
91
	drive->dev_flags |= IDE_DFLAG_MEDIA_CHANGED;
92
	drive->atapi_flags &= ~IDE_AFLAG_TOC_VALID;
L
Linus Torvalds 已提交
93 94 95 96 97 98 99
}

static int cdrom_log_sense(ide_drive_t *drive, struct request *rq,
			   struct request_sense *sense)
{
	int log = 0;

B
Borislav Petkov 已提交
100
	ide_debug_log(IDE_DBG_SENSE, "sense_key: 0x%x", sense->sense_key);
101

102
	if (!sense || !rq || (rq->cmd_flags & REQ_QUIET))
L
Linus Torvalds 已提交
103 104 105
		return 0;

	switch (sense->sense_key) {
106 107 108 109 110
	case NO_SENSE:
	case RECOVERED_ERROR:
		break;
	case NOT_READY:
		/*
B
Borislav Petkov 已提交
111 112
		 * don't care about tray state messages for e.g. capacity
		 * commands or in-progress or becoming ready
113 114
		 */
		if (sense->asc == 0x3a || sense->asc == 0x04)
L
Linus Torvalds 已提交
115
			break;
116 117 118 119
		log = 1;
		break;
	case ILLEGAL_REQUEST:
		/*
B
Borislav Petkov 已提交
120 121
		 * don't log START_STOP unit with LoEj set, since we cannot
		 * reliably check if drive can auto-close
122 123
		 */
		if (rq->cmd[0] == GPCMD_START_STOP_UNIT && sense->asc == 0x24)
L
Linus Torvalds 已提交
124
			break;
125 126 127 128
		log = 1;
		break;
	case UNIT_ATTENTION:
		/*
B
Borislav Petkov 已提交
129 130 131
		 * Make good and sure we've seen this potential media change.
		 * Some drives (i.e. Creative) fail to present the correct sense
		 * key in the error register.
132 133 134 135 136 137
		 */
		cdrom_saw_media_change(drive);
		break;
	default:
		log = 1;
		break;
L
Linus Torvalds 已提交
138 139 140 141
	}
	return log;
}

142
static void cdrom_analyze_sense_data(ide_drive_t *drive,
L
Linus Torvalds 已提交
143 144 145
			      struct request *failed_command,
			      struct request_sense *sense)
{
A
Alan Cox 已提交
146 147 148 149
	unsigned long sector;
	unsigned long bio_sectors;
	struct cdrom_info *info = drive->driver_data;

B
Borislav Petkov 已提交
150 151
	ide_debug_log(IDE_DBG_SENSE, "error_code: 0x%x, sense_key: 0x%x",
				     sense->error_code, sense->sense_key);
152 153

	if (failed_command)
B
Borislav Petkov 已提交
154 155
		ide_debug_log(IDE_DBG_SENSE, "failed cmd: 0x%x",
					     failed_command->cmd[0]);
156

L
Linus Torvalds 已提交
157 158 159 160
	if (!cdrom_log_sense(drive, failed_command, sense))
		return;

	/*
B
Borislav Petkov 已提交
161 162 163
	 * If a read toc is executed for a CD-R or CD-RW medium where the first
	 * toc has not been recorded yet, it will fail with 05/24/00 (which is a
	 * confusing error)
L
Linus Torvalds 已提交
164 165 166 167 168
	 */
	if (failed_command && failed_command->cmd[0] == GPCMD_READ_TOC_PMA_ATIP)
		if (sense->sense_key == 0x05 && sense->asc == 0x24)
			return;

B
Borislav Petkov 已提交
169 170
	/* current error */
	if (sense->error_code == 0x70) {
171
		switch (sense->sense_key) {
A
Alan Cox 已提交
172 173 174 175 176 177 178 179 180 181 182 183 184 185
		case MEDIUM_ERROR:
		case VOLUME_OVERFLOW:
		case ILLEGAL_REQUEST:
			if (!sense->valid)
				break;
			if (failed_command == NULL ||
					!blk_fs_request(failed_command))
				break;
			sector = (sense->information[0] << 24) |
				 (sense->information[1] << 16) |
				 (sense->information[2] <<  8) |
				 (sense->information[3]);

			if (drive->queue->hardsect_size == 2048)
B
Borislav Petkov 已提交
186 187
				/* device sector size is 2K */
				sector <<= 2;
188 189

			bio_sectors = max(bio_sectors(failed_command->bio), 4U);
190
			sector &= ~(bio_sectors - 1);
A
Alan Cox 已提交
191

192 193 194 195 196 197 198 199
			/*
			 * The SCSI specification allows for the value
			 * returned by READ CAPACITY to be up to 75 2K
			 * sectors past the last readable block.
			 * Therefore, if we hit a medium error within the
			 * last 75 2K sectors, we decrease the saved size
			 * value.
			 */
A
Alan Cox 已提交
200
			if (sector < get_capacity(info->disk) &&
201
			    drive->probed_capacity - sector < 4 * 75)
A
Alan Cox 已提交
202
				set_capacity(info->disk, sector);
203 204
		}
	}
L
Linus Torvalds 已提交
205

206
	ide_cd_log_error(drive->name, failed_command, sense);
L
Linus Torvalds 已提交
207 208 209 210 211 212
}

static void cdrom_queue_request_sense(ide_drive_t *drive, void *sense,
				      struct request *failed_command)
{
	struct cdrom_info *info		= drive->driver_data;
213
	struct request *rq		= &drive->request_sense_rq;
L
Linus Torvalds 已提交
214

B
Borislav Petkov 已提交
215
	ide_debug_log(IDE_DBG_SENSE, "enter");
216

L
Linus Torvalds 已提交
217 218 219 220
	if (sense == NULL)
		sense = &info->sense_data;

	/* stuff the sense request in front of our current request */
F
FUJITA Tomonori 已提交
221 222 223
	blk_rq_init(NULL, rq);
	rq->cmd_type = REQ_TYPE_ATA_PC;
	rq->rq_disk = info->disk;
L
Linus Torvalds 已提交
224 225 226

	rq->data = sense;
	rq->cmd[0] = GPCMD_REQUEST_SENSE;
227 228
	rq->cmd[4] = 18;
	rq->data_len = 18;
L
Linus Torvalds 已提交
229

230
	rq->cmd_type = REQ_TYPE_SENSE;
231
	rq->cmd_flags |= REQ_PREEMPT;
L
Linus Torvalds 已提交
232 233 234 235

	/* NOTE! Save the failed command in "rq->buffer" */
	rq->buffer = (void *) failed_command;

236
	if (failed_command)
B
Borislav Petkov 已提交
237 238
		ide_debug_log(IDE_DBG_SENSE, "failed_cmd: 0x%x",
					     failed_command->cmd[0]);
239

240 241 242
	drive->hwif->rq = NULL;

	elv_add_request(drive->queue, rq, ELEVATOR_INSERT_FRONT, 0);
L
Linus Torvalds 已提交
243 244
}

245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267
static void ide_cd_complete_failed_rq(ide_drive_t *drive, struct request *rq)
{
	/*
	 * For REQ_TYPE_SENSE, "rq->buffer" points to the original
	 * failed request
	 */
	struct request *failed = (struct request *)rq->buffer;
	struct cdrom_info *info = drive->driver_data;
	void *sense = &info->sense_data;

	if (failed) {
		if (failed->sense) {
			sense = failed->sense;
			failed->sense_len = rq->sense_len;
		}
		cdrom_analyze_sense_data(drive, failed, sense);

		if (ide_end_rq(drive, failed, -EIO, blk_rq_bytes(failed)))
			BUG();
	} else
		cdrom_analyze_sense_data(drive, NULL, sense);
}

B
Borislav Petkov 已提交
268 269 270
/*
 * Returns:
 * 0: if the request should be continued.
271 272
 * 1: if the request will be going through error recovery.
 * 2: if the request should be ended.
B
Borislav Petkov 已提交
273
 */
L
Linus Torvalds 已提交
274 275
static int cdrom_decode_status(ide_drive_t *drive, int good_stat, int *stat_ret)
{
276
	ide_hwif_t *hwif = drive->hwif;
277
	struct request *rq = hwif->rq;
L
Linus Torvalds 已提交
278
	int stat, err, sense_key;
279

B
Borislav Petkov 已提交
280
	/* check for errors */
281
	stat = hwif->tp_ops->read_status(hwif);
282

L
Linus Torvalds 已提交
283 284 285 286 287 288
	if (stat_ret)
		*stat_ret = stat;

	if (OK_STAT(stat, good_stat, BAD_R_STAT))
		return 0;

B
Borislav Petkov 已提交
289
	/* get the IDE error register */
290
	err = ide_read_error(drive);
L
Linus Torvalds 已提交
291 292
	sense_key = err >> 4;

B
Borislav Petkov 已提交
293 294 295 296
	ide_debug_log(IDE_DBG_RQ, "stat: 0x%x, good_stat: 0x%x, cmd[0]: 0x%x, "
				  "rq->cmd_type: 0x%x, err: 0x%x",
				  stat, good_stat, rq->cmd[0], rq->cmd_type,
				  err);
297

298
	if (blk_sense_request(rq)) {
B
Borislav Petkov 已提交
299 300 301 302 303
		/*
		 * We got an error trying to get sense info from the drive
		 * (probably while trying to recover from a former error).
		 * Just give up.
		 */
304
		rq->cmd_flags |= REQ_FAILED;
305
		return 2;
306
	} else if (blk_pc_request(rq) || rq->cmd_type == REQ_TYPE_ATA_PC) {
L
Linus Torvalds 已提交
307 308 309 310 311 312
		/* All other functions, except for READ. */

		/*
		 * if we have an error, pass back CHECK_CONDITION as the
		 * scsi status byte
		 */
313
		if (blk_pc_request(rq) && !rq->errors)
L
Linus Torvalds 已提交
314 315
			rq->errors = SAM_STAT_CHECK_CONDITION;

B
Borislav Petkov 已提交
316
		/* check for tray open */
L
Linus Torvalds 已提交
317
		if (sense_key == NOT_READY) {
318
			cdrom_saw_media_change(drive);
L
Linus Torvalds 已提交
319
		} else if (sense_key == UNIT_ATTENTION) {
B
Borislav Petkov 已提交
320
			/* check for media change */
321
			cdrom_saw_media_change(drive);
L
Linus Torvalds 已提交
322
			return 0;
323 324 325 326 327 328 329 330 331
		} else if (sense_key == ILLEGAL_REQUEST &&
			   rq->cmd[0] == GPCMD_START_STOP_UNIT) {
			/*
			 * Don't print error message for this condition--
			 * SFF8090i indicates that 5/24/00 is the correct
			 * response to a request to close the tray if the
			 * drive doesn't have that capability.
			 * cdrom_log_sense() knows this!
			 */
332
		} else if (!(rq->cmd_flags & REQ_QUIET)) {
B
Borislav Petkov 已提交
333
			/* otherwise, print an error */
L
Linus Torvalds 已提交
334 335
			ide_dump_status(drive, "packet command error", stat);
		}
336

337
		rq->cmd_flags |= REQ_FAILED;
L
Linus Torvalds 已提交
338 339 340 341 342 343

		/*
		 * instead of playing games with moving completions around,
		 * remove failed request completely and end it when the
		 * request sense has completed
		 */
344
		goto end_request;
L
Linus Torvalds 已提交
345 346 347 348

	} else if (blk_fs_request(rq)) {
		int do_end_request = 0;

B
Borislav Petkov 已提交
349
		/* handle errors from READ and WRITE requests */
L
Linus Torvalds 已提交
350 351 352 353 354

		if (blk_noretry_request(rq))
			do_end_request = 1;

		if (sense_key == NOT_READY) {
B
Borislav Petkov 已提交
355
			/* tray open */
L
Linus Torvalds 已提交
356
			if (rq_data_dir(rq) == READ) {
357
				cdrom_saw_media_change(drive);
L
Linus Torvalds 已提交
358

B
Borislav Petkov 已提交
359
				/* fail the request */
360 361
				printk(KERN_ERR PFX "%s: tray open\n",
						drive->name);
L
Linus Torvalds 已提交
362 363 364 365
				do_end_request = 1;
			} else {
				struct cdrom_info *info = drive->driver_data;

B
Borislav Petkov 已提交
366 367
				/*
				 * Allow the drive 5 seconds to recover, some
L
Linus Torvalds 已提交
368
				 * devices will return this error while flushing
B
Borislav Petkov 已提交
369 370
				 * data from cache.
				 */
L
Linus Torvalds 已提交
371
				if (!rq->errors)
372 373
					info->write_timeout = jiffies +
							ATAPI_WAIT_WRITE_BUSY;
L
Linus Torvalds 已提交
374 375 376 377
				rq->errors = 1;
				if (time_after(jiffies, info->write_timeout))
					do_end_request = 1;
				else {
378
					struct request_queue *q = drive->queue;
L
Linus Torvalds 已提交
379 380 381
					unsigned long flags;

					/*
B
Borislav Petkov 已提交
382 383
					 * take a breather relying on the unplug
					 * timer to kick us again
L
Linus Torvalds 已提交
384
					 */
385 386 387 388
					spin_lock_irqsave(q->queue_lock, flags);
					blk_plug_device(q);
					spin_unlock_irqrestore(q->queue_lock, flags);

L
Linus Torvalds 已提交
389 390 391 392
					return 1;
				}
			}
		} else if (sense_key == UNIT_ATTENTION) {
B
Borislav Petkov 已提交
393
			/* media change */
394
			cdrom_saw_media_change(drive);
L
Linus Torvalds 已提交
395

396
			/*
B
Borislav Petkov 已提交
397 398
			 * Arrange to retry the request but be sure to give up
			 * if we've retried too many times.
399
			 */
L
Linus Torvalds 已提交
400 401 402 403
			if (++rq->errors > ERROR_MAX)
				do_end_request = 1;
		} else if (sense_key == ILLEGAL_REQUEST ||
			   sense_key == DATA_PROTECT) {
404
			/*
B
Borislav Petkov 已提交
405 406
			 * No point in retrying after an illegal request or data
			 * protect error.
407
			 */
408
			ide_dump_status(drive, "command error", stat);
L
Linus Torvalds 已提交
409 410
			do_end_request = 1;
		} else if (sense_key == MEDIUM_ERROR) {
411 412
			/*
			 * No point in re-trying a zillion times on a bad
B
Borislav Petkov 已提交
413
			 * sector. If we got here the error is not correctable.
414
			 */
415 416
			ide_dump_status(drive, "media error (bad sector)",
					stat);
L
Linus Torvalds 已提交
417 418
			do_end_request = 1;
		} else if (sense_key == BLANK_CHECK) {
B
Borislav Petkov 已提交
419
			/* disk appears blank ?? */
420
			ide_dump_status(drive, "media error (blank)", stat);
L
Linus Torvalds 已提交
421
			do_end_request = 1;
422
		} else if ((err & ~ATA_ABORTED) != 0) {
B
Borislav Petkov 已提交
423
			/* go to the default handler for other errors */
L
Linus Torvalds 已提交
424 425 426
			ide_error(drive, "cdrom_decode_status", stat);
			return 1;
		} else if ((++rq->errors > ERROR_MAX)) {
B
Borislav Petkov 已提交
427
			/* we've racked up too many retries, abort */
L
Linus Torvalds 已提交
428 429 430
			do_end_request = 1;
		}

B
Borislav Petkov 已提交
431 432 433 434 435
		/*
		 * End a request through request sense analysis when we have
		 * sense data. We need this in order to perform end of media
		 * processing.
		 */
436 437
		if (do_end_request)
			goto end_request;
A
Alan Cox 已提交
438

439
		/*
B
Borislav Petkov 已提交
440 441
		 * If we got a CHECK_CONDITION status, queue
		 * a request sense command.
442
		 */
443
		if (stat & ATA_ERR)
444
			cdrom_queue_request_sense(drive, NULL, NULL);
445
		return 1;
L
Linus Torvalds 已提交
446
	} else {
447
		blk_dump_rq_flags(rq, PFX "bad rq");
448
		return 2;
L
Linus Torvalds 已提交
449 450
	}

451
end_request:
452
	if (stat & ATA_ERR) {
453
		struct request_queue *q = drive->queue;
454 455
		unsigned long flags;

456
		spin_lock_irqsave(q->queue_lock, flags);
457
		blkdev_dequeue_request(rq);
458
		spin_unlock_irqrestore(q->queue_lock, flags);
459

460
		hwif->rq = NULL;
461

462
		cdrom_queue_request_sense(drive, rq->sense, rq);
463
		return 1;
464
	} else
465
		return 2;
L
Linus Torvalds 已提交
466 467 468 469 470 471 472
}

/*
 * Check the contents of the interrupt reason register from the cdrom
 * and attempt to recover if there are problems.  Returns  0 if everything's
 * ok; nonzero if the request has been terminated.
 */
473 474
static int ide_cd_check_ireason(ide_drive_t *drive, struct request *rq,
				int len, int ireason, int rw)
L
Linus Torvalds 已提交
475
{
476 477
	ide_hwif_t *hwif = drive->hwif;

B
Borislav Petkov 已提交
478
	ide_debug_log(IDE_DBG_FUNC, "ireason: 0x%x, rw: 0x%x", ireason, rw);
479

480 481 482 483 484
	/*
	 * ireason == 0: the drive wants to receive data from us
	 * ireason == 2: the drive is expecting to transfer data to us
	 */
	if (ireason == (!rw << 1))
L
Linus Torvalds 已提交
485
		return 0;
486
	else if (ireason == (rw << 1)) {
487

B
Borislav Petkov 已提交
488
		/* whoops... */
489
		printk(KERN_ERR PFX "%s: %s: wrong transfer direction!\n",
490
				drive->name, __func__);
L
Linus Torvalds 已提交
491

492
		ide_pad_transfer(drive, rw, len);
493
	} else  if (rw == 0 && ireason == 1) {
B
Borislav Petkov 已提交
494 495 496
		/*
		 * Some drives (ASUS) seem to tell us that status info is
		 * available.  Just get it and ignore.
L
Linus Torvalds 已提交
497
		 */
498
		(void)hwif->tp_ops->read_status(hwif);
L
Linus Torvalds 已提交
499 500
		return 0;
	} else {
B
Borislav Petkov 已提交
501
		/* drive wants a command packet, or invalid ireason... */
502
		printk(KERN_ERR PFX "%s: %s: bad interrupt reason 0x%02x\n",
503
				drive->name, __func__, ireason);
L
Linus Torvalds 已提交
504 505
	}

506 507 508
	if (rq->cmd_type == REQ_TYPE_ATA_PC)
		rq->cmd_flags |= REQ_FAILED;

L
Linus Torvalds 已提交
509 510 511
	return -1;
}

512
static void ide_cd_request_sense_fixup(ide_drive_t *drive, struct request *rq)
513
{
B
Borislav Petkov 已提交
514
	ide_debug_log(IDE_DBG_FUNC, "rq->cmd[0]: 0x%x", rq->cmd[0]);
515

516 517 518 519 520 521 522 523 524 525 526 527
	/*
	 * Some of the trailing request sense fields are optional,
	 * and some drives don't send them.  Sigh.
	 */
	if (rq->cmd[0] == GPCMD_REQUEST_SENSE &&
	    rq->data_len > 0 && rq->data_len <= 5)
		while (rq->data_len > 0) {
			*(u8 *)rq->data++ = 0;
			--rq->data_len;
		}
}

528 529 530 531
int ide_cd_queue_pc(ide_drive_t *drive, const unsigned char *cmd,
		    int write, void *buffer, unsigned *bufflen,
		    struct request_sense *sense, int timeout,
		    unsigned int cmd_flags)
L
Linus Torvalds 已提交
532
{
533 534
	struct cdrom_info *info = drive->driver_data;
	struct request_sense local_sense;
L
Linus Torvalds 已提交
535
	int retries = 10;
536
	unsigned int flags = 0;
L
Linus Torvalds 已提交
537

538 539
	if (!sense)
		sense = &local_sense;
L
Linus Torvalds 已提交
540

B
Borislav Petkov 已提交
541 542 543
	ide_debug_log(IDE_DBG_PC, "cmd[0]: 0x%x, write: 0x%x, timeout: %d, "
				  "cmd_flags: 0x%x",
				  cmd[0], write, timeout, cmd_flags);
544

B
Borislav Petkov 已提交
545
	/* start of retry loop */
L
Linus Torvalds 已提交
546
	do {
547
		struct request *rq;
L
Linus Torvalds 已提交
548 549
		int error;

550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568
		rq = blk_get_request(drive->queue, write, __GFP_WAIT);

		memcpy(rq->cmd, cmd, BLK_MAX_CDB);
		rq->cmd_type = REQ_TYPE_ATA_PC;
		rq->sense = sense;
		rq->cmd_flags |= cmd_flags;
		rq->timeout = timeout;
		if (buffer) {
			rq->data = buffer;
			rq->data_len = *bufflen;
		}

		error = blk_execute_rq(drive->queue, info->disk, rq, 0);

		if (buffer)
			*bufflen = rq->data_len;

		flags = rq->cmd_flags;
		blk_put_request(rq);
L
Linus Torvalds 已提交
569

B
Borislav Petkov 已提交
570 571 572 573
		/*
		 * FIXME: we should probably abort/retry or something in case of
		 * failure.
		 */
574
		if (flags & REQ_FAILED) {
B
Borislav Petkov 已提交
575 576 577 578
			/*
			 * The request failed.  Retry if it was due to a unit
			 * attention status (usually means media was changed).
			 */
579
			struct request_sense *reqbuf = sense;
L
Linus Torvalds 已提交
580 581 582 583 584

			if (reqbuf->sense_key == UNIT_ATTENTION)
				cdrom_saw_media_change(drive);
			else if (reqbuf->sense_key == NOT_READY &&
				 reqbuf->asc == 4 && reqbuf->ascq != 4) {
B
Borislav Petkov 已提交
585 586 587 588 589
				/*
				 * The drive is in the process of loading
				 * a disk.  Retry, but wait a little to give
				 * the drive time to complete the load.
				 */
L
Linus Torvalds 已提交
590 591
				ssleep(2);
			} else {
B
Borislav Petkov 已提交
592
				/* otherwise, don't retry */
L
Linus Torvalds 已提交
593 594 595 596 597
				retries = 0;
			}
			--retries;
		}

B
Borislav Petkov 已提交
598
		/* end of retry loop */
599
	} while ((flags & REQ_FAILED) && retries >= 0);
L
Linus Torvalds 已提交
600

B
Borislav Petkov 已提交
601
	/* return an error if the command failed */
602
	return (flags & REQ_FAILED) ? -EIO : 0;
L
Linus Torvalds 已提交
603 604
}

605 606 607 608 609 610 611 612 613 614 615
static void ide_cd_error_cmd(ide_drive_t *drive, struct ide_cmd *cmd)
{
	unsigned int nr_bytes = cmd->nbytes - cmd->nleft;

	if (cmd->tf_flags & IDE_TFLAG_WRITE)
		nr_bytes -= cmd->last_xfer_len;

	if (nr_bytes > 0)
		ide_complete_rq(drive, 0, nr_bytes);
}

616
/*
B
Borislav Petkov 已提交
617 618 619
 * Called from blk_end_request_callback() after the data of the request is
 * completed and before the request itself is completed. By returning value '1',
 * blk_end_request_callback() returns immediately without completing it.
620 621 622 623 624 625
 */
static int cdrom_newpc_intr_dummy_cb(struct request *rq)
{
	return 1;
}

L
Linus Torvalds 已提交
626 627
static ide_startstop_t cdrom_newpc_intr(ide_drive_t *drive)
{
628
	ide_hwif_t *hwif = drive->hwif;
629
	struct ide_cmd *cmd = &hwif->cmd;
630
	struct request *rq = hwif->rq;
L
Linus Torvalds 已提交
631
	xfer_func_t *xferfunc;
632
	ide_expiry_t *expiry = NULL;
633
	int dma_error = 0, dma, stat, thislen, uptodate = 0;
634
	int write = (rq_data_dir(rq) == WRITE) ? 1 : 0, rc, nsectors;
635
	int sense = blk_sense_request(rq);
636
	unsigned int timeout;
637 638
	u16 len;
	u8 ireason;
L
Linus Torvalds 已提交
639

B
Borislav Petkov 已提交
640 641
	ide_debug_log(IDE_DBG_PC, "cmd[0]: 0x%x, write: 0x%x",
				  rq->cmd[0], write);
642

B
Borislav Petkov 已提交
643
	/* check for errors */
644
	dma = drive->dma;
L
Linus Torvalds 已提交
645
	if (dma) {
646
		drive->dma = 0;
647
		dma_error = hwif->dma_ops->dma_end(drive);
648
		if (dma_error) {
649
			printk(KERN_ERR PFX "%s: DMA %s error\n", drive->name,
650
					write ? "write" : "read");
651 652
			ide_dma_off(drive);
		}
L
Linus Torvalds 已提交
653 654
	}

655 656 657 658
	rc = cdrom_decode_status(drive, 0, &stat);
	if (rc) {
		if (rc == 2)
			goto out_end;
L
Linus Torvalds 已提交
659
		return ide_stopped;
660
	}
L
Linus Torvalds 已提交
661

B
Borislav Petkov 已提交
662
	/* using dma, transfer is complete now */
L
Linus Torvalds 已提交
663
	if (dma) {
664
		if (dma_error)
L
Linus Torvalds 已提交
665
			return ide_error(drive, "dma error", stat);
666
		if (blk_fs_request(rq)) {
667 668
			ide_complete_rq(drive, 0, rq->nr_sectors
				? (rq->nr_sectors << 9) : ide_rq_bytes(rq));
669
			return ide_stopped;
670
		} else if (rq->cmd_type == REQ_TYPE_ATA_PC && !rq->bio) {
671
			ide_complete_rq(drive, 0, 512);
672
			return ide_stopped;
673
		}
674 675 676
		if (blk_pc_request(rq) == 0 && uptodate == 0)
			rq->cmd_flags |= REQ_FAILED;
		goto out_end;
L
Linus Torvalds 已提交
677 678
	}

679
	ide_read_bcount_and_ireason(drive, &len, &ireason);
680 681

	thislen = blk_fs_request(rq) ? len : rq->data_len;
L
Linus Torvalds 已提交
682 683 684
	if (thislen > len)
		thislen = len;

B
Borislav Petkov 已提交
685 686
	ide_debug_log(IDE_DBG_PC, "DRQ: stat: 0x%x, thislen: %d",
				  stat, thislen);
687

B
Borislav Petkov 已提交
688
	/* If DRQ is clear, the command has completed. */
689
	if ((stat & ATA_DRQ) == 0) {
690 691 692 693 694 695
		if (blk_fs_request(rq)) {
			/*
			 * If we're not done reading/writing, complain.
			 * Otherwise, complete the command normally.
			 */
			uptodate = 1;
696
			if (cmd->nleft > 0) {
697
				printk(KERN_ERR PFX "%s: %s: data underrun "
698 699
					"(%u bytes)\n", drive->name, __func__,
					cmd->nleft);
700 701 702 703 704
				if (!write)
					rq->cmd_flags |= REQ_FAILED;
				uptodate = 0;
			}
		} else if (!blk_pc_request(rq)) {
705
			ide_cd_request_sense_fixup(drive, rq);
B
Borislav Petkov 已提交
706
			/* complain if we still have data left to transfer */
707
			uptodate = rq->data_len ? 0 : 1;
708 709
			if (uptodate == 0)
				rq->cmd_flags |= REQ_FAILED;
710
		}
711
		goto out_end;
712
	}
L
Linus Torvalds 已提交
713

B
Borislav Petkov 已提交
714
	/* check which way to transfer data */
715 716 717
	rc = ide_cd_check_ireason(drive, rq, len, ireason, write);
	if (rc)
		goto out_end;
718

719
	cmd->last_xfer_len = 0;
L
Linus Torvalds 已提交
720

721 722
	if (ireason == 0) {
		write = 1;
723
		xferfunc = hwif->tp_ops->output_data;
724
	} else {
725
		write = 0;
726
		xferfunc = hwif->tp_ops->input_data;
L
Linus Torvalds 已提交
727 728
	}

B
Borislav Petkov 已提交
729 730 731
	ide_debug_log(IDE_DBG_PC, "data transfer, rq->cmd_type: 0x%x, "
				  "ireason: 0x%x",
				  rq->cmd_type, ireason);
732

B
Borislav Petkov 已提交
733
	/* transfer data */
L
Linus Torvalds 已提交
734
	while (thislen > 0) {
735
		u8 *ptr = blk_fs_request(rq) ? NULL : rq->data;
736
		int blen = rq->data_len;
L
Linus Torvalds 已提交
737

B
Borislav Petkov 已提交
738
		/* bio backed? */
L
Linus Torvalds 已提交
739
		if (rq->bio) {
740
			if (blk_fs_request(rq)) {
741
				blen = min_t(int, thislen, cmd->nleft);
742 743 744 745
			} else {
				ptr = bio_data(rq->bio);
				blen = bio_iovec(rq->bio)->bv_len;
			}
L
Linus Torvalds 已提交
746 747
		}

748 749
		if ((blk_fs_request(rq) && cmd->nleft == 0) ||
		    (blk_fs_request(rq) == 0 && ptr == NULL)) {
750 751
			if (blk_fs_request(rq) && !write)
				/*
752
				 * If the buffers are full, pipe the rest into
B
Borislav Petkov 已提交
753 754
				 * oblivion.
				 */
755
				ide_pad_transfer(drive, 0, thislen);
756
			else {
757
				printk(KERN_ERR PFX "%s: confused, missing data\n",
758 759 760 761 762
						drive->name);
				blk_dump_rq_flags(rq, rq_data_dir(rq)
						  ? "cdrom_newpc_intr, write"
						  : "cdrom_newpc_intr, read");
			}
L
Linus Torvalds 已提交
763 764 765 766 767 768
			break;
		}

		if (blen > thislen)
			blen = thislen;

769 770 771 772 773
		if (blk_fs_request(rq)) {
			ide_pio_bytes(drive, cmd, write, blen);
			cmd->last_xfer_len += blen;
		} else
			xferfunc(drive, NULL, ptr, blen);
L
Linus Torvalds 已提交
774 775 776 777

		thislen -= blen;
		len -= blen;

778
		if (blk_fs_request(rq) == 0) {
779 780
			rq->data_len -= blen;

781 782 783 784 785 786
			/*
			 * The request can't be completed until DRQ is cleared.
			 * So complete the data, but don't complete the request
			 * using the dummy function for the callback feature
			 * of blk_end_request_callback().
			 */
787 788
			if (rq->bio)
				blk_end_request_callback(rq, 0, blen,
789
						 cdrom_newpc_intr_dummy_cb);
790 791 792
			else
				rq->data += blen;
		}
793
		if (sense && write == 0)
A
Andreas Schwab 已提交
794
			rq->sense_len += blen;
L
Linus Torvalds 已提交
795 796
	}

B
Borislav Petkov 已提交
797
	/* pad, if necessary */
798
	if (!blk_fs_request(rq) && len > 0)
799
		ide_pad_transfer(drive, write, len);
L
Linus Torvalds 已提交
800

801 802 803 804
	if (blk_pc_request(rq)) {
		timeout = rq->timeout;
	} else {
		timeout = ATAPI_WAIT_PC;
805
		if (!blk_fs_request(rq))
806
			expiry = ide_cd_expiry;
807 808
	}

809 810
	hwif->expiry = expiry;
	ide_set_handler(drive, cdrom_newpc_intr, timeout);
L
Linus Torvalds 已提交
811
	return ide_started;
812

813
out_end:
814
	if (blk_pc_request(rq) && rc == 0) {
815 816 817 818
		unsigned int dlen = rq->data_len;

		if (dma)
			rq->data_len = 0;
819

820
		if (blk_end_request(rq, 0, dlen))
821
			BUG();
822

823
		hwif->rq = NULL;
824
	} else {
825 826 827 828
		if (sense && uptodate)
			ide_cd_complete_failed_rq(drive, rq);

		if (blk_fs_request(rq)) {
829
			if (cmd->nleft == 0)
830
				uptodate = 1;
831 832
			if (uptodate == 0)
				ide_cd_error_cmd(drive, cmd);
833 834 835 836 837 838 839 840 841
		} else {
			if (uptodate <= 0 && rq->errors == 0)
				rq->errors = -EIO;
		}

		/* make sure it's fully ended */
		if (blk_pc_request(rq))
			nsectors = (rq->data_len + 511) >> 9;
		else
842
			nsectors = rq->hard_nr_sectors;
843 844 845 846 847 848

		if (nsectors == 0)
			nsectors = 1;

		ide_complete_rq(drive, uptodate ? 0 : -EIO, nsectors << 9);

849 850
		if (sense && rc == 2)
			ide_error(drive, "request sense failure", stat);
851 852
	}
	return ide_stopped;
L
Linus Torvalds 已提交
853 854
}

855
static ide_startstop_t cdrom_start_rw(ide_drive_t *drive, struct request *rq)
L
Linus Torvalds 已提交
856
{
857
	struct cdrom_info *cd = drive->driver_data;
858
	struct request_queue *q = drive->queue;
859 860
	int write = rq_data_dir(rq) == WRITE;
	unsigned short sectors_per_frame =
861
		queue_hardsect_size(q) >> SECTOR_BITS;
L
Linus Torvalds 已提交
862

863
	ide_debug_log(IDE_DBG_RQ, "rq->cmd[0]: 0x%x, rq->cmd_flags: 0x%x, "
B
Borislav Petkov 已提交
864
				  "secs_per_frame: %u",
865
				  rq->cmd[0], rq->cmd_flags, sectors_per_frame);
866

867
	if (write) {
B
Borislav Petkov 已提交
868
		/* disk has become write protected */
869
		if (get_disk_ro(cd->disk))
870 871 872 873 874 875
			return ide_stopped;
	} else {
		/*
		 * We may be retrying this request after an error.  Fix up any
		 * weirdness which might be present in the request packet.
		 */
876
		q->prep_rq_fn(q, rq);
L
Linus Torvalds 已提交
877 878
	}

879
	/* fs requests *must* be hardware frame aligned */
880
	if ((rq->nr_sectors & (sectors_per_frame - 1)) ||
881 882 883 884 885
	    (rq->sector & (sectors_per_frame - 1)))
		return ide_stopped;

	/* use DMA, if possible */
	drive->dma = !!(drive->dev_flags & IDE_DFLAG_USING_DMA);
L
Linus Torvalds 已提交
886

887 888
	if (write)
		cd->devinfo.media_written = 1;
L
Linus Torvalds 已提交
889

890 891
	rq->timeout = ATAPI_WAIT_PC;

892
	return ide_started;
L
Linus Torvalds 已提交
893 894
}

895
static void cdrom_do_block_pc(ide_drive_t *drive, struct request *rq)
L
Linus Torvalds 已提交
896 897
{

B
Borislav Petkov 已提交
898 899
	ide_debug_log(IDE_DBG_PC, "rq->cmd[0]: 0x%x, rq->cmd_type: 0x%x",
				  rq->cmd[0], rq->cmd_type);
900

901 902 903 904
	if (blk_pc_request(rq))
		rq->cmd_flags |= REQ_QUIET;
	else
		rq->cmd_flags &= ~REQ_FAILED;
L
Linus Torvalds 已提交
905

906
	drive->dma = 0;
L
Linus Torvalds 已提交
907

B
Borislav Petkov 已提交
908
	/* sg request */
909 910 911
	if (rq->bio || ((rq->cmd_type == REQ_TYPE_ATA_PC) && rq->data_len)) {
		struct request_queue *q = drive->queue;
		unsigned int alignment;
912
		char *buf;
L
Linus Torvalds 已提交
913

914
		if (rq->bio)
915
			buf = bio_data(rq->bio);
916
		else
917
			buf = rq->data;
918

919
		drive->dma = !!(drive->dev_flags & IDE_DFLAG_USING_DMA);
L
Linus Torvalds 已提交
920 921 922

		/*
		 * check if dma is safe
923 924 925
		 *
		 * NOTE! The "len" and "addr" checks should possibly have
		 * separate masks.
L
Linus Torvalds 已提交
926
		 */
927
		alignment = queue_dma_alignment(q) | q->dma_pad_mask;
928 929
		if ((unsigned long)buf & alignment
		    || rq->data_len & q->dma_pad_mask
930
		    || object_is_on_stack(buf))
931
			drive->dma = 0;
L
Linus Torvalds 已提交
932 933 934
	}
}

935
static ide_startstop_t ide_cd_do_request(ide_drive_t *drive, struct request *rq,
936
					sector_t block)
L
Linus Torvalds 已提交
937
{
938
	struct ide_cmd cmd;
939
	int uptodate = 0, nsectors;
940

B
Borislav Petkov 已提交
941 942 943 944 945
	ide_debug_log(IDE_DBG_RQ, "cmd: 0x%x, block: %llu",
				  rq->cmd[0], (unsigned long long)block);

	if (drive->debug_mask & IDE_DBG_RQ)
		blk_dump_rq_flags(rq, "ide_cd_do_request");
946

L
Linus Torvalds 已提交
947
	if (blk_fs_request(rq)) {
948
		if (cdrom_start_rw(drive, rq) == ide_stopped)
949
			goto out_end;
950
	} else if (blk_sense_request(rq) || blk_pc_request(rq) ||
951
		   rq->cmd_type == REQ_TYPE_ATA_PC) {
952 953 954
		if (!rq->timeout)
			rq->timeout = ATAPI_WAIT_PC;

955
		cdrom_do_block_pc(drive, rq);
956
	} else if (blk_special_request(rq)) {
B
Borislav Petkov 已提交
957
		/* right now this can only be a reset... */
958 959
		uptodate = 1;
		goto out_end;
960
	} else {
961
		blk_dump_rq_flags(rq, DRV_NAME " bad flags");
962 963
		if (rq->errors == 0)
			rq->errors = -EIO;
964
		goto out_end;
L
Linus Torvalds 已提交
965
	}
966

967 968 969 970 971 972 973
	memset(&cmd, 0, sizeof(cmd));

	if (rq_data_dir(rq))
		cmd.tf_flags |= IDE_TFLAG_WRITE;

	cmd.rq = rq;

974 975 976 977 978
	if (blk_fs_request(rq)) {
		ide_init_sg_cmd(&cmd, rq->nr_sectors << 9);
		ide_map_sg(drive, &cmd);
	}

979
	return ide_issue_pc(drive, &cmd);
980
out_end:
981
	nsectors = rq->hard_nr_sectors;
982 983 984 985 986 987

	if (nsectors == 0)
		nsectors = 1;

	ide_complete_rq(drive, uptodate ? 0 : -EIO, nsectors << 9);

988
	return ide_stopped;
L
Linus Torvalds 已提交
989 990
}

B
Borislav Petkov 已提交
991
/*
L
Linus Torvalds 已提交
992 993
 * Ioctl handling.
 *
B
Borislav Petkov 已提交
994 995 996 997 998
 * Routines which queue packet commands take as a final argument a pointer to a
 * request_sense struct. If execution of the command results in an error with a
 * CHECK CONDITION status, this structure will be filled with the results of the
 * subsequent request sense command. The pointer can also be NULL, in which case
 * no sense information is returned.
L
Linus Torvalds 已提交
999
 */
1000
static void msf_from_bcd(struct atapi_msf *msf)
L
Linus Torvalds 已提交
1001
{
A
Adrian Bunk 已提交
1002 1003 1004
	msf->minute = bcd2bin(msf->minute);
	msf->second = bcd2bin(msf->second);
	msf->frame  = bcd2bin(msf->frame);
L
Linus Torvalds 已提交
1005 1006
}

1007
int cdrom_check_status(ide_drive_t *drive, struct request_sense *sense)
L
Linus Torvalds 已提交
1008 1009 1010
{
	struct cdrom_info *info = drive->driver_data;
	struct cdrom_device_info *cdi = &info->devinfo;
1011
	unsigned char cmd[BLK_MAX_CDB];
L
Linus Torvalds 已提交
1012

B
Borislav Petkov 已提交
1013
	ide_debug_log(IDE_DBG_FUNC, "enter");
1014

1015 1016
	memset(cmd, 0, BLK_MAX_CDB);
	cmd[0] = GPCMD_TEST_UNIT_READY;
L
Linus Torvalds 已提交
1017

1018
	/*
B
Borislav Petkov 已提交
1019 1020
	 * Sanyo 3 CD changer uses byte 7 of TEST_UNIT_READY to switch CDs
	 * instead of supporting the LOAD_UNLOAD opcode.
1021
	 */
1022
	cmd[7] = cdi->sanyo_slot % 3;
L
Linus Torvalds 已提交
1023

1024
	return ide_cd_queue_pc(drive, cmd, 0, NULL, NULL, sense, 0, REQ_QUIET);
L
Linus Torvalds 已提交
1025 1026 1027 1028 1029 1030 1031
}

static int cdrom_read_capacity(ide_drive_t *drive, unsigned long *capacity,
			       unsigned long *sectors_per_frame,
			       struct request_sense *sense)
{
	struct {
1032 1033
		__be32 lba;
		__be32 blocklen;
L
Linus Torvalds 已提交
1034 1035 1036
	} capbuf;

	int stat;
1037 1038
	unsigned char cmd[BLK_MAX_CDB];
	unsigned len = sizeof(capbuf);
1039
	u32 blocklen;
L
Linus Torvalds 已提交
1040

B
Borislav Petkov 已提交
1041
	ide_debug_log(IDE_DBG_FUNC, "enter");
1042

1043 1044
	memset(cmd, 0, BLK_MAX_CDB);
	cmd[0] = GPCMD_READ_CDVD_CAPACITY;
L
Linus Torvalds 已提交
1045

1046 1047
	stat = ide_cd_queue_pc(drive, cmd, 0, &capbuf, &len, sense, 0,
			       REQ_QUIET);
1048 1049 1050 1051 1052 1053
	if (stat)
		return stat;

	/*
	 * Sanity check the given block size
	 */
1054 1055 1056 1057 1058 1059
	blocklen = be32_to_cpu(capbuf.blocklen);
	switch (blocklen) {
	case 512:
	case 1024:
	case 2048:
	case 4096:
1060 1061
		break;
	default:
1062 1063 1064 1065
		printk(KERN_ERR PFX "%s: weird block size %u\n",
				drive->name, blocklen);
		printk(KERN_ERR PFX "%s: default to 2kb block size\n",
				drive->name);
1066
		blocklen = 2048;
1067
		break;
L
Linus Torvalds 已提交
1068 1069
	}

1070
	*capacity = 1 + be32_to_cpu(capbuf.lba);
1071
	*sectors_per_frame = blocklen >> SECTOR_BITS;
B
Borislav Petkov 已提交
1072

B
Borislav Petkov 已提交
1073 1074
	ide_debug_log(IDE_DBG_PROBE, "cap: %lu, sectors_per_frame: %lu",
				     *capacity, *sectors_per_frame);
B
Borislav Petkov 已提交
1075

1076
	return 0;
L
Linus Torvalds 已提交
1077 1078 1079 1080 1081 1082
}

static int cdrom_read_tocentry(ide_drive_t *drive, int trackno, int msf_flag,
				int format, char *buf, int buflen,
				struct request_sense *sense)
{
1083
	unsigned char cmd[BLK_MAX_CDB];
L
Linus Torvalds 已提交
1084

B
Borislav Petkov 已提交
1085
	ide_debug_log(IDE_DBG_FUNC, "enter");
1086

1087
	memset(cmd, 0, BLK_MAX_CDB);
L
Linus Torvalds 已提交
1088

1089 1090 1091 1092 1093
	cmd[0] = GPCMD_READ_TOC_PMA_ATIP;
	cmd[6] = trackno;
	cmd[7] = (buflen >> 8);
	cmd[8] = (buflen & 0xff);
	cmd[9] = (format << 6);
L
Linus Torvalds 已提交
1094 1095

	if (msf_flag)
1096
		cmd[1] = 2;
L
Linus Torvalds 已提交
1097

1098
	return ide_cd_queue_pc(drive, cmd, 0, buf, &buflen, sense, 0, REQ_QUIET);
L
Linus Torvalds 已提交
1099 1100 1101
}

/* Try to read the entire TOC for the disk into our internal buffer. */
1102
int ide_cd_read_toc(ide_drive_t *drive, struct request_sense *sense)
L
Linus Torvalds 已提交
1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114
{
	int stat, ntracks, i;
	struct cdrom_info *info = drive->driver_data;
	struct cdrom_device_info *cdi = &info->devinfo;
	struct atapi_toc *toc = info->toc;
	struct {
		struct atapi_toc_header hdr;
		struct atapi_toc_entry  ent;
	} ms_tmp;
	long last_written;
	unsigned long sectors_per_frame = SECTORS_PER_FRAME;

B
Borislav Petkov 已提交
1115
	ide_debug_log(IDE_DBG_FUNC, "enter");
1116

L
Linus Torvalds 已提交
1117
	if (toc == NULL) {
B
Borislav Petkov 已提交
1118
		/* try to allocate space */
J
Jesper Juhl 已提交
1119
		toc = kmalloc(sizeof(struct atapi_toc), GFP_KERNEL);
L
Linus Torvalds 已提交
1120
		if (toc == NULL) {
1121
			printk(KERN_ERR PFX "%s: No cdrom TOC buffer!\n",
1122
					drive->name);
L
Linus Torvalds 已提交
1123 1124
			return -ENOMEM;
		}
J
Jesper Juhl 已提交
1125
		info->toc = toc;
L
Linus Torvalds 已提交
1126 1127
	}

B
Borislav Petkov 已提交
1128 1129 1130 1131
	/*
	 * Check to see if the existing data is still valid. If it is,
	 * just return.
	 */
L
Linus Torvalds 已提交
1132 1133
	(void) cdrom_check_status(drive, sense);

1134
	if (drive->atapi_flags & IDE_AFLAG_TOC_VALID)
L
Linus Torvalds 已提交
1135 1136
		return 0;

B
Borislav Petkov 已提交
1137
	/* try to get the total cdrom capacity and sector size */
L
Linus Torvalds 已提交
1138 1139 1140 1141 1142 1143
	stat = cdrom_read_capacity(drive, &toc->capacity, &sectors_per_frame,
				   sense);
	if (stat)
		toc->capacity = 0x1fffff;

	set_capacity(info->disk, toc->capacity * sectors_per_frame);
B
Borislav Petkov 已提交
1144
	/* save a private copy of the TOC capacity for error handling */
A
Alan Cox 已提交
1145 1146
	drive->probed_capacity = toc->capacity * sectors_per_frame;

L
Linus Torvalds 已提交
1147 1148 1149
	blk_queue_hardsect_size(drive->queue,
				sectors_per_frame << SECTOR_BITS);

B
Borislav Petkov 已提交
1150
	/* first read just the header, so we know how long the TOC is */
L
Linus Torvalds 已提交
1151 1152
	stat = cdrom_read_tocentry(drive, 0, 1, 0, (char *) &toc->hdr,
				    sizeof(struct atapi_toc_header), sense);
J
Jesper Juhl 已提交
1153 1154
	if (stat)
		return stat;
L
Linus Torvalds 已提交
1155

1156
	if (drive->atapi_flags & IDE_AFLAG_TOCTRACKS_AS_BCD) {
A
Adrian Bunk 已提交
1157 1158
		toc->hdr.first_track = bcd2bin(toc->hdr.first_track);
		toc->hdr.last_track  = bcd2bin(toc->hdr.last_track);
L
Linus Torvalds 已提交
1159 1160 1161 1162 1163 1164 1165 1166
	}

	ntracks = toc->hdr.last_track - toc->hdr.first_track + 1;
	if (ntracks <= 0)
		return -EIO;
	if (ntracks > MAX_TRACKS)
		ntracks = MAX_TRACKS;

B
Borislav Petkov 已提交
1167
	/* now read the whole schmeer */
L
Linus Torvalds 已提交
1168 1169 1170 1171 1172 1173 1174
	stat = cdrom_read_tocentry(drive, toc->hdr.first_track, 1, 0,
				  (char *)&toc->hdr,
				   sizeof(struct atapi_toc_header) +
				   (ntracks + 1) *
				   sizeof(struct atapi_toc_entry), sense);

	if (stat && toc->hdr.first_track > 1) {
B
Borislav Petkov 已提交
1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186
		/*
		 * Cds with CDI tracks only don't have any TOC entries, despite
		 * of this the returned values are
		 * first_track == last_track = number of CDI tracks + 1,
		 * so that this case is indistinguishable from the same layout
		 * plus an additional audio track. If we get an error for the
		 * regular case, we assume a CDI without additional audio
		 * tracks. In this case the readable TOC is empty (CDI tracks
		 * are not included) and only holds the Leadout entry.
		 *
		 * Heiko Eißfeldt.
		 */
L
Linus Torvalds 已提交
1187 1188 1189 1190 1191 1192 1193
		ntracks = 0;
		stat = cdrom_read_tocentry(drive, CDROM_LEADOUT, 1, 0,
					   (char *)&toc->hdr,
					   sizeof(struct atapi_toc_header) +
					   (ntracks + 1) *
					   sizeof(struct atapi_toc_entry),
					   sense);
1194
		if (stat)
L
Linus Torvalds 已提交
1195
			return stat;
1196

1197
		if (drive->atapi_flags & IDE_AFLAG_TOCTRACKS_AS_BCD) {
A
Adrian Bunk 已提交
1198 1199
			toc->hdr.first_track = (u8)bin2bcd(CDROM_LEADOUT);
			toc->hdr.last_track = (u8)bin2bcd(CDROM_LEADOUT);
1200
		} else {
L
Linus Torvalds 已提交
1201 1202 1203 1204 1205 1206 1207 1208
			toc->hdr.first_track = CDROM_LEADOUT;
			toc->hdr.last_track = CDROM_LEADOUT;
		}
	}

	if (stat)
		return stat;

1209
	toc->hdr.toc_length = be16_to_cpu(toc->hdr.toc_length);
L
Linus Torvalds 已提交
1210

1211
	if (drive->atapi_flags & IDE_AFLAG_TOCTRACKS_AS_BCD) {
A
Adrian Bunk 已提交
1212 1213
		toc->hdr.first_track = bcd2bin(toc->hdr.first_track);
		toc->hdr.last_track  = bcd2bin(toc->hdr.last_track);
L
Linus Torvalds 已提交
1214 1215
	}

1216
	for (i = 0; i <= ntracks; i++) {
1217 1218
		if (drive->atapi_flags & IDE_AFLAG_TOCADDR_AS_BCD) {
			if (drive->atapi_flags & IDE_AFLAG_TOCTRACKS_AS_BCD)
A
Adrian Bunk 已提交
1219
				toc->ent[i].track = bcd2bin(toc->ent[i].track);
L
Linus Torvalds 已提交
1220 1221
			msf_from_bcd(&toc->ent[i].addr.msf);
		}
1222 1223 1224
		toc->ent[i].addr.lba = msf_to_lba(toc->ent[i].addr.msf.minute,
						  toc->ent[i].addr.msf.second,
						  toc->ent[i].addr.msf.frame);
L
Linus Torvalds 已提交
1225 1226 1227
	}

	if (toc->hdr.first_track != CDROM_LEADOUT) {
B
Borislav Petkov 已提交
1228
		/* read the multisession information */
L
Linus Torvalds 已提交
1229 1230
		stat = cdrom_read_tocentry(drive, 0, 0, 1, (char *)&ms_tmp,
					   sizeof(ms_tmp), sense);
J
Jesper Juhl 已提交
1231 1232
		if (stat)
			return stat;
L
Linus Torvalds 已提交
1233 1234 1235

		toc->last_session_lba = be32_to_cpu(ms_tmp.ent.addr.lba);
	} else {
1236 1237
		ms_tmp.hdr.last_track = CDROM_LEADOUT;
		ms_tmp.hdr.first_track = ms_tmp.hdr.last_track;
L
Linus Torvalds 已提交
1238 1239 1240
		toc->last_session_lba = msf_to_lba(0, 2, 0); /* 0m 2s 0f */
	}

1241
	if (drive->atapi_flags & IDE_AFLAG_TOCADDR_AS_BCD) {
B
Borislav Petkov 已提交
1242
		/* re-read multisession information using MSF format */
L
Linus Torvalds 已提交
1243 1244 1245 1246 1247
		stat = cdrom_read_tocentry(drive, 0, 1, 1, (char *)&ms_tmp,
					   sizeof(ms_tmp), sense);
		if (stat)
			return stat;

1248
		msf_from_bcd(&ms_tmp.ent.addr.msf);
L
Linus Torvalds 已提交
1249
		toc->last_session_lba = msf_to_lba(ms_tmp.ent.addr.msf.minute,
1250
						   ms_tmp.ent.addr.msf.second,
L
Linus Torvalds 已提交
1251 1252 1253 1254 1255
						   ms_tmp.ent.addr.msf.frame);
	}

	toc->xa_flag = (ms_tmp.hdr.first_track != ms_tmp.hdr.last_track);

B
Borislav Petkov 已提交
1256
	/* now try to get the total cdrom capacity */
L
Linus Torvalds 已提交
1257 1258 1259 1260
	stat = cdrom_get_last_written(cdi, &last_written);
	if (!stat && (last_written > toc->capacity)) {
		toc->capacity = last_written;
		set_capacity(info->disk, toc->capacity * sectors_per_frame);
A
Alan Cox 已提交
1261
		drive->probed_capacity = toc->capacity * sectors_per_frame;
L
Linus Torvalds 已提交
1262 1263 1264
	}

	/* Remember that we've read this stuff. */
1265
	drive->atapi_flags |= IDE_AFLAG_TOC_VALID;
L
Linus Torvalds 已提交
1266 1267 1268 1269

	return 0;
}

1270
int ide_cdrom_get_capabilities(ide_drive_t *drive, u8 *buf)
E
Eric Piel 已提交
1271 1272 1273 1274
{
	struct cdrom_info *info = drive->driver_data;
	struct cdrom_device_info *cdi = &info->devinfo;
	struct packet_command cgc;
1275
	int stat, attempts = 3, size = ATAPI_CAPABILITIES_PAGE_SIZE;
E
Eric Piel 已提交
1276

B
Borislav Petkov 已提交
1277
	ide_debug_log(IDE_DBG_FUNC, "enter");
1278

1279
	if ((drive->atapi_flags & IDE_AFLAG_FULL_CAPS_PAGE) == 0)
1280
		size -= ATAPI_CAPABILITIES_PAGE_PAD_SIZE;
E
Eric Piel 已提交
1281

1282
	init_cdrom_command(&cgc, buf, size, CGC_DATA_UNKNOWN);
B
Borislav Petkov 已提交
1283 1284
	do {
		/* we seem to get stat=0x01,err=0x00 the first time (??) */
E
Eric Piel 已提交
1285 1286 1287 1288 1289 1290 1291
		stat = cdrom_mode_sense(cdi, &cgc, GPMODE_CAPABILITIES_PAGE, 0);
		if (!stat)
			break;
	} while (--attempts);
	return stat;
}

1292
void ide_cdrom_update_speed(ide_drive_t *drive, u8 *buf)
E
Eric Piel 已提交
1293
{
1294
	struct cdrom_info *cd = drive->driver_data;
1295 1296
	u16 curspeed, maxspeed;

B
Borislav Petkov 已提交
1297
	ide_debug_log(IDE_DBG_FUNC, "enter");
1298

1299
	if (drive->atapi_flags & IDE_AFLAG_LE_SPEED_FIELDS) {
1300 1301
		curspeed = le16_to_cpup((__le16 *)&buf[8 + 14]);
		maxspeed = le16_to_cpup((__le16 *)&buf[8 + 8]);
E
Eric Piel 已提交
1302
	} else {
1303 1304
		curspeed = be16_to_cpup((__be16 *)&buf[8 + 14]);
		maxspeed = be16_to_cpup((__be16 *)&buf[8 + 8]);
E
Eric Piel 已提交
1305
	}
1306

B
Borislav Petkov 已提交
1307 1308
	ide_debug_log(IDE_DBG_PROBE, "curspeed: %u, maxspeed: %u",
				     curspeed, maxspeed);
B
Borislav Petkov 已提交
1309

1310 1311
	cd->current_speed = (curspeed + (176/2)) / 176;
	cd->max_speed = (maxspeed + (176/2)) / 176;
E
Eric Piel 已提交
1312 1313
}

1314 1315 1316 1317 1318 1319
#define IDE_CD_CAPABILITIES \
	(CDC_CLOSE_TRAY | CDC_OPEN_TRAY | CDC_LOCK | CDC_SELECT_SPEED | \
	 CDC_SELECT_DISC | CDC_MULTI_SESSION | CDC_MCN | CDC_MEDIA_CHANGED | \
	 CDC_PLAY_AUDIO | CDC_RESET | CDC_DRIVE_STATUS | CDC_CD_R | \
	 CDC_CD_RW | CDC_DVD | CDC_DVD_R | CDC_DVD_RAM | CDC_GENERIC_PACKET | \
	 CDC_MO_DRIVE | CDC_MRW | CDC_MRW_W | CDC_RAM)
L
Linus Torvalds 已提交
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332

static struct cdrom_device_ops ide_cdrom_dops = {
	.open			= ide_cdrom_open_real,
	.release		= ide_cdrom_release_real,
	.drive_status		= ide_cdrom_drive_status,
	.media_changed		= ide_cdrom_check_media_change_real,
	.tray_move		= ide_cdrom_tray_move,
	.lock_door		= ide_cdrom_lock_door,
	.select_speed		= ide_cdrom_select_speed,
	.get_last_session	= ide_cdrom_get_last_session,
	.get_mcn		= ide_cdrom_get_mcn,
	.reset			= ide_cdrom_reset,
	.audio_ioctl		= ide_cdrom_audio_ioctl,
1333
	.capability		= IDE_CD_CAPABILITIES,
L
Linus Torvalds 已提交
1334 1335 1336
	.generic_packet		= ide_cdrom_packet,
};

1337
static int ide_cdrom_register(ide_drive_t *drive, int nslots)
L
Linus Torvalds 已提交
1338 1339 1340 1341
{
	struct cdrom_info *info = drive->driver_data;
	struct cdrom_device_info *devinfo = &info->devinfo;

B
Borislav Petkov 已提交
1342
	ide_debug_log(IDE_DBG_PROBE, "nslots: %d", nslots);
1343

L
Linus Torvalds 已提交
1344
	devinfo->ops = &ide_cdrom_dops;
1345
	devinfo->speed = info->current_speed;
L
Linus Torvalds 已提交
1346
	devinfo->capacity = nslots;
J
Jesper Juhl 已提交
1347
	devinfo->handle = drive;
L
Linus Torvalds 已提交
1348 1349
	strcpy(devinfo->name, drive->name);

1350
	if (drive->atapi_flags & IDE_AFLAG_NO_SPEED_SELECT)
1351 1352
		devinfo->mask |= CDC_SELECT_SPEED;

L
Linus Torvalds 已提交
1353 1354 1355 1356
	devinfo->disk = info->disk;
	return register_cdrom(devinfo);
}

1357
static int ide_cdrom_probe_capabilities(ide_drive_t *drive)
L
Linus Torvalds 已提交
1358
{
1359 1360
	struct cdrom_info *cd = drive->driver_data;
	struct cdrom_device_info *cdi = &cd->devinfo;
1361 1362
	u8 buf[ATAPI_CAPABILITIES_PAGE_SIZE];
	mechtype_t mechtype;
L
Linus Torvalds 已提交
1363 1364
	int nslots = 1;

B
Borislav Petkov 已提交
1365 1366
	ide_debug_log(IDE_DBG_PROBE, "media: 0x%x, atapi_flags: 0x%lx",
				     drive->media, drive->atapi_flags);
1367

1368 1369 1370 1371
	cdi->mask = (CDC_CD_R | CDC_CD_RW | CDC_DVD | CDC_DVD_R |
		     CDC_DVD_RAM | CDC_SELECT_DISC | CDC_PLAY_AUDIO |
		     CDC_MO_DRIVE | CDC_RAM);

L
Linus Torvalds 已提交
1372
	if (drive->media == ide_optical) {
1373
		cdi->mask &= ~(CDC_MO_DRIVE | CDC_RAM);
1374
		printk(KERN_ERR PFX "%s: ATAPI magneto-optical drive\n",
1375
				drive->name);
L
Linus Torvalds 已提交
1376 1377 1378
		return nslots;
	}

1379 1380
	if (drive->atapi_flags & IDE_AFLAG_PRE_ATAPI12) {
		drive->atapi_flags &= ~IDE_AFLAG_NO_EJECT;
1381
		cdi->mask &= ~CDC_PLAY_AUDIO;
L
Linus Torvalds 已提交
1382 1383 1384 1385
		return nslots;
	}

	/*
B
Borislav Petkov 已提交
1386 1387 1388 1389
	 * We have to cheat a little here. the packet will eventually be queued
	 * with ide_cdrom_packet(), which extracts the drive from cdi->handle.
	 * Since this device hasn't been registered with the Uniform layer yet,
	 * it can't do this. Same goes for cdi->ops.
L
Linus Torvalds 已提交
1390
	 */
J
Jesper Juhl 已提交
1391
	cdi->handle = drive;
L
Linus Torvalds 已提交
1392 1393
	cdi->ops = &ide_cdrom_dops;

1394
	if (ide_cdrom_get_capabilities(drive, buf))
L
Linus Torvalds 已提交
1395 1396
		return 0;

1397
	if ((buf[8 + 6] & 0x01) == 0)
1398
		drive->dev_flags &= ~IDE_DFLAG_DOORLOCKING;
1399
	if (buf[8 + 6] & 0x08)
1400
		drive->atapi_flags &= ~IDE_AFLAG_NO_EJECT;
1401
	if (buf[8 + 3] & 0x01)
1402
		cdi->mask &= ~CDC_CD_R;
1403
	if (buf[8 + 3] & 0x02)
1404
		cdi->mask &= ~(CDC_CD_RW | CDC_RAM);
1405
	if (buf[8 + 2] & 0x38)
1406
		cdi->mask &= ~CDC_DVD;
1407
	if (buf[8 + 3] & 0x20)
1408
		cdi->mask &= ~(CDC_DVD_RAM | CDC_RAM);
1409
	if (buf[8 + 3] & 0x10)
1410
		cdi->mask &= ~CDC_DVD_R;
1411
	if ((buf[8 + 4] & 0x01) || (drive->atapi_flags & IDE_AFLAG_PLAY_AUDIO_OK))
1412
		cdi->mask &= ~CDC_PLAY_AUDIO;
1413 1414

	mechtype = buf[8 + 6] >> 5;
B
Borislav Petkov 已提交
1415 1416 1417
	if (mechtype == mechtype_caddy ||
	    mechtype == mechtype_popup ||
	    (drive->atapi_flags & IDE_AFLAG_NO_AUTOCLOSE))
1418
		cdi->mask |= CDC_CLOSE_TRAY;
L
Linus Torvalds 已提交
1419 1420

	if (cdi->sanyo_slot > 0) {
1421
		cdi->mask &= ~CDC_SELECT_DISC;
L
Linus Torvalds 已提交
1422
		nslots = 3;
1423 1424
	} else if (mechtype == mechtype_individual_changer ||
		   mechtype == mechtype_cartridge_changer) {
1425 1426
		nslots = cdrom_number_of_slots(cdi);
		if (nslots > 1)
1427
			cdi->mask &= ~CDC_SELECT_DISC;
L
Linus Torvalds 已提交
1428 1429
	}

1430
	ide_cdrom_update_speed(drive, buf);
1431

1432
	printk(KERN_INFO PFX "%s: ATAPI", drive->name);
1433 1434

	/* don't print speed if the drive reported 0 */
1435 1436
	if (cd->max_speed)
		printk(KERN_CONT " %dX", cd->max_speed);
1437

1438
	printk(KERN_CONT " %s", (cdi->mask & CDC_DVD) ? "CD-ROM" : "DVD-ROM");
L
Linus Torvalds 已提交
1439

1440 1441 1442
	if ((cdi->mask & CDC_DVD_R) == 0 || (cdi->mask & CDC_DVD_RAM) == 0)
		printk(KERN_CONT " DVD%s%s",
				 (cdi->mask & CDC_DVD_R) ? "" : "-R",
1443
				 (cdi->mask & CDC_DVD_RAM) ? "" : "/RAM");
L
Linus Torvalds 已提交
1444

1445 1446 1447 1448
	if ((cdi->mask & CDC_CD_R) == 0 || (cdi->mask & CDC_CD_RW) == 0)
		printk(KERN_CONT " CD%s%s",
				 (cdi->mask & CDC_CD_R) ? "" : "-R",
				 (cdi->mask & CDC_CD_RW) ? "" : "/RW");
L
Linus Torvalds 已提交
1449

1450 1451 1452 1453
	if ((cdi->mask & CDC_SELECT_DISC) == 0)
		printk(KERN_CONT " changer w/%d slots", nslots);
	else
		printk(KERN_CONT " drive");
L
Linus Torvalds 已提交
1454

1455 1456
	printk(KERN_CONT ", %dkB Cache\n",
			 be16_to_cpup((__be16 *)&buf[8 + 12]));
L
Linus Torvalds 已提交
1457 1458 1459 1460

	return nslots;
}

B
Borislav Petkov 已提交
1461
/* standard prep_rq_fn that builds 10 byte cmds */
1462
static int ide_cdrom_prep_fs(struct request_queue *q, struct request *rq)
L
Linus Torvalds 已提交
1463 1464 1465 1466 1467
{
	int hard_sect = queue_hardsect_size(q);
	long block = (long)rq->hard_sector / (hard_sect >> 9);
	unsigned long blocks = rq->hard_nr_sectors / (hard_sect >> 9);

1468
	memset(rq->cmd, 0, BLK_MAX_CDB);
L
Linus Torvalds 已提交
1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499

	if (rq_data_dir(rq) == READ)
		rq->cmd[0] = GPCMD_READ_10;
	else
		rq->cmd[0] = GPCMD_WRITE_10;

	/*
	 * fill in lba
	 */
	rq->cmd[2] = (block >> 24) & 0xff;
	rq->cmd[3] = (block >> 16) & 0xff;
	rq->cmd[4] = (block >>  8) & 0xff;
	rq->cmd[5] = block & 0xff;

	/*
	 * and transfer length
	 */
	rq->cmd[7] = (blocks >> 8) & 0xff;
	rq->cmd[8] = blocks & 0xff;
	rq->cmd_len = 10;
	return BLKPREP_OK;
}

/*
 * Most of the SCSI commands are supported directly by ATAPI devices.
 * This transform handles the few exceptions.
 */
static int ide_cdrom_prep_pc(struct request *rq)
{
	u8 *c = rq->cmd;

B
Borislav Petkov 已提交
1500
	/* transform 6-byte read/write commands to the 10-byte version */
L
Linus Torvalds 已提交
1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521
	if (c[0] == READ_6 || c[0] == WRITE_6) {
		c[8] = c[4];
		c[5] = c[3];
		c[4] = c[2];
		c[3] = c[1] & 0x1f;
		c[2] = 0;
		c[1] &= 0xe0;
		c[0] += (READ_10 - READ_6);
		rq->cmd_len = 10;
		return BLKPREP_OK;
	}

	/*
	 * it's silly to pretend we understand 6-byte sense commands, just
	 * reject with ILLEGAL_REQUEST and the caller should take the
	 * appropriate action
	 */
	if (c[0] == MODE_SENSE || c[0] == MODE_SELECT) {
		rq->errors = ILLEGAL_REQUEST;
		return BLKPREP_KILL;
	}
1522

L
Linus Torvalds 已提交
1523 1524 1525
	return BLKPREP_OK;
}

1526
static int ide_cdrom_prep_fn(struct request_queue *q, struct request *rq)
L
Linus Torvalds 已提交
1527
{
1528
	if (blk_fs_request(rq))
L
Linus Torvalds 已提交
1529
		return ide_cdrom_prep_fs(q, rq);
1530
	else if (blk_pc_request(rq))
L
Linus Torvalds 已提交
1531 1532 1533 1534 1535
		return ide_cdrom_prep_pc(rq);

	return 0;
}

1536 1537 1538 1539 1540 1541
struct cd_list_entry {
	const char	*id_model;
	const char	*id_firmware;
	unsigned int	cd_flags;
};

1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552
#ifdef CONFIG_IDE_PROC_FS
static sector_t ide_cdrom_capacity(ide_drive_t *drive)
{
	unsigned long capacity, sectors_per_frame;

	if (cdrom_read_capacity(drive, &capacity, &sectors_per_frame, NULL))
		return 0;

	return capacity * sectors_per_frame;
}

1553 1554
static int proc_idecd_read_capacity(char *page, char **start, off_t off,
					int count, int *eof, void *data)
1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567
{
	ide_drive_t *drive = data;
	int len;

	len = sprintf(page, "%llu\n", (long long)ide_cdrom_capacity(drive));
	PROC_IDE_READ_RETURN(page, start, off, count, eof, len);
}

static ide_proc_entry_t idecd_proc[] = {
	{ "capacity", S_IFREG|S_IRUGO, proc_idecd_read_capacity, NULL },
	{ NULL, 0, NULL, NULL }
};

1568 1569 1570 1571 1572 1573 1574
static ide_proc_entry_t *ide_cd_proc_entries(ide_drive_t *drive)
{
	return idecd_proc;
}

static const struct ide_proc_devset *ide_cd_proc_devsets(ide_drive_t *drive)
{
1575
	return NULL;
1576
}
1577 1578
#endif

1579 1580
static const struct cd_list_entry ide_cd_quirks_list[] = {
	/* SCR-3231 doesn't support the SET_CD_SPEED command. */
1581
	{ "SAMSUNG CD-ROM SCR-3231", NULL,   IDE_AFLAG_NO_SPEED_SELECT	     },
1582
	/* Old NEC260 (not R) was released before ATAPI 1.2 spec. */
1583 1584
	{ "NEC CD-ROM DRIVE:260",    "1.01", IDE_AFLAG_TOCADDR_AS_BCD |
					     IDE_AFLAG_PRE_ATAPI12,	     },
1585
	/* Vertos 300, some versions of this drive like to talk BCD. */
1586
	{ "V003S0DS",		     NULL,   IDE_AFLAG_VERTOS_300_SSD,	     },
1587
	/* Vertos 600 ESD. */
1588
	{ "V006E0DS",		     NULL,   IDE_AFLAG_VERTOS_600_ESD,	     },
1589 1590 1591 1592
	/*
	 * Sanyo 3 CD changer uses a non-standard command for CD changing
	 * (by default standard ATAPI support for CD changers is used).
	 */
1593 1594 1595
	{ "CD-ROM CDR-C3 G",	     NULL,   IDE_AFLAG_SANYO_3CD	     },
	{ "CD-ROM CDR-C3G",	     NULL,   IDE_AFLAG_SANYO_3CD	     },
	{ "CD-ROM CDR_C36",	     NULL,   IDE_AFLAG_SANYO_3CD	     },
1596
	/* Stingray 8X CD-ROM. */
1597
	{ "STINGRAY 8422 IDE 8X CD-ROM 7-27-95", NULL, IDE_AFLAG_PRE_ATAPI12 },
1598 1599 1600 1601
	/*
	 * ACER 50X CD-ROM and WPI 32X CD-ROM require the full spec length
	 * mode sense page capabilities size, but older drives break.
	 */
1602 1603
	{ "ATAPI CD ROM DRIVE 50X MAX",	NULL,	IDE_AFLAG_FULL_CAPS_PAGE     },
	{ "WPI CDS-32X",		NULL,	IDE_AFLAG_FULL_CAPS_PAGE     },
1604
	/* ACER/AOpen 24X CD-ROM has the speed fields byte-swapped. */
1605
	{ "",			     "241N", IDE_AFLAG_LE_SPEED_FIELDS       },
1606 1607 1608 1609
	/*
	 * Some drives used by Apple don't advertise audio play
	 * but they do support reading TOC & audio datas.
	 */
1610 1611 1612 1613 1614
	{ "MATSHITADVD-ROM SR-8187", NULL,   IDE_AFLAG_PLAY_AUDIO_OK	     },
	{ "MATSHITADVD-ROM SR-8186", NULL,   IDE_AFLAG_PLAY_AUDIO_OK	     },
	{ "MATSHITADVD-ROM SR-8176", NULL,   IDE_AFLAG_PLAY_AUDIO_OK	     },
	{ "MATSHITADVD-ROM SR-8174", NULL,   IDE_AFLAG_PLAY_AUDIO_OK	     },
	{ "Optiarc DVD RW AD-5200A", NULL,   IDE_AFLAG_PLAY_AUDIO_OK	     },
1615
	{ "Optiarc DVD RW AD-7200A", NULL,   IDE_AFLAG_PLAY_AUDIO_OK	     },
B
Borislav Petkov 已提交
1616
	{ "Optiarc DVD RW AD-7543A", NULL,   IDE_AFLAG_NO_AUTOCLOSE	     },
1617
	{ "TEAC CD-ROM CD-224E",     NULL,   IDE_AFLAG_NO_AUTOCLOSE	     },
1618 1619 1620
	{ NULL, NULL, 0 }
};

1621
static unsigned int ide_cd_flags(u16 *id)
1622 1623 1624 1625
{
	const struct cd_list_entry *cle = ide_cd_quirks_list;

	while (cle->id_model) {
1626
		if (strcmp(cle->id_model, (char *)&id[ATA_ID_PROD]) == 0 &&
1627
		    (cle->id_firmware == NULL ||
1628
		     strstr((char *)&id[ATA_ID_FW_REV], cle->id_firmware)))
1629 1630 1631 1632 1633 1634 1635
			return cle->cd_flags;
		cle++;
	}

	return 0;
}

1636
static int ide_cdrom_setup(ide_drive_t *drive)
L
Linus Torvalds 已提交
1637
{
1638 1639
	struct cdrom_info *cd = drive->driver_data;
	struct cdrom_device_info *cdi = &cd->devinfo;
1640 1641
	u16 *id = drive->id;
	char *fw_rev = (char *)&id[ATA_ID_FW_REV];
L
Linus Torvalds 已提交
1642 1643
	int nslots;

B
Borislav Petkov 已提交
1644
	ide_debug_log(IDE_DBG_PROBE, "enter");
1645

L
Linus Torvalds 已提交
1646 1647
	blk_queue_prep_rq(drive->queue, ide_cdrom_prep_fn);
	blk_queue_dma_alignment(drive->queue, 31);
1648
	blk_queue_update_dma_pad(drive->queue, 15);
L
Linus Torvalds 已提交
1649 1650 1651 1652
	drive->queue->unplug_delay = (1 * HZ) / 1000;
	if (!drive->queue->unplug_delay)
		drive->queue->unplug_delay = 1;

1653 1654
	drive->dev_flags |= IDE_DFLAG_MEDIA_CHANGED;
	drive->atapi_flags = IDE_AFLAG_NO_EJECT | ide_cd_flags(id);
L
Linus Torvalds 已提交
1655

1656
	if ((drive->atapi_flags & IDE_AFLAG_VERTOS_300_SSD) &&
1657
	    fw_rev[4] == '1' && fw_rev[6] <= '2')
1658 1659 1660
		drive->atapi_flags |= (IDE_AFLAG_TOCTRACKS_AS_BCD |
				     IDE_AFLAG_TOCADDR_AS_BCD);
	else if ((drive->atapi_flags & IDE_AFLAG_VERTOS_600_ESD) &&
1661
		 fw_rev[4] == '1' && fw_rev[6] <= '2')
1662 1663
		drive->atapi_flags |= IDE_AFLAG_TOCTRACKS_AS_BCD;
	else if (drive->atapi_flags & IDE_AFLAG_SANYO_3CD)
B
Borislav Petkov 已提交
1664 1665
		/* 3 => use CD in slot 0 */
		cdi->sanyo_slot = 3;
L
Linus Torvalds 已提交
1666

1667
	nslots = ide_cdrom_probe_capabilities(drive);
L
Linus Torvalds 已提交
1668

B
Borislav Petkov 已提交
1669
	/* set correct block size */
L
Linus Torvalds 已提交
1670 1671 1672
	blk_queue_hardsect_size(drive->queue, CD_FRAMESIZE);

	if (ide_cdrom_register(drive, nslots)) {
1673
		printk(KERN_ERR PFX "%s: %s failed to register device with the"
1674
				" cdrom driver.\n", drive->name, __func__);
1675
		cd->devinfo.handle = NULL;
L
Linus Torvalds 已提交
1676 1677
		return 1;
	}
1678 1679

	ide_proc_register_driver(drive, cd->driver);
L
Linus Torvalds 已提交
1680 1681 1682
	return 0;
}

1683
static void ide_cd_remove(ide_drive_t *drive)
L
Linus Torvalds 已提交
1684 1685 1686
{
	struct cdrom_info *info = drive->driver_data;

B
Borislav Petkov 已提交
1687
	ide_debug_log(IDE_DBG_FUNC, "enter");
1688

1689
	ide_proc_unregister_driver(drive, info->driver);
1690
	device_del(&info->dev);
L
Linus Torvalds 已提交
1691 1692
	del_gendisk(info->disk);

1693 1694 1695
	mutex_lock(&idecd_ref_mutex);
	put_device(&info->dev);
	mutex_unlock(&idecd_ref_mutex);
L
Linus Torvalds 已提交
1696 1697
}

1698
static void ide_cd_release(struct device *dev)
L
Linus Torvalds 已提交
1699
{
1700
	struct cdrom_info *info = to_ide_drv(dev, cdrom_info);
L
Linus Torvalds 已提交
1701 1702 1703 1704
	struct cdrom_device_info *devinfo = &info->devinfo;
	ide_drive_t *drive = info->drive;
	struct gendisk *g = info->disk;

B
Borislav Petkov 已提交
1705
	ide_debug_log(IDE_DBG_FUNC, "enter");
1706

1707
	kfree(info->toc);
1708 1709
	if (devinfo->handle == drive)
		unregister_cdrom(devinfo);
L
Linus Torvalds 已提交
1710 1711 1712 1713 1714 1715 1716
	drive->driver_data = NULL;
	blk_queue_prep_rq(drive->queue, NULL);
	g->private_data = NULL;
	put_disk(g);
	kfree(info);
}

1717
static int ide_cd_probe(ide_drive_t *);
L
Linus Torvalds 已提交
1718

1719
static struct ide_driver ide_cdrom_driver = {
1720
	.gen_driver = {
1721
		.owner		= THIS_MODULE,
1722 1723 1724
		.name		= "ide-cdrom",
		.bus		= &ide_bus_type,
	},
1725 1726
	.probe			= ide_cd_probe,
	.remove			= ide_cd_remove,
L
Linus Torvalds 已提交
1727
	.version		= IDECD_VERSION,
1728
	.do_request		= ide_cd_do_request,
1729
#ifdef CONFIG_IDE_PROC_FS
1730 1731
	.proc_entries		= ide_cd_proc_entries,
	.proc_devsets		= ide_cd_proc_devsets,
1732
#endif
L
Linus Torvalds 已提交
1733 1734
};

A
Al Viro 已提交
1735
static int idecd_open(struct block_device *bdev, fmode_t mode)
L
Linus Torvalds 已提交
1736
{
A
Al Viro 已提交
1737
	struct cdrom_info *info = ide_cd_get(bdev->bd_disk);
L
Linus Torvalds 已提交
1738 1739
	int rc = -ENOMEM;

1740
	if (!info)
L
Linus Torvalds 已提交
1741 1742
		return -ENXIO;

A
Al Viro 已提交
1743
	rc = cdrom_open(&info->devinfo, bdev, mode);
L
Linus Torvalds 已提交
1744 1745 1746 1747 1748 1749 1750

	if (rc < 0)
		ide_cd_put(info);

	return rc;
}

A
Al Viro 已提交
1751
static int idecd_release(struct gendisk *disk, fmode_t mode)
L
Linus Torvalds 已提交
1752
{
B
Borislav Petkov 已提交
1753
	struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
L
Linus Torvalds 已提交
1754

A
Al Viro 已提交
1755
	cdrom_release(&info->devinfo, mode);
L
Linus Torvalds 已提交
1756 1757 1758 1759 1760 1761

	ide_cd_put(info);

	return 0;
}

1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786
static int idecd_set_spindown(struct cdrom_device_info *cdi, unsigned long arg)
{
	struct packet_command cgc;
	char buffer[16];
	int stat;
	char spindown;

	if (copy_from_user(&spindown, (void __user *)arg, sizeof(char)))
		return -EFAULT;

	init_cdrom_command(&cgc, buffer, sizeof(buffer), CGC_DATA_UNKNOWN);

	stat = cdrom_mode_sense(cdi, &cgc, GPMODE_CDROM_PAGE, 0);
	if (stat)
		return stat;

	buffer[11] = (buffer[11] & 0xf0) | (spindown & 0x0f);
	return cdrom_mode_select(cdi, &cgc);
}

static int idecd_get_spindown(struct cdrom_device_info *cdi, unsigned long arg)
{
	struct packet_command cgc;
	char buffer[16];
	int stat;
1787
	char spindown;
1788 1789 1790 1791 1792 1793 1794 1795

	init_cdrom_command(&cgc, buffer, sizeof(buffer), CGC_DATA_UNKNOWN);

	stat = cdrom_mode_sense(cdi, &cgc, GPMODE_CDROM_PAGE, 0);
	if (stat)
		return stat;

	spindown = buffer[11] & 0x0f;
1796
	if (copy_to_user((void __user *)arg, &spindown, sizeof(char)))
1797 1798 1799 1800
		return -EFAULT;
	return 0;
}

A
Al Viro 已提交
1801
static int idecd_ioctl(struct block_device *bdev, fmode_t mode,
L
Linus Torvalds 已提交
1802 1803
			unsigned int cmd, unsigned long arg)
{
B
Borislav Petkov 已提交
1804
	struct cdrom_info *info = ide_drv_g(bdev->bd_disk, cdrom_info);
L
Linus Torvalds 已提交
1805 1806
	int err;

1807
	switch (cmd) {
1808
	case CDROMSETSPINDOWN:
1809
		return idecd_set_spindown(&info->devinfo, arg);
1810
	case CDROMGETSPINDOWN:
1811 1812 1813
		return idecd_get_spindown(&info->devinfo, arg);
	default:
		break;
1814
	}
1815

1816
	err = generic_ide_ioctl(info->drive, bdev, cmd, arg);
L
Linus Torvalds 已提交
1817
	if (err == -EINVAL)
A
Al Viro 已提交
1818
		err = cdrom_ioctl(&info->devinfo, bdev, mode, cmd, arg);
L
Linus Torvalds 已提交
1819 1820 1821 1822 1823 1824

	return err;
}

static int idecd_media_changed(struct gendisk *disk)
{
B
Borislav Petkov 已提交
1825
	struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
L
Linus Torvalds 已提交
1826 1827 1828 1829 1830
	return cdrom_media_changed(&info->devinfo);
}

static int idecd_revalidate_disk(struct gendisk *disk)
{
B
Borislav Petkov 已提交
1831
	struct cdrom_info *info = ide_drv_g(disk, cdrom_info);
L
Linus Torvalds 已提交
1832
	struct request_sense sense;
1833 1834 1835

	ide_cd_read_toc(info->drive, &sense);

L
Linus Torvalds 已提交
1836 1837 1838 1839
	return  0;
}

static struct block_device_operations idecd_ops = {
1840
	.owner			= THIS_MODULE,
A
Al Viro 已提交
1841 1842 1843
	.open			= idecd_open,
	.release		= idecd_release,
	.locked_ioctl		= idecd_ioctl,
1844 1845
	.media_changed		= idecd_media_changed,
	.revalidate_disk	= idecd_revalidate_disk
L
Linus Torvalds 已提交
1846 1847
};

B
Borislav Petkov 已提交
1848
/* module options */
1849 1850 1851
static unsigned long debug_mask;
module_param(debug_mask, ulong, 0644);

L
Linus Torvalds 已提交
1852 1853
MODULE_DESCRIPTION("ATAPI CD-ROM Driver");

1854
static int ide_cd_probe(ide_drive_t *drive)
L
Linus Torvalds 已提交
1855 1856 1857 1858 1859
{
	struct cdrom_info *info;
	struct gendisk *g;
	struct request_sense sense;

B
Borislav Petkov 已提交
1860 1861
	ide_debug_log(IDE_DBG_PROBE, "driver_req: %s, media: 0x%x",
				     drive->driver_req, drive->media);
1862

L
Linus Torvalds 已提交
1863 1864
	if (!strstr("ide-cdrom", drive->driver_req))
		goto failed;
1865

L
Linus Torvalds 已提交
1866 1867
	if (drive->media != ide_cdrom && drive->media != ide_optical)
		goto failed;
1868

1869
	drive->debug_mask = debug_mask;
1870
	drive->irq_handler = cdrom_newpc_intr;
1871

1872
	info = kzalloc(sizeof(struct cdrom_info), GFP_KERNEL);
L
Linus Torvalds 已提交
1873
	if (info == NULL) {
1874
		printk(KERN_ERR PFX "%s: Can't allocate a cdrom structure\n",
1875
				drive->name);
L
Linus Torvalds 已提交
1876 1877 1878 1879 1880 1881 1882 1883 1884
		goto failed;
	}

	g = alloc_disk(1 << PARTN_BITS);
	if (!g)
		goto out_free_cd;

	ide_init_disk(g, drive);

1885 1886 1887 1888 1889 1890
	info->dev.parent = &drive->gendev;
	info->dev.release = ide_cd_release;
	dev_set_name(&info->dev, dev_name(&drive->gendev));

	if (device_register(&info->dev))
		goto out_free_disk;
L
Linus Torvalds 已提交
1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903

	info->drive = drive;
	info->driver = &ide_cdrom_driver;
	info->disk = g;

	g->private_data = &info->driver;

	drive->driver_data = info;

	g->minors = 1;
	g->driverfs_dev = &drive->gendev;
	g->flags = GENHD_FL_CD | GENHD_FL_REMOVABLE;
	if (ide_cdrom_setup(drive)) {
1904
		put_device(&info->dev);
L
Linus Torvalds 已提交
1905 1906 1907
		goto failed;
	}

1908
	ide_cd_read_toc(drive, &sense);
L
Linus Torvalds 已提交
1909 1910 1911 1912 1913
	g->fops = &idecd_ops;
	g->flags |= GENHD_FL_REMOVABLE;
	add_disk(g);
	return 0;

1914 1915
out_free_disk:
	put_disk(g);
L
Linus Torvalds 已提交
1916 1917 1918
out_free_cd:
	kfree(info);
failed:
1919
	return -ENODEV;
L
Linus Torvalds 已提交
1920 1921 1922 1923
}

static void __exit ide_cdrom_exit(void)
{
1924
	driver_unregister(&ide_cdrom_driver.gen_driver);
L
Linus Torvalds 已提交
1925
}
1926 1927

static int __init ide_cdrom_init(void)
L
Linus Torvalds 已提交
1928
{
1929
	printk(KERN_INFO DRV_NAME " driver " IDECD_VERSION "\n");
1930
	return driver_register(&ide_cdrom_driver.gen_driver);
L
Linus Torvalds 已提交
1931 1932
}

1933
MODULE_ALIAS("ide:*m-cdrom*");
1934
MODULE_ALIAS("ide-cd");
L
Linus Torvalds 已提交
1935 1936 1937
module_init(ide_cdrom_init);
module_exit(ide_cdrom_exit);
MODULE_LICENSE("GPL");