diff options
-rw-r--r-- | drivers/ide/ide-atapi.c | 15 | ||||
-rw-r--r-- | drivers/ide/ide-floppy.c | 19 | ||||
-rw-r--r-- | drivers/ide/ide-tape.c | 24 | ||||
-rw-r--r-- | include/linux/ide.h | 1 |
4 files changed, 24 insertions, 35 deletions
diff --git a/drivers/ide/ide-atapi.c b/drivers/ide/ide-atapi.c index c647a40c0d33..58411591edf3 100644 --- a/drivers/ide/ide-atapi.c +++ b/drivers/ide/ide-atapi.c | |||
@@ -162,6 +162,21 @@ int ide_queue_pc_tail(ide_drive_t *drive, struct gendisk *disk, | |||
162 | } | 162 | } |
163 | EXPORT_SYMBOL_GPL(ide_queue_pc_tail); | 163 | EXPORT_SYMBOL_GPL(ide_queue_pc_tail); |
164 | 164 | ||
165 | int ide_do_start_stop(ide_drive_t *drive, struct gendisk *disk, int start) | ||
166 | { | ||
167 | struct ide_atapi_pc pc; | ||
168 | |||
169 | ide_init_pc(&pc); | ||
170 | pc.c[0] = START_STOP; | ||
171 | pc.c[4] = start; | ||
172 | |||
173 | if (drive->media == ide_tape) | ||
174 | pc.flags |= PC_FLAG_WAIT_FOR_DSC; | ||
175 | |||
176 | return ide_queue_pc_tail(drive, disk, &pc); | ||
177 | } | ||
178 | EXPORT_SYMBOL_GPL(ide_do_start_stop); | ||
179 | |||
165 | int ide_set_media_lock(ide_drive_t *drive, struct gendisk *disk, int on) | 180 | int ide_set_media_lock(ide_drive_t *drive, struct gendisk *disk, int on) |
166 | { | 181 | { |
167 | struct ide_atapi_pc pc; | 182 | struct ide_atapi_pc pc; |
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c index f39cf404b030..b221a456e535 100644 --- a/drivers/ide/ide-floppy.c +++ b/drivers/ide/ide-floppy.c | |||
@@ -359,13 +359,6 @@ void ide_floppy_create_mode_sense_cmd(struct ide_atapi_pc *pc, u8 page_code) | |||
359 | pc->req_xfer = length; | 359 | pc->req_xfer = length; |
360 | } | 360 | } |
361 | 361 | ||
362 | static void idefloppy_create_start_stop_cmd(struct ide_atapi_pc *pc, int start) | ||
363 | { | ||
364 | ide_init_pc(pc); | ||
365 | pc->c[0] = GPCMD_START_STOP_UNIT; | ||
366 | pc->c[4] = start; | ||
367 | } | ||
368 | |||
369 | static void idefloppy_create_rw_cmd(idefloppy_floppy_t *floppy, | 362 | static void idefloppy_create_rw_cmd(idefloppy_floppy_t *floppy, |
370 | struct ide_atapi_pc *pc, struct request *rq, | 363 | struct ide_atapi_pc *pc, struct request *rq, |
371 | unsigned long sector) | 364 | unsigned long sector) |
@@ -800,10 +793,8 @@ static int idefloppy_open(struct inode *inode, struct file *filp) | |||
800 | ide_init_pc(&pc); | 793 | ide_init_pc(&pc); |
801 | pc.c[0] = GPCMD_TEST_UNIT_READY; | 794 | pc.c[0] = GPCMD_TEST_UNIT_READY; |
802 | 795 | ||
803 | if (ide_queue_pc_tail(drive, disk, &pc)) { | 796 | if (ide_queue_pc_tail(drive, disk, &pc)) |
804 | idefloppy_create_start_stop_cmd(&pc, 1); | 797 | ide_do_start_stop(drive, disk, 1); |
805 | (void)ide_queue_pc_tail(drive, disk, &pc); | ||
806 | } | ||
807 | 798 | ||
808 | if (ide_floppy_get_capacity(drive) | 799 | if (ide_floppy_get_capacity(drive) |
809 | && (filp->f_flags & O_NDELAY) == 0 | 800 | && (filp->f_flags & O_NDELAY) == 0 |
@@ -880,10 +871,8 @@ static int ide_floppy_lockdoor(ide_drive_t *drive, struct ide_atapi_pc *pc, | |||
880 | 871 | ||
881 | ide_set_media_lock(drive, disk, prevent); | 872 | ide_set_media_lock(drive, disk, prevent); |
882 | 873 | ||
883 | if (cmd == CDROMEJECT) { | 874 | if (cmd == CDROMEJECT) |
884 | idefloppy_create_start_stop_cmd(pc, 2); | 875 | ide_do_start_stop(drive, disk, 2); |
885 | (void)ide_queue_pc_tail(drive, disk, pc); | ||
886 | } | ||
887 | 876 | ||
888 | return 0; | 877 | return 0; |
889 | } | 878 | } |
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c index b7f3eebc0d15..5204bef4a21c 100644 --- a/drivers/ide/ide-tape.c +++ b/drivers/ide/ide-tape.c | |||
@@ -1125,15 +1125,6 @@ static void idetape_create_test_unit_ready_cmd(struct ide_atapi_pc *pc) | |||
1125 | pc->c[0] = TEST_UNIT_READY; | 1125 | pc->c[0] = TEST_UNIT_READY; |
1126 | } | 1126 | } |
1127 | 1127 | ||
1128 | static void idetape_create_load_unload_cmd(ide_drive_t *drive, | ||
1129 | struct ide_atapi_pc *pc, int cmd) | ||
1130 | { | ||
1131 | ide_init_pc(pc); | ||
1132 | pc->c[0] = START_STOP; | ||
1133 | pc->c[4] = cmd; | ||
1134 | pc->flags |= PC_FLAG_WAIT_FOR_DSC; | ||
1135 | } | ||
1136 | |||
1137 | static int idetape_wait_ready(ide_drive_t *drive, unsigned long timeout) | 1128 | static int idetape_wait_ready(ide_drive_t *drive, unsigned long timeout) |
1138 | { | 1129 | { |
1139 | idetape_tape_t *tape = drive->driver_data; | 1130 | idetape_tape_t *tape = drive->driver_data; |
@@ -1153,9 +1144,7 @@ static int idetape_wait_ready(ide_drive_t *drive, unsigned long timeout) | |||
1153 | /* no media */ | 1144 | /* no media */ |
1154 | if (load_attempted) | 1145 | if (load_attempted) |
1155 | return -ENOMEDIUM; | 1146 | return -ENOMEDIUM; |
1156 | idetape_create_load_unload_cmd(drive, &pc, | 1147 | ide_do_start_stop(drive, disk, IDETAPE_LU_LOAD_MASK); |
1157 | IDETAPE_LU_LOAD_MASK); | ||
1158 | ide_queue_pc_tail(drive, disk, &pc); | ||
1159 | load_attempted = 1; | 1148 | load_attempted = 1; |
1160 | /* not about to be ready */ | 1149 | /* not about to be ready */ |
1161 | } else if (!(tape->sense_key == 2 && tape->asc == 4 && | 1150 | } else if (!(tape->sense_key == 2 && tape->asc == 4 && |
@@ -1836,9 +1825,7 @@ static int idetape_mtioctop(ide_drive_t *drive, short mt_op, int mt_count) | |||
1836 | return 0; | 1825 | return 0; |
1837 | case MTLOAD: | 1826 | case MTLOAD: |
1838 | ide_tape_discard_merge_buffer(drive, 0); | 1827 | ide_tape_discard_merge_buffer(drive, 0); |
1839 | idetape_create_load_unload_cmd(drive, &pc, | 1828 | return ide_do_start_stop(drive, disk, IDETAPE_LU_LOAD_MASK); |
1840 | IDETAPE_LU_LOAD_MASK); | ||
1841 | return ide_queue_pc_tail(drive, disk, &pc); | ||
1842 | case MTUNLOAD: | 1829 | case MTUNLOAD: |
1843 | case MTOFFL: | 1830 | case MTOFFL: |
1844 | /* | 1831 | /* |
@@ -1850,9 +1837,7 @@ static int idetape_mtioctop(ide_drive_t *drive, short mt_op, int mt_count) | |||
1850 | tape->door_locked = DOOR_UNLOCKED; | 1837 | tape->door_locked = DOOR_UNLOCKED; |
1851 | } | 1838 | } |
1852 | ide_tape_discard_merge_buffer(drive, 0); | 1839 | ide_tape_discard_merge_buffer(drive, 0); |
1853 | idetape_create_load_unload_cmd(drive, &pc, | 1840 | retval = ide_do_start_stop(drive, disk, !IDETAPE_LU_LOAD_MASK); |
1854 | !IDETAPE_LU_LOAD_MASK); | ||
1855 | retval = ide_queue_pc_tail(drive, disk, &pc); | ||
1856 | if (!retval) | 1841 | if (!retval) |
1857 | clear_bit(IDE_AFLAG_MEDIUM_PRESENT, &drive->atapi_flags); | 1842 | clear_bit(IDE_AFLAG_MEDIUM_PRESENT, &drive->atapi_flags); |
1858 | return retval; | 1843 | return retval; |
@@ -1861,9 +1846,8 @@ static int idetape_mtioctop(ide_drive_t *drive, short mt_op, int mt_count) | |||
1861 | return idetape_flush_tape_buffers(drive); | 1846 | return idetape_flush_tape_buffers(drive); |
1862 | case MTRETEN: | 1847 | case MTRETEN: |
1863 | ide_tape_discard_merge_buffer(drive, 0); | 1848 | ide_tape_discard_merge_buffer(drive, 0); |
1864 | idetape_create_load_unload_cmd(drive, &pc, | 1849 | return ide_do_start_stop(drive, disk, |
1865 | IDETAPE_LU_RETENSION_MASK | IDETAPE_LU_LOAD_MASK); | 1850 | IDETAPE_LU_RETENSION_MASK | IDETAPE_LU_LOAD_MASK); |
1866 | return ide_queue_pc_tail(drive, disk, &pc); | ||
1867 | case MTEOM: | 1851 | case MTEOM: |
1868 | idetape_create_space_cmd(&pc, 0, IDETAPE_SPACE_TO_EOD); | 1852 | idetape_create_space_cmd(&pc, 0, IDETAPE_SPACE_TO_EOD); |
1869 | return ide_queue_pc_tail(drive, disk, &pc); | 1853 | return ide_queue_pc_tail(drive, disk, &pc); |
diff --git a/include/linux/ide.h b/include/linux/ide.h index ac067a3c1be3..be79122b9431 100644 --- a/include/linux/ide.h +++ b/include/linux/ide.h | |||
@@ -1142,6 +1142,7 @@ void ide_queue_pc_head(ide_drive_t *, struct gendisk *, struct ide_atapi_pc *, | |||
1142 | struct request *); | 1142 | struct request *); |
1143 | int ide_queue_pc_tail(ide_drive_t *, struct gendisk *, struct ide_atapi_pc *); | 1143 | int ide_queue_pc_tail(ide_drive_t *, struct gendisk *, struct ide_atapi_pc *); |
1144 | 1144 | ||
1145 | int ide_do_start_stop(ide_drive_t *, struct gendisk *, int); | ||
1145 | int ide_set_media_lock(ide_drive_t *, struct gendisk *, int); | 1146 | int ide_set_media_lock(ide_drive_t *, struct gendisk *, int); |
1146 | 1147 | ||
1147 | ide_startstop_t ide_pc_intr(ide_drive_t *drive, struct ide_atapi_pc *pc, | 1148 | ide_startstop_t ide_pc_intr(ide_drive_t *drive, struct ide_atapi_pc *pc, |