aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide-tape.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/ide-tape.c')
-rw-r--r--drivers/ide/ide-tape.c43
1 files changed, 2 insertions, 41 deletions
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c
index 99084663a7c0..3d15e8e729ef 100644
--- a/drivers/ide/ide-tape.c
+++ b/drivers/ide/ide-tape.c
@@ -107,8 +107,6 @@ typedef struct os_dat_s {
107 * The following are used to debug the driver: 107 * The following are used to debug the driver:
108 * 108 *
109 * Setting IDETAPE_DEBUG_LOG to 1 will log driver flow control. 109 * Setting IDETAPE_DEBUG_LOG to 1 will log driver flow control.
110 * Setting IDETAPE_DEBUG_BUGS to 1 will enable self-sanity checks in
111 * some places.
112 * 110 *
113 * Setting them to 0 will restore normal operation mode: 111 * Setting them to 0 will restore normal operation mode:
114 * 112 *
@@ -121,7 +119,6 @@ typedef struct os_dat_s {
121 * esthetic. 119 * esthetic.
122 */ 120 */
123#define IDETAPE_DEBUG_LOG 0 121#define IDETAPE_DEBUG_LOG 0
124#define IDETAPE_DEBUG_BUGS 1
125 122
126/* 123/*
127 * After each failed packet command we issue a request sense command 124 * After each failed packet command we issue a request sense command
@@ -847,14 +844,12 @@ static void idetape_input_buffers (ide_drive_t *drive, idetape_pc_t *pc, unsigne
847 int count; 844 int count;
848 845
849 while (bcount) { 846 while (bcount) {
850#if IDETAPE_DEBUG_BUGS
851 if (bh == NULL) { 847 if (bh == NULL) {
852 printk(KERN_ERR "ide-tape: bh == NULL in " 848 printk(KERN_ERR "ide-tape: bh == NULL in "
853 "idetape_input_buffers\n"); 849 "idetape_input_buffers\n");
854 idetape_discard_data(drive, bcount); 850 idetape_discard_data(drive, bcount);
855 return; 851 return;
856 } 852 }
857#endif /* IDETAPE_DEBUG_BUGS */
858 count = min((unsigned int)(bh->b_size - atomic_read(&bh->b_count)), bcount); 853 count = min((unsigned int)(bh->b_size - atomic_read(&bh->b_count)), bcount);
859 HWIF(drive)->atapi_input_bytes(drive, bh->b_data + atomic_read(&bh->b_count), count); 854 HWIF(drive)->atapi_input_bytes(drive, bh->b_data + atomic_read(&bh->b_count), count);
860 bcount -= count; 855 bcount -= count;
@@ -874,13 +869,11 @@ static void idetape_output_buffers (ide_drive_t *drive, idetape_pc_t *pc, unsign
874 int count; 869 int count;
875 870
876 while (bcount) { 871 while (bcount) {
877#if IDETAPE_DEBUG_BUGS
878 if (bh == NULL) { 872 if (bh == NULL) {
879 printk(KERN_ERR "ide-tape: bh == NULL in " 873 printk(KERN_ERR "ide-tape: bh == NULL in "
880 "idetape_output_buffers\n"); 874 "idetape_output_buffers\n");
881 return; 875 return;
882 } 876 }
883#endif /* IDETAPE_DEBUG_BUGS */
884 count = min((unsigned int)pc->b_count, (unsigned int)bcount); 877 count = min((unsigned int)pc->b_count, (unsigned int)bcount);
885 HWIF(drive)->atapi_output_bytes(drive, pc->b_data, count); 878 HWIF(drive)->atapi_output_bytes(drive, pc->b_data, count);
886 bcount -= count; 879 bcount -= count;
@@ -905,13 +898,11 @@ static void idetape_update_buffers (idetape_pc_t *pc)
905 if (test_bit(PC_WRITING, &pc->flags)) 898 if (test_bit(PC_WRITING, &pc->flags))
906 return; 899 return;
907 while (bcount) { 900 while (bcount) {
908#if IDETAPE_DEBUG_BUGS
909 if (bh == NULL) { 901 if (bh == NULL) {
910 printk(KERN_ERR "ide-tape: bh == NULL in " 902 printk(KERN_ERR "ide-tape: bh == NULL in "
911 "idetape_update_buffers\n"); 903 "idetape_update_buffers\n");
912 return; 904 return;
913 } 905 }
914#endif /* IDETAPE_DEBUG_BUGS */
915 count = min((unsigned int)bh->b_size, (unsigned int)bcount); 906 count = min((unsigned int)bh->b_size, (unsigned int)bcount);
916 atomic_set(&bh->b_count, count); 907 atomic_set(&bh->b_count, count);
917 if (atomic_read(&bh->b_count) == bh->b_size) 908 if (atomic_read(&bh->b_count) == bh->b_size)
@@ -1065,12 +1056,10 @@ static void idetape_active_next_stage (ide_drive_t *drive)
1065 if (tape->debug_level >= 4) 1056 if (tape->debug_level >= 4)
1066 printk(KERN_INFO "ide-tape: Reached idetape_active_next_stage\n"); 1057 printk(KERN_INFO "ide-tape: Reached idetape_active_next_stage\n");
1067#endif /* IDETAPE_DEBUG_LOG */ 1058#endif /* IDETAPE_DEBUG_LOG */
1068#if IDETAPE_DEBUG_BUGS
1069 if (stage == NULL) { 1059 if (stage == NULL) {
1070 printk(KERN_ERR "ide-tape: bug: Trying to activate a non existing stage\n"); 1060 printk(KERN_ERR "ide-tape: bug: Trying to activate a non existing stage\n");
1071 return; 1061 return;
1072 } 1062 }
1073#endif /* IDETAPE_DEBUG_BUGS */
1074 1063
1075 rq->rq_disk = tape->disk; 1064 rq->rq_disk = tape->disk;
1076 rq->buffer = NULL; 1065 rq->buffer = NULL;
@@ -1145,28 +1134,24 @@ static void idetape_remove_stage_head (ide_drive_t *drive)
1145 if (tape->debug_level >= 4) 1134 if (tape->debug_level >= 4)
1146 printk(KERN_INFO "ide-tape: Reached idetape_remove_stage_head\n"); 1135 printk(KERN_INFO "ide-tape: Reached idetape_remove_stage_head\n");
1147#endif /* IDETAPE_DEBUG_LOG */ 1136#endif /* IDETAPE_DEBUG_LOG */
1148#if IDETAPE_DEBUG_BUGS
1149 if (tape->first_stage == NULL) { 1137 if (tape->first_stage == NULL) {
1150 printk(KERN_ERR "ide-tape: bug: tape->first_stage is NULL\n"); 1138 printk(KERN_ERR "ide-tape: bug: tape->first_stage is NULL\n");
1151 return; 1139 return;
1152 } 1140 }
1153 if (tape->active_stage == tape->first_stage) { 1141 if (tape->active_stage == tape->first_stage) {
1154 printk(KERN_ERR "ide-tape: bug: Trying to free our active pipeline stage\n"); 1142 printk(KERN_ERR "ide-tape: bug: Trying to free our active pipeline stage\n");
1155 return; 1143 return;
1156 } 1144 }
1157#endif /* IDETAPE_DEBUG_BUGS */
1158 stage = tape->first_stage; 1145 stage = tape->first_stage;
1159 tape->first_stage = stage->next; 1146 tape->first_stage = stage->next;
1160 idetape_kfree_stage(tape, stage); 1147 idetape_kfree_stage(tape, stage);
1161 tape->nr_stages--; 1148 tape->nr_stages--;
1162 if (tape->first_stage == NULL) { 1149 if (tape->first_stage == NULL) {
1163 tape->last_stage = NULL; 1150 tape->last_stage = NULL;
1164#if IDETAPE_DEBUG_BUGS
1165 if (tape->next_stage != NULL) 1151 if (tape->next_stage != NULL)
1166 printk(KERN_ERR "ide-tape: bug: tape->next_stage != NULL\n"); 1152 printk(KERN_ERR "ide-tape: bug: tape->next_stage != NULL\n");
1167 if (tape->nr_stages) 1153 if (tape->nr_stages)
1168 printk(KERN_ERR "ide-tape: bug: nr_stages should be 0 now\n"); 1154 printk(KERN_ERR "ide-tape: bug: nr_stages should be 0 now\n");
1169#endif /* IDETAPE_DEBUG_BUGS */
1170 } 1155 }
1171} 1156}
1172 1157
@@ -1654,13 +1639,11 @@ static ide_startstop_t idetape_issue_packet_command (ide_drive_t *drive, idetape
1654 int dma_ok = 0; 1639 int dma_ok = 0;
1655 u16 bcount; 1640 u16 bcount;
1656 1641
1657#if IDETAPE_DEBUG_BUGS
1658 if (tape->pc->c[0] == IDETAPE_REQUEST_SENSE_CMD && 1642 if (tape->pc->c[0] == IDETAPE_REQUEST_SENSE_CMD &&
1659 pc->c[0] == IDETAPE_REQUEST_SENSE_CMD) { 1643 pc->c[0] == IDETAPE_REQUEST_SENSE_CMD) {
1660 printk(KERN_ERR "ide-tape: possible ide-tape.c bug - " 1644 printk(KERN_ERR "ide-tape: possible ide-tape.c bug - "
1661 "Two request sense in serial were issued\n"); 1645 "Two request sense in serial were issued\n");
1662 } 1646 }
1663#endif /* IDETAPE_DEBUG_BUGS */
1664 1647
1665 if (tape->failed_pc == NULL && pc->c[0] != IDETAPE_REQUEST_SENSE_CMD) 1648 if (tape->failed_pc == NULL && pc->c[0] != IDETAPE_REQUEST_SENSE_CMD)
1666 tape->failed_pc = pc; 1649 tape->failed_pc = pc;
@@ -1971,7 +1954,6 @@ static ide_startstop_t idetape_do_request(ide_drive_t *drive,
1971 tape->pc->c[0] == IDETAPE_REQUEST_SENSE_CMD) { 1954 tape->pc->c[0] == IDETAPE_REQUEST_SENSE_CMD) {
1972 return idetape_issue_packet_command(drive, tape->failed_pc); 1955 return idetape_issue_packet_command(drive, tape->failed_pc);
1973 } 1956 }
1974#if IDETAPE_DEBUG_BUGS
1975 if (postponed_rq != NULL) 1957 if (postponed_rq != NULL)
1976 if (rq != postponed_rq) { 1958 if (rq != postponed_rq) {
1977 printk(KERN_ERR "ide-tape: ide-tape.c bug - " 1959 printk(KERN_ERR "ide-tape: ide-tape.c bug - "
@@ -1979,7 +1961,6 @@ static ide_startstop_t idetape_do_request(ide_drive_t *drive,
1979 idetape_end_request(drive, 0, 0); 1961 idetape_end_request(drive, 0, 0);
1980 return ide_stopped; 1962 return ide_stopped;
1981 } 1963 }
1982#endif /* IDETAPE_DEBUG_BUGS */
1983 1964
1984 tape->postponed_rq = NULL; 1965 tape->postponed_rq = NULL;
1985 1966
@@ -2166,13 +2147,11 @@ static int idetape_copy_stage_from_user (idetape_tape_t *tape, idetape_stage_t *
2166 int ret = 0; 2147 int ret = 0;
2167 2148
2168 while (n) { 2149 while (n) {
2169#if IDETAPE_DEBUG_BUGS
2170 if (bh == NULL) { 2150 if (bh == NULL) {
2171 printk(KERN_ERR "ide-tape: bh == NULL in " 2151 printk(KERN_ERR "ide-tape: bh == NULL in "
2172 "idetape_copy_stage_from_user\n"); 2152 "idetape_copy_stage_from_user\n");
2173 return 1; 2153 return 1;
2174 } 2154 }
2175#endif /* IDETAPE_DEBUG_BUGS */
2176 count = min((unsigned int)(bh->b_size - atomic_read(&bh->b_count)), (unsigned int)n); 2155 count = min((unsigned int)(bh->b_size - atomic_read(&bh->b_count)), (unsigned int)n);
2177 if (copy_from_user(bh->b_data + atomic_read(&bh->b_count), buf, count)) 2156 if (copy_from_user(bh->b_data + atomic_read(&bh->b_count), buf, count))
2178 ret = 1; 2157 ret = 1;
@@ -2196,13 +2175,11 @@ static int idetape_copy_stage_to_user (idetape_tape_t *tape, char __user *buf, i
2196 int ret = 0; 2175 int ret = 0;
2197 2176
2198 while (n) { 2177 while (n) {
2199#if IDETAPE_DEBUG_BUGS
2200 if (bh == NULL) { 2178 if (bh == NULL) {
2201 printk(KERN_ERR "ide-tape: bh == NULL in " 2179 printk(KERN_ERR "ide-tape: bh == NULL in "
2202 "idetape_copy_stage_to_user\n"); 2180 "idetape_copy_stage_to_user\n");
2203 return 1; 2181 return 1;
2204 } 2182 }
2205#endif /* IDETAPE_DEBUG_BUGS */
2206 count = min(tape->b_count, n); 2183 count = min(tape->b_count, n);
2207 if (copy_to_user(buf, tape->b_data, count)) 2184 if (copy_to_user(buf, tape->b_data, count))
2208 ret = 1; 2185 ret = 1;
@@ -2282,12 +2259,10 @@ static void idetape_wait_for_request (ide_drive_t *drive, struct request *rq)
2282 DECLARE_COMPLETION_ONSTACK(wait); 2259 DECLARE_COMPLETION_ONSTACK(wait);
2283 idetape_tape_t *tape = drive->driver_data; 2260 idetape_tape_t *tape = drive->driver_data;
2284 2261
2285#if IDETAPE_DEBUG_BUGS
2286 if (rq == NULL || !blk_special_request(rq)) { 2262 if (rq == NULL || !blk_special_request(rq)) {
2287 printk (KERN_ERR "ide-tape: bug: Trying to sleep on non-valid request\n"); 2263 printk (KERN_ERR "ide-tape: bug: Trying to sleep on non-valid request\n");
2288 return; 2264 return;
2289 } 2265 }
2290#endif /* IDETAPE_DEBUG_BUGS */
2291 rq->end_io_data = &wait; 2266 rq->end_io_data = &wait;
2292 rq->end_io = blk_end_sync_rq; 2267 rq->end_io = blk_end_sync_rq;
2293 spin_unlock_irq(&tape->spinlock); 2268 spin_unlock_irq(&tape->spinlock);
@@ -2602,12 +2577,10 @@ static int idetape_queue_rw_tail(ide_drive_t *drive, int cmd, int blocks, struct
2602 if (tape->debug_level >= 2) 2577 if (tape->debug_level >= 2)
2603 printk(KERN_INFO "ide-tape: idetape_queue_rw_tail: cmd=%d\n",cmd); 2578 printk(KERN_INFO "ide-tape: idetape_queue_rw_tail: cmd=%d\n",cmd);
2604#endif /* IDETAPE_DEBUG_LOG */ 2579#endif /* IDETAPE_DEBUG_LOG */
2605#if IDETAPE_DEBUG_BUGS
2606 if (idetape_pipeline_active(tape)) { 2580 if (idetape_pipeline_active(tape)) {
2607 printk(KERN_ERR "ide-tape: bug: the pipeline is active in idetape_queue_rw_tail\n"); 2581 printk(KERN_ERR "ide-tape: bug: the pipeline is active in idetape_queue_rw_tail\n");
2608 return (0); 2582 return (0);
2609 } 2583 }
2610#endif /* IDETAPE_DEBUG_BUGS */
2611 2584
2612 idetape_init_rq(&rq, cmd); 2585 idetape_init_rq(&rq, cmd);
2613 rq.rq_disk = tape->disk; 2586 rq.rq_disk = tape->disk;
@@ -2792,8 +2765,7 @@ static void idetape_empty_write_pipeline (ide_drive_t *drive)
2792 idetape_tape_t *tape = drive->driver_data; 2765 idetape_tape_t *tape = drive->driver_data;
2793 int blocks, min; 2766 int blocks, min;
2794 struct idetape_bh *bh; 2767 struct idetape_bh *bh;
2795 2768
2796#if IDETAPE_DEBUG_BUGS
2797 if (tape->chrdev_direction != idetape_direction_write) { 2769 if (tape->chrdev_direction != idetape_direction_write) {
2798 printk(KERN_ERR "ide-tape: bug: Trying to empty write pipeline, but we are not writing.\n"); 2770 printk(KERN_ERR "ide-tape: bug: Trying to empty write pipeline, but we are not writing.\n");
2799 return; 2771 return;
@@ -2802,7 +2774,6 @@ static void idetape_empty_write_pipeline (ide_drive_t *drive)
2802 printk(KERN_ERR "ide-tape: bug: merge_buffer too big\n"); 2774 printk(KERN_ERR "ide-tape: bug: merge_buffer too big\n");
2803 tape->merge_stage_size = tape->stage_size; 2775 tape->merge_stage_size = tape->stage_size;
2804 } 2776 }
2805#endif /* IDETAPE_DEBUG_BUGS */
2806 if (tape->merge_stage_size) { 2777 if (tape->merge_stage_size) {
2807 blocks = tape->merge_stage_size / tape->tape_block_size; 2778 blocks = tape->merge_stage_size / tape->tape_block_size;
2808 if (tape->merge_stage_size % tape->tape_block_size) { 2779 if (tape->merge_stage_size % tape->tape_block_size) {
@@ -2847,7 +2818,6 @@ static void idetape_empty_write_pipeline (ide_drive_t *drive)
2847 * can be totally different on the next backup). 2818 * can be totally different on the next backup).
2848 */ 2819 */
2849 tape->max_stages = tape->min_pipeline; 2820 tape->max_stages = tape->min_pipeline;
2850#if IDETAPE_DEBUG_BUGS
2851 if (tape->first_stage != NULL || 2821 if (tape->first_stage != NULL ||
2852 tape->next_stage != NULL || 2822 tape->next_stage != NULL ||
2853 tape->last_stage != NULL || 2823 tape->last_stage != NULL ||
@@ -2858,7 +2828,6 @@ static void idetape_empty_write_pipeline (ide_drive_t *drive)
2858 tape->first_stage, tape->next_stage, 2828 tape->first_stage, tape->next_stage,
2859 tape->last_stage, tape->nr_stages); 2829 tape->last_stage, tape->nr_stages);
2860 } 2830 }
2861#endif /* IDETAPE_DEBUG_BUGS */
2862} 2831}
2863 2832
2864static void idetape_restart_speed_control (ide_drive_t *drive) 2833static void idetape_restart_speed_control (ide_drive_t *drive)
@@ -2889,12 +2858,10 @@ static int idetape_initiate_read (ide_drive_t *drive, int max_stages)
2889 idetape_empty_write_pipeline(drive); 2858 idetape_empty_write_pipeline(drive);
2890 idetape_flush_tape_buffers(drive); 2859 idetape_flush_tape_buffers(drive);
2891 } 2860 }
2892#if IDETAPE_DEBUG_BUGS
2893 if (tape->merge_stage || tape->merge_stage_size) { 2861 if (tape->merge_stage || tape->merge_stage_size) {
2894 printk (KERN_ERR "ide-tape: merge_stage_size should be 0 now\n"); 2862 printk (KERN_ERR "ide-tape: merge_stage_size should be 0 now\n");
2895 tape->merge_stage_size = 0; 2863 tape->merge_stage_size = 0;
2896 } 2864 }
2897#endif /* IDETAPE_DEBUG_BUGS */
2898 if ((tape->merge_stage = __idetape_kmalloc_stage(tape, 0, 0)) == NULL) 2865 if ((tape->merge_stage = __idetape_kmalloc_stage(tape, 0, 0)) == NULL)
2899 return -ENOMEM; 2866 return -ENOMEM;
2900 tape->chrdev_direction = idetape_direction_read; 2867 tape->chrdev_direction = idetape_direction_read;
@@ -2995,12 +2962,10 @@ static int idetape_add_chrdev_read_request (ide_drive_t *drive,int blocks)
2995 tape->pipeline_head++; 2962 tape->pipeline_head++;
2996 calculate_speeds(drive); 2963 calculate_speeds(drive);
2997 } 2964 }
2998#if IDETAPE_DEBUG_BUGS
2999 if (bytes_read > blocks * tape->tape_block_size) { 2965 if (bytes_read > blocks * tape->tape_block_size) {
3000 printk(KERN_ERR "ide-tape: bug: trying to return more bytes than requested\n"); 2966 printk(KERN_ERR "ide-tape: bug: trying to return more bytes than requested\n");
3001 bytes_read = blocks * tape->tape_block_size; 2967 bytes_read = blocks * tape->tape_block_size;
3002 } 2968 }
3003#endif /* IDETAPE_DEBUG_BUGS */
3004 return (bytes_read); 2969 return (bytes_read);
3005} 2970}
3006 2971
@@ -3299,13 +3264,11 @@ static ssize_t idetape_chrdev_write (struct file *file, const char __user *buf,
3299 if (tape->chrdev_direction != idetape_direction_write) { 3264 if (tape->chrdev_direction != idetape_direction_write) {
3300 if (tape->chrdev_direction == idetape_direction_read) 3265 if (tape->chrdev_direction == idetape_direction_read)
3301 idetape_discard_read_pipeline(drive, 1); 3266 idetape_discard_read_pipeline(drive, 1);
3302#if IDETAPE_DEBUG_BUGS
3303 if (tape->merge_stage || tape->merge_stage_size) { 3267 if (tape->merge_stage || tape->merge_stage_size) {
3304 printk(KERN_ERR "ide-tape: merge_stage_size " 3268 printk(KERN_ERR "ide-tape: merge_stage_size "
3305 "should be 0 now\n"); 3269 "should be 0 now\n");
3306 tape->merge_stage_size = 0; 3270 tape->merge_stage_size = 0;
3307 } 3271 }
3308#endif /* IDETAPE_DEBUG_BUGS */
3309 if ((tape->merge_stage = __idetape_kmalloc_stage(tape, 0, 0)) == NULL) 3272 if ((tape->merge_stage = __idetape_kmalloc_stage(tape, 0, 0)) == NULL)
3310 return -ENOMEM; 3273 return -ENOMEM;
3311 tape->chrdev_direction = idetape_direction_write; 3274 tape->chrdev_direction = idetape_direction_write;
@@ -3333,12 +3296,10 @@ static ssize_t idetape_chrdev_write (struct file *file, const char __user *buf,
3333 if (tape->restart_speed_control_req) 3296 if (tape->restart_speed_control_req)
3334 idetape_restart_speed_control(drive); 3297 idetape_restart_speed_control(drive);
3335 if (tape->merge_stage_size) { 3298 if (tape->merge_stage_size) {
3336#if IDETAPE_DEBUG_BUGS
3337 if (tape->merge_stage_size >= tape->stage_size) { 3299 if (tape->merge_stage_size >= tape->stage_size) {
3338 printk(KERN_ERR "ide-tape: bug: merge buffer too big\n"); 3300 printk(KERN_ERR "ide-tape: bug: merge buffer too big\n");
3339 tape->merge_stage_size = 0; 3301 tape->merge_stage_size = 0;
3340 } 3302 }
3341#endif /* IDETAPE_DEBUG_BUGS */
3342 actually_written = min((unsigned int)(tape->stage_size - tape->merge_stage_size), (unsigned int)count); 3303 actually_written = min((unsigned int)(tape->stage_size - tape->merge_stage_size), (unsigned int)count);
3343 if (idetape_copy_stage_from_user(tape, tape->merge_stage, buf, actually_written)) 3304 if (idetape_copy_stage_from_user(tape, tape->merge_stage, buf, actually_written))
3344 ret = -EFAULT; 3305 ret = -EFAULT;