diff options
-rw-r--r-- | drivers/ide/ide-io.c | 2 | ||||
-rw-r--r-- | drivers/ide/ide-taskfile.c | 29 | ||||
-rw-r--r-- | include/linux/ide.h | 5 |
3 files changed, 17 insertions, 19 deletions
diff --git a/drivers/ide/ide-io.c b/drivers/ide/ide-io.c index f4f7e3db10ac..1112d8b049b9 100644 --- a/drivers/ide/ide-io.c +++ b/drivers/ide/ide-io.c | |||
@@ -340,7 +340,7 @@ void ide_end_drive_cmd (ide_drive_t *drive, u8 stat, u8 err) | |||
340 | if (args) { | 340 | if (args) { |
341 | struct ide_taskfile *tf = &args->tf; | 341 | struct ide_taskfile *tf = &args->tf; |
342 | 342 | ||
343 | if (args->tf_in_flags.b.data) { | 343 | if (args->tf_flags & IDE_TFLAG_IN_DATA) { |
344 | u16 data = hwif->INW(IDE_DATA_REG); | 344 | u16 data = hwif->INW(IDE_DATA_REG); |
345 | 345 | ||
346 | tf->data = data & 0xff; | 346 | tf->data = data & 0xff; |
diff --git a/drivers/ide/ide-taskfile.c b/drivers/ide/ide-taskfile.c index ff28449bbcaf..03c4a0c55bf4 100644 --- a/drivers/ide/ide-taskfile.c +++ b/drivers/ide/ide-taskfile.c | |||
@@ -599,8 +599,8 @@ int ide_taskfile_ioctl (ide_drive_t *drive, unsigned int cmd, unsigned long arg) | |||
599 | 599 | ||
600 | memcpy(&args.tf_array[0], req_task->hob_ports, HDIO_DRIVE_HOB_HDR_SIZE - 2); | 600 | memcpy(&args.tf_array[0], req_task->hob_ports, HDIO_DRIVE_HOB_HDR_SIZE - 2); |
601 | memcpy(&args.tf_array[6], req_task->io_ports, HDIO_DRIVE_TASK_HDR_SIZE); | 601 | memcpy(&args.tf_array[6], req_task->io_ports, HDIO_DRIVE_TASK_HDR_SIZE); |
602 | args.tf_in_flags = req_task->in_flags; | 602 | |
603 | args.data_phase = req_task->data_phase; | 603 | args.data_phase = req_task->data_phase; |
604 | 604 | ||
605 | args.tf_flags = IDE_TFLAG_OUT_DEVICE; | 605 | args.tf_flags = IDE_TFLAG_OUT_DEVICE; |
606 | if (drive->addressing == 1) | 606 | if (drive->addressing == 1) |
@@ -637,6 +637,9 @@ int ide_taskfile_ioctl (ide_drive_t *drive, unsigned int cmd, unsigned long arg) | |||
637 | args.tf_flags |= IDE_TFLAG_OUT_HOB; | 637 | args.tf_flags |= IDE_TFLAG_OUT_HOB; |
638 | } | 638 | } |
639 | 639 | ||
640 | if (req_task->in_flags.b.data) | ||
641 | args.tf_flags |= IDE_TFLAG_IN_DATA; | ||
642 | |||
640 | drive->io_32bit = 0; | 643 | drive->io_32bit = 0; |
641 | switch(req_task->data_phase) { | 644 | switch(req_task->data_phase) { |
642 | case TASKFILE_MULTI_OUT: | 645 | case TASKFILE_MULTI_OUT: |
@@ -704,7 +707,13 @@ int ide_taskfile_ioctl (ide_drive_t *drive, unsigned int cmd, unsigned long arg) | |||
704 | 707 | ||
705 | memcpy(req_task->hob_ports, &args.tf_array[0], HDIO_DRIVE_HOB_HDR_SIZE - 2); | 708 | memcpy(req_task->hob_ports, &args.tf_array[0], HDIO_DRIVE_HOB_HDR_SIZE - 2); |
706 | memcpy(req_task->io_ports, &args.tf_array[6], HDIO_DRIVE_TASK_HDR_SIZE); | 709 | memcpy(req_task->io_ports, &args.tf_array[6], HDIO_DRIVE_TASK_HDR_SIZE); |
707 | req_task->in_flags = args.tf_in_flags; | 710 | |
711 | if ((args.tf_flags & IDE_TFLAG_FLAGGED_SET_IN_FLAGS) && | ||
712 | req_task->in_flags.all == 0) { | ||
713 | req_task->in_flags.all = IDE_TASKFILE_STD_IN_FLAGS; | ||
714 | if (drive->addressing == 1) | ||
715 | req_task->in_flags.all |= (IDE_HOB_STD_IN_FLAGS << 8); | ||
716 | } | ||
708 | 717 | ||
709 | if (copy_to_user(buf, req_task, tasksize)) { | 718 | if (copy_to_user(buf, req_task, tasksize)) { |
710 | err = -EFAULT; | 719 | err = -EFAULT; |
@@ -846,19 +855,7 @@ ide_startstop_t flagged_taskfile (ide_drive_t *drive, ide_task_t *task) | |||
846 | } | 855 | } |
847 | } | 856 | } |
848 | 857 | ||
849 | /* | 858 | task->tf_flags |= IDE_TFLAG_FLAGGED_SET_IN_FLAGS; |
850 | * (ks) Check taskfile in flags. | ||
851 | * If set, then execute as it is defined. | ||
852 | * If not set, then define default settings. | ||
853 | * The default values are: | ||
854 | * read all taskfile registers (except data) | ||
855 | * read the hob registers (sector, nsector, lcyl, hcyl) | ||
856 | */ | ||
857 | if (task->tf_in_flags.all == 0) { | ||
858 | task->tf_in_flags.all = IDE_TASKFILE_STD_IN_FLAGS; | ||
859 | if (drive->addressing == 1) | ||
860 | task->tf_in_flags.all |= (IDE_HOB_STD_IN_FLAGS << 8); | ||
861 | } | ||
862 | 859 | ||
863 | return do_rw_taskfile(drive, task); | 860 | return do_rw_taskfile(drive, task); |
864 | } | 861 | } |
diff --git a/include/linux/ide.h b/include/linux/ide.h index 7485fc705ca4..c23ef2df2cbb 100644 --- a/include/linux/ide.h +++ b/include/linux/ide.h | |||
@@ -910,6 +910,8 @@ enum { | |||
910 | IDE_TFLAG_OUT_LBAH, | 910 | IDE_TFLAG_OUT_LBAH, |
911 | IDE_TFLAG_OUT_DEVICE = (1 << 14), | 911 | IDE_TFLAG_OUT_DEVICE = (1 << 14), |
912 | IDE_TFLAG_WRITE = (1 << 15), | 912 | IDE_TFLAG_WRITE = (1 << 15), |
913 | IDE_TFLAG_FLAGGED_SET_IN_FLAGS = (1 << 16), | ||
914 | IDE_TFLAG_IN_DATA = (1 << 17), | ||
913 | }; | 915 | }; |
914 | 916 | ||
915 | struct ide_taskfile { | 917 | struct ide_taskfile { |
@@ -946,8 +948,7 @@ typedef struct ide_task_s { | |||
946 | struct ide_taskfile tf; | 948 | struct ide_taskfile tf; |
947 | u8 tf_array[14]; | 949 | u8 tf_array[14]; |
948 | }; | 950 | }; |
949 | u16 tf_flags; | 951 | u32 tf_flags; |
950 | ide_reg_valid_t tf_in_flags; | ||
951 | int data_phase; | 952 | int data_phase; |
952 | ide_pre_handler_t *prehandler; | 953 | ide_pre_handler_t *prehandler; |
953 | ide_handler_t *handler; | 954 | ide_handler_t *handler; |