2  *  linux/drivers/ide/ide_cd.h
 
   4  *  Copyright (C) 1996-98  Erik Andersen
 
   5  *  Copyright (C) 1998-2000 Jens Axboe
 
  10 #include <linux/cdrom.h>
 
  11 #include <asm/byteorder.h>
 
  13 /* Turn this on to have the driver print out the meanings of the
 
  14    ATAPI error codes.  This will use up additional kernel-space
 
  17 #ifndef VERBOSE_IDE_CD_ERRORS
 
  18 #define VERBOSE_IDE_CD_ERRORS 1
 
  22 /* Turning this on will remove code to work around various nonstandard
 
  23    ATAPI implementations.  If you know your drive follows the standard,
 
  24    this will give you a slightly smaller kernel. */
 
  26 #ifndef STANDARD_ATAPI
 
  27 #define STANDARD_ATAPI 0
 
  31 /* Turning this on will disable the door-locking functionality.
 
  32    This is apparently needed for supermount. */
 
  34 #ifndef NO_DOOR_LOCKING
 
  35 #define NO_DOOR_LOCKING 0
 
  39  * typical timeout for packet command
 
  41 #define ATAPI_WAIT_PC           (60 * HZ)
 
  42 #define ATAPI_WAIT_WRITE_BUSY   (10 * HZ)
 
  44 /************************************************************************/
 
  48 #define SECTOR_SIZE             (1 << SECTOR_BITS)
 
  50 #define SECTORS_PER_FRAME       (CD_FRAMESIZE >> SECTOR_BITS)
 
  51 #define SECTOR_BUFFER_SIZE      (CD_FRAMESIZE * 32)
 
  52 #define SECTORS_BUFFER          (SECTOR_BUFFER_SIZE >> SECTOR_BITS)
 
  53 #define SECTORS_MAX             (131072 >> SECTOR_BITS)
 
  55 #define BLOCKS_PER_FRAME        (CD_FRAMESIZE / BLOCK_SIZE)
 
  57 /* special command codes for strategy routine. */
 
  58 #define PACKET_COMMAND        4315
 
  59 #define REQUEST_SENSE_COMMAND 4316
 
  60 #define RESET_DRIVE_COMMAND   4317
 
  63 /* Configuration flags.  These describe the capabilities of the drive.
 
  64    They generally do not change after initialization, unless we learn
 
  65    more about the drive from stuff failing. */
 
  66 struct ide_cd_config_flags {
 
  67         __u8 drq_interrupt      : 1; /* Device sends an interrupt when ready
 
  68                                         for a packet command. */
 
  69         __u8 no_doorlock        : 1; /* Drive cannot lock the door. */
 
  70         __u8 no_eject           : 1; /* Drive cannot eject the disc. */
 
  71         __u8 nec260             : 1; /* Drive is a pre-1.2 NEC 260 drive. */
 
  72         __u8 playmsf_as_bcd     : 1; /* PLAYMSF command takes BCD args. */
 
  73         __u8 tocaddr_as_bcd     : 1; /* TOC addresses are in BCD. */
 
  74         __u8 toctracks_as_bcd   : 1; /* TOC track numbers are in BCD. */
 
  75         __u8 subchan_as_bcd     : 1; /* Subchannel info is in BCD. */
 
  76         __u8 is_changer         : 1; /* Drive is a changer. */
 
  77         __u8 cd_r               : 1; /* Drive can write to CD-R media . */
 
  78         __u8 cd_rw              : 1; /* Drive can write to CD-R/W media . */
 
  79         __u8 dvd                : 1; /* Drive is a DVD-ROM */
 
  80         __u8 dvd_r              : 1; /* Drive can write DVD-R */
 
  81         __u8 dvd_ram            : 1; /* Drive can write DVD-RAM */
 
  82         __u8 ram                : 1; /* generic WRITE (dvd-ram/mrw) */
 
  83         __u8 test_write         : 1; /* Drive can fake writes */
 
  84         __u8 supp_disc_present  : 1; /* Changer can report exact contents
 
  86         __u8 limit_nframes      : 1; /* Drive does not provide data in
 
  87                                         multiples of SECTOR_SIZE when more
 
  88                                         than one interrupt is needed. */
 
  89         __u8 seeking            : 1; /* Seeking in progress */
 
  90         __u8 audio_play         : 1; /* can do audio related commands */
 
  91         __u8 close_tray         : 1; /* can close the tray */
 
  92         __u8 writing            : 1; /* pseudo write in progress */
 
  93         __u8 mo_drive           : 1; /* drive is an MO device */
 
  95         byte max_speed;              /* Max speed of the drive */
 
  97 #define CDROM_CONFIG_FLAGS(drive) (&(((struct cdrom_info *)(drive->driver_data))->config_flags))
 
 100 /* State flags.  These give information about the current state of the
 
 101    drive, and will change during normal operation. */
 
 102 struct ide_cd_state_flags {
 
 103         __u8 media_changed : 1; /* Driver has noticed a media change. */
 
 104         __u8 toc_valid     : 1; /* Saved TOC information is current. */
 
 105         __u8 door_locked   : 1; /* We think that the drive door is locked. */
 
 106         __u8 writing       : 1; /* the drive is currently writing */
 
 108         byte current_speed;     /* Current speed of the drive */
 
 111 #define CDROM_STATE_FLAGS(drive) (&(((struct cdrom_info *)(drive->driver_data))->state_flags))
 
 113 /* Structure of a MSF cdrom address. */
 
 121 /* Space to hold the disk TOC. */
 
 122 #define MAX_TRACKS 99
 
 123 struct atapi_toc_header {
 
 124         unsigned short toc_length;
 
 129 struct atapi_toc_entry {
 
 131 #if defined(__BIG_ENDIAN_BITFIELD)
 
 134 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 138 #error "Please fix <asm/byteorder.h>"
 
 144                 struct atapi_msf msf;
 
 149         int    last_session_lba;
 
 151         unsigned long capacity;
 
 152         struct atapi_toc_header hdr;
 
 153         struct atapi_toc_entry  ent[MAX_TRACKS+1];
 
 154           /* One extra for the leadout. */
 
 158 /* This structure is annoyingly close to, but not identical with,
 
 159    the cdrom_subchnl structure from cdrom.h. */
 
 160 struct atapi_cdrom_subchnl {
 
 161         u_char  acdsc_reserved;
 
 162         u_char  acdsc_audiostatus;
 
 163         u_short acdsc_length;
 
 166 #if defined(__BIG_ENDIAN_BITFIELD)
 
 167         u_char  acdsc_ctrl:     4;
 
 169 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 171         u_char  acdsc_ctrl:     4;
 
 173 #error "Please fix <asm/byteorder.h>"
 
 178                 struct atapi_msf msf;
 
 182                 struct atapi_msf msf;
 
 189 /* This should probably go into cdrom.h along with the other
 
 190  * generic stuff now in the Mt. Fuji spec.
 
 192 struct atapi_capabilities_page {
 
 193         struct mode_page_header header;
 
 194 #if defined(__BIG_ENDIAN_BITFIELD)
 
 195         __u8 parameters_saveable : 1;
 
 198 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 201         __u8 parameters_saveable : 1;
 
 203 #error "Please fix <asm/byteorder.h>"
 
 208 #if defined(__BIG_ENDIAN_BITFIELD)
 
 210         /* Drive supports reading of DVD-RAM discs */
 
 211         __u8 dvd_ram_read        : 1;
 
 212         /* Drive supports reading of DVD-R discs */
 
 214         /* Drive supports reading of DVD-ROM discs */
 
 216         /* Drive supports reading CD-R discs with addressing method 2 */
 
 217         __u8 method2             : 1; /* reserved in 1.2 */
 
 218         /* Drive can read from CD-R/W (CD-E) discs (orange book, part III) */
 
 219         __u8 cd_rw_read          : 1; /* reserved in 1.2 */
 
 220         /* Drive supports read from CD-R discs (orange book, part II) */
 
 221         __u8 cd_r_read           : 1; /* reserved in 1.2 */
 
 222 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 223         /* Drive supports read from CD-R discs (orange book, part II) */
 
 224         __u8 cd_r_read           : 1; /* reserved in 1.2 */
 
 225         /* Drive can read from CD-R/W (CD-E) discs (orange book, part III) */
 
 226         __u8 cd_rw_read          : 1; /* reserved in 1.2 */
 
 227         /* Drive supports reading CD-R discs with addressing method 2 */
 
 229         /* Drive supports reading of DVD-ROM discs */
 
 231         /* Drive supports reading of DVD-R discs */
 
 233         /* Drive supports reading of DVD-RAM discs */
 
 234         __u8 dvd_ram_read        : 1;
 
 237 #error "Please fix <asm/byteorder.h>"
 
 240 #if defined(__BIG_ENDIAN_BITFIELD)
 
 242         /* Drive can write DVD-RAM discs */
 
 243         __u8 dvd_ram_write       : 1;
 
 244         /* Drive can write DVD-R discs */
 
 245         __u8 dvd_r_write         : 1;
 
 247         /* Drive can fake writes */
 
 249         /* Drive can write to CD-R/W (CD-E) discs (orange book, part III) */
 
 250         __u8 cd_rw_write         : 1; /* reserved in 1.2 */
 
 251         /* Drive supports write to CD-R discs (orange book, part II) */
 
 252         __u8 cd_r_write          : 1; /* reserved in 1.2 */
 
 253 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 254         /* Drive can write to CD-R discs (orange book, part II) */
 
 255         __u8 cd_r_write          : 1; /* reserved in 1.2 */
 
 256         /* Drive can write to CD-R/W (CD-E) discs (orange book, part III) */
 
 257         __u8 cd_rw_write         : 1; /* reserved in 1.2 */
 
 258         /* Drive can fake writes */
 
 261         /* Drive can write DVD-R discs */
 
 262         __u8 dvd_r_write         : 1;
 
 263         /* Drive can write DVD-RAM discs */
 
 264         __u8 dvd_ram_write       : 1;
 
 267 #error "Please fix <asm/byteorder.h>"
 
 270 #if defined(__BIG_ENDIAN_BITFIELD)
 
 272         /* Drive can read multisession discs. */
 
 273         __u8 multisession        : 1;
 
 274         /* Drive can read mode 2, form 2 data. */
 
 275         __u8 mode2_form2         : 1;
 
 276         /* Drive can read mode 2, form 1 (XA) data. */
 
 277         __u8 mode2_form1         : 1;
 
 278         /* Drive supports digital output on port 2. */
 
 280         /* Drive supports digital output on port 1. */
 
 282         /* Drive can deliver a composite audio/video data stream. */
 
 284         /* Drive supports audio play operations. */
 
 286 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 287         /* Drive supports audio play operations. */
 
 289         /* Drive can deliver a composite audio/video data stream. */
 
 291         /* Drive supports digital output on port 1. */
 
 293         /* Drive supports digital output on port 2. */
 
 295         /* Drive can read mode 2, form 1 (XA) data. */
 
 296         __u8 mode2_form1         : 1;
 
 297         /* Drive can read mode 2, form 2 data. */
 
 298         __u8 mode2_form2         : 1;
 
 299         /* Drive can read multisession discs. */
 
 300         __u8 multisession        : 1;
 
 303 #error "Please fix <asm/byteorder.h>"
 
 306 #if defined(__BIG_ENDIAN_BITFIELD)
 
 308         /* Drive can return Media Catalog Number (UPC) info. */
 
 310         /* Drive can return International Standard Recording Code info. */
 
 312         /* Drive supports C2 error pointers. */
 
 313         __u8 c2_pointers         : 1;
 
 314         /* R-W data will be returned deinterleaved and error corrected. */
 
 316         /* Subchannel reads can return combined R-W information. */
 
 317         __u8 rw_supported        : 1;
 
 318         /* Drive can continue a read cdda operation from a loss of streaming.*/
 
 319         __u8 cdda_accurate       : 1;
 
 320         /* Drive can read Red Book audio data. */
 
 322 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 323         /* Drive can read Red Book audio data. */
 
 325         /* Drive can continue a read cdda operation from a loss of streaming.*/
 
 326         __u8 cdda_accurate       : 1;
 
 327         /* Subchannel reads can return combined R-W information. */
 
 328         __u8 rw_supported        : 1;
 
 329         /* R-W data will be returned deinterleaved and error corrected. */
 
 331         /* Drive supports C2 error pointers. */
 
 332         __u8 c2_pointers         : 1;
 
 333         /* Drive can return International Standard Recording Code info. */
 
 335         /* Drive can return Media Catalog Number (UPC) info. */
 
 339 #error "Please fix <asm/byteorder.h>"
 
 342 #if defined(__BIG_ENDIAN_BITFIELD)
 
 343         /* Drive mechanism types. */
 
 344         mechtype_t mechtype      : 3;
 
 346         /* Drive can eject a disc or changer cartridge. */
 
 348         /* State of prevent/allow jumper. */
 
 349         __u8 prevent_jumper      : 1;
 
 350         /* Present state of door lock. */
 
 352         /* Drive can lock the door. */
 
 354 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 356         /* Drive can lock the door. */
 
 358         /* Present state of door lock. */
 
 360         /* State of prevent/allow jumper. */
 
 361         __u8 prevent_jumper      : 1;
 
 362         /* Drive can eject a disc or changer cartridge. */
 
 365         /* Drive mechanism types. */
 
 366         mechtype_t mechtype      : 3;
 
 368 #error "Please fix <asm/byteorder.h>"
 
 371 #if defined(__BIG_ENDIAN_BITFIELD)
 
 373         /* Drive supports software slot selection. */
 
 374         __u8 sss                 : 1;  /* reserved in 1.2 */
 
 375         /* Changer can report exact contents of slots. */
 
 376         __u8 disc_present        : 1;  /* reserved in 1.2 */
 
 377         /* Audio for each channel can be muted independently. */
 
 378         __u8 separate_mute       : 1;
 
 379         /* Audio level for each channel can be controlled independently. */
 
 380         __u8 separate_volume     : 1;
 
 381 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 383         /* Audio level for each channel can be controlled independently. */
 
 384         __u8 separate_volume     : 1;
 
 385         /* Audio for each channel can be muted independently. */
 
 386         __u8 separate_mute       : 1;
 
 387         /* Changer can report exact contents of slots. */
 
 388         __u8 disc_present        : 1;  /* reserved in 1.2 */
 
 389         /* Drive supports software slot selection. */
 
 390         __u8 sss                 : 1;  /* reserved in 1.2 */
 
 393 #error "Please fix <asm/byteorder.h>"
 
 396         /* Note: the following four fields are returned in big-endian form. */
 
 397         /* Maximum speed (in kB/s). */
 
 398         unsigned short maxspeed;
 
 399         /* Number of discrete volume levels. */
 
 400         unsigned short n_vol_levels;
 
 401         /* Size of cache in drive, in kB. */
 
 402         unsigned short buffer_size;
 
 403         /* Current speed (in kB/s). */
 
 404         unsigned short curspeed;
 
 409 struct atapi_mechstat_header {
 
 410 #if defined(__BIG_ENDIAN_BITFIELD)
 
 412         __u8 changer_state : 2;
 
 414 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 416         __u8 changer_state : 2;
 
 419 #error "Please fix <asm/byteorder.h>"
 
 422 #if defined(__BIG_ENDIAN_BITFIELD)
 
 426 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 431 #error "Please fix <asm/byteorder.h>"
 
 441 #if defined(__BIG_ENDIAN_BITFIELD)
 
 442         __u8 disc_present : 1;
 
 445 #elif defined(__LITTLE_ENDIAN_BITFIELD)
 
 448         __u8 disc_present : 1;
 
 450 #error "Please fix <asm/byteorder.h>"
 
 456 struct atapi_changer_info {
 
 457         struct atapi_mechstat_header hdr;
 
 458         struct atapi_slot slots[0];
 
 461 /* Extra per-device info for cdrom drives. */
 
 464         ide_driver_t    *driver;
 
 465         struct gendisk  *disk;
 
 468         /* Buffer for table of contents.  NULL if we haven't allocated
 
 469            a TOC buffer for this device yet. */
 
 471         struct atapi_toc *toc;
 
 473         unsigned long   sector_buffered;
 
 474         unsigned long   nsectors_buffered;
 
 475         unsigned char   *buffer;
 
 477         /* The result of the last successful request sense command
 
 479         struct request_sense sense_data;
 
 481         struct request request_sense_request;
 
 484         unsigned long last_block;
 
 485         unsigned long start_seek;
 
 486         /* Buffer to hold mechanism status and changer slot table. */
 
 487         struct atapi_changer_info *changer_info;
 
 489         struct ide_cd_config_flags      config_flags;
 
 490         struct ide_cd_state_flags       state_flags;
 
 492         /* Per-device info needed by cdrom.c generic driver. */
 
 493         struct cdrom_device_info devinfo;
 
 495         unsigned long write_timeout;
 
 498 /****************************************************************************
 
 499  * Descriptions of ATAPI error codes.
 
 502 #define ARY_LEN(a) ((sizeof(a) / sizeof(a[0])))
 
 504 /* This stuff should be in cdrom.h, since it is now generic... */
 
 506 /* ATAPI sense keys (from table 140 of ATAPI 2.6) */
 
 507 #define NO_SENSE                0x00
 
 508 #define RECOVERED_ERROR         0x01
 
 509 #define NOT_READY               0x02
 
 510 #define MEDIUM_ERROR            0x03
 
 511 #define HARDWARE_ERROR          0x04
 
 512 #define ILLEGAL_REQUEST         0x05
 
 513 #define UNIT_ATTENTION          0x06
 
 514 #define DATA_PROTECT            0x07
 
 515 #define BLANK_CHECK             0x08
 
 516 #define ABORTED_COMMAND         0x0b
 
 517 #define MISCOMPARE              0x0e
 
 521 /* This stuff should be in cdrom.h, since it is now generic... */
 
 522 #if VERBOSE_IDE_CD_ERRORS
 
 524  /* The generic packet command opcodes for CD/DVD Logical Units,
 
 525  * From Table 57 of the SFF8090 Ver. 3 (Mt. Fuji) draft standard. */ 
 
 526 static const struct {
 
 527         unsigned short packet_command;
 
 528         const char * const text;
 
 529 } packet_command_texts[] = {
 
 530         { GPCMD_TEST_UNIT_READY, "Test Unit Ready" },
 
 531         { GPCMD_REQUEST_SENSE, "Request Sense" },
 
 532         { GPCMD_FORMAT_UNIT, "Format Unit" },
 
 533         { GPCMD_INQUIRY, "Inquiry" },
 
 534         { GPCMD_START_STOP_UNIT, "Start/Stop Unit" },
 
 535         { GPCMD_PREVENT_ALLOW_MEDIUM_REMOVAL, "Prevent/Allow Medium Removal" },
 
 536         { GPCMD_READ_FORMAT_CAPACITIES, "Read Format Capacities" },
 
 537         { GPCMD_READ_CDVD_CAPACITY, "Read Cd/Dvd Capacity" },
 
 538         { GPCMD_READ_10, "Read 10" },
 
 539         { GPCMD_WRITE_10, "Write 10" },
 
 540         { GPCMD_SEEK, "Seek" },
 
 541         { GPCMD_WRITE_AND_VERIFY_10, "Write and Verify 10" },
 
 542         { GPCMD_VERIFY_10, "Verify 10" },
 
 543         { GPCMD_FLUSH_CACHE, "Flush Cache" },
 
 544         { GPCMD_READ_SUBCHANNEL, "Read Subchannel" },
 
 545         { GPCMD_READ_TOC_PMA_ATIP, "Read Table of Contents" },
 
 546         { GPCMD_READ_HEADER, "Read Header" },
 
 547         { GPCMD_PLAY_AUDIO_10, "Play Audio 10" },
 
 548         { GPCMD_GET_CONFIGURATION, "Get Configuration" },
 
 549         { GPCMD_PLAY_AUDIO_MSF, "Play Audio MSF" },
 
 550         { GPCMD_PLAYAUDIO_TI, "Play Audio TrackIndex" },
 
 551         { GPCMD_GET_EVENT_STATUS_NOTIFICATION, "Get Event Status Notification" },
 
 552         { GPCMD_PAUSE_RESUME, "Pause/Resume" },
 
 553         { GPCMD_STOP_PLAY_SCAN, "Stop Play/Scan" },
 
 554         { GPCMD_READ_DISC_INFO, "Read Disc Info" },
 
 555         { GPCMD_READ_TRACK_RZONE_INFO, "Read Track Rzone Info" },
 
 556         { GPCMD_RESERVE_RZONE_TRACK, "Reserve Rzone Track" },
 
 557         { GPCMD_SEND_OPC, "Send OPC" },
 
 558         { GPCMD_MODE_SELECT_10, "Mode Select 10" },
 
 559         { GPCMD_REPAIR_RZONE_TRACK, "Repair Rzone Track" },
 
 560         { GPCMD_MODE_SENSE_10, "Mode Sense 10" },
 
 561         { GPCMD_CLOSE_TRACK, "Close Track" },
 
 562         { GPCMD_BLANK, "Blank" },
 
 563         { GPCMD_SEND_EVENT, "Send Event" },
 
 564         { GPCMD_SEND_KEY, "Send Key" },
 
 565         { GPCMD_REPORT_KEY, "Report Key" },
 
 566         { GPCMD_LOAD_UNLOAD, "Load/Unload" },
 
 567         { GPCMD_SET_READ_AHEAD, "Set Read-ahead" },
 
 568         { GPCMD_READ_12, "Read 12" },
 
 569         { GPCMD_GET_PERFORMANCE, "Get Performance" },
 
 570         { GPCMD_SEND_DVD_STRUCTURE, "Send DVD Structure" },
 
 571         { GPCMD_READ_DVD_STRUCTURE, "Read DVD Structure" },
 
 572         { GPCMD_SET_STREAMING, "Set Streaming" },
 
 573         { GPCMD_READ_CD_MSF, "Read CD MSF" },
 
 574         { GPCMD_SCAN, "Scan" },
 
 575         { GPCMD_SET_SPEED, "Set Speed" },
 
 576         { GPCMD_PLAY_CD, "Play CD" },
 
 577         { GPCMD_MECHANISM_STATUS, "Mechanism Status" },
 
 578         { GPCMD_READ_CD, "Read CD" },
 
 583 /* From Table 303 of the SFF8090 Ver. 3 (Mt. Fuji) draft standard. */
 
 584 static const char * const sense_key_texts[16] = {
 
 603 /* From Table 304 of the SFF8090 Ver. 3 (Mt. Fuji) draft standard. */
 
 604 static const struct {
 
 605         unsigned long asc_ascq;
 
 606         const char * const text;
 
 607 } sense_data_texts[] = {
 
 608         { 0x000000, "No additional sense information" },
 
 609         { 0x000011, "Play operation in progress" },
 
 610         { 0x000012, "Play operation paused" },
 
 611         { 0x000013, "Play operation successfully completed" },
 
 612         { 0x000014, "Play operation stopped due to error" },
 
 613         { 0x000015, "No current audio status to return" },
 
 614         { 0x010c0a, "Write error - padding blocks added" },
 
 615         { 0x011700, "Recovered data with no error correction applied" },
 
 616         { 0x011701, "Recovered data with retries" },
 
 617         { 0x011702, "Recovered data with positive head offset" },
 
 618         { 0x011703, "Recovered data with negative head offset" },
 
 619         { 0x011704, "Recovered data with retries and/or CIRC applied" },
 
 620         { 0x011705, "Recovered data using previous sector ID" },
 
 621         { 0x011800, "Recovered data with error correction applied" },
 
 622         { 0x011801, "Recovered data with error correction and retries applied"},
 
 623         { 0x011802, "Recovered data - the data was auto-reallocated" },
 
 624         { 0x011803, "Recovered data with CIRC" },
 
 625         { 0x011804, "Recovered data with L-EC" },
 
 627             "Failure prediction threshold exceeded - Predicted logical unit failure" },
 
 629             "Failure prediction threshold exceeded - Predicted media failure" },
 
 630         { 0x015dff, "Failure prediction threshold exceeded - False" },
 
 631         { 0x017301, "Power calibration area almost full" },
 
 632         { 0x020400, "Logical unit not ready - cause not reportable" },
 
 633         /* Following is misspelled in ATAPI 2.6, _and_ in Mt. Fuji */
 
 635           "Logical unit not ready - in progress [sic] of becoming ready" },
 
 636         { 0x020402, "Logical unit not ready - initializing command required" },
 
 637         { 0x020403, "Logical unit not ready - manual intervention required" },
 
 638         { 0x020404, "Logical unit not ready - format in progress" },
 
 639         { 0x020407, "Logical unit not ready - operation in progress" },
 
 640         { 0x020408, "Logical unit not ready - long write in progress" },
 
 641         { 0x020600, "No reference position found (media may be upside down)" },
 
 642         { 0x023000, "Incompatible medium installed" },
 
 643         { 0x023a00, "Medium not present" },
 
 644         { 0x025300, "Media load or eject failed" },
 
 645         { 0x025700, "Unable to recover table of contents" },
 
 646         { 0x030300, "Peripheral device write fault" },
 
 647         { 0x030301, "No write current" },
 
 648         { 0x030302, "Excessive write errors" },
 
 649         { 0x030c00, "Write error" },
 
 650         { 0x030c01, "Write error - Recovered with auto reallocation" },
 
 651         { 0x030c02, "Write error - auto reallocation failed" },
 
 652         { 0x030c03, "Write error - recommend reassignment" },
 
 653         { 0x030c04, "Compression check miscompare error" },
 
 654         { 0x030c05, "Data expansion occurred during compress" },
 
 655         { 0x030c06, "Block not compressible" },
 
 656         { 0x030c07, "Write error - recovery needed" },
 
 657         { 0x030c08, "Write error - recovery failed" },
 
 658         { 0x030c09, "Write error - loss of streaming" },
 
 659         { 0x031100, "Unrecovered read error" },
 
 660         { 0x031106, "CIRC unrecovered error" },
 
 661         { 0x033101, "Format command failed" },
 
 662         { 0x033200, "No defect spare location available" },
 
 663         { 0x033201, "Defect list update failure" },
 
 664         { 0x035100, "Erase failure" },
 
 665         { 0x037200, "Session fixation error" },
 
 666         { 0x037201, "Session fixation error writin lead-in" },
 
 667         { 0x037202, "Session fixation error writin lead-out" },
 
 668         { 0x037300, "CD control error" },
 
 669         { 0x037302, "Power calibration area is full" },
 
 670         { 0x037303, "Power calibration area error" },
 
 671         { 0x037304, "Program memory area / RMA update failure" },
 
 672         { 0x037305, "Program memory area / RMA is full" },
 
 673         { 0x037306, "Program memory area / RMA is (almost) full" },
 
 675         { 0x040200, "No seek complete" },
 
 676         { 0x040300, "Write fault" },
 
 677         { 0x040900, "Track following error" },
 
 678         { 0x040901, "Tracking servo failure" },
 
 679         { 0x040902, "Focus servo failure" },
 
 680         { 0x040903, "Spindle servo failure" },
 
 681         { 0x041500, "Random positioning error" },
 
 682         { 0x041501, "Mechanical positioning or changer error" },
 
 683         { 0x041502, "Positioning error detected by read of medium" },
 
 684         { 0x043c00, "Mechanical positioning or changer error" },
 
 685         { 0x044000, "Diagnostic failure on component (ASCQ)" },
 
 686         { 0x044400, "Internal CD/DVD logical unit failure" },
 
 687         { 0x04b600, "Media load mechanism failed" },
 
 688         { 0x051a00, "Parameter list length error" },
 
 689         { 0x052000, "Invalid command operation code" },
 
 690         { 0x052100, "Logical block address out of range" },
 
 691         { 0x052102, "Invalid address for write" },
 
 692         { 0x052400, "Invalid field in command packet" },
 
 693         { 0x052600, "Invalid field in parameter list" },
 
 694         { 0x052601, "Parameter not supported" },
 
 695         { 0x052602, "Parameter value invalid" },
 
 696         { 0x052700, "Write protected media" },
 
 697         { 0x052c00, "Command sequence error" },
 
 698         { 0x052c03, "Current program area is not empty" },
 
 699         { 0x052c04, "Current program area is empty" },
 
 700         { 0x053001, "Cannot read medium - unknown format" },
 
 701         { 0x053002, "Cannot read medium - incompatible format" },
 
 702         { 0x053900, "Saving parameters not supported" },
 
 703         { 0x054e00, "Overlapped commands attempted" },
 
 704         { 0x055302, "Medium removal prevented" },
 
 705         { 0x055500, "System resource failure" },
 
 706         { 0x056300, "End of user area encountered on this track" },
 
 707         { 0x056400, "Illegal mode for this track or incompatible medium" },
 
 708         { 0x056f00, "Copy protection key exchange failure - Authentication failure" },
 
 709         { 0x056f01, "Copy protection key exchange failure - Key not present" },
 
 710         { 0x056f02, "Copy protection key exchange failure - Key not established" },
 
 711         { 0x056f03, "Read of scrambled sector without authentication" },
 
 712         { 0x056f04, "Media region code is mismatched to logical unit" },
 
 713         { 0x056f05,  "Drive region must be permanent / region reset count error" },
 
 714         { 0x057203, "Session fixation error - incomplete track in session" },
 
 715         { 0x057204, "Empty or partially written reserved track" },
 
 716         { 0x057205, "No more RZONE reservations are allowed" },
 
 717         { 0x05bf00, "Loss of streaming" },
 
 718         { 0x062800, "Not ready to ready transition, medium may have changed" },
 
 719         { 0x062900, "Power on, reset or hardware reset occurred" },
 
 720         { 0x062a00, "Parameters changed" },
 
 721         { 0x062a01, "Mode parameters changed" },
 
 722         { 0x062e00, "Insufficient time for operation" },
 
 723         { 0x063f00, "Logical unit operating conditions have changed" },
 
 724         { 0x063f01, "Microcode has been changed" },
 
 725         { 0x065a00, "Operator request or state change input (unspecified)" },
 
 726         { 0x065a01, "Operator medium removal request" },
 
 727         { 0x0bb900, "Play operation aborted" },
 
 729         /* Here we use 0xff for the key (not a valid key) to signify
 
 730          * that these can have _any_ key value associated with them... */
 
 731         { 0xff0401, "Logical unit is in process of becoming ready" },
 
 732         { 0xff0400, "Logical unit not ready, cause not reportable" },
 
 733         { 0xff0402, "Logical unit not ready, initializing command required" },
 
 734         { 0xff0403, "Logical unit not ready, manual intervention required" },
 
 735         { 0xff0500, "Logical unit does not respond to selection" },
 
 736         { 0xff0800, "Logical unit communication failure" },
 
 737         { 0xff0802, "Logical unit communication parity error" },
 
 738         { 0xff0801, "Logical unit communication time-out" },
 
 739         { 0xff2500, "Logical unit not supported" },
 
 740         { 0xff4c00, "Logical unit failed self-configuration" },
 
 741         { 0xff3e00, "Logical unit has not self-configured yet" },
 
 746 #endif /* _IDE_CD_H */