diff options
-rw-r--r-- | drivers/ide/ide-cd.c | 43 | ||||
-rw-r--r-- | drivers/ide/ide-cd.h | 10 |
2 files changed, 10 insertions, 43 deletions
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c index 1232086d2e1a..206d038c1a1f 100644 --- a/drivers/ide/ide-cd.c +++ b/drivers/ide/ide-cd.c | |||
@@ -1775,7 +1775,6 @@ ide_do_rw_cdrom (ide_drive_t *drive, struct request *rq, sector_t block) | |||
1775 | * can also be NULL, in which case no sense information is returned. | 1775 | * can also be NULL, in which case no sense information is returned. |
1776 | */ | 1776 | */ |
1777 | 1777 | ||
1778 | #if ! STANDARD_ATAPI | ||
1779 | static inline | 1778 | static inline |
1780 | int bin2bcd (int x) | 1779 | int bin2bcd (int x) |
1781 | { | 1780 | { |
@@ -1797,9 +1796,6 @@ void msf_from_bcd (struct atapi_msf *msf) | |||
1797 | msf->frame = bcd2bin (msf->frame); | 1796 | msf->frame = bcd2bin (msf->frame); |
1798 | } | 1797 | } |
1799 | 1798 | ||
1800 | #endif /* not STANDARD_ATAPI */ | ||
1801 | |||
1802 | |||
1803 | static inline | 1799 | static inline |
1804 | void lba_to_msf (int lba, byte *m, byte *s, byte *f) | 1800 | void lba_to_msf (int lba, byte *m, byte *s, byte *f) |
1805 | { | 1801 | { |
@@ -1830,12 +1826,11 @@ static int cdrom_check_status(ide_drive_t *drive, struct request_sense *sense) | |||
1830 | req.cmd[0] = GPCMD_TEST_UNIT_READY; | 1826 | req.cmd[0] = GPCMD_TEST_UNIT_READY; |
1831 | req.cmd_flags |= REQ_QUIET; | 1827 | req.cmd_flags |= REQ_QUIET; |
1832 | 1828 | ||
1833 | #if ! STANDARD_ATAPI | 1829 | /* |
1834 | /* the Sanyo 3 CD changer uses byte 7 of TEST_UNIT_READY to | 1830 | * Sanyo 3 CD changer uses byte 7 of TEST_UNIT_READY to |
1835 | switch CDs instead of supporting the LOAD_UNLOAD opcode */ | 1831 | * switch CDs instead of supporting the LOAD_UNLOAD opcode. |
1836 | 1832 | */ | |
1837 | req.cmd[7] = cdi->sanyo_slot % 3; | 1833 | req.cmd[7] = cdi->sanyo_slot % 3; |
1838 | #endif /* not STANDARD_ATAPI */ | ||
1839 | 1834 | ||
1840 | return cdrom_queue_packet_command(drive, &req); | 1835 | return cdrom_queue_packet_command(drive, &req); |
1841 | } | 1836 | } |
@@ -2024,12 +2019,10 @@ static int cdrom_read_toc(ide_drive_t *drive, struct request_sense *sense) | |||
2024 | if (stat) | 2019 | if (stat) |
2025 | return stat; | 2020 | return stat; |
2026 | 2021 | ||
2027 | #if ! STANDARD_ATAPI | ||
2028 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) { | 2022 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) { |
2029 | toc->hdr.first_track = bcd2bin(toc->hdr.first_track); | 2023 | toc->hdr.first_track = bcd2bin(toc->hdr.first_track); |
2030 | toc->hdr.last_track = bcd2bin(toc->hdr.last_track); | 2024 | toc->hdr.last_track = bcd2bin(toc->hdr.last_track); |
2031 | } | 2025 | } |
2032 | #endif /* not STANDARD_ATAPI */ | ||
2033 | 2026 | ||
2034 | ntracks = toc->hdr.last_track - toc->hdr.first_track + 1; | 2027 | ntracks = toc->hdr.last_track - toc->hdr.first_track + 1; |
2035 | if (ntracks <= 0) | 2028 | if (ntracks <= 0) |
@@ -2061,16 +2054,13 @@ static int cdrom_read_toc(ide_drive_t *drive, struct request_sense *sense) | |||
2061 | (ntracks + 1) * | 2054 | (ntracks + 1) * |
2062 | sizeof(struct atapi_toc_entry), | 2055 | sizeof(struct atapi_toc_entry), |
2063 | sense); | 2056 | sense); |
2064 | if (stat) { | 2057 | if (stat) |
2065 | return stat; | 2058 | return stat; |
2066 | } | 2059 | |
2067 | #if ! STANDARD_ATAPI | ||
2068 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) { | 2060 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) { |
2069 | toc->hdr.first_track = bin2bcd(CDROM_LEADOUT); | 2061 | toc->hdr.first_track = bin2bcd(CDROM_LEADOUT); |
2070 | toc->hdr.last_track = bin2bcd(CDROM_LEADOUT); | 2062 | toc->hdr.last_track = bin2bcd(CDROM_LEADOUT); |
2071 | } else | 2063 | } else { |
2072 | #endif /* not STANDARD_ATAPI */ | ||
2073 | { | ||
2074 | toc->hdr.first_track = CDROM_LEADOUT; | 2064 | toc->hdr.first_track = CDROM_LEADOUT; |
2075 | toc->hdr.last_track = CDROM_LEADOUT; | 2065 | toc->hdr.last_track = CDROM_LEADOUT; |
2076 | } | 2066 | } |
@@ -2081,21 +2071,17 @@ static int cdrom_read_toc(ide_drive_t *drive, struct request_sense *sense) | |||
2081 | 2071 | ||
2082 | toc->hdr.toc_length = ntohs (toc->hdr.toc_length); | 2072 | toc->hdr.toc_length = ntohs (toc->hdr.toc_length); |
2083 | 2073 | ||
2084 | #if ! STANDARD_ATAPI | ||
2085 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) { | 2074 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) { |
2086 | toc->hdr.first_track = bcd2bin(toc->hdr.first_track); | 2075 | toc->hdr.first_track = bcd2bin(toc->hdr.first_track); |
2087 | toc->hdr.last_track = bcd2bin(toc->hdr.last_track); | 2076 | toc->hdr.last_track = bcd2bin(toc->hdr.last_track); |
2088 | } | 2077 | } |
2089 | #endif /* not STANDARD_ATAPI */ | ||
2090 | 2078 | ||
2091 | for (i=0; i<=ntracks; i++) { | 2079 | for (i = 0; i <= ntracks; i++) { |
2092 | #if ! STANDARD_ATAPI | ||
2093 | if (info->cd_flags & IDE_CD_FLAG_TOCADDR_AS_BCD) { | 2080 | if (info->cd_flags & IDE_CD_FLAG_TOCADDR_AS_BCD) { |
2094 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) | 2081 | if (info->cd_flags & IDE_CD_FLAG_TOCTRACKS_AS_BCD) |
2095 | toc->ent[i].track = bcd2bin(toc->ent[i].track); | 2082 | toc->ent[i].track = bcd2bin(toc->ent[i].track); |
2096 | msf_from_bcd(&toc->ent[i].addr.msf); | 2083 | msf_from_bcd(&toc->ent[i].addr.msf); |
2097 | } | 2084 | } |
2098 | #endif /* not STANDARD_ATAPI */ | ||
2099 | toc->ent[i].addr.lba = msf_to_lba (toc->ent[i].addr.msf.minute, | 2085 | toc->ent[i].addr.lba = msf_to_lba (toc->ent[i].addr.msf.minute, |
2100 | toc->ent[i].addr.msf.second, | 2086 | toc->ent[i].addr.msf.second, |
2101 | toc->ent[i].addr.msf.frame); | 2087 | toc->ent[i].addr.msf.frame); |
@@ -2115,7 +2101,6 @@ static int cdrom_read_toc(ide_drive_t *drive, struct request_sense *sense) | |||
2115 | toc->last_session_lba = msf_to_lba(0, 2, 0); /* 0m 2s 0f */ | 2101 | toc->last_session_lba = msf_to_lba(0, 2, 0); /* 0m 2s 0f */ |
2116 | } | 2102 | } |
2117 | 2103 | ||
2118 | #if ! STANDARD_ATAPI | ||
2119 | if (info->cd_flags & IDE_CD_FLAG_TOCADDR_AS_BCD) { | 2104 | if (info->cd_flags & IDE_CD_FLAG_TOCADDR_AS_BCD) { |
2120 | /* Re-read multisession information using MSF format */ | 2105 | /* Re-read multisession information using MSF format */ |
2121 | stat = cdrom_read_tocentry(drive, 0, 1, 1, (char *)&ms_tmp, | 2106 | stat = cdrom_read_tocentry(drive, 0, 1, 1, (char *)&ms_tmp, |
@@ -2128,7 +2113,6 @@ static int cdrom_read_toc(ide_drive_t *drive, struct request_sense *sense) | |||
2128 | ms_tmp.ent.addr.msf.second, | 2113 | ms_tmp.ent.addr.msf.second, |
2129 | ms_tmp.ent.addr.msf.frame); | 2114 | ms_tmp.ent.addr.msf.frame); |
2130 | } | 2115 | } |
2131 | #endif /* not STANDARD_ATAPI */ | ||
2132 | 2116 | ||
2133 | toc->xa_flag = (ms_tmp.hdr.first_track != ms_tmp.hdr.last_track); | 2117 | toc->xa_flag = (ms_tmp.hdr.first_track != ms_tmp.hdr.last_track); |
2134 | 2118 | ||
@@ -2705,16 +2689,11 @@ int ide_cdrom_probe_capabilities (ide_drive_t *drive) | |||
2705 | strcmp(drive->id->model, "MATSHITADVD-ROM SR-8174") == 0) | 2689 | strcmp(drive->id->model, "MATSHITADVD-ROM SR-8174") == 0) |
2706 | cdi->mask &= ~CDC_PLAY_AUDIO; | 2690 | cdi->mask &= ~CDC_PLAY_AUDIO; |
2707 | 2691 | ||
2708 | #if ! STANDARD_ATAPI | ||
2709 | if (cdi->sanyo_slot > 0) { | 2692 | if (cdi->sanyo_slot > 0) { |
2710 | cdi->mask &= ~CDC_SELECT_DISC; | 2693 | cdi->mask &= ~CDC_SELECT_DISC; |
2711 | nslots = 3; | 2694 | nslots = 3; |
2712 | } | 2695 | } else if (mechtype == mechtype_individual_changer || |
2713 | 2696 | mechtype == mechtype_cartridge_changer) { | |
2714 | else | ||
2715 | #endif /* not STANDARD_ATAPI */ | ||
2716 | if (mechtype == mechtype_individual_changer || | ||
2717 | mechtype == mechtype_cartridge_changer) { | ||
2718 | nslots = cdrom_number_of_slots(cdi); | 2697 | nslots = cdrom_number_of_slots(cdi); |
2719 | if (nslots > 1) | 2698 | if (nslots > 1) |
2720 | cdi->mask &= ~CDC_SELECT_DISC; | 2699 | cdi->mask &= ~CDC_SELECT_DISC; |
@@ -2868,7 +2847,6 @@ int ide_cdrom_setup (ide_drive_t *drive) | |||
2868 | else if (!strcmp(drive->id->model, "SAMSUNG CD-ROM SCR-3231")) | 2847 | else if (!strcmp(drive->id->model, "SAMSUNG CD-ROM SCR-3231")) |
2869 | cd->cd_flags |= IDE_CD_FLAG_NO_SPEED_SELECT; | 2848 | cd->cd_flags |= IDE_CD_FLAG_NO_SPEED_SELECT; |
2870 | 2849 | ||
2871 | #if ! STANDARD_ATAPI | ||
2872 | if (strcmp (drive->id->model, "V003S0DS") == 0 && | 2850 | if (strcmp (drive->id->model, "V003S0DS") == 0 && |
2873 | drive->id->fw_rev[4] == '1' && | 2851 | drive->id->fw_rev[4] == '1' && |
2874 | drive->id->fw_rev[6] <= '2') { | 2852 | drive->id->fw_rev[6] <= '2') { |
@@ -2901,7 +2879,6 @@ int ide_cdrom_setup (ide_drive_t *drive) | |||
2901 | /* uses CD in slot 0 when value is set to 3 */ | 2879 | /* uses CD in slot 0 when value is set to 3 */ |
2902 | cdi->sanyo_slot = 3; | 2880 | cdi->sanyo_slot = 3; |
2903 | } | 2881 | } |
2904 | #endif /* not STANDARD_ATAPI */ | ||
2905 | 2882 | ||
2906 | nslots = ide_cdrom_probe_capabilities (drive); | 2883 | nslots = ide_cdrom_probe_capabilities (drive); |
2907 | 2884 | ||
diff --git a/drivers/ide/ide-cd.h b/drivers/ide/ide-cd.h index 59b43935630f..34e9291c0a8e 100644 --- a/drivers/ide/ide-cd.h +++ b/drivers/ide/ide-cd.h | |||
@@ -18,16 +18,6 @@ | |||
18 | #define VERBOSE_IDE_CD_ERRORS 1 | 18 | #define VERBOSE_IDE_CD_ERRORS 1 |
19 | #endif | 19 | #endif |
20 | 20 | ||
21 | |||
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. */ | ||
25 | |||
26 | #ifndef STANDARD_ATAPI | ||
27 | #define STANDARD_ATAPI 0 | ||
28 | #endif | ||
29 | |||
30 | |||
31 | /* | 21 | /* |
32 | * typical timeout for packet command | 22 | * typical timeout for packet command |
33 | */ | 23 | */ |