diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/ide/ide-tape.c | 80 |
1 files changed, 1 insertions, 79 deletions
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c index cbba475ebc5a..d907abaed909 100644 --- a/drivers/ide/ide-tape.c +++ b/drivers/ide/ide-tape.c | |||
@@ -686,37 +686,6 @@ static void __idetape_kfree_stage(idetape_stage_t *stage) | |||
686 | kfree(stage); | 686 | kfree(stage); |
687 | } | 687 | } |
688 | 688 | ||
689 | static void idetape_kfree_stage(idetape_tape_t *tape, idetape_stage_t *stage) | ||
690 | { | ||
691 | __idetape_kfree_stage(stage); | ||
692 | } | ||
693 | |||
694 | /* | ||
695 | * This will free all the pipeline stages starting from new_last_stage->next | ||
696 | * to the end of the list, and point tape->last_stage to new_last_stage. | ||
697 | */ | ||
698 | static void idetape_abort_pipeline(ide_drive_t *drive, | ||
699 | idetape_stage_t *new_last_stage) | ||
700 | { | ||
701 | idetape_tape_t *tape = drive->driver_data; | ||
702 | idetape_stage_t *stage = new_last_stage->next; | ||
703 | idetape_stage_t *nstage; | ||
704 | |||
705 | debug_log(DBG_PROCS, "%s: Enter %s\n", tape->name, __func__); | ||
706 | |||
707 | while (stage) { | ||
708 | nstage = stage->next; | ||
709 | idetape_kfree_stage(tape, stage); | ||
710 | --tape->nr_stages; | ||
711 | --tape->nr_pending_stages; | ||
712 | stage = nstage; | ||
713 | } | ||
714 | if (new_last_stage) | ||
715 | new_last_stage->next = NULL; | ||
716 | tape->last_stage = new_last_stage; | ||
717 | tape->next_stage = NULL; | ||
718 | } | ||
719 | |||
720 | /* | 689 | /* |
721 | * Finish servicing a request and insert a pending pipeline request into the | 690 | * Finish servicing a request and insert a pending pipeline request into the |
722 | * main device queue. | 691 | * main device queue. |
@@ -727,7 +696,6 @@ static int idetape_end_request(ide_drive_t *drive, int uptodate, int nr_sects) | |||
727 | idetape_tape_t *tape = drive->driver_data; | 696 | idetape_tape_t *tape = drive->driver_data; |
728 | unsigned long flags; | 697 | unsigned long flags; |
729 | int error; | 698 | int error; |
730 | idetape_stage_t *active_stage; | ||
731 | 699 | ||
732 | debug_log(DBG_PROCS, "Enter %s\n", __func__); | 700 | debug_log(DBG_PROCS, "Enter %s\n", __func__); |
733 | 701 | ||
@@ -747,55 +715,9 @@ static int idetape_end_request(ide_drive_t *drive, int uptodate, int nr_sects) | |||
747 | 715 | ||
748 | spin_lock_irqsave(&tape->lock, flags); | 716 | spin_lock_irqsave(&tape->lock, flags); |
749 | 717 | ||
750 | /* The request was a pipelined data transfer request */ | ||
751 | if (tape->active_data_rq == rq) { | ||
752 | active_stage = tape->active_stage; | ||
753 | tape->active_stage = NULL; | ||
754 | tape->active_data_rq = NULL; | ||
755 | tape->nr_pending_stages--; | ||
756 | if (rq->cmd[0] & REQ_IDETAPE_WRITE) { | ||
757 | if (error) { | ||
758 | set_bit(IDETAPE_FLAG_PIPELINE_ERR, | ||
759 | &tape->flags); | ||
760 | if (error == IDETAPE_ERROR_EOD) | ||
761 | idetape_abort_pipeline(drive, | ||
762 | active_stage); | ||
763 | } | ||
764 | } else if (rq->cmd[0] & REQ_IDETAPE_READ) { | ||
765 | if (error == IDETAPE_ERROR_EOD) { | ||
766 | set_bit(IDETAPE_FLAG_PIPELINE_ERR, | ||
767 | &tape->flags); | ||
768 | idetape_abort_pipeline(drive, active_stage); | ||
769 | } | ||
770 | } | ||
771 | if (tape->next_stage != NULL) { | ||
772 | idetape_activate_next_stage(drive); | ||
773 | |||
774 | /* Insert the next request into the request queue. */ | ||
775 | (void)ide_do_drive_cmd(drive, tape->active_data_rq, | ||
776 | ide_end); | ||
777 | } else if (!error) { | ||
778 | /* | ||
779 | * This is a part of the feedback loop which tries to | ||
780 | * find the optimum number of stages. We are starting | ||
781 | * from a minimum maximum number of stages, and if we | ||
782 | * sense that the pipeline is empty, we try to increase | ||
783 | * it, until we reach the user compile time memory | ||
784 | * limit. | ||
785 | */ | ||
786 | int i = (tape->max_pipeline - tape->min_pipeline) / 10; | ||
787 | |||
788 | tape->max_stages += max(i, 1); | ||
789 | tape->max_stages = max(tape->max_stages, | ||
790 | tape->min_pipeline); | ||
791 | tape->max_stages = min(tape->max_stages, | ||
792 | tape->max_pipeline); | ||
793 | } | ||
794 | } | ||
795 | ide_end_drive_cmd(drive, 0, 0); | 718 | ide_end_drive_cmd(drive, 0, 0); |
796 | 719 | ||
797 | if (tape->active_data_rq == NULL) | 720 | clear_bit(IDETAPE_FLAG_PIPELINE_ACTIVE, &tape->flags); |
798 | clear_bit(IDETAPE_FLAG_PIPELINE_ACTIVE, &tape->flags); | ||
799 | spin_unlock_irqrestore(&tape->lock, flags); | 721 | spin_unlock_irqrestore(&tape->lock, flags); |
800 | return 0; | 722 | return 0; |
801 | } | 723 | } |